aboutsummaryrefslogtreecommitdiff
path: root/server
diff options
context:
space:
mode:
Diffstat (limited to 'server')
-rw-r--r--server/src/Thermoprint/Server/Queue.hs16
1 files changed, 15 insertions, 1 deletions
diff --git a/server/src/Thermoprint/Server/Queue.hs b/server/src/Thermoprint/Server/Queue.hs
index cfe0970..68dc7a9 100644
--- a/server/src/Thermoprint/Server/Queue.hs
+++ b/server/src/Thermoprint/Server/Queue.hs
@@ -1,5 +1,6 @@
1{-# LANGUAGE FlexibleInstances #-} 1{-# LANGUAGE FlexibleInstances #-}
2{-# LANGUAGE ViewPatterns #-} 2{-# LANGUAGE ViewPatterns #-}
3{-# LANGUAGE RecordWildCards #-}
3{-# LANGUAGE DeriveGeneric, DeriveAnyClass #-} 4{-# LANGUAGE DeriveGeneric, DeriveAnyClass #-}
4{-# LANGUAGE ExistentialQuantification #-} 5{-# LANGUAGE ExistentialQuantification #-}
5 6
@@ -14,7 +15,7 @@ import qualified Thermoprint.API as API (JobStatus(..))
14 15
15import Thermoprint.Server.Database 16import Thermoprint.Server.Database
16 17
17import Data.Sequence (Seq) 18import Data.Sequence (Seq, ViewL(..), viewl)
18import qualified Data.Sequence as Seq 19import qualified Data.Sequence as Seq
19 20
20import Data.Time 21import Data.Time
@@ -33,6 +34,8 @@ import Data.Default.Class
33import Control.Monad.Morph 34import Control.Monad.Morph
34import Control.Monad.Trans.Compose 35import Control.Monad.Trans.Compose
35 36
37import Data.Monoid
38
36-- | Zipper for 'Seq QueueEntry' with additional support for 'PrintingError' in the section after point 39-- | Zipper for 'Seq QueueEntry' with additional support for 'PrintingError' in the section after point
37data Queue = Queue 40data Queue = Queue
38 { pending :: Seq QueueEntry -- ^ Pending jobs, closest last 41 { pending :: Seq QueueEntry -- ^ Pending jobs, closest last
@@ -41,6 +44,17 @@ data Queue = Queue
41 } 44 }
42 deriving (Typeable, Generic, NFData) 45 deriving (Typeable, Generic, NFData)
43 46
47toSeq :: Queue -> Seq (Bool, QueueEntry, Maybe PrintingError)
48toSeq Queue{..} = fmap (\x -> (False, x, Nothing)) pending <> maybe Seq.empty (\c -> Seq.singleton (True, c, Nothing)) current <> fmap (\(x, p) -> (False, x, p)) history
49
50fromSeq :: Seq (Bool, QueueEntry, Maybe PrintingError) -> Queue
51fromSeq s = Queue pending' current' history'
52 where
53 (fmap (\(_, x, _) -> x) -> pending', pending'') = Seq.breakl (\(c, _, _) -> c) s
54 (current', history') = case viewl pending'' of
55 EmptyL -> (Nothing, Seq.empty)
56 (_, a, _) :< as -> (Just a, fmap (\(_, x, p) -> (x, p)) as)
57
44class HasQueue a where 58class HasQueue a where
45 extractQueue :: a -> TVar Queue 59 extractQueue :: a -> TVar Queue
46 60