module System.Wlog.Color
( colorizer
) where
import System.Console.ANSI (Color (Blue, Green, Magenta, Red, Yellow),
ColorIntensity (Vivid), ConsoleLayer (Foreground),
SGR (Reset, SetColor), setSGRCode)
import System.Log.Logger (Priority (DEBUG, ERROR, INFO, NOTICE, WARNING))
table :: Priority -> (String, String)
table priority = case priority of
ERROR -> (setColor Red , reset)
DEBUG -> (setColor Green , reset)
NOTICE -> (setColor Magenta , reset)
WARNING -> (setColor Yellow , reset)
INFO -> (setColor Blue , reset)
_ -> ("", "")
where
setColor color = setSGRCode [SetColor Foreground Vivid color]
reset = setSGRCode [Reset]
colorizer :: Priority -> String -> String
colorizer pr s = before ++ s ++ after
where
(before, after) = table pr