Andrew Geissler | 9aee500 | 2022-03-30 16:27:02 +0000 | [diff] [blame] | 1 | SUMMARY = "Advanced front-end for dpkg" |
| 2 | DESCRIPTION = "APT is the Advanced Package Tool, an advanced interface to the Debian packaging system which provides the apt-get program." |
| 3 | HOMEPAGE = "https://packages.debian.org/jessie/apt" |
| 4 | LICENSE = "GPL-2.0-or-later" |
| 5 | SECTION = "base" |
| 6 | |
| 7 | # Triehash script taken from https://github.com/julian-klode/triehash |
| 8 | SRC_URI = "${DEBIAN_MIRROR}/main/a/apt/${BPN}_${PV}.tar.xz \ |
| 9 | file://triehash \ |
| 10 | file://0001-Disable-documentation-directory-altogether.patch \ |
| 11 | file://0001-Fix-musl-build.patch \ |
| 12 | file://0001-CMakeLists.txt-avoid-changing-install-paths-based-on.patch \ |
| 13 | file://0001-cmake-Do-not-build-po-files.patch \ |
| 14 | file://0001-Hide-fstatat64-and-prlimit64-defines-on-musl.patch \ |
| 15 | file://0001-aptwebserver.cc-Include-array.patch \ |
| 16 | " |
| 17 | |
| 18 | SRC_URI:append:class-native = " \ |
| 19 | file://0001-Do-not-init-tables-from-dpkg-configuration.patch \ |
| 20 | file://0001-Revert-always-run-dpkg-configure-a-at-the-end-of-our.patch \ |
| 21 | " |
| 22 | |
| 23 | SRC_URI:append:class-nativesdk = " \ |
| 24 | file://0001-Do-not-init-tables-from-dpkg-configuration.patch \ |
| 25 | file://0001-Revert-always-run-dpkg-configure-a-at-the-end-of-our.patch \ |
| 26 | " |
| 27 | |
| 28 | SRC_URI[sha256sum] = "5a7215ca924302da0b2205862cd2d651326eea222a589184ec6ce663885729f7" |
| 29 | LIC_FILES_CHKSUM = "file://COPYING.GPL;md5=b234ee4d69f5fce4486a80fdaf4a4263" |
| 30 | |
| 31 | # the package is taken from snapshots.debian.org; that source is static and goes stale |
| 32 | # so we check the latest upstream from a directory that does get updated |
| 33 | UPSTREAM_CHECK_URI = "${DEBIAN_MIRROR}/main/a/apt/" |
| 34 | |
| 35 | inherit cmake perlnative bash-completion upstream-version-is-even useradd |
| 36 | |
| 37 | # User is added to allow apt to drop privs, will runtime warn without |
| 38 | USERADD_PACKAGES = "${PN}" |
| 39 | USERADD_PARAM:${PN} = "--system --home /nonexistent --no-create-home _apt" |
| 40 | |
| 41 | BBCLASSEXTEND = "native nativesdk" |
| 42 | |
| 43 | DEPENDS += "db gnutls lz4 zlib bzip2 xz libgcrypt xxhash" |
| 44 | |
| 45 | EXTRA_OECMAKE:append = " -DCURRENT_VENDOR=debian -DWITH_DOC=False \ |
| 46 | -DDPKG_DATADIR=${datadir}/dpkg \ |
| 47 | -DTRIEHASH_EXECUTABLE=${WORKDIR}/triehash \ |
| 48 | -DCMAKE_DISABLE_FIND_PACKAGE_ZSTD=True \ |
| 49 | -DCMAKE_DISABLE_FIND_PACKAGE_SECCOMP=True \ |
| 50 | -DWITH_TESTS=False \ |
| 51 | " |
| 52 | |
| 53 | do_configure:prepend() { |
| 54 | echo "set( CMAKE_FIND_ROOT_PATH_MODE_INCLUDE BOTH )" >> ${WORKDIR}/toolchain.cmake |
| 55 | } |
| 56 | |
| 57 | # Unfortunately apt hardcodes this all over the place |
| 58 | FILES:${PN} += "${prefix}/lib/dpkg ${prefix}/lib/apt" |
| 59 | RDEPENDS:${PN} += "bash perl dpkg" |
| 60 | |
| 61 | customize_apt_conf_sample() { |
| 62 | cat > ${D}${sysconfdir}/apt/apt.conf.sample << EOF |
| 63 | Dir "${STAGING_DIR_NATIVE}/" |
| 64 | { |
| 65 | State "var/lib/apt/" |
| 66 | { |
| 67 | Lists "#APTCONF#/lists/"; |
| 68 | status "#ROOTFS#/var/lib/dpkg/status"; |
| 69 | }; |
| 70 | Cache "var/cache/apt/" |
| 71 | { |
| 72 | Archives "archives/"; |
| 73 | pkgcache ""; |
| 74 | srcpkgcache ""; |
| 75 | }; |
| 76 | Bin "${STAGING_BINDIR_NATIVE}/" |
| 77 | { |
| 78 | methods "${STAGING_LIBDIR}/apt/methods/"; |
| 79 | gzip "/bin/gzip"; |
| 80 | dpkg "dpkg"; |
| 81 | dpkg-source "dpkg-source"; |
| 82 | dpkg-buildpackage "dpkg-buildpackage"; |
| 83 | apt-get "apt-get"; |
| 84 | apt-cache "apt-cache"; |
| 85 | }; |
| 86 | Etc "#APTCONF#" |
| 87 | { |
| 88 | Preferences "preferences"; |
| 89 | }; |
| 90 | Log "var/log/apt"; |
| 91 | }; |
| 92 | |
| 93 | APT |
| 94 | { |
| 95 | Install-Recommends "true"; |
| 96 | Immediate-Configure "false"; |
| 97 | Architecture "i586"; |
| 98 | Get |
| 99 | { |
| 100 | Assume-Yes "true"; |
| 101 | }; |
| 102 | }; |
| 103 | |
| 104 | Acquire |
| 105 | { |
| 106 | AllowInsecureRepositories "true"; |
| 107 | }; |
| 108 | |
| 109 | DPkg::Options {"--root=#ROOTFS#";"--admindir=#ROOTFS#/var/lib/dpkg";"--force-all";"--no-debsig"}; |
| 110 | DPkg::Path ""; |
| 111 | EOF |
| 112 | } |
| 113 | |
| 114 | do_install:append:class-native() { |
| 115 | customize_apt_conf_sample |
| 116 | } |
| 117 | |
| 118 | do_install:append:class-nativesdk() { |
| 119 | customize_apt_conf_sample |
| 120 | } |
| 121 | |
| 122 | do_install:append:class-target() { |
| 123 | # Write the correct apt-architecture to apt.conf |
| 124 | APT_CONF=${D}${sysconfdir}/apt/apt.conf |
| 125 | echo 'APT::Architecture "${DPKG_ARCH}";' > ${APT_CONF} |
| 126 | |
| 127 | # Remove /var/log/apt. /var/log is normally a link to /var/volatile/log |
| 128 | # and /var/volatile is a tmpfs mount. So anything created in /var/log |
| 129 | # will not be available when the tmpfs is mounted. |
| 130 | rm -rf ${D}${localstatedir}/log |
| 131 | } |
| 132 | |
| 133 | do_install:append() { |
| 134 | # Avoid non-reproducible -src package |
| 135 | sed -i -e "s,${B},,g" ${B}/apt-pkg/tagfile-keys.cc |
| 136 | } |