module ParseMonad (
AlexInput, alexInputPrevChar, alexGetChar, alexGetByte,
AlexPosn(..), alexStartPos,
P, runP, StartCode, failP, lookupSMac, lookupRMac, newSMac, newRMac,
setStartCode, getStartCode, getInput, setInput,
) where
import AbsSyn hiding ( StartCode )
import CharSet ( CharSet )
import Map ( Map )
import qualified Map hiding ( Map )
import UTF8
import Data.Word (Word8)
import Control.Monad ( ap )
import Control.Applicative ( Applicative(..) )
type Byte = Word8
type AlexInput = (AlexPosn,
Char,
[Byte],
String)
alexInputPrevChar :: AlexInput -> Char
alexInputPrevChar :: AlexInput -> Char
alexInputPrevChar (AlexPosn
_,Char
c,[Byte]
_,String
_) = Char
c
alexGetChar :: AlexInput -> Maybe (Char,AlexInput)
alexGetChar :: AlexInput -> Maybe (Char, AlexInput)
alexGetChar (AlexPosn
_,Char
_,[],[]) = Maybe (Char, AlexInput)
forall a. Maybe a
Nothing
alexGetChar (AlexPosn
p,Char
_,[],(Char
c:String
s)) = let p' :: AlexPosn
p' = AlexPosn -> Char -> AlexPosn
alexMove AlexPosn
p Char
c in AlexPosn
p' AlexPosn -> Maybe (Char, AlexInput) -> Maybe (Char, AlexInput)
`seq`
(Char, AlexInput) -> Maybe (Char, AlexInput)
forall a. a -> Maybe a
Just (Char
c, (AlexPosn
p', Char
c, [], String
s))
alexGetByte :: AlexInput -> Maybe (Byte,AlexInput)
alexGetByte :: AlexInput -> Maybe (Byte, AlexInput)
alexGetByte (AlexPosn
p,Char
c,(Byte
b:[Byte]
bs),String
s) = (Byte, AlexInput) -> Maybe (Byte, AlexInput)
forall a. a -> Maybe a
Just (Byte
b,(AlexPosn
p,Char
c,[Byte]
bs,String
s))
alexGetByte (AlexPosn
_,Char
_,[],[]) = Maybe (Byte, AlexInput)
forall a. Maybe a
Nothing
alexGetByte (AlexPosn
p,Char
_,[],(Char
c:String
s)) = let p' :: AlexPosn
p' = AlexPosn -> Char -> AlexPosn
alexMove AlexPosn
p Char
c
(Byte
b:[Byte]
bs) = Char -> [Byte]
UTF8.encode Char
c
in AlexPosn
p' AlexPosn -> Maybe (Byte, AlexInput) -> Maybe (Byte, AlexInput)
`seq` (Byte, AlexInput) -> Maybe (Byte, AlexInput)
forall a. a -> Maybe a
Just (Byte
b, (AlexPosn
p', Char
c, [Byte]
bs, String
s))
data AlexPosn = AlexPn !Int !Int !Int
deriving (AlexPosn -> AlexPosn -> Bool
(AlexPosn -> AlexPosn -> Bool)
-> (AlexPosn -> AlexPosn -> Bool) -> Eq AlexPosn
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: AlexPosn -> AlexPosn -> Bool
$c/= :: AlexPosn -> AlexPosn -> Bool
== :: AlexPosn -> AlexPosn -> Bool
$c== :: AlexPosn -> AlexPosn -> Bool
Eq,Int -> AlexPosn -> ShowS
[AlexPosn] -> ShowS
AlexPosn -> String
(Int -> AlexPosn -> ShowS)
-> (AlexPosn -> String) -> ([AlexPosn] -> ShowS) -> Show AlexPosn
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [AlexPosn] -> ShowS
$cshowList :: [AlexPosn] -> ShowS
show :: AlexPosn -> String
$cshow :: AlexPosn -> String
showsPrec :: Int -> AlexPosn -> ShowS
$cshowsPrec :: Int -> AlexPosn -> ShowS
Show)
alexStartPos :: AlexPosn
alexStartPos :: AlexPosn
alexStartPos = Int -> Int -> Int -> AlexPosn
AlexPn Int
0 Int
1 Int
1
alexMove :: AlexPosn -> Char -> AlexPosn
alexMove :: AlexPosn -> Char -> AlexPosn
alexMove (AlexPn Int
a Int
l Int
c) Char
'\t' = Int -> Int -> Int -> AlexPosn
AlexPn (Int
aInt -> Int -> Int
forall a. Num a => a -> a -> a
+Int
1) Int
l (((Int
cInt -> Int -> Int
forall a. Num a => a -> a -> a
+Int
7) Int -> Int -> Int
forall a. Integral a => a -> a -> a
`div` Int
8)Int -> Int -> Int
forall a. Num a => a -> a -> a
*Int
8Int -> Int -> Int
forall a. Num a => a -> a -> a
+Int
1)
alexMove (AlexPn Int
a Int
l Int
_) Char
'\n' = Int -> Int -> Int -> AlexPosn
AlexPn (Int
aInt -> Int -> Int
forall a. Num a => a -> a -> a
+Int
1) (Int
lInt -> Int -> Int
forall a. Num a => a -> a -> a
+Int
1) Int
1
alexMove (AlexPn Int
a Int
l Int
c) Char
_ = Int -> Int -> Int -> AlexPosn
AlexPn (Int
aInt -> Int -> Int
forall a. Num a => a -> a -> a
+Int
1) Int
l (Int
cInt -> Int -> Int
forall a. Num a => a -> a -> a
+Int
1)
type ParseError = (Maybe AlexPosn, String)
type StartCode = Int
data PState = PState {
PState -> Map String CharSet
smac_env :: Map String CharSet,
PState -> Map String RExp
rmac_env :: Map String RExp,
PState -> Int
startcode :: Int,
PState -> AlexInput
input :: AlexInput
}
newtype P a = P { P a -> PState -> Either ParseError (PState, a)
unP :: PState -> Either ParseError (PState,a) }
instance Monad P where
(P PState -> Either ParseError (PState, a)
m) >>= :: P a -> (a -> P b) -> P b
>>= a -> P b
k = (PState -> Either ParseError (PState, b)) -> P b
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, b)) -> P b)
-> (PState -> Either ParseError (PState, b)) -> P b
forall a b. (a -> b) -> a -> b
$ \PState
env -> case PState -> Either ParseError (PState, a)
m PState
env of
Left ParseError
err -> ParseError -> Either ParseError (PState, b)
forall a b. a -> Either a b
Left ParseError
err
Right (PState
env',a
ok) -> P b -> PState -> Either ParseError (PState, b)
forall a. P a -> PState -> Either ParseError (PState, a)
unP (a -> P b
k a
ok) PState
env'
return :: a -> P a
return a
a = (PState -> Either ParseError (PState, a)) -> P a
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, a)) -> P a)
-> (PState -> Either ParseError (PState, a)) -> P a
forall a b. (a -> b) -> a -> b
$ \PState
env -> (PState, a) -> Either ParseError (PState, a)
forall a b. b -> Either a b
Right (PState
env,a
a)
runP :: String -> (Map String CharSet, Map String RExp)
-> P a -> Either ParseError a
runP :: String
-> (Map String CharSet, Map String RExp)
-> P a
-> Either ParseError a
runP String
str (Map String CharSet
senv,Map String RExp
renv) (P PState -> Either ParseError (PState, a)
p)
= case PState -> Either ParseError (PState, a)
p PState
initial_state of
Left ParseError
err -> ParseError -> Either ParseError a
forall a b. a -> Either a b
Left ParseError
err
Right (PState
_,a
a) -> a -> Either ParseError a
forall a b. b -> Either a b
Right a
a
where initial_state :: PState
initial_state =
PState :: Map String CharSet -> Map String RExp -> Int -> AlexInput -> PState
PState{ smac_env :: Map String CharSet
smac_env=Map String CharSet
senv, rmac_env :: Map String RExp
rmac_env=Map String RExp
renv,
startcode :: Int
startcode = Int
0, input :: AlexInput
input=(AlexPosn
alexStartPos,Char
'\n',[],String
str) }
instance Functor P where
fmap :: (a -> b) -> P a -> P b
fmap a -> b
f P a
a = P a
a P a -> (a -> P b) -> P b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= (b -> P b
forall (m :: * -> *) a. Monad m => a -> m a
return (b -> P b) -> (a -> b) -> a -> P b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. a -> b
f)
instance Applicative P where
<*> :: P (a -> b) -> P a -> P b
(<*>) = P (a -> b) -> P a -> P b
forall (m :: * -> *) a b. Monad m => m (a -> b) -> m a -> m b
ap
pure :: a -> P a
pure = a -> P a
forall (m :: * -> *) a. Monad m => a -> m a
return
failP :: String -> P a
failP :: String -> P a
failP String
str = (PState -> Either ParseError (PState, a)) -> P a
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, a)) -> P a)
-> (PState -> Either ParseError (PState, a)) -> P a
forall a b. (a -> b) -> a -> b
$ \PState{ input :: PState -> AlexInput
input = (AlexPosn
p,Char
_,[Byte]
_,String
_) } -> ParseError -> Either ParseError (PState, a)
forall a b. a -> Either a b
Left (AlexPosn -> Maybe AlexPosn
forall a. a -> Maybe a
Just AlexPosn
p,String
str)
lookupSMac :: (AlexPosn,String) -> P CharSet
lookupSMac :: (AlexPosn, String) -> P CharSet
lookupSMac (AlexPosn
posn,String
smac)
= (PState -> Either ParseError (PState, CharSet)) -> P CharSet
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, CharSet)) -> P CharSet)
-> (PState -> Either ParseError (PState, CharSet)) -> P CharSet
forall a b. (a -> b) -> a -> b
$ \s :: PState
s@PState{ smac_env :: PState -> Map String CharSet
smac_env = Map String CharSet
senv } ->
case String -> Map String CharSet -> Maybe CharSet
forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
smac Map String CharSet
senv of
Just CharSet
ok -> (PState, CharSet) -> Either ParseError (PState, CharSet)
forall a b. b -> Either a b
Right (PState
s,CharSet
ok)
Maybe CharSet
Nothing -> ParseError -> Either ParseError (PState, CharSet)
forall a b. a -> Either a b
Left (AlexPosn -> Maybe AlexPosn
forall a. a -> Maybe a
Just AlexPosn
posn, String
"unknown set macro: $" String -> ShowS
forall a. [a] -> [a] -> [a]
++ String
smac)
lookupRMac :: String -> P RExp
lookupRMac :: String -> P RExp
lookupRMac String
rmac
= (PState -> Either ParseError (PState, RExp)) -> P RExp
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, RExp)) -> P RExp)
-> (PState -> Either ParseError (PState, RExp)) -> P RExp
forall a b. (a -> b) -> a -> b
$ \s :: PState
s@PState{ rmac_env :: PState -> Map String RExp
rmac_env = Map String RExp
renv } ->
case String -> Map String RExp -> Maybe RExp
forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
rmac Map String RExp
renv of
Just RExp
ok -> (PState, RExp) -> Either ParseError (PState, RExp)
forall a b. b -> Either a b
Right (PState
s,RExp
ok)
Maybe RExp
Nothing -> ParseError -> Either ParseError (PState, RExp)
forall a b. a -> Either a b
Left (Maybe AlexPosn
forall a. Maybe a
Nothing, String
"unknown regex macro: %" String -> ShowS
forall a. [a] -> [a] -> [a]
++ String
rmac)
newSMac :: String -> CharSet -> P ()
newSMac :: String -> CharSet -> P ()
newSMac String
smac CharSet
set
= (PState -> Either ParseError (PState, ())) -> P ()
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, ())) -> P ())
-> (PState -> Either ParseError (PState, ())) -> P ()
forall a b. (a -> b) -> a -> b
$ \PState
s -> (PState, ()) -> Either ParseError (PState, ())
forall a b. b -> Either a b
Right (PState
s{smac_env :: Map String CharSet
smac_env = String -> CharSet -> Map String CharSet -> Map String CharSet
forall k a. Ord k => k -> a -> Map k a -> Map k a
Map.insert String
smac CharSet
set (PState -> Map String CharSet
smac_env PState
s)}, ())
newRMac :: String -> RExp -> P ()
newRMac :: String -> RExp -> P ()
newRMac String
rmac RExp
rexp
= (PState -> Either ParseError (PState, ())) -> P ()
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, ())) -> P ())
-> (PState -> Either ParseError (PState, ())) -> P ()
forall a b. (a -> b) -> a -> b
$ \PState
s -> (PState, ()) -> Either ParseError (PState, ())
forall a b. b -> Either a b
Right (PState
s{rmac_env :: Map String RExp
rmac_env = String -> RExp -> Map String RExp -> Map String RExp
forall k a. Ord k => k -> a -> Map k a -> Map k a
Map.insert String
rmac RExp
rexp (PState -> Map String RExp
rmac_env PState
s)}, ())
setStartCode :: StartCode -> P ()
setStartCode :: Int -> P ()
setStartCode Int
sc = (PState -> Either ParseError (PState, ())) -> P ()
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, ())) -> P ())
-> (PState -> Either ParseError (PState, ())) -> P ()
forall a b. (a -> b) -> a -> b
$ \PState
s -> (PState, ()) -> Either ParseError (PState, ())
forall a b. b -> Either a b
Right (PState
s{ startcode :: Int
startcode = Int
sc }, ())
getStartCode :: P StartCode
getStartCode :: P Int
getStartCode = (PState -> Either ParseError (PState, Int)) -> P Int
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, Int)) -> P Int)
-> (PState -> Either ParseError (PState, Int)) -> P Int
forall a b. (a -> b) -> a -> b
$ \PState
s -> (PState, Int) -> Either ParseError (PState, Int)
forall a b. b -> Either a b
Right (PState
s, PState -> Int
startcode PState
s)
getInput :: P AlexInput
getInput :: P AlexInput
getInput = (PState -> Either ParseError (PState, AlexInput)) -> P AlexInput
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, AlexInput)) -> P AlexInput)
-> (PState -> Either ParseError (PState, AlexInput)) -> P AlexInput
forall a b. (a -> b) -> a -> b
$ \PState
s -> (PState, AlexInput) -> Either ParseError (PState, AlexInput)
forall a b. b -> Either a b
Right (PState
s, PState -> AlexInput
input PState
s)
setInput :: AlexInput -> P ()
setInput :: AlexInput -> P ()
setInput AlexInput
inp = (PState -> Either ParseError (PState, ())) -> P ()
forall a. (PState -> Either ParseError (PState, a)) -> P a
P ((PState -> Either ParseError (PState, ())) -> P ())
-> (PState -> Either ParseError (PState, ())) -> P ()
forall a b. (a -> b) -> a -> b
$ \PState
s -> (PState, ()) -> Either ParseError (PState, ())
forall a b. b -> Either a b
Right (PState
s{ input :: AlexInput
input = AlexInput
inp }, ())