aboutsummaryrefslogtreecommitdiffstats
path: root/app/Git/CommitHash.hs
diff options
context:
space:
mode:
Diffstat (limited to 'app/Git/CommitHash.hs')
-rw-r--r--app/Git/CommitHash.hs37
1 files changed, 37 insertions, 0 deletions
diff --git a/app/Git/CommitHash.hs b/app/Git/CommitHash.hs
new file mode 100644
index 0000000..db7a478
--- /dev/null
+++ b/app/Git/CommitHash.hs
@@ -0,0 +1,37 @@
+module Git.CommitHash
+ ( CommitHash (..),
+ toShortText,
+ toText,
+ )
+where
+
+import Data.Binary (Binary)
+import Data.Maybe (fromMaybe)
+import Data.Text qualified as T
+import GHC.Generics (Generic)
+import Render qualified as P
+
+data CommitHash
+ = WorkingTree
+ | Commit T.Text
+ deriving (Eq, Show, Binary, Generic)
+
+toShortText :: CommitHash -> Maybe T.Text
+toShortText = fmap (T.take 7) . toText
+
+toText :: CommitHash -> Maybe T.Text
+toText WorkingTree = Nothing
+toText (Commit hash) = Just hash
+
+instance P.Render CommitHash where
+ render = P.render . P.Detailed
+
+instance P.Render (P.Detailed CommitHash) where
+ render (P.Detailed commitHash) =
+ P.styled [P.color P.Yellow] $
+ P.render (fromMaybe "<dirty>" (toText commitHash))
+
+instance P.Render (P.Summarized CommitHash) where
+ render (P.Summarized commitHash) =
+ P.styled [P.color P.Yellow] $
+ P.render (fromMaybe "<dirty>" (toShortText commitHash))