-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathMain.hs
More file actions
70 lines (60 loc) · 2.24 KB
/
Main.hs
File metadata and controls
70 lines (60 loc) · 2.24 KB
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
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
{-# LANGUAGE TemplateHaskell #-}
module Main where
import Control.Monad.IO.Class ( liftIO )
import Control.Monad.Logger as L
import qualified Data.Text as T
import Library as Lib
main :: IO ()
main = do
putStrLn "Please enter some texts: "
msg <- getLine
foo msg
foo' msg
bar msg
bar' msg
foobar msg
foobar' msg
-- call preFoo and supply a file based logging capability
foo :: String -> IO ()
foo msg = L.runFileLoggingT "/tmp/demo.log" $ do
liftIO $ putStrLn ""
$(L.logInfo) $ T.pack $ "[foo] Got user input: " ++ msg
out <- preFoo msg
liftIO $ putStrLn out
-- call preFooIO and the inner logging will be library default stderr based logging
foo' :: String -> IO ()
foo' msg = L.runFileLoggingT "/tmp/demo.log" $ do
liftIO $ putStrLn ""
$(L.logInfo) $ T.pack $ "[foo'] Got user input: " ++ msg
out <- liftIO $ preFooIO msg
liftIO $ putStrLn out
-- call runBarWith and supply file based logging action of caller
bar :: String -> IO ()
bar msg = L.runFileLoggingT "/tmp/demo.log" $ do
liftIO $ putStrLn ""
$(L.logInfo) $ T.pack $ "[bar] Got user input: " ++ msg
out <- liftIO $ runBar $ preBar msg
liftIO $ putStrLn out
-- call runBarWithLogger and the inner logging is fixed to stderr logging again
bar' :: String -> IO ()
bar' msg = L.runFileLoggingT "/tmp/demo.log" $ do
liftIO $ putStrLn ""
$(L.logInfo) $ T.pack $ "[bar'] Got user input: " ++ msg
-- get the logging action from caller's logging context
logAction <- L.askLoggerIO
out <- liftIO $ runBarWithLogger (`runLoggingT` logAction) $ preBar msg
liftIO $ putStrLn out
-- run runFooBarT and supply a file based logging capability
foobar :: String -> IO ()
foobar msg = L.runFileLoggingT "/tmp/demo.log" $ do
liftIO $ putStrLn ""
$(L.logInfo) $ T.pack $ "[foobar] Got user input: " ++ msg
out <- runFooBarT $ preFooBar msg
liftIO $ putStrLn out
-- run runFooBarIO and the inner logging will be library default stderr based logging
foobar' :: String -> IO ()
foobar' msg = L.runFileLoggingT "/tmp/demo.log" $ do
liftIO $ putStrLn ""
$(L.logInfo) $ T.pack $ "[foobar'] Got user input: " ++ msg
out <- liftIO $ runFooBarIO $ preFooBar msg
liftIO $ putStrLn out