Skip to content

Commit

Permalink
Support Git submodules in source-package-respository
Browse files Browse the repository at this point in the history
  • Loading branch information
akshaymankar committed Sep 7, 2021
1 parent 451ef1c commit ddd7244
Showing 1 changed file with 16 additions and 13 deletions.
29 changes: 16 additions & 13 deletions cabal-install/src/Distribution/Client/VCS.hs
Original file line number Diff line number Diff line change
Expand Up @@ -386,7 +386,7 @@ vcsGit =
vcsCloneRepo verbosity prog repo srcuri destdir =
[ programInvocation prog cloneArgs ]
-- And if there's a tag, we have to do that in a second step:
++ [ (programInvocation prog (checkoutArgs tag)) {
++ [ (programInvocation prog (resetArgs tag)) {
progInvokeCwd = Just destdir
}
| tag <- maybeToList (srpTag repo) ]
Expand All @@ -396,7 +396,7 @@ vcsGit =
branchArgs = case srpBranch repo of
Just b -> ["--branch", b]
Nothing -> []
checkoutArgs tag = "checkout" : verboseArg ++ [tag, "--"]
resetArgs tag = "reset" : verboseArg ++ ["--hard", tag, "--"]
verboseArg = [ "--quiet" | verbosity < Verbosity.normal ]

vcsSyncRepos :: Verbosity
Expand All @@ -419,24 +419,27 @@ vcsGit =
if exists
then git localDir ["fetch"]
else git (takeDirectory localDir) cloneArgs
git localDir checkoutArgs
git localDir resetArgs
git localDir ["submodule", "sync", "--recursive"]
git localDir ["submodule", "update", "--force", "--init", "--recursive"]
git localDir ["submodule", "foreach", "--recursive", "git clean -ffxdq"]
git localDir ["clean", "-ffxdq"]
where
git :: FilePath -> [String] -> IO ()
git cwd args = runProgramInvocation verbosity $
(programInvocation gitProg args) {
progInvokeCwd = Just cwd
}

cloneArgs = ["clone", "--no-checkout", loc, localDir]
++ case peer of
Nothing -> []
Just peerLocalDir -> ["--reference", peerLocalDir]
++ verboseArg
where loc = srpLocation
checkoutArgs = "checkout" : verboseArg ++ ["--detach", "--force"
, checkoutTarget, "--" ]
checkoutTarget = fromMaybe "HEAD" (srpBranch `mplus` srpTag)
verboseArg = [ "--quiet" | verbosity < Verbosity.normal ]
cloneArgs = ["clone", "--no-checkout", loc, localDir]
++ case peer of
Nothing -> []
Just peerLocalDir -> ["--reference", peerLocalDir]
++ verboseArg
where loc = srpLocation
resetArgs = "reset" : verboseArg ++ ["--hard", resetTarget, "--" ]
resetTarget = fromMaybe "HEAD" (srpBranch `mplus` srpTag)
verboseArg = [ "--quiet" | verbosity < Verbosity.normal ]

gitProgram :: Program
gitProgram = (simpleProgram "git") {
Expand Down

0 comments on commit ddd7244

Please sign in to comment.