aboutsummaryrefslogtreecommitdiff
path: root/tprint/src
diff options
context:
space:
mode:
Diffstat (limited to 'tprint/src')
-rw-r--r--tprint/src/Main.hs9
1 files changed, 9 insertions, 0 deletions
diff --git a/tprint/src/Main.hs b/tprint/src/Main.hs
index 44cc2f6..f0f0186 100644
--- a/tprint/src/Main.hs
+++ b/tprint/src/Main.hs
@@ -7,6 +7,7 @@ import Data.Sequence (Seq)
7import qualified Data.Sequence as Seq 7import qualified Data.Sequence as Seq
8import Data.Text (Text) 8import Data.Text (Text)
9import qualified Data.Text as T 9import qualified Data.Text as T
10import qualified Data.Text.IO as T
10import qualified Data.ByteString.Lazy.Char8 as Lazy (ByteString) 11import qualified Data.ByteString.Lazy.Char8 as Lazy (ByteString)
11import qualified Data.ByteString.Lazy.Char8 as LCBS 12import qualified Data.ByteString.Lazy.Char8 as LCBS
12import Data.Time 13import Data.Time
@@ -15,14 +16,17 @@ import Data.Foldable
15import Data.List 16import Data.List
16import Data.Monoid 17import Data.Monoid
17import Data.Maybe 18import Data.Maybe
19import Data.Either
18 20
19import Control.Monad 21import Control.Monad
22import Control.Monad.Catch
20 23
21import Text.Show.Pretty (dumpStr) 24import Text.Show.Pretty (dumpStr)
22import Data.Aeson.Encode.Pretty (encodePretty) 25import Data.Aeson.Encode.Pretty (encodePretty)
23 26
24import System.IO 27import System.IO
25 28
29import Thermoprint.Printout.BBCode
26import Thermoprint.Client 30import Thermoprint.Client
27import Options 31import Options
28 32
@@ -67,6 +71,11 @@ tprint TPrint{ operation = Drafts, ..} Client{..} out = drafts >>= format
67 | (Human, _) <- output = mapM_ (\(DraftId n, fromMaybe "" . fmap T.unpack -> t) -> hPutStrLn out $ show n ++ "\t" ++ t) $ Map.toAscList ds 71 | (Human, _) <- output = mapM_ (\(DraftId n, fromMaybe "" . fmap T.unpack -> t) -> hPutStrLn out $ show n ++ "\t" ++ t) $ Map.toAscList ds
68 | (JSON, _) <- output = LCBS.hPutStrLn out $ encodePretty ds 72 | (JSON, _) <- output = LCBS.hPutStrLn out $ encodePretty ds
69 | otherwise = hPutStrLn out . dumpStr $ Map.toAscList ds 73 | otherwise = hPutStrLn out . dumpStr $ Map.toAscList ds
74
75tprint TPrint{ operation = Job{..}, ..} Client{..} out = job jobId >>= format
76 where format p
77 | (JSON, _) <- output = LCBS.hPutStrLn out $ encodePretty p
78 | otherwise <- output = T.hPutStrLn out =<< either throwM return (cobbcode p)
70 79
71 80
72tprint _ _ _ = undefined 81tprint _ _ _ = undefined