Saurik's version of apt managed for tvOS/ARM64

Trần Ngọc Quân 417e83d0d7 debian: Add default compress option to xz 10 years ago
abicheck c5f0d8e6f8 fix some more ABI issues, abicheck is happy now 10 years ago
apt-inst b68ce88357 apt-inst: Do not try to create a substring of an empty string in error reporting 10 years ago
apt-pkg 035a31392a Merge remote-tracking branch 'mvo/feature/more-fancy-progress' into debian/sid 10 years ago
apt-private 63ff420898 enable fvisibility=hidden for our private library 10 years ago
buildlib 7f350a377e use liblzma-dev to provide xz/lzma support 10 years ago
cmdline 8bc31a93c3 enable DPkg::Progress-Fancy by default 10 years ago
debian 417e83d0d7 debian: Add default compress option to xz 10 years ago
doc 1701312682 Merge remote-tracking branch 'mvo/feature/apt-manpage' into debian/sid 10 years ago
dselect 0806f2a6c4 dselect/install: add new DSELECT_UPGRADE_OPTS="-f" 10 years ago
ftparchive 453b82a388 cleanup headers and especially #includes everywhere 10 years ago
methods 0ec6b98b24 add a config option to switch uncompress methods to compress 10 years ago
po fd95168ffb l10n: vi.po (623t): Update Vietnamese translation 10 years ago
test 355a960dd8 Merge branch 'debian/sid' into feature/more-fancy-progress 10 years ago
vendor fa19cc9573 autogenerate makefile for vendor system 10 years ago
.bzrignore 04e9cc0814 * doc/examples/sources.list: 12 years ago
.gitignore e421512027 add debian/apt.install to gitignore 10 years ago
.travis.yml be297c7ab3 tests: install --no-install-recommends and stunnel4 for travis 10 years ago
AUTHORS 9720f8d337 AUTHORS: updated again 14 years ago
COMPILING 1e3f4083db Fix typos in documentation (codespell) 10 years ago
COPYING 6ae07b8231 merged r1811 from lp:~donkult/apt/experimenal 15 years ago
COPYING.GPL a62f8bb911 QT1 license exception 19 years ago
Makefile eef71f11a5 introduce a vendor system to change sources.list 10 years ago
README.MultiArch 28166356f3 Remove the "pseudopackage" handling of Architecture: all packages for 13 years ago
README.ddtp 1e3f4083db Fix typos in documentation (codespell) 10 years ago
README.make 1e3f4083db Fix typos in documentation (codespell) 10 years ago
README.progress-reporting 1e3f4083db Fix typos in documentation (codespell) 10 years ago
configure.ac 384c9b0d4f Release 0.9.16.1 10 years ago
mirror-failure.py 2769f0bcf6 * mirror-failure.py: example mirror failure cgi 17 years ago
prepare-release 54298f49d7 move defines for version to macros.h 10 years ago

README.MultiArch

Before we start with this topic: Note that MultiArch is not yet ready for
prime time and/or for the casual user. The implementation is so far widely
untested and only useful for developers of packagemanagment tools which
use APT and his friends and maintainers of (upcoming) MultiArch packages.
This README is especially NOT written for the casual user and is NOT a
usage guide - you have been warned. It is assumed that the reader has
at least a bit of knowledge about APT internals, dependency relations
and the MultiArch spec [0].

Note also that the toolchain isn't ready yet, e.g. while you can simulate
the installation of MultiArch packages they will more sooner than later
cause enormous problems if really installed as dpkg can't handle MultiArch
yet (no, --force-{overwrite,architecture} aren't good options here).
Other parts of the big picture are missing and/or untested too.
You have been warned!


The implementation is focused on NOT breaking existing singleArch-only
applications and/or systems as this is the current status-quo for all
systems. Also, many systems don't need (or can't make use of) MultiArch,
so APT will proceed in thinking SingleArch as long as it is not explicitly
told to handle MultiArch:
To activate MultiArch handling you need to specify architectures you
want to be considered by APT with the config list APT::Architectures
(Insert architectures in order of preference).
APT will download Packages files for all these architectures in the
update step. Exception: In the sourcelist is the optionfield used:
deb [ arch=amd64,i386 ] http://example.org/ experimental main
(This optionfield is a NOP in previous apt versions)

Internally in APT a package is represented as a PkgIterator -
before MultiArch this PkgIterator was architecture unaware,
only VerIterators include the architecture they came from.
This is/was a big problem as all versions in a package are
considered for dependency resolution, so pinning will not work in all cases.

The problem is solved by a conceptional change:
A PkgIterator is now architecture aware, so the packages
of foobar for amd64 and for i386 are now for apt internal totally
different packages. That is a good thing for e.g. pinning, but
sometimes you need the information that such packages are belonging together:
All these foobar packages therefore form a Group accessible with GrpIterators.
Note that the GrpIterator has the same name as all the packages in this group,
so e.g. apt-cache pkgnames iterates over GrpIterator to get the package names:
This is compatible to SingleArch as a Group consists only of a single package
and also to MultiArch as a Group consists of possible many packages which
all have the same name and are therefore out of interest for pkgnames.


Given all these internal changes it is quite interesting that the actual
implementation of MultiArch is trivial: Some implicit dependencies and a few
more provides are all changes needed to get it working. Especially noteworthy
is that it wasn't needed to change the resolver in any way and other parts only
need to be told about using GrpIterator instead of PkgIterator, so chances are
good that libapt-applications will proceed to work without or at least only
require minor changes, but your mileage may vary…


Known Issues and/or noteworthy stuff:
* The implementation is mostly untested, so it is very likely that APT will
eat your kids if you aren't as lucky as the author of these patches.

[0] https://wiki.ubuntu.com/MultiarchSpec