summaryrefslogtreecommitdiff
path: root/Git
diff options
context:
space:
mode:
Diffstat (limited to 'Git')
-rw-r--r--Git/CatFile.hs27
1 files changed, 1 insertions, 26 deletions
diff --git a/Git/CatFile.hs b/Git/CatFile.hs
index f7438b410..2565dff94 100644
--- a/Git/CatFile.hs
+++ b/Git/CatFile.hs
@@ -73,10 +73,7 @@ catObjectDetails (CatFileHandle hdl repo) object = CoProcess.query hdl send rece
| otherwise -> dne
_
| header == show object ++ " missing" -> dne
- | otherwise ->
- if any isSpace query
- then fallback
- else error $ "unknown response from git cat-file " ++ show (header, object)
+ | otherwise -> error $ "unknown response from git cat-file " ++ show (header, object)
readcontent bytes from sha = do
content <- S.hGet from bytes
eatchar '\n' from
@@ -87,28 +84,6 @@ catObjectDetails (CatFileHandle hdl repo) object = CoProcess.query hdl send rece
when (c /= expected) $
error $ "missing " ++ (show expected) ++ " from git cat-file"
- {- Work around a bug in git 1.8.4 rc0 which broke it for filenames
- - containing spaces. http://bugs.debian.org/718517
- - Slow! Also can use a lot of memory, if the object is large. -}
- fallback = do
- let p = gitCreateProcess
- [ Param "cat-file"
- , Param "-p"
- , Param query
- ] repo
- (_, Just h, _, pid) <- withNullHandle $ \h ->
- createProcess p
- { std_out = CreatePipe
- , std_err = UseHandle h
- }
- fileEncoding h
- content <- L.hGetContents h
- let sha = (\s -> length s `seq` s) (show $ sha1 content)
- ok <- checkSuccessProcess pid
- return $ if ok
- then Just (content, Ref sha)
- else Nothing
-
{- Gets a list of files and directories in a tree. (Not recursive.) -}
catTree :: CatFileHandle -> Ref -> IO [(FilePath, FileMode)]
catTree h treeref = go <$> catObjectDetails h treeref