diff options
Diffstat (limited to 'nixpkgs/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix')
-rw-r--r-- | nixpkgs/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix | 47 |
1 files changed, 24 insertions, 23 deletions
diff --git a/nixpkgs/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix b/nixpkgs/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix index 738fef022010..dedb877448a6 100644 --- a/nixpkgs/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix +++ b/nixpkgs/pkgs/tools/typesetting/tex/texlive/generate-fixed-hashes.nix @@ -1,32 +1,33 @@ with import ../../../../.. { }; with lib; let - # NOTE: the fixed naming scheme must match default.nix - # name for the URL - mkURLName = { pname, tlType, ... }: pname + lib.optionalString (tlType != "run" && tlType != "tlpkg") ".${tlType}"; - # name + revision for the fixed output hashes - mkFixedName = { tlType, revision, extraRevision ? "", ... }@attrs: mkURLName attrs + (lib.optionalString (tlType == "tlpkg") ".tlpkg") + ".r${toString revision}${extraRevision}"; - - uniqueByName = fods: catAttrs "fod" (genericClosure { - startSet = map (fod: { key = fod.name; inherit fod; }) fods; - operator = _: [ ]; - }); + isFod = p: p.tlType != "bin" && isDerivation p; # ugly hack to extract combine from collection-latexextra, since it is masked by texlive.combine - combine = lib.findFirst (p: (lib.head p.pkgs).pname == "combine") { pkgs = []; } (lib.head texlive.collection-latexextra.pkgs).tlDeps; - all = concatLists (map (p: p.pkgs or []) (attrValues (removeAttrs texlive [ "bin" "combine" "combined" "tlpdb" ]))) ++ combine.pkgs; - - # fixed hashes only for run, doc, source, tlpkg types - fods = sort (a: b: a.name < b.name) (uniqueByName (filter (p: isDerivation p && p.tlType != "bin") all)); + combine = lib.findFirst (p: (lib.head p.pkgs).pname == "combine") { pkgs = [ ]; } (lib.head texlive.collection-latexextra.pkgs).tlDeps; + all = filter (p: p ? pkgs) (attrValues (removeAttrs texlive [ "bin" "combine" "combined" "tlpdb" ])) ++ [ combine ]; + sorted = sort (a: b: (head a.pkgs).pname < (head b.pkgs).pname) all; + fods = filter isFod (concatMap (p: p.pkgs or [ ]) all); - computeHash = fod: runCommand "${fod.name}-fixed-hash" + computeHash = fod: runCommand "${fod.pname}-${fod.tlType}-fixed-hash" { buildInputs = [ nix ]; inherit fod; } ''echo -n "$(nix-hash --base32 --type sha256 "$fod")" >"$out"''; hash = fod: fod.outputHash or (builtins.readFile (computeHash fod)); - hashLine = fod: '' - "${mkFixedName fod}"="${hash fod}"; - ''; + + hashes = { pkgs }: + concatMapStrings ({ tlType, ... }@p: lib.optionalString (isFod p) (''${tlType}="${hash p}";'')) pkgs; + + hashLine = { pkgs }@pkg: + let + fods = lib.filter isFod pkgs; + first = lib.head fods; + # NOTE: the fixed naming scheme must match default.nix + fixedName = with first; "${pname}-${toString revision}${first.extraRevision or ""}"; + in + lib.optionalString (fods != [ ]) '' + ${strings.escapeNixIdentifier fixedName}={${hashes pkg}}; + ''; in { # fixedHashesNix uses 'import from derivation' which does not parallelize well @@ -34,8 +35,8 @@ in newHashes = map computeHash (filter (fod: ! fod ? outputHash) fods); fixedHashesNix = writeText "fixed-hashes.nix" - '' - { - ${lib.concatMapStrings hashLine fods}} - ''; + '' + { + ${lib.concatMapStrings hashLine sorted}} + ''; } |