Simplify rootSrc fetchGit logic
This commit is contained in:
parent
64de97c480
commit
5ad681b894
|
@ -74,18 +74,15 @@ let
|
||||||
in outputs;
|
in outputs;
|
||||||
|
|
||||||
rootSrc = let
|
rootSrc = let
|
||||||
dir = builtins.readDir src;
|
|
||||||
gitDir = builtins.readDir (src + "/.git");
|
|
||||||
isGit = dir ? ".git";
|
|
||||||
isGitDir = isGit && dir.".git" == "directory";
|
|
||||||
isShallow = isGitDir && gitDir ? "shallow";
|
|
||||||
# Try to clean the source tree by using fetchGit, if this source
|
# Try to clean the source tree by using fetchGit, if this source
|
||||||
# tree is a valid git repository.
|
# tree is a valid git repository.
|
||||||
# NB git worktrees have a file for .git, so we don't check the type of .git
|
|
||||||
tryFetchGit = src:
|
tryFetchGit = src:
|
||||||
if isGit && !isShallow
|
if isGit && !isShallow
|
||||||
then builtins.fetchGit src
|
then builtins.fetchGit src
|
||||||
else { outPath = src; };
|
else { outPath = src; };
|
||||||
|
# NB git worktrees have a file for .git, so we don't check the type of .git
|
||||||
|
isGit = builtins.pathExists (src + "/.git");
|
||||||
|
isShallow = builtins.pathExists (src + "/.git/shallow");
|
||||||
|
|
||||||
in
|
in
|
||||||
(if src ? outPath then src else tryFetchGit src)
|
(if src ? outPath then src else tryFetchGit src)
|
||||||
|
|
Loading…
Reference in a new issue