2024-06-30 08:16:52 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
stdenvNoCC,
|
|
|
|
mercurial,
|
|
|
|
}:
|
|
|
|
{
|
|
|
|
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
|
2024-06-30 08:16:52 +00:00
|
|
|
# TODO: statically check if mercurial as the https support if the url starts woth https.
|
|
|
|
stdenvNoCC.mkDerivation {
|
|
|
|
name = "hg-archive" + (lib.optionalString (name != null) "-${name}");
|
|
|
|
builder = ./builder.sh;
|
|
|
|
nativeBuildInputs = [ mercurial ];
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
impureEnvVars = lib.fetchers.proxyImpureEnvVars;
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +00:00
|
|
|
subrepoClause = lib.optionalString fetchSubrepos "S";
|
2024-05-02 00:46:19 +00:00
|
|
|
|
2024-06-30 08:16:52 +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-06-30 08:16:52 +00:00
|
|
|
inherit url rev;
|
|
|
|
inherit preferLocalBuild;
|
|
|
|
}
|