{ lib, stdenv, fetchurl, getopt, util-linuxMinimal, which, gperf, nix-update-script }: stdenv.mkDerivation rec { pname = "libseccomp"; version = "2.5.5"; src = fetchurl { url = "https://github.com/seccomp/libseccomp/releases/download/v${version}/libseccomp-${version}.tar.gz"; hash = "sha256-JIosik2bmFiqa69ScSw0r+/PnJ6Ut23OAsHJqiX7M3U="; }; outputs = [ "out" "lib" "dev" "man" "pythonsrc" ]; nativeBuildInputs = [ gperf ]; buildInputs = [ getopt ]; patchPhase = '' patchShebangs . ''; nativeCheckInputs = [ util-linuxMinimal which ]; doCheck = !(stdenv.targetPlatform.useLLVM or false); # Hack to ensure that patchelf --shrink-rpath get rids of a $TMPDIR reference. preFixup = "rm -rfv src"; # Copy the python module code into a tarball that we can export and use as the # src input for buildPythonPackage calls postInstall = '' cp -R ./src/python/ tmp-pythonsrc/ tar -zcf $pythonsrc --mtime="@$SOURCE_DATE_EPOCH" --sort=name --transform s/tmp-pythonsrc/python-foundationdb/ ./tmp-pythonsrc/ ''; passthru = { updateScript = nix-update-script { }; }; meta = with lib; { description = "High level library for the Linux Kernel seccomp filter"; mainProgram = "scmp_sys_resolver"; homepage = "https://github.com/seccomp/libseccomp"; license = licenses.lgpl21Only; platforms = platforms.linux; badPlatforms = [ "alpha-linux" "loongarch64-linux" "m68k-linux" "microblaze-linux" "microblazeel-linux" "riscv32-linux" "sparc-linux" "sparc64-linux" ]; maintainers = with maintainers; [ thoughtpolice ]; }; }