aboutsummaryrefslogtreecommitdiffstats
path: root/app/Review.hs
diff options
context:
space:
mode:
Diffstat (limited to 'app/Review.hs')
-rw-r--r--app/Review.hs42
1 files changed, 34 insertions, 8 deletions
diff --git a/app/Review.hs b/app/Review.hs
index e134a62..ef901ce 100644
--- a/app/Review.hs
+++ b/app/Review.hs
@@ -2,8 +2,7 @@ module Review
( Plan (..),
PlanStep (..),
formulatePlan,
- reviewPatch,
- separateReview,
+ reviewStep,
)
where
@@ -38,6 +37,7 @@ type BranchName = T.Text
data PlanStep = PlanStep
{ commit :: Git.CommitHash,
+ earlierCommit :: Git.CommitHash,
changes :: D.FileDeltas
}
deriving (Show, Generic, B.Binary)
@@ -58,31 +58,57 @@ formulatePlan perCommit baseBranch featureBranch = do
fileDeltas <-
fmap concat . forM commits $
\(commit, earlierCommit) ->
- map (earlierCommit,) . (: []) . (.fileDeltas)
+ map ((commit, earlierCommit),) . (: []) . (.fileDeltas)
<$> Git.diffOf earlierCommit commit
pure
Plan
{ steps =
- NE.fromList (map (uncurry PlanStep) fileDeltas),
+ NE.fromList
+ ( map
+ ( \((commit, earlierCommit), changes) ->
+ PlanStep {..}
+ )
+ fileDeltas
+ ),
..
}
-reviewPatch :: D.FileDeltas -> IO D.FileDeltas
-reviewPatch fileDeltas =
+reviewStep :: PlanStep -> IO D.FileDeltas
+reviewStep step = do
+ commitMessages <-
+ T.decodeUtf8 . LB.toStrict
+ <$> sh
+ ( proc
+ "git log %..%"
+ (Git.toTextUnsafe step.earlierCommit)
+ (Git.toTextUnsafe step.commit)
+ )
+ separateReview step.earlierCommit step.changes
+ =<< reviewPatch commitMessages step.changes
+
+reviewPatch :: T.Text -> D.FileDeltas -> IO D.FileDeltas
+reviewPatch commitMessages fileDeltas =
withSystemTempDirectory "anissue" $ \tmp -> do
let patchFile = tmp </> "a.patch"
patchFile' = tmp </> "b.patch"
- T.writeFile patchFile (renderAsText (A.Patch fileDeltas))
- T.writeFile patchFile' (renderAsText (A.Patch fileDeltas))
+ patchContents = renderAsText (A.Patch fileDeltas)
+ T.writeFile patchFile patchContents
+ T.writeFile patchFile' (addCommitMessages <> patchContents)
sh_ (proc "${EDITOR-vi} %" patchFile')
T.writeFile patchFile'
. (renderAsText . A.Patch)
. addComments
. ((.fileDeltas) . A.parse)
+ . stripCommitMessages
=<< T.readFile patchFile'
((.fileDeltas) . A.parse . T.decodeUtf8 . LB.toStrict)
<$> sh (proc "rediff % %" patchFile patchFile')
+ where
+ addCommitMessages =
+ T.unlines . map ("# " <>) . T.lines $ commitMessages
+ stripCommitMessages =
+ T.unlines . dropWhile ("# " `T.isPrefixOf`) . T.lines
addComments :: D.FileDeltas -> D.FileDeltas
addComments =