aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLibravatar Alexander Foremny <aforemny@posteo.de>2023-10-16 14:20:23 +0200
committerLibravatar Alexander Foremny <aforemny@posteo.de>2023-10-16 14:21:23 +0200
commit82737c98e809bb3e970aa16750aa70f1adcfa03a (patch)
treef0b6d5f2352ff6b62f5bc5113b989c3c9b479055
parentb0112000b3f2966489bbf5ac1f2e15815f463d06 (diff)
refactor `Git.withWorkingTree`
-rw-r--r--anissue.cabal1
-rw-r--r--app/Git.hs15
-rw-r--r--app/History.hs27
3 files changed, 28 insertions, 15 deletions
diff --git a/anissue.cabal b/anissue.cabal
index 25c6b65..ace9580 100644
--- a/anissue.cabal
+++ b/anissue.cabal
@@ -66,6 +66,7 @@ executable anissue
-- Modules included in this executable, other than Main.
other-modules:
+ Git
History
Issue
Issue.Filter
diff --git a/app/Git.hs b/app/Git.hs
new file mode 100644
index 0000000..57fffdc
--- /dev/null
+++ b/app/Git.hs
@@ -0,0 +1,15 @@
+module Git (withWorkingTree) where
+
+import Control.Exception (finally)
+import Data.Text (Text)
+import Process (proc, sh_)
+import System.Directory (createDirectoryIfMissing)
+import System.FilePath (dropTrailingPathSeparator, takeDirectory)
+
+-- | Runs an IO-action within a working tree.
+withWorkingTree :: FilePath -> Text -> IO a -> IO a
+withWorkingTree path hash action = do
+ createDirectoryIfMissing True (takeDirectory (dropTrailingPathSeparator path))
+ sh_ $ proc "git worktree add --quiet --detach % %" path hash
+ action `finally` do
+ sh_ $ proc "git worktree remove --force %" path
diff --git a/app/History.hs b/app/History.hs
index ff7f889..4f62610 100644
--- a/app/History.hs
+++ b/app/History.hs
@@ -10,12 +10,13 @@ import Data.Maybe (catMaybes, mapMaybe)
import Data.Text (Text, append, isPrefixOf, lines, pack, unpack)
import Data.Text.Encoding (decodeUtf8)
import GHC.Generics (Generic)
+import Git qualified
import Issue (Issue (..), fromMatch, id)
import Issue.Filter (Filter, applyFilter)
-import Issue.Tag qualified as I
import Issue.Sort (Sort, applySort)
+import Issue.Tag qualified as I
import Parallel (parMapM)
-import Process (proc, sh, sh_)
+import Process (proc, sh)
import System.Directory (createDirectoryIfMissing, doesFileExist, getCurrentDirectory)
import System.Exit (ExitCode (ExitFailure), exitWith)
import System.FilePath (takeExtension, (</>))
@@ -220,25 +221,21 @@ getIssuesAndFilesWorkingTreeChanged paths = do
getIssuesCommitAll :: Text -> IO [Issue]
getIssuesCommitAll hash = do
withSystemTempDirectory "history" $ \tmp -> do
- cwd <- do
- let cwd = tmp </> unpack hash
- sh_ $ proc "git worktree add --detach % %" cwd (unpack hash)
- pure cwd
- files <- gitLsFilesAll cwd
- concat <$> catch (getIssuesPar cwd files) (dieOfInvalidTreeGrepperResult)
+ let cwd = tmp </> unpack hash
+ Git.withWorkingTree cwd hash do
+ files <- gitLsFilesAll cwd
+ concat <$> catch (getIssuesPar cwd files) (dieOfInvalidTreeGrepperResult)
-- | Given the hash of a commit, get all issues in the files which have
-- been changed by this commit, as well as all changed files.
getIssuesAndFilesCommitChanged :: Text -> IO ([Issue], [FilePath])
getIssuesAndFilesCommitChanged hash = do
withSystemTempDirectory "history" $ \tmp -> do
- cwd <- do
- let cwd = tmp </> unpack hash
- sh_ $ proc "git worktree add --detach % %" cwd (unpack hash)
- pure cwd
- files <- gitShowChanged cwd
- issues <- concat <$> catch (getIssuesPar cwd files) (dieOfInvalidTreeGrepperResult)
- pure (issues, files)
+ let cwd = tmp </> unpack hash
+ Git.withWorkingTree cwd hash do
+ files <- gitShowChanged cwd
+ issues <- concat <$> catch (getIssuesPar cwd files) (dieOfInvalidTreeGrepperResult)
+ pure (issues, files)
gitLsFilesAll :: FilePath -> IO [FilePath]
gitLsFilesAll cwd =