79 lines
1.8 KiB
Nix
79 lines
1.8 KiB
Nix
{ lib
|
|
, stdenv
|
|
, callPackage
|
|
, python27
|
|
, fetchFromGitHub
|
|
, installShellFiles
|
|
, rSrc
|
|
, version
|
|
, oildev
|
|
, configargparse
|
|
, gawk
|
|
, binlore
|
|
, resholve
|
|
, resholve-utils
|
|
}:
|
|
|
|
let
|
|
sedparse = python27.pkgs.buildPythonPackage rec {
|
|
pname = "sedparse";
|
|
version = "0.1.2";
|
|
src = fetchFromGitHub {
|
|
owner = "aureliojargas";
|
|
repo = "sedparse";
|
|
rev = "0.1.2";
|
|
hash = "sha256-Q17A/oJ3GZbdSK55hPaMdw85g43WhTW9tuAuJtDfHHU=";
|
|
};
|
|
};
|
|
|
|
in python27.pkgs.buildPythonApplication {
|
|
pname = "resholve";
|
|
inherit version;
|
|
src = rSrc;
|
|
|
|
nativeBuildInputs = [ installShellFiles ];
|
|
|
|
propagatedBuildInputs = [
|
|
oildev
|
|
configargparse
|
|
sedparse
|
|
];
|
|
|
|
makeWrapperArgs = [
|
|
"--prefix PATH : ${lib.makeBinPath [ gawk ]}"
|
|
];
|
|
|
|
postPatch = ''
|
|
for file in setup.cfg _resholve/version.py; do
|
|
substituteInPlace $file --subst-var-by version ${version}
|
|
done
|
|
'';
|
|
|
|
postInstall = ''
|
|
installManPage resholve.1
|
|
'';
|
|
|
|
# Do not propagate Python; may be obsoleted by nixos/nixpkgs#102613
|
|
# for context on why, see abathur/resholve#20
|
|
postFixup = ''
|
|
rm $out/nix-support/propagated-build-inputs
|
|
'';
|
|
|
|
passthru = {
|
|
inherit (resholve-utils) mkDerivation phraseSolution writeScript writeScriptBin;
|
|
tests = callPackage ./test.nix { inherit rSrc binlore python27 resholve; };
|
|
};
|
|
|
|
meta = with lib; {
|
|
description = "Resolve external shell-script dependencies";
|
|
homepage = "https://github.com/abathur/resholve";
|
|
license = with licenses; [ mit ];
|
|
maintainers = with maintainers; [ abathur ];
|
|
platforms = platforms.all;
|
|
knownVulnerabilities = [ ''
|
|
resholve depends on python27 (EOL). While it's safe to
|
|
run on trusted input in the build sandbox, you should
|
|
avoid running it on untrusted input.
|
|
'' ];
|
|
};
|
|
}
|