diff options
author | Joey Hess <joey@kitenet.net> | 2012-01-13 12:52:09 -0400 |
---|---|---|
committer | Joey Hess <joey@kitenet.net> | 2012-01-13 12:52:09 -0400 |
commit | 1ae780ee7990dc542a61714522c902754e76fb05 (patch) | |
tree | 1adfc326dc9110dcf7421304980103b981a6701d /Git | |
parent | daff9029ba85cee772b707add61e8ce1d7fd953f (diff) |
git-annex, git-union-merge: Support GIT_DIR and GIT_WORK_TREE.
Note that GIT_WORK_TREE cannot influence GIT_DIR; that is necessary for
git-fake-bare and vcsh type things to work.
Diffstat (limited to 'Git')
-rw-r--r-- | Git/Construct.hs | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/Git/Construct.hs b/Git/Construct.hs index 51fa656bc..7b77a72ba 100644 --- a/Git/Construct.hs +++ b/Git/Construct.hs @@ -6,6 +6,7 @@ -} module Git.Construct ( + fromCurrent, fromCwd, fromAbsPath, fromUrl, @@ -19,6 +20,8 @@ module Git.Construct ( ) where import System.Posix.User +import System.Posix.Env (getEnv) +import System.Posix.Directory (changeWorkingDirectory) import qualified Data.Map as M hiding (map, split) import Network.URI @@ -27,7 +30,23 @@ import Git.Types import Git import qualified Git.Url as Url -{- Finds the current git repository, which may be in a parent directory. -} +{- Finds the current git repository. + - + - GIT_DIR can override the location of the .git directory. + - + - When GIT_WORK_TREE is set, chdir to it, so that anything using + - this repository runs in the right location. However, this chdir is + - done after determining GIT_DIR; git does not let GIT_WORK_TREE + - influence the git directory. + -} +fromCurrent :: IO Repo +fromCurrent = do + r <- maybe fromCwd fromAbsPath =<< getEnv "GIT_DIR" + maybe (return ()) changeWorkingDirectory =<< getEnv "GIT_WORK_TREE" + return r + +{- Finds the git repository used for the Cwd, which may be in a parent + - directory. -} fromCwd :: IO Repo fromCwd = getCurrentDirectory >>= seekUp isRepoTop >>= maybe norepo makerepo where |