diff options
| -rw-r--r-- | tprint/src/Main.hs | 24 | 
1 files changed, 17 insertions, 7 deletions
| diff --git a/tprint/src/Main.hs b/tprint/src/Main.hs index f78349e..71bbb2f 100644 --- a/tprint/src/Main.hs +++ b/tprint/src/Main.hs | |||
| @@ -59,17 +59,18 @@ humanJobStatus (Printing _) _ = "printing" | |||
| 59 | humanJobStatus (Done) _ = "finished successfully" | 59 | humanJobStatus (Done) _ = "finished successfully" | 
| 60 | humanJobStatus (Failed err) _ = "failed: " ++ show err | 60 | humanJobStatus (Failed err) _ = "failed: " ++ show err | 
| 61 | 61 | ||
| 62 | blockLoop :: Client IO -> JobId -> IO () | 62 | blockLoop :: Client IO -> Handle -> JobId -> IO () | 
| 63 | blockLoop client@Client{..} jId = do | 63 | blockLoop client@Client{..} out jId@(JobId n) = do | 
| 64 | threadDelay (10^6) | 64 | threadDelay (10^6) | 
| 65 | status <- jobStatus jId | 65 | status <- jobStatus jId | 
| 66 | case status of | 66 | case status of | 
| 67 | Done -> return () | 67 | Done -> hPutStrLn out $ show n | 
| 68 | Failed err -> throwM err | 68 | Failed err -> throwM err | 
| 69 | _ -> blockLoop client jId | 69 | _ -> blockLoop client out jId | 
| 70 | 70 | ||
| 71 | tprint :: TPrint -> Client IO -> Handle -> IO () | 71 | tprint :: TPrint -> Client IO -> Handle -> IO () | 
| 72 | 72 | ||
| 73 | -- Query | ||
| 73 | tprint TPrint{ operation = Printers, ..} Client{..} out = printers >>= format | 74 | tprint TPrint{ operation = Printers, ..} Client{..} out = printers >>= format | 
| 74 | where format ps | 75 | where format ps | 
| 75 | | (Human, _) <- output = mapM_ (\(PrinterId n, st) -> hPutStrLn out $ show n ++ "\t" ++ humanStatus st) $ Map.toAscList ps | 76 | | (Human, _) <- output = mapM_ (\(PrinterId n, st) -> hPutStrLn out $ show n ++ "\t" ++ humanStatus st) $ Map.toAscList ps | 
| @@ -102,18 +103,27 @@ tprint TPrint{ operation = Job{..}, ..} Client{..} out = job jobId >>= format | |||
| 102 | | (JSON, _) <- output = LCBS.hPutStrLn out $ encodePretty p | 103 | | (JSON, _) <- output = LCBS.hPutStrLn out $ encodePretty p | 
| 103 | | otherwise <- output = T.hPutStrLn out =<< either throwM return (cobbcode p) | 104 | | otherwise <- output = T.hPutStrLn out =<< either throwM return (cobbcode p) | 
| 104 | 105 | ||
| 105 | tprint TPrint{ operation = JobCreate{..}, ..} client@Client{..} _ = withInput input $ \inH -> do | 106 | -- Mutate | 
| 107 | tprint TPrint{ operation = JobCreate{..}, ..} client@Client{..} out = withInput input $ \inH -> do | ||
| 106 | let | 108 | let | 
| 107 | p' | 109 | p' | 
| 108 | | (BBCode, _) <- input = either throwM return . bbcode =<< T.hGetContents inH | 110 | | (BBCode, _) <- input = either throwM return . bbcode =<< T.hGetContents inH | 
| 109 | | otherwise = either (throwM . userError) return . eitherDecode' =<< LCBS.hGetContents inH | 111 | | otherwise = either (throwM . userError) return . eitherDecode' =<< LCBS.hGetContents inH | 
| 110 | block' | 112 | block' | 
| 111 | | block = blockLoop client | 113 | | block = blockLoop client out | 
| 112 | | otherwise = const $ return () | 114 | | otherwise = hPutStrLn out . show | 
| 113 | p <- force <$> p' | 115 | p <- force <$> p' | 
| 114 | unless dryRun $ block' =<< jobCreate printer p | 116 | unless dryRun $ block' =<< jobCreate printer p | 
| 115 | 117 | ||
| 116 | tprint TPrint{ operation = JobDelete{..}, ..} Client{..} _ = unless dryRun $ jobDelete jobId | 118 | tprint TPrint{ operation = JobDelete{..}, ..} Client{..} _ = unless dryRun $ jobDelete jobId | 
| 117 | 119 | ||
| 120 | tprint TPrint{ operation = DraftCreate{..}, ..} Client{..} out = withInput input $ \inH -> do | ||
| 121 | let | ||
| 122 | p' | ||
| 123 | | (BBCode, _) <- input = either throwM return . bbcode =<< T.hGetContents inH | ||
| 124 | | otherwise = either (throwM . userError) return . eitherDecode' =<< LCBS.hGetContents inH | ||
| 125 | p <- force <$> p' | ||
| 126 | unless dryRun $ hPutStrLn out . show =<< draftCreate draftTitle p | ||
| 127 | |||
| 118 | 128 | ||
| 119 | tprint _ _ _ = undefined | 129 | tprint _ _ _ = undefined | 
