{-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE TypeFamilies #-} {- | Module : System.Log.Handler Copyright : Copyright (C) 2004-2011 John Goerzen License : BSD3 Maintainer : John Goerzen Stability : provisional Portability: portable Definition of log handler support For some handlers, check out "System.WLog.Handler.Simple" and "System.WLog.Handler.Syslog". Please see "System.WLog.Logger" for extensive documentation on the logging system. Written by John Goerzen, jgoerzen\@complete.org -} module System.Wlog.Handler ( -- * Basic Types LogHandlerTag(..) , LogHandler(..) ) where import Data.Text.Lazy.Builder as B import System.Wlog.Formatter (LogFormatter, nullFormatter) import System.Wlog.Severity (LogRecord (..), Severity) import Universum -- | Tag identifying handlers. data LogHandlerTag = HandlerFilelike FilePath | HandlerOther String deriving (Show, Eq) -- | This is the base class for the various log handlers. They should -- all adhere to this class. class LogHandler a where -- TODO it should be data/type family like in 'System.Exception' -- | Tag of handler. Is arbitrary. Made for identification. getTag :: a -> LogHandlerTag -- | Sets the log level. 'handle' will drop items beneath this -- level. setLevel :: a -> Severity -> a -- | Gets the current level. getLevel :: a -> Severity -- | Set a log formatter to customize the log format for this Handler setFormatter :: a -> LogFormatter a -> a getFormatter :: a -> LogFormatter a getFormatter _h = nullFormatter -- | Logs an event if it meets the requirements -- given by the most recent call to 'setLevel'. handle :: a -> LogRecord -> String -> IO () handle h lr@(LR pri _) logname = when (pri >= (getLevel h)) $ do formattedMsg <- (getFormatter h) h lr (toText logname) emit h formattedMsg logname -- | Forces an event to be logged regardless of -- the configured level. emit :: a -> B.Builder -> String -> IO () -- | Read back from logger (e.g. file), newest first. You specify -- the number of (newest) logging entries. Logger can return @pure -- []@ if this behaviour can't be emulated or store buffer. readBack :: a -> Int -> IO [Text] -- | Closes the logging system, causing it to close -- any open files, etc. close :: a -> IO ()