aboutsummaryrefslogtreecommitdiff
path: root/server/src/Thermoprint/Server
diff options
context:
space:
mode:
authorGregor Kleen <gkleen@yggdrasil.li>2016-01-31 14:14:07 +0000
committerGregor Kleen <gkleen@yggdrasil.li>2016-01-31 14:14:07 +0000
commit25234d9fc9f281805ab9ab9d44338962213fb23e (patch)
treeb633ddb1249af79b3c6df74cf6182d30e7d5b4a0 /server/src/Thermoprint/Server
parent9dd562eef0c4ff6f15e6ef3e7c360f5fdf04573b (diff)
downloadthermoprint-25234d9fc9f281805ab9ab9d44338962213fb23e.tar
thermoprint-25234d9fc9f281805ab9ab9d44338962213fb23e.tar.gz
thermoprint-25234d9fc9f281805ab9ab9d44338962213fb23e.tar.bz2
thermoprint-25234d9fc9f281805ab9ab9d44338962213fb23e.tar.xz
thermoprint-25234d9fc9f281805ab9ab9d44338962213fb23e.zip
Removed danger of crash due to corner case
Diffstat (limited to 'server/src/Thermoprint/Server')
-rw-r--r--server/src/Thermoprint/Server/Printer.hs4
1 files changed, 3 insertions, 1 deletions
diff --git a/server/src/Thermoprint/Server/Printer.hs b/server/src/Thermoprint/Server/Printer.hs
index 55bfabc..67180c4 100644
--- a/server/src/Thermoprint/Server/Printer.hs
+++ b/server/src/Thermoprint/Server/Printer.hs
@@ -89,7 +89,9 @@ runPrinter Printer{..} = forever $ do
89 return jobId 89 return jobId
90 job <- runSqlPool (get jobId) =<< ask 90 job <- runSqlPool (get jobId) =<< ask
91 case job of 91 case job of
92 Nothing -> $(logWarn) "Nonexistent job id in printer queue" 92 Nothing -> do
93 atomically' $ modifyTVar' queue (\Queue{..} -> force $ Queue pending Nothing history)
94 $(logWarn) "Nonexistent job id in printer queue"
93 Just job -> do 95 Just job -> do
94 $(logInfo) . T.pack $ "Printing " ++ show (unSqlBackendKey . unJobKey $ jobId) 96 $(logInfo) . T.pack $ "Printing " ++ show (unSqlBackendKey . unJobKey $ jobId)
95 printReturn <- (unPM print) (jobContent job) -- We could, at this point, do some exception handling. It was decided that this would be undesirable, because we really don't have any idea what exceptions to catch 97 printReturn <- (unPM print) (jobContent job) -- We could, at this point, do some exception handling. It was decided that this would be undesirable, because we really don't have any idea what exceptions to catch