git-annex/Types/Messages.hs

50 lines
1.1 KiB
Haskell
Raw Normal View History

{- git-annex Messages data types
-
- Copyright 2012 Joey Hess <id@joeyh.name>
-
- Licensed under the GNU GPL version 3 or higher.
-}
{-# LANGUAGE CPP #-}
module Types.Messages where
2015-04-03 23:56:56 +00:00
import Data.Default
import qualified Data.Aeson as Aeson
2015-04-03 23:56:56 +00:00
#ifdef WITH_CONCURRENTOUTPUT
import System.Console.Regions (ConsoleRegion)
#endif
data OutputType = NormalOutput | QuietOutput | JSONOutput Bool
deriving (Show)
data SideActionBlock = NoBlock | StartBlock | InBlock
deriving (Eq)
data MessageState = MessageState
{ outputType :: OutputType
, concurrentOutputEnabled :: Bool
, sideActionBlock :: SideActionBlock
, implicitMessages :: Bool
2015-11-06 16:51:25 +00:00
#ifdef WITH_CONCURRENTOUTPUT
, consoleRegion :: Maybe ConsoleRegion
, consoleRegionErrFlag :: Bool
2015-11-06 16:51:25 +00:00
#endif
, jsonBuffer :: Maybe Aeson.Object
}
2015-04-03 23:56:56 +00:00
instance Default MessageState
where
2015-11-06 16:51:25 +00:00
def = MessageState
{ outputType = NormalOutput
, concurrentOutputEnabled = False
2015-11-06 16:51:25 +00:00
, sideActionBlock = NoBlock
, implicitMessages = True
2015-11-06 16:51:25 +00:00
#ifdef WITH_CONCURRENTOUTPUT
, consoleRegion = Nothing
, consoleRegionErrFlag = False
#endif
, jsonBuffer = Nothing
2015-11-06 16:51:25 +00:00
}