aboutsummaryrefslogtreecommitdiff
path: root/spec/src/Thermoprint
diff options
context:
space:
mode:
Diffstat (limited to 'spec/src/Thermoprint')
-rw-r--r--spec/src/Thermoprint/Printout/BBCode.hs26
1 files changed, 24 insertions, 2 deletions
diff --git a/spec/src/Thermoprint/Printout/BBCode.hs b/spec/src/Thermoprint/Printout/BBCode.hs
index ca69efc..f80f780 100644
--- a/spec/src/Thermoprint/Printout/BBCode.hs
+++ b/spec/src/Thermoprint/Printout/BBCode.hs
@@ -9,7 +9,13 @@ module Thermoprint.Printout.BBCode
9 ) where 9 ) where
10 10
11import Data.Text (Text) 11import Data.Text (Text)
12import qualified Data.Text as T () 12import qualified Data.Text as T (unpack)
13
14import Data.Map (Map)
15import qualified Data.Map as Map (lookup)
16
17import Data.CaseInsensitive (CI)
18import qualified Data.CaseInsensitive as CI
13 19
14import GHC.Generics (Generic) 20import GHC.Generics (Generic)
15import Control.Exception (Exception) 21import Control.Exception (Exception)
@@ -18,6 +24,10 @@ import Data.Typeable (Typeable)
18import Data.Bifunctor (bimap, first) 24import Data.Bifunctor (bimap, first)
19import Control.Monad (join) 25import Control.Monad (join)
20 26
27import Text.Read (readMaybe)
28
29import Data.Maybe (fromMaybe)
30
21import Text.BBCode (DomTree(..), TreeError(..)) 31import Text.BBCode (DomTree(..), TreeError(..))
22import qualified Text.BBCode as Raw (bbcode, BBCodeError(..)) 32import qualified Text.BBCode as Raw (bbcode, BBCodeError(..))
23 33
@@ -31,7 +41,8 @@ data BBCodeError = LexerError String -- ^ Error while parsing input to stream of
31 41
32instance Exception BBCodeError 42instance Exception BBCodeError
33 43
34data SemanticError = Placeholder 44data SemanticError = BlockTagInLineContext Text
45 | UnmappedTag Text
35 deriving (Show, Eq, Generic, Typeable) 46 deriving (Show, Eq, Generic, Typeable)
36 47
37instance Exception SemanticError 48instance Exception SemanticError
@@ -45,3 +56,14 @@ morph' (Raw.TreeError x) = TreeError x
45 56
46morph :: [DomTree] -> Either SemanticError Printout 57morph :: [DomTree] -> Either SemanticError Printout
47morph = undefined 58morph = undefined
59
60asBlock :: CI Text -> Map (CI Text) Text -> Either SemanticError Block
61asBlock "VSpace" = Right . VSpace . lookupAttr "size" 1
62asBlock t = Left . const (UnmappedTag . CI.original $ t)
63
64asLine :: CI Text -> Map (CI Text) Text -> Either SemanticError Line
65asLine "HSpace" = Right . HSpace . lookupAttr "size" 1
66asLine t = Left . const (UnmappedTag . CI.original $ t)
67
68lookupAttr :: Read a => CI Text -> a -> Map (CI Text) Text -> a
69lookupAttr t def attrs = fromMaybe def $ Map.lookup t attrs >>= (readMaybe . T.unpack)