Merge pull request #24275 from spacekitteh/fetchFromGitRepo
fetchRepoProject: Fix buildCommand
This commit is contained in:
commit
7dc489d95a
@ -1,24 +1,34 @@
|
|||||||
{stdenv, git, gitRepo, gnupg ? null, cacert}:
|
{ stdenv, git, gitRepo, gnupg ? null, cacert }:
|
||||||
|
|
||||||
{name, manifest, rev ? "HEAD", sha256 ? "", repoRepoURL ? "", repoRepoRev ? "", referenceDir ? "",
|
{ name, manifest, rev ? "HEAD", sha256 ? "", repoRepoURL ? "", repoRepoRev ? "", referenceDir ? ""
|
||||||
localManifests ? [] }:
|
, localManifests ? []
|
||||||
|
}:
|
||||||
|
|
||||||
assert repoRepoRev != "" -> repoRepoURL != "";
|
assert repoRepoRev != "" -> repoRepoURL != "";
|
||||||
|
|
||||||
|
with stdenv.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
extraRepoInitFlags = [
|
||||||
|
(optionalString (repoRepoURL != "") "--repo-url=${repoRepoURL}")
|
||||||
|
(optionalString (repoRepoRev != "") "--repo-branch=${repoRepoRev}")
|
||||||
|
(optionalString (referenceDir != "") "--reference=${referenceDir}")
|
||||||
|
];
|
||||||
|
in
|
||||||
|
|
||||||
stdenv.mkDerivation {
|
stdenv.mkDerivation {
|
||||||
buildCommand = with stdenv.lib; ''
|
buildCommand = ''
|
||||||
mkdir ./.repo
|
mkdir ./.repo
|
||||||
mkdir ./.repo/local_manifests
|
mkdir ./.repo/local_manifests
|
||||||
for local_manifest in ${concatMapStringsSep " " (x: "${x}") localManifests}
|
for local_manifest in ${concatMapStringsSep " " toString localManifests}
|
||||||
do
|
do
|
||||||
cp $local_manifest ./.repo/local_manifests/$(stripHash $local_manifest; echo $strippedName)
|
cp $local_manifest ./.repo/local_manifests/$(stripHash $local_manifest; echo $strippedName)
|
||||||
done
|
done
|
||||||
|
|
||||||
export HOME=.repo
|
export HOME=.repo
|
||||||
repo init --manifest-url=${manifest} --manifest-branch=${rev} --depth=1 --no-clone-bundle
|
repo init --manifest-url=${manifest} --manifest-branch=${rev} --depth=1 --no-clone-bundle \
|
||||||
${optionalString (repoRepoURL != "") " --repo-url=${repoRepoURL}"}
|
${concatStringsSep " " extraRepoInitFlags}
|
||||||
${optionalString (repoRepoRev != "") " --repo-branch=${repoRepoRev}"}
|
|
||||||
${optionalString (referenceDir != "") " --reference=${referenceDir}"}
|
|
||||||
repo sync --jobs=$NIX_BUILD_CORES --current-branch
|
repo sync --jobs=$NIX_BUILD_CORES --current-branch
|
||||||
rm -rf $out/.repo
|
rm -rf $out/.repo
|
||||||
'';
|
'';
|
||||||
@ -29,7 +39,7 @@ stdenv.mkDerivation {
|
|||||||
"GIT_PROXY_COMMAND" "SOCKS_SERVER"
|
"GIT_PROXY_COMMAND" "SOCKS_SERVER"
|
||||||
];
|
];
|
||||||
|
|
||||||
buildInputs = [git gitRepo cacert] ++ stdenv.lib.optional (gnupg != null) [gnupg] ;
|
buildInputs = [git gitRepo cacert] ++ optional (gnupg != null) [gnupg] ;
|
||||||
|
|
||||||
outputHashAlgo = "sha256";
|
outputHashAlgo = "sha256";
|
||||||
outputHashMode = "recursive";
|
outputHashMode = "recursive";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user