module Rattletrap.Main where import Rattletrap.Json () import Rattletrap.Replay import Rattletrap.Version import qualified Data.Aeson as Aeson import qualified Data.Binary.Get as Binary import qualified Data.Binary.Put as Binary import qualified Data.ByteString.Lazy as ByteString import qualified Data.Version as Version import qualified System.Environment as Environment main :: IO () main = do args <- Environment.getArgs mainWithArgs args mainWithArgs :: [String] -> IO () mainWithArgs args = case args of ["version"] -> putStrLn (Version.showVersion version) "decode":files -> do (getInput, putOutput) <- getIO files input <- getInput let replay = Binary.runGet getReplay input let output = Aeson.encode replay putOutput output "encode":files -> do (getInput, putOutput) <- getIO files input <- getInput case Aeson.eitherDecode input of Left message -> fail ("could not parse JSON: " ++ message) Right replay -> do let output = Binary.runPut (putReplay replay) putOutput output _ -> fail ("unexpected arguments " ++ show args) getIO :: Monad m => [FilePath] -> m (IO ByteString.ByteString, ByteString.ByteString -> IO ()) getIO files = case files of [] -> pure (ByteString.getContents, ByteString.putStr) [i] -> pure (ByteString.readFile i, ByteString.putStr) [i, o] -> pure (ByteString.readFile i, ByteString.writeFile o) _ -> fail ("unexpected arguments " ++ show files)