pacman: 5.2.2 -> 6.0.1

Co-authored-by: Renaud <c0bw3b@gmail.com>
This commit is contained in:
SamLukeYes 2022-08-30 11:27:06 +08:00
parent a63021a330
commit 550c5b1947
3 changed files with 109 additions and 22 deletions

View File

@ -11542,6 +11542,12 @@
fingerprint = "AE8C 0836 FDF6 3FFC 9580 C588 B156 8953 B193 9F1C";
}];
};
samlukeyes123 = {
email = "samlukeyes123@gmail.com";
github = "SamLukeYes";
githubId = 12882091;
name = "Sam L. Yes";
};
samrose = {
email = "samuel.rose@gmail.com";
github = "samrose";

View File

@ -1,41 +1,102 @@
{ stdenv, lib, fetchurl, pkg-config, m4, perl, libarchive, openssl, zlib, bzip2,
xz, curl, runtimeShell }:
{ lib
, stdenv
, fetchpatch
, fetchurl
, asciidoc
, binutils
, bzip2
, coreutils
, curl
, gnupg
, gpgme
, installShellFiles
, libarchive
, makeWrapper
, meson
, ninja
, openssl
, perl
, pkg-config
, xz
, zlib
# Tells pacman where to find ALPM hooks provided by packages.
# This path is very likely to be used in an Arch-like root.
, sysHookDir ? "/usr/share/libalpm/hooks/"
}:
stdenv.mkDerivation rec {
pname = "pacman";
version = "5.2.2";
version = "6.0.1";
src = fetchurl {
url = "https://sources.archlinux.org/other/${pname}/${pname}-${version}.tar.gz";
sha256 = "1829jcc300fxidr3cahx5kpnxkpg500daqgn2782hg5m5ygil85v";
url = "https://sources.archlinux.org/other/${pname}/${pname}-${version}.tar.xz";
hash = "sha256-DbYUVuVqpJ4mDokcCwJb4hAxnmKxVSHynT6TsA079zE=";
};
enableParallelBuilding = true;
configureFlags = [
# trying to build docs fails with a2x errors, unable to fix through asciidoc
"--disable-doc"
"--sysconfdir=/etc"
"--localstatedir=/var"
"--with-scriptlet-shell=${runtimeShell}"
nativeBuildInputs = [
asciidoc
installShellFiles
makeWrapper
meson
ninja
pkg-config
];
installFlags = [ "sysconfdir=${placeholder "out"}/etc" ];
buildInputs = [
bzip2
curl
gpgme
libarchive
openssl
perl
xz
zlib
];
nativeBuildInputs = [ pkg-config m4 ];
buildInputs = [ curl perl libarchive openssl zlib bzip2 xz ];
patches = [
./dont-create-empty-dirs.patch
# Add keyringdir meson option to configure the keyring directory
(fetchpatch {
url = "https://gitlab.archlinux.org/pacman/pacman/-/commit/79bd512181af12ec80fd8f79486fc9508fa4a1b3.patch";
hash = "sha256-ivTPwWe06Q5shn++R6EY0x3GC0P4X0SuC+F5sndfAtM=";
})
];
postFixup = ''
substituteInPlace $out/bin/repo-add \
postPatch = ''
substituteInPlace meson.build \
--replace "install_dir : SYSCONFDIR" "install_dir : '$out/etc'" \
--replace "join_paths(DATAROOTDIR, 'libalpm/hooks/')" "'${sysHookDir}'" \
--replace "join_paths(PREFIX, DATAROOTDIR, get_option('keyringdir'))" "'\$KEYRING_IMPORT_DIR'"
substituteInPlace doc/meson.build \
--replace "/bin/true" "${coreutils}/bin/true"
substituteInPlace scripts/repo-add.sh.in \
--replace bsdtar "${libarchive}/bin/bsdtar"
substituteInPlace scripts/pacman-key.sh.in \
--replace "local KEYRING_IMPORT_DIR='@keyringdir@'" "" \
--subst-var-by keyringdir '\$KEYRING_IMPORT_DIR' \
--replace "--batch --check-trustdb" "--batch --check-trustdb --allow-weak-key-signatures"
''; # the line above should be removed once Arch migrates to gnupg 2.3.x
mesonFlags = [
"--sysconfdir=/etc"
"--localstatedir=/var"
];
postInstall = ''
installShellCompletion --bash scripts/pacman --zsh scripts/_pacman
wrapProgram $out/bin/makepkg \
--prefix PATH : ${lib.makeBinPath [ binutils ]}
wrapProgram $out/bin/pacman-key \
--prefix PATH : ${lib.makeBinPath [ gnupg ]}
'';
meta = with lib; {
description = "A simple library-based package manager";
homepage = "https://www.archlinux.org/pacman/";
license = licenses.gpl2;
homepage = "https://archlinux.org/pacman/";
changelog = "https://gitlab.archlinux.org/pacman/pacman/-/raw/v${version}/NEWS";
license = licenses.gpl2Plus;
platforms = platforms.linux;
maintainers = with maintainers; [ mt-caret ];
maintainers = with maintainers; [ samlukeyes123 ];
};
}

View File

@ -0,0 +1,20 @@
diff --git a/meson.build b/meson.build
index c8ee42fd..610401ca 100644
--- a/meson.build
+++ b/meson.build
@@ -414,15 +414,6 @@ install_data(
'proto/proto.install',
install_dir : join_paths(DATAROOTDIR, 'pacman'))
-foreach path : [
- join_paths(LOCALSTATEDIR, 'lib/pacman/'),
- join_paths(LOCALSTATEDIR, 'cache/pacman/pkg/'),
- join_paths(DATAROOTDIR, 'makepkg-template/'),
- join_paths(DATAROOTDIR, 'libalpm/hooks/'),
- ]
- meson.add_install_script('sh', '-c', 'mkdir -p "$DESTDIR/@0@"'.format(path))
-endforeach
-
TEST_ENV = environment()
TEST_ENV.set('PMTEST_SCRIPTLIB_DIR', join_paths(meson.project_source_root(), 'scripts/library/'))
TEST_ENV.set('PMTEST_LIBMAKEPKG_DIR', join_paths(meson.project_build_root(), 'scripts/libmakepkg/'))