1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 |
-------------------------------------------------------------------------- --- This module provides operation for log messages and setting --- the log level for the analyses. --- --- @author Michael Hanus --- @version January 2025 -------------------------------------------------------------------------- module Analysis.Logging ( DLevel(..), debugMessage, debugString ) where import Control.Monad import System.IO ( hPutStr, stderr ) -------------------------------------------------------------------------- --- Debug levels intended as first parameter in debug operations below: --- 0 : show nothing --- 1 : show worker activity, e.g., timings --- 2 : show server communication --- 3 : ...and show read/store information --- 4 : ...show also stored/computed analysis data data DLevel = Quiet | Timing | Communicate | Storage | AllData deriving Enum --- Prints a message line (to stderr) if debugging level is at least n. debugMessage :: DLevel -> Int -> String -> IO () debugMessage dl n message = debugString dl n (message ++ "\n") --- Prints a string (to stderr) if debugging level is at least n. debugString :: DLevel -> Int -> String -> IO () debugString dl n message = when (fromEnum dl >= n) $ hPutStr stderr message -------------------------------------------------------------------------- |