module Agda.Syntax.Parser.Alex
(
AlexInput(..)
, lensLexInput
, alexInputPrevChar
, alexGetChar, alexGetByte
, LexAction(..), LexPredicate
, (.&&.), (.||.), not'
, PreviousInput, CurrentInput, TokenLength
, getLexInput, setLexInput
)
where
import Control.Monad.State
import Data.Char
import Data.Word
import Agda.Syntax.Position
import Agda.Syntax.Parser.Monad
import Agda.Utils.Lens
import Agda.Utils.Tuple
data AlexInput = AlexInput
{ AlexInput -> SrcFile
lexSrcFile :: !SrcFile
, AlexInput -> PositionWithoutFile
lexPos :: !PositionWithoutFile
, AlexInput -> String
lexInput :: String
, AlexInput -> Char
lexPrevChar :: !Char
}
lensLexInput :: Lens' String AlexInput
lensLexInput :: Lens' String AlexInput
lensLexInput String -> f String
f AlexInput
r = String -> f String
f (AlexInput -> String
lexInput AlexInput
r) forall (m :: * -> *) a b. Functor m => m a -> (a -> b) -> m b
<&> \ String
s -> AlexInput
r { lexInput :: String
lexInput = String
s }
alexInputPrevChar :: AlexInput -> Char
alexInputPrevChar :: AlexInput -> Char
alexInputPrevChar = AlexInput -> Char
lexPrevChar
alexGetChar :: AlexInput -> Maybe (Char, AlexInput)
alexGetChar :: AlexInput -> Maybe (Char, AlexInput)
alexGetChar (AlexInput { lexInput :: AlexInput -> String
lexInput = [] }) = forall a. Maybe a
Nothing
alexGetChar inp :: AlexInput
inp@(AlexInput { lexInput :: AlexInput -> String
lexInput = Char
c:String
s, lexPos :: AlexInput -> PositionWithoutFile
lexPos = PositionWithoutFile
p }) =
forall a. a -> Maybe a
Just (Char
c, AlexInput
{ lexSrcFile :: SrcFile
lexSrcFile = AlexInput -> SrcFile
lexSrcFile AlexInput
inp
, lexInput :: String
lexInput = String
s
, lexPos :: PositionWithoutFile
lexPos = forall a. Position' a -> Char -> Position' a
movePos PositionWithoutFile
p Char
c
, lexPrevChar :: Char
lexPrevChar = Char
c
}
)
alexGetByte :: AlexInput -> Maybe (Word8, AlexInput)
alexGetByte :: AlexInput -> Maybe (Word8, AlexInput)
alexGetByte AlexInput
ai =
forall a c b. (a -> c) -> (a, b) -> (c, b)
mapFst (forall a b. (Integral a, Num b) => a -> b
fromIntegral forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a. Enum a => a -> Int
fromEnum forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> Char
toASCII) forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> AlexInput -> Maybe (Char, AlexInput)
alexGetChar AlexInput
ai
where
toASCII :: Char -> Char
toASCII Char
c
| Char -> Bool
isSpace Char
c Bool -> Bool -> Bool
&& Char
c forall a. Eq a => a -> a -> Bool
/= Char
'\t' Bool -> Bool -> Bool
&& Char
c forall a. Eq a => a -> a -> Bool
/= Char
'\n' = Char
' '
| Char -> Bool
isAscii Char
c = Char
c
| Char -> Bool
isPrint Char
c = if Char -> Bool
isAlpha Char
c then Char
'z'
else Char
'+'
| Bool
otherwise = Char
'\1'
getLexInput :: Parser AlexInput
getLexInput :: Parser AlexInput
getLexInput = forall s (m :: * -> *) a. MonadState s m => (s -> a) -> m a
gets ParseState -> AlexInput
getInp
where
getInp :: ParseState -> AlexInput
getInp ParseState
s = AlexInput
{ lexSrcFile :: SrcFile
lexSrcFile = ParseState -> SrcFile
parseSrcFile ParseState
s
, lexPos :: PositionWithoutFile
lexPos = ParseState -> PositionWithoutFile
parsePos ParseState
s
, lexInput :: String
lexInput = ParseState -> String
parseInp ParseState
s
, lexPrevChar :: Char
lexPrevChar = ParseState -> Char
parsePrevChar ParseState
s
}
setLexInput :: AlexInput -> Parser ()
setLexInput :: AlexInput -> Parser ()
setLexInput AlexInput
inp = forall s (m :: * -> *). MonadState s m => (s -> s) -> m ()
modify ParseState -> ParseState
upd
where
upd :: ParseState -> ParseState
upd ParseState
s = ParseState
s { parseSrcFile :: SrcFile
parseSrcFile = AlexInput -> SrcFile
lexSrcFile AlexInput
inp
, parsePos :: PositionWithoutFile
parsePos = AlexInput -> PositionWithoutFile
lexPos AlexInput
inp
, parseInp :: String
parseInp = AlexInput -> String
lexInput AlexInput
inp
, parsePrevChar :: Char
parsePrevChar = AlexInput -> Char
lexPrevChar AlexInput
inp
}
type PreviousInput = AlexInput
type CurrentInput = AlexInput
type TokenLength = Int
newtype LexAction r
= LexAction { forall r. LexAction r -> AlexInput -> AlexInput -> Int -> Parser r
runLexAction :: PreviousInput -> CurrentInput -> TokenLength -> Parser r }
deriving (forall a b. a -> LexAction b -> LexAction a
forall a b. (a -> b) -> LexAction a -> LexAction b
forall (f :: * -> *).
(forall a b. (a -> b) -> f a -> f b)
-> (forall a b. a -> f b -> f a) -> Functor f
<$ :: forall a b. a -> LexAction b -> LexAction a
$c<$ :: forall a b. a -> LexAction b -> LexAction a
fmap :: forall a b. (a -> b) -> LexAction a -> LexAction b
$cfmap :: forall a b. (a -> b) -> LexAction a -> LexAction b
Functor)
instance Applicative LexAction where
pure :: forall a. a -> LexAction a
pure a
r = forall r.
(AlexInput -> AlexInput -> Int -> Parser r) -> LexAction r
LexAction forall a b. (a -> b) -> a -> b
$ \ AlexInput
_ AlexInput
_ Int
_ -> forall (f :: * -> *) a. Applicative f => a -> f a
pure a
r
LexAction (a -> b)
mf <*> :: forall a b. LexAction (a -> b) -> LexAction a -> LexAction b
<*> LexAction a
mr = forall r.
(AlexInput -> AlexInput -> Int -> Parser r) -> LexAction r
LexAction forall a b. (a -> b) -> a -> b
$ \ AlexInput
a AlexInput
b Int
c -> forall r. LexAction r -> AlexInput -> AlexInput -> Int -> Parser r
runLexAction LexAction (a -> b)
mf AlexInput
a AlexInput
b Int
c forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> forall r. LexAction r -> AlexInput -> AlexInput -> Int -> Parser r
runLexAction LexAction a
mr AlexInput
a AlexInput
b Int
c
instance Monad LexAction where
return :: forall a. a -> LexAction a
return = forall (f :: * -> *) a. Applicative f => a -> f a
pure
LexAction a
m >>= :: forall a b. LexAction a -> (a -> LexAction b) -> LexAction b
>>= a -> LexAction b
k = forall r.
(AlexInput -> AlexInput -> Int -> Parser r) -> LexAction r
LexAction forall a b. (a -> b) -> a -> b
$ \ AlexInput
a AlexInput
b Int
c -> do
a
r <- forall r. LexAction r -> AlexInput -> AlexInput -> Int -> Parser r
runLexAction LexAction a
m AlexInput
a AlexInput
b Int
c
forall r. LexAction r -> AlexInput -> AlexInput -> Int -> Parser r
runLexAction (a -> LexAction b
k a
r) AlexInput
a AlexInput
b Int
c
instance MonadState ParseState LexAction where
get :: LexAction ParseState
get = forall r.
(AlexInput -> AlexInput -> Int -> Parser r) -> LexAction r
LexAction forall a b. (a -> b) -> a -> b
$ \ AlexInput
_ AlexInput
_ Int
_ -> forall s (m :: * -> *). MonadState s m => m s
get
put :: ParseState -> LexAction ()
put ParseState
s = forall r.
(AlexInput -> AlexInput -> Int -> Parser r) -> LexAction r
LexAction forall a b. (a -> b) -> a -> b
$ \ AlexInput
_ AlexInput
_ Int
_ -> forall s (m :: * -> *). MonadState s m => s -> m ()
put ParseState
s
type LexPredicate = ([LexState], ParseFlags) -> PreviousInput -> TokenLength -> CurrentInput -> Bool
(.&&.) :: LexPredicate -> LexPredicate -> LexPredicate
LexPredicate
p1 .&&. :: LexPredicate -> LexPredicate -> LexPredicate
.&&. LexPredicate
p2 = \([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u -> LexPredicate
p1 ([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u Bool -> Bool -> Bool
&& LexPredicate
p2 ([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u
(.||.) :: LexPredicate -> LexPredicate -> LexPredicate
LexPredicate
p1 .||. :: LexPredicate -> LexPredicate -> LexPredicate
.||. LexPredicate
p2 = \([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u -> LexPredicate
p1 ([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u Bool -> Bool -> Bool
|| LexPredicate
p2 ([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u
not' :: LexPredicate -> LexPredicate
not' :: LexPredicate -> LexPredicate
not' LexPredicate
p = \([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u -> Bool -> Bool
not (LexPredicate
p ([Int], ParseFlags)
x AlexInput
y Int
z AlexInput
u)