{-# LANGUAGE Safe #-}
module Text.ParserCombinators.Parsec.Utils(
GeneralizedToken, GeneralizedTokenParser,
togtok, tokeng, satisfyg, oneOfg, noneOfg,
specificg, allg,
notMatching
) where
import safe Text.ParserCombinators.Parsec
( (<?>),
(<|>),
getPosition,
many,
token,
unexpected,
try,
SourcePos,
GenParser )
type GeneralizedToken a = (SourcePos, a)
type GeneralizedTokenParser a st b = GenParser (GeneralizedToken a) st b
togtok :: a -> GenParser b st (GeneralizedToken a)
togtok :: a -> GenParser b st (GeneralizedToken a)
togtok a
tok = do
SourcePos
x <- ParsecT [b] st Identity SourcePos
forall (m :: * -> *) s u. Monad m => ParsecT s u m SourcePos
getPosition
GeneralizedToken a -> GenParser b st (GeneralizedToken a)
forall (m :: * -> *) a. Monad m => a -> m a
return (SourcePos
x, a
tok)
tokeng :: (Show a) => (a -> Maybe b) -> GeneralizedTokenParser a st b
tokeng :: (a -> Maybe b) -> GeneralizedTokenParser a st b
tokeng a -> Maybe b
test =
((SourcePos, a) -> String)
-> ((SourcePos, a) -> SourcePos)
-> ((SourcePos, a) -> Maybe b)
-> GeneralizedTokenParser a st b
forall s t a u.
Stream s Identity t =>
(t -> String) -> (t -> SourcePos) -> (t -> Maybe a) -> Parsec s u a
token (a -> String
forall a. Show a => a -> String
show (a -> String) -> ((SourcePos, a) -> a) -> (SourcePos, a) -> String
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (SourcePos, a) -> a
forall a b. (a, b) -> b
snd) ((SourcePos, a) -> SourcePos
forall a b. (a, b) -> a
fst) (a -> Maybe b
test (a -> Maybe b)
-> ((SourcePos, a) -> a) -> (SourcePos, a) -> Maybe b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (SourcePos, a) -> a
forall a b. (a, b) -> b
snd)
satisfyg :: (Show a) => (a -> Bool) -> GeneralizedTokenParser a st a
satisfyg :: (a -> Bool) -> GeneralizedTokenParser a st a
satisfyg a -> Bool
test = (a -> Maybe a) -> GeneralizedTokenParser a st a
forall a b st.
Show a =>
(a -> Maybe b) -> GeneralizedTokenParser a st b
tokeng (\a
t -> if a -> Bool
test a
t then a -> Maybe a
forall a. a -> Maybe a
Just a
t else Maybe a
forall a. Maybe a
Nothing)
oneOfg :: (Eq a, Show a) => [a] -> GeneralizedTokenParser a st a
oneOfg :: [a] -> GeneralizedTokenParser a st a
oneOfg [a]
i = (a -> Bool) -> GeneralizedTokenParser a st a
forall a st. Show a => (a -> Bool) -> GeneralizedTokenParser a st a
satisfyg (\a
x -> a -> [a] -> Bool
forall (t :: * -> *) a. (Foldable t, Eq a) => a -> t a -> Bool
elem a
x [a]
i)
allg :: (Show a) => GeneralizedTokenParser a st [a]
allg :: GeneralizedTokenParser a st [a]
allg = ParsecT [GeneralizedToken a] st Identity a
-> GeneralizedTokenParser a st [a]
forall s u (m :: * -> *) a. ParsecT s u m a -> ParsecT s u m [a]
many (ParsecT [GeneralizedToken a] st Identity a
-> GeneralizedTokenParser a st [a])
-> ParsecT [GeneralizedToken a] st Identity a
-> GeneralizedTokenParser a st [a]
forall a b. (a -> b) -> a -> b
$ (a -> Bool) -> ParsecT [GeneralizedToken a] st Identity a
forall a st. Show a => (a -> Bool) -> GeneralizedTokenParser a st a
satisfyg (\a
_ -> Bool
True)
noneOfg :: (Eq a, Show a) => [a] -> GeneralizedTokenParser a st a
noneOfg :: [a] -> GeneralizedTokenParser a st a
noneOfg [a]
l = (a -> Bool) -> GeneralizedTokenParser a st a
forall a st. Show a => (a -> Bool) -> GeneralizedTokenParser a st a
satisfyg (\a
x -> Bool -> Bool
not (a -> [a] -> Bool
forall (t :: * -> *) a. (Foldable t, Eq a) => a -> t a -> Bool
elem a
x [a]
l))
specificg :: (Eq a, Show a) => a -> GeneralizedTokenParser a st a
specificg :: a -> GeneralizedTokenParser a st a
specificg a
i = (a -> Bool) -> GeneralizedTokenParser a st a
forall a st. Show a => (a -> Bool) -> GeneralizedTokenParser a st a
satisfyg (a -> a -> Bool
forall a. Eq a => a -> a -> Bool
== a
i) GeneralizedTokenParser a st a
-> String -> GeneralizedTokenParser a st a
forall s u (m :: * -> *) a.
ParsecT s u m a -> String -> ParsecT s u m a
<?> a -> String
forall a. Show a => a -> String
show a
i
notMatching :: GenParser a b c -> String -> GenParser a b ()
notMatching :: GenParser a b c -> String -> GenParser a b ()
notMatching GenParser a b c
p String
errormsg =
let maybeRead :: ParsecT [a] b Identity (Maybe c)
maybeRead = ParsecT [a] b Identity (Maybe c)
-> ParsecT [a] b Identity (Maybe c)
forall tok st a. GenParser tok st a -> GenParser tok st a
try (do
c
x <- GenParser a b c
p
Maybe c -> ParsecT [a] b Identity (Maybe c)
forall (m :: * -> *) a. Monad m => a -> m a
return (c -> Maybe c
forall a. a -> Maybe a
Just c
x)
)
ParsecT [a] b Identity (Maybe c)
-> ParsecT [a] b Identity (Maybe c)
-> ParsecT [a] b Identity (Maybe c)
forall s u (m :: * -> *) a.
ParsecT s u m a -> ParsecT s u m a -> ParsecT s u m a
<|> Maybe c -> ParsecT [a] b Identity (Maybe c)
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe c
forall a. Maybe a
Nothing
workerFunc :: GenParser a b ()
workerFunc = do
Maybe c
x <- ParsecT [a] b Identity (Maybe c)
maybeRead
case Maybe c
x of
Maybe c
Nothing -> () -> GenParser a b ()
forall (m :: * -> *) a. Monad m => a -> m a
return ()
Just c
_ -> String -> GenParser a b ()
forall s (m :: * -> *) t u a.
Stream s m t =>
String -> ParsecT s u m a
unexpected String
errormsg
in
GenParser a b () -> GenParser a b ()
forall tok st a. GenParser tok st a -> GenParser tok st a
try GenParser a b ()
workerFunc