diff options
author | Alexander Foremny <aforemny@posteo.de> | 2023-10-04 10:13:06 +0200 |
---|---|---|
committer | Alexander Foremny <aforemny@posteo.de> | 2023-10-04 10:13:06 +0200 |
commit | d2b6efc9d434d7bf06772e53cbae6ef05efd7c50 (patch) | |
tree | 35bf01d97099e6b4af405928a04982424f433cf1 | |
parent | 4d94bf390c87c4a44850c1523ee4e45e0ab4711e (diff) |
improve error handling when calling external processes
-rw-r--r-- | app/Main.hs | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/app/Main.hs b/app/Main.hs index ed059e5..ebe9856 100644 --- a/app/Main.hs +++ b/app/Main.hs @@ -48,9 +48,10 @@ module Main where -import Control.Exception (Exception, catch, throw) +import Control.Exception (Exception, catch, throw, throwIO) import Data.Aeson qualified as A -import Data.ByteString.Lazy.Char8 qualified as LB8 +import Data.ByteString.Lazy qualified as L +import Data.ByteString.Lazy.Char8 qualified as L8 import Data.Maybe (catMaybes) import Data.Maybe qualified as Maybe import Data.String qualified as String @@ -173,8 +174,7 @@ getIssues filename = . concatMap (\result -> map ((,) result) result.matches) . map fixTreeGrepper . decode - . snd - <$> P.readProcessStdout + <$> sh ( String.fromString ( "tree-grepper --query '" ++ treeGrepperLanguage @@ -186,11 +186,23 @@ getIssues filename = ) ) +data ProcessException = ProcessException String ExitCode L.ByteString + deriving (Show) + +instance Exception ProcessException + +sh :: P.ProcessConfig stdin stdoutIgnored stderr -> IO L.ByteString +sh proc = do + (exitCode, out, err) <- P.readProcess proc + if exitCode == P.ExitSuccess + then pure out + else throwIO $ ProcessException (show proc) exitCode err + fixTreeGrepper :: G.Result -> G.Result fixTreeGrepper treeGrepperResult = treeGrepperResult {G.matches = G.merge treeGrepperResult.matches} getFiles :: IO [String] getFiles = - fmap (lines . LB8.unpack . snd) $ - P.readProcessStdout "git ls-files --cached --exclude-standard --other" + fmap (lines . L8.unpack) $ + sh "git ls-files --cached --exclude-standard --other" |