2024-05-02 00:46:19 +00:00
|
|
|
{ lib, stdenvNoCC, mercurial }:
|
2024-05-13 21:24:10 +00:00
|
|
|
{ name ? null, url, rev ? null, sha256 ? null, hash ? null
|
|
|
|
, fetchSubrepos ? false, preferLocalBuild ? true }:
|
2024-05-02 00:46:19 +00:00
|
|
|
|
|
|
|
if hash != null && sha256 != null then
|
|
|
|
throw "Only one of sha256 or hash can be set"
|
|
|
|
else
|
|
|
|
# TODO: statically check if mercurial as the https support if the url starts woth https.
|
2024-05-13 21:24:10 +00:00
|
|
|
stdenvNoCC.mkDerivation {
|
|
|
|
name = "hg-archive" + (lib.optionalString (name != null) "-${name}");
|
|
|
|
builder = ./builder.sh;
|
|
|
|
nativeBuildInputs = [ mercurial ];
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-05-13 21:24:10 +00:00
|
|
|
impureEnvVars = lib.fetchers.proxyImpureEnvVars;
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-05-13 21:24:10 +00:00
|
|
|
subrepoClause = lib.optionalString fetchSubrepos "S";
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-05-13 21:24:10 +00:00
|
|
|
outputHashAlgo = if hash != null then null else "sha256";
|
|
|
|
outputHashMode = "recursive";
|
|
|
|
outputHash = if hash != null then
|
|
|
|
hash
|
|
|
|
else if sha256 != null then
|
|
|
|
sha256
|
|
|
|
else
|
|
|
|
lib.fakeSha256;
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-05-13 21:24:10 +00:00
|
|
|
inherit url rev;
|
|
|
|
inherit preferLocalBuild;
|
|
|
|
}
|