| Safe Haskell | None | 
|---|---|
| Language | Haskell2010 | 
System.Logger.Class
Description
The MonadLogger type-class and associated functions.
- data Settings
- defSettings :: Settings
- logLevel :: Settings -> Level
- setLogLevel :: Level -> Settings -> Settings
- output :: Settings -> Output
- setOutput :: Output -> Settings -> Settings
- format :: Settings -> Maybe DateFormat
- setFormat :: DateFormat -> Settings -> Settings
- delimiter :: Settings -> ByteString
- setDelimiter :: ByteString -> Settings -> Settings
- netstrings :: Settings -> Bool
- setNetStrings :: Bool -> Settings -> Settings
- bufSize :: Settings -> Int
- setBufSize :: Int -> Settings -> Settings
- name :: Settings -> Maybe Text
- setName :: Maybe Text -> Settings -> Settings
- data Level
- data Output
- data DateFormat
- iso8601UTC :: DateFormat
- data Logger
- new :: MonadIO m => Settings -> m Logger
- create :: MonadIO m => Output -> m Logger
- level :: Logger -> Level
- flush :: MonadIO m => Logger -> m ()
- close :: MonadIO m => Logger -> m ()
- clone :: Maybe Text -> Logger -> Logger
- settings :: Logger -> Settings
- class Monad m => MonadLogger m where
- trace :: MonadLogger m => (Msg -> Msg) -> m ()
- debug :: MonadLogger m => (Msg -> Msg) -> m ()
- info :: MonadLogger m => (Msg -> Msg) -> m ()
- warn :: MonadLogger m => (Msg -> Msg) -> m ()
- err :: MonadLogger m => (Msg -> Msg) -> m ()
- fatal :: MonadLogger m => (Msg -> Msg) -> m ()
Documentation
defSettings :: Settings Source
Default settings:
- logLevel=- Debug
- output=- StdOut
- format=- iso8601UTC
- delimiter= ", "
- netstrings= False
- bufSize=- defaultBufSize
- name= Nothing
setLogLevel :: Level -> Settings -> Settings Source
format :: Settings -> Maybe DateFormat Source
The time and date format used for the timestamp part of a log line.
setFormat :: DateFormat -> Settings -> Settings Source
delimiter :: Settings -> ByteString Source
Delimiter string which separates log line parts.
setDelimiter :: ByteString -> Settings -> Settings Source
netstrings :: Settings -> Bool Source
Whether to use netstring encoding for log lines.
setNetStrings :: Bool -> Settings -> Settings Source
setBufSize :: Int -> Settings -> Settings Source
data DateFormat Source
Instances
iso8601UTC :: DateFormat Source
ISO 8601 date-time format.
new :: MonadIO m => Settings -> m Logger Source
Create a new Logger with the given Settings.
 Please note that the logLevel can be dynamically adjusted by setting
 the environment variable LOG_LEVEL accordingly. Likewise the buffer
 size can be dynamically set via LOG_BUFFER and netstrings encoding
 can be enabled with LOG_NETSTR=True
Since version 0.11 one can also use LOG_LEVEL_MAP to specify log
 levels per (named) logger. The syntax uses standard haskell syntax for
 association lists of type [(Text, Level)]. For example:
$ LOG_LEVEL=Info LOG_LEVEL_MAP='[("foo", Warn), ("bar", Trace)]' cabal repl
> g1 <- new defSettings
> let g2 = clone (Just "foo") g
> let g3 = clone (Just "bar") g
> let g4 = clone (Just "xxx") g
> logLevel (settings g1)
Info
> logLevel (settings g2)
Warn
> logLevel (settings g3)
Trace
> logLevel (settings g4)
Info
create :: MonadIO m => Output -> m Logger Source
Invokes new with default settings and the given output as log sink.
clone :: Maybe Text -> Logger -> Logger Source
Clone the given logger and optionally give it a name
 (use Nothing to clear).
If logLevelOf returns a custom Level for this name
 then the cloned logger will use it for its log messages.
trace :: MonadLogger m => (Msg -> Msg) -> m () Source
Abbreviation for log using the corresponding log level.
debug :: MonadLogger m => (Msg -> Msg) -> m () Source
Abbreviation for log using the corresponding log level.
info :: MonadLogger m => (Msg -> Msg) -> m () Source
Abbreviation for log using the corresponding log level.
warn :: MonadLogger m => (Msg -> Msg) -> m () Source
Abbreviation for log using the corresponding log level.