summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGravatar Joey Hess <joeyh@joeyh.name>2016-11-01 14:03:55 -0400
committerGravatar Joey Hess <joeyh@joeyh.name>2016-11-01 14:03:59 -0400
commit3d3a578e2e471437f3b0c893f207e863f3749374 (patch)
tree072afbb4df63570b85bac33b9d9769ed1118eaaa
parent8d16ba5f1f241318e4a912d86cd70c3f4242a22a (diff)
restart coprocess in raw mode
Restarting a crashing git process could result in filename encoding issues when not in a unicode locale, as the restarted processes's handles were not read in raw mode. Since rawMode is always used when starting a coprocess, didn't bother to parameterise it and just always enable it for simplicity. This commit was sponsored by Jake Vosloo on Patreon.
-rw-r--r--CHANGELOG8
-rw-r--r--Git/CatFile.hs2
-rw-r--r--Git/CheckAttr.hs2
-rw-r--r--Git/CheckIgnore.hs2
-rw-r--r--Git/HashObject.hs2
-rw-r--r--Git/Tree.hs2
-rw-r--r--Utility/CoProcess.hs22
7 files changed, 21 insertions, 19 deletions
diff --git a/CHANGELOG b/CHANGELOG
index 6a1301b3e..a939435cf 100644
--- a/CHANGELOG
+++ b/CHANGELOG
@@ -1,3 +1,11 @@
+git-annex (6.20161032) UNRELEASED; urgency=medium
+
+ * Restarting a crashing git process could result in filename encoding
+ issues when not in a unicode locale, as the restarted processes's
+ handles were not read in raw mode.
+
+ -- Joey Hess <id@joeyh.name> Tue, 01 Nov 2016 14:02:06 -0400
+
git-annex (6.20161031) unstable; urgency=medium
* Assistant, repair: Fix ignoring of git fsck errors due to
diff --git a/Git/CatFile.hs b/Git/CatFile.hs
index 9af46fb51..061349f05 100644
--- a/Git/CatFile.hs
+++ b/Git/CatFile.hs
@@ -51,7 +51,7 @@ catFileStart' restartable repo = CatFileHandle
<$> startp "--batch"
<*> startp "--batch-check=%(objectname) %(objecttype) %(objectsize)"
where
- startp p = CoProcess.rawMode =<< gitCoProcessStart restartable
+ startp p = gitCoProcessStart restartable
[ Param "cat-file"
, Param p
] repo
diff --git a/Git/CheckAttr.hs b/Git/CheckAttr.hs
index b94bc0ee1..a248f4982 100644
--- a/Git/CheckAttr.hs
+++ b/Git/CheckAttr.hs
@@ -24,7 +24,7 @@ type Attr = String
checkAttrStart :: [Attr] -> Repo -> IO CheckAttrHandle
checkAttrStart attrs repo = do
currdir <- getCurrentDirectory
- h <- CoProcess.rawMode =<< gitCoProcessStart True params repo
+ h <- gitCoProcessStart True params repo
oldgit <- Git.Version.older "1.7.7"
return (h, attrs, oldgit, currdir)
where
diff --git a/Git/CheckIgnore.hs b/Git/CheckIgnore.hs
index 7d30e5ada..594882a81 100644
--- a/Git/CheckIgnore.hs
+++ b/Git/CheckIgnore.hs
@@ -37,7 +37,7 @@ type CheckIgnoreHandle = CoProcess.CoProcessHandle
-}
checkIgnoreStart :: Repo -> IO (Maybe CheckIgnoreHandle)
checkIgnoreStart repo = ifM supportedGitVersion
- ( Just <$> (CoProcess.rawMode =<< gitCoProcessStart True params repo')
+ ( Just <$> gitCoProcessStart True params repo'
, return Nothing
)
where
diff --git a/Git/HashObject.hs b/Git/HashObject.hs
index ed3baf4c6..4cd54ef54 100644
--- a/Git/HashObject.hs
+++ b/Git/HashObject.hs
@@ -20,7 +20,7 @@ import Utility.Tmp
type HashObjectHandle = CoProcess.CoProcessHandle
hashObjectStart :: Repo -> IO HashObjectHandle
-hashObjectStart = CoProcess.rawMode <=< gitCoProcessStart True
+hashObjectStart = gitCoProcessStart True
[ Param "hash-object"
, Param "-w"
, Param "--stdin-paths"
diff --git a/Git/Tree.hs b/Git/Tree.hs
index c341e1f5b..282643f49 100644
--- a/Git/Tree.hs
+++ b/Git/Tree.hs
@@ -59,7 +59,7 @@ newtype MkTreeHandle = MkTreeHandle CoProcess.CoProcessHandle
withMkTreeHandle :: (MonadIO m, MonadMask m) => Repo -> (MkTreeHandle -> m a) -> m a
withMkTreeHandle repo a = bracketIO setup cleanup (a . MkTreeHandle)
where
- setup = CoProcess.rawMode =<< gitCoProcessStart False ps repo
+ setup = gitCoProcessStart False ps repo
ps = [Param "mktree", Param "--batch", Param "-z"]
cleanup = CoProcess.stop
diff --git a/Utility/CoProcess.hs b/Utility/CoProcess.hs
index 9854b47fc..94d5ac3bc 100644
--- a/Utility/CoProcess.hs
+++ b/Utility/CoProcess.hs
@@ -13,7 +13,6 @@ module Utility.CoProcess (
start,
stop,
query,
- rawMode
) where
import Common
@@ -44,7 +43,15 @@ start numrestarts cmd params environ = do
start' :: CoProcessSpec -> IO CoProcessState
start' s = do
(pid, from, to) <- startInteractiveProcess (coProcessCmd s) (coProcessParams s) (coProcessEnv s)
+ rawMode from
+ rawMode to
return $ CoProcessState pid to from s
+ where
+ rawMode h = do
+ fileEncoding h
+#ifdef mingw32_HOST_OS
+ hSetNewlineMode h noNewlineTranslation
+#endif
stop :: CoProcessHandle -> IO ()
stop ch = do
@@ -79,16 +86,3 @@ query ch send receive = do
{ coProcessNumRestarts = coProcessNumRestarts (coProcessSpec s) - 1 }
putMVar ch s'
query ch send receive
-
-rawMode :: CoProcessHandle -> IO CoProcessHandle
-rawMode ch = do
- s <- readMVar ch
- raw $ coProcessFrom s
- raw $ coProcessTo s
- return ch
- where
- raw h = do
- fileEncoding h
-#ifdef mingw32_HOST_OS
- hSetNewlineMode h noNewlineTranslation
-#endif