summaryrefslogtreecommitdiff
path: root/Git
diff options
context:
space:
mode:
authorGravatar Joey Hess <joey@kitenet.net>2012-06-12 21:13:15 -0400
committerGravatar Joey Hess <joey@kitenet.net>2012-06-12 21:13:15 -0400
commitda62edb42af02ce34e9ea69edcd8ec2f30cdd625 (patch)
treef001c384056798363557aea62914d5bead850cd0 /Git
parent7d458c40db7778f677c00cbc076d37b5e4abf60d (diff)
optimisation and memory leak fix
Diffstat (limited to 'Git')
-rw-r--r--Git/Queue.hs12
-rw-r--r--Git/UpdateIndex.hs2
2 files changed, 7 insertions, 7 deletions
diff --git a/Git/Queue.hs b/Git/Queue.hs
index acf6cd091..ddcf13519 100644
--- a/Git/Queue.hs
+++ b/Git/Queue.hs
@@ -34,7 +34,7 @@ data Action
{- Updating the index file, using a list of streamers that can
- be added to as the queue grows. -}
= UpdateIndexAction
- { getStreamers :: [Git.UpdateIndex.Streamer]
+ { getStreamers :: [Git.UpdateIndex.Streamer] -- in reverse order
}
{- A git command to run, on a list of files that can be added to
- as the queue grows. -}
@@ -104,9 +104,8 @@ addUpdateIndex streamer q repo =
updateQueue action different 1 q repo
where
key = actionKey action
- -- streamer is added to the end of the list, since
- -- order does matter for update-index input
- action = UpdateIndexAction $ streamers ++ [streamer]
+ -- the list is built in reverse order
+ action = UpdateIndexAction $ streamer : streamers
streamers = maybe [] getStreamers $ M.lookup key $ items q
different (UpdateIndexAction _) = False
@@ -116,7 +115,7 @@ addUpdateIndex streamer q repo =
- different action, it will be flushed; this is to ensure that conflicting
- actions, like add and rm, are run in the right order.-}
updateQueue :: Action -> (Action -> Bool) -> Int -> Queue -> Repo -> IO Queue
-updateQueue action different sizeincrease q repo
+updateQueue !action different sizeincrease q repo
| null (filter different (M.elems (items q))) = return $ go q
| otherwise = go <$> flush q repo
where
@@ -147,7 +146,8 @@ flush (Queue _ lim m) repo = do
- this allows queueing commands that do not need a list of files. -}
runAction :: Repo -> Action -> IO ()
runAction repo (UpdateIndexAction streamers) =
- Git.UpdateIndex.streamUpdateIndex repo streamers
+ -- list is stored in reverse order
+ Git.UpdateIndex.streamUpdateIndex repo $ reverse streamers
runAction repo action@(CommandAction {}) =
pOpen WriteToPipe "xargs" ("-0":"git":params) feedxargs
where
diff --git a/Git/UpdateIndex.hs b/Git/UpdateIndex.hs
index 31e8a45b2..abdc4bcbe 100644
--- a/Git/UpdateIndex.hs
+++ b/Git/UpdateIndex.hs
@@ -71,7 +71,7 @@ unstageFile file repo = do
{- A streamer that adds a symlink to the index. -}
stageSymlink :: FilePath -> Sha -> Repo -> IO Streamer
stageSymlink file sha repo = do
- line <- updateIndexLine
+ !line <- updateIndexLine
<$> pure sha
<*> pure SymlinkBlob
<*> toTopFilePath file repo