Files
nixpkgs/pkgs/by-name/ap/apparmor-parser/package.nix
Dark Steveneq 646b892680
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
push sheeet
2025-10-09 14:15:47 +02:00

78 lines
1.7 KiB
Nix

{
lib,
stdenv,
which,
flex,
bison,
linuxHeaders ? stdenv.cc.libc.linuxHeaders,
buildPackages,
# apparmor deps
libapparmor,
apparmor-bin-utils,
# testing
perl,
python3,
bashInteractive,
}:
stdenv.mkDerivation (finalAttrs: {
pname = "apparmor-parser";
inherit (libapparmor) version src;
postPatch = ''
patchShebangs .
cd parser
substituteInPlace Makefile \
--replace-fail "/usr/include/linux/capability.h" "${linuxHeaders}/include/linux/capability.h"
substituteInPlace rc.apparmor.functions \
--replace-fail "/sbin/apparmor_parser" "$out/bin/apparmor_parser" # FIXME
substituteInPlace rc.apparmor.functions \
--replace-fail "/usr/sbin/aa-status" "${lib.getExe' apparmor-bin-utils "aa-status"}"
sed -i rc.apparmor.functions -e '2i . ${./fix-rc.apparmor.functions.sh}'
'';
nativeBuildInputs = [
bison
flex
which
];
buildInputs = [ libapparmor ];
makeFlags = [
"LANGS="
"USE_SYSTEM=1"
"INCLUDEDIR=${libapparmor}/include"
"AR=${stdenv.cc.bintools.targetPrefix}ar"
"POD2MAN=${lib.getExe' buildPackages.perl "pod2man"}"
"POD2HTML=${lib.getExe' buildPackages.perl "pod2html"}"
"MANDIR=share/man"
]
++ lib.optional finalAttrs.doCheck "PROVE=${lib.getExe' perl "prove"}";
installFlags = [
"DESTDIR=$(out)"
"DISTRO=unknown"
];
preCheck = "pushd ./tst";
checkTarget = "tests";
postCheck = "popd";
doCheck = stdenv.hostPlatform == stdenv.buildPlatform;
checkInputs = [
bashInteractive
perl
python3
];
meta = libapparmor.meta // {
description = "Mandatory access control system - core library";
mainProgram = "apparmor_parser";
};
})