{-# LANGUAGE BangPatterns, CPP, ScopedTypeVariables #-}
module Data.Attoparsec.Internal
( compareResults
, prompt
, demandInput
, demandInput_
, wantInput
, endOfInput
, atEnd
, satisfyElem
, concatReverse
) where
#if !MIN_VERSION_base(4,8,0)
import Control.Applicative ((<$>))
import Data.Monoid (Monoid, mconcat)
#endif
import Data.Attoparsec.Internal.Types
import Data.ByteString (ByteString)
import Data.Text (Text)
import Prelude hiding (succ)
compareResults :: (Eq i, Eq r) => IResult i r -> IResult i r -> Maybe Bool
compareResults :: forall i r.
(Eq i, Eq r) =>
IResult i r -> IResult i r -> Maybe Bool
compareResults (Fail i
t0 [String]
ctxs0 String
msg0) (Fail i
t1 [String]
ctxs1 String
msg1) =
forall a. a -> Maybe a
Just (i
t0 forall a. Eq a => a -> a -> Bool
== i
t1 Bool -> Bool -> Bool
&& [String]
ctxs0 forall a. Eq a => a -> a -> Bool
== [String]
ctxs1 Bool -> Bool -> Bool
&& String
msg0 forall a. Eq a => a -> a -> Bool
== String
msg1)
compareResults (Done i
t0 r
r0) (Done i
t1 r
r1) =
forall a. a -> Maybe a
Just (i
t0 forall a. Eq a => a -> a -> Bool
== i
t1 Bool -> Bool -> Bool
&& r
r0 forall a. Eq a => a -> a -> Bool
== r
r1)
compareResults (Partial i -> IResult i r
_) (Partial i -> IResult i r
_) = forall a. Maybe a
Nothing
compareResults IResult i r
_ IResult i r
_ = forall a. a -> Maybe a
Just Bool
False
prompt :: Chunk t
=> State t -> Pos -> More
-> (State t -> Pos -> More -> IResult t r)
-> (State t -> Pos -> More -> IResult t r)
-> IResult t r
prompt :: forall t r.
Chunk t =>
State t
-> Pos
-> More
-> (State t -> Pos -> More -> IResult t r)
-> (State t -> Pos -> More -> IResult t r)
-> IResult t r
prompt State t
t Pos
pos More
_more State t -> Pos -> More -> IResult t r
lose State t -> Pos -> More -> IResult t r
succ = forall i r. (i -> IResult i r) -> IResult i r
Partial forall a b. (a -> b) -> a -> b
$ \t
s ->
if forall c. Chunk c => c -> Bool
nullChunk t
s
then State t -> Pos -> More -> IResult t r
lose State t
t Pos
pos More
Complete
else State t -> Pos -> More -> IResult t r
succ (forall c. Chunk c => State c -> c -> State c
pappendChunk State t
t t
s) Pos
pos More
Incomplete
{-# SPECIALIZE prompt :: State ByteString -> Pos -> More
-> (State ByteString -> Pos -> More
-> IResult ByteString r)
-> (State ByteString -> Pos -> More
-> IResult ByteString r)
-> IResult ByteString r #-}
{-# SPECIALIZE prompt :: State Text -> Pos -> More
-> (State Text -> Pos -> More -> IResult Text r)
-> (State Text -> Pos -> More -> IResult Text r)
-> IResult Text r #-}
demandInput :: Chunk t => Parser t ()
demandInput :: forall t. Chunk t => Parser t ()
demandInput = forall i a.
(forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r)
-> Parser i a
Parser forall a b. (a -> b) -> a -> b
$ \State t
t Pos
pos More
more Failure t (State t) r
lose Success t (State t) () r
succ ->
case More
more of
More
Complete -> Failure t (State t) r
lose State t
t Pos
pos More
more [] String
"not enough input"
More
_ -> let lose' :: p -> Pos -> More -> IResult t r
lose' p
_ Pos
pos' More
more' = Failure t (State t) r
lose State t
t Pos
pos' More
more' [] String
"not enough input"
succ' :: State t -> Pos -> More -> IResult t r
succ' State t
t' Pos
pos' More
more' = Success t (State t) () r
succ State t
t' Pos
pos' More
more' ()
in forall t r.
Chunk t =>
State t
-> Pos
-> More
-> (State t -> Pos -> More -> IResult t r)
-> (State t -> Pos -> More -> IResult t r)
-> IResult t r
prompt State t
t Pos
pos More
more forall {p}. p -> Pos -> More -> IResult t r
lose' State t -> Pos -> More -> IResult t r
succ'
{-# SPECIALIZE demandInput :: Parser ByteString () #-}
{-# SPECIALIZE demandInput :: Parser Text () #-}
demandInput_ :: Chunk t => Parser t t
demandInput_ :: forall t. Chunk t => Parser t t
demandInput_ = forall i a.
(forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r)
-> Parser i a
Parser forall a b. (a -> b) -> a -> b
$ \State t
t Pos
pos More
more Failure t (State t) r
lose Success t (State t) t r
succ ->
case More
more of
More
Complete -> Failure t (State t) r
lose State t
t Pos
pos More
more [] String
"not enough input"
More
_ -> forall i r. (i -> IResult i r) -> IResult i r
Partial forall a b. (a -> b) -> a -> b
$ \t
s ->
if forall c. Chunk c => c -> Bool
nullChunk t
s
then Failure t (State t) r
lose State t
t Pos
pos More
Complete [] String
"not enough input"
else Success t (State t) t r
succ (forall c. Chunk c => State c -> c -> State c
pappendChunk State t
t t
s) Pos
pos More
more t
s
{-# SPECIALIZE demandInput_ :: Parser ByteString ByteString #-}
{-# SPECIALIZE demandInput_ :: Parser Text Text #-}
wantInput :: forall t . Chunk t => Parser t Bool
wantInput :: forall t. Chunk t => Parser t Bool
wantInput = forall i a.
(forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r)
-> Parser i a
Parser forall a b. (a -> b) -> a -> b
$ \State t
t Pos
pos More
more Failure t (State t) r
_lose Success t (State t) Bool r
succ ->
case () of
()
_ | Pos
pos forall a. Ord a => a -> a -> Bool
< forall c. Chunk c => c -> State c -> Pos
atBufferEnd (forall a. HasCallStack => a
undefined :: t) State t
t -> Success t (State t) Bool r
succ State t
t Pos
pos More
more Bool
True
| More
more forall a. Eq a => a -> a -> Bool
== More
Complete -> Success t (State t) Bool r
succ State t
t Pos
pos More
more Bool
False
| Bool
otherwise -> let lose' :: State t -> Pos -> More -> IResult t r
lose' State t
t' Pos
pos' More
more' = Success t (State t) Bool r
succ State t
t' Pos
pos' More
more' Bool
False
succ' :: State t -> Pos -> More -> IResult t r
succ' State t
t' Pos
pos' More
more' = Success t (State t) Bool r
succ State t
t' Pos
pos' More
more' Bool
True
in forall t r.
Chunk t =>
State t
-> Pos
-> More
-> (State t -> Pos -> More -> IResult t r)
-> (State t -> Pos -> More -> IResult t r)
-> IResult t r
prompt State t
t Pos
pos More
more State t -> Pos -> More -> IResult t r
lose' State t -> Pos -> More -> IResult t r
succ'
{-# INLINE wantInput #-}
endOfInput :: forall t . Chunk t => Parser t ()
endOfInput :: forall t. Chunk t => Parser t ()
endOfInput = forall i a.
(forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r)
-> Parser i a
Parser forall a b. (a -> b) -> a -> b
$ \State t
t Pos
pos More
more Failure t (State t) r
lose Success t (State t) () r
succ ->
case () of
()
_| Pos
pos forall a. Ord a => a -> a -> Bool
< forall c. Chunk c => c -> State c -> Pos
atBufferEnd (forall a. HasCallStack => a
undefined :: t) State t
t -> Failure t (State t) r
lose State t
t Pos
pos More
more [] String
"endOfInput"
| More
more forall a. Eq a => a -> a -> Bool
== More
Complete -> Success t (State t) () r
succ State t
t Pos
pos More
more ()
| Bool
otherwise ->
let lose' :: State t -> Pos -> More -> p -> p -> IResult t r
lose' State t
t' Pos
pos' More
more' p
_ctx p
_msg = Success t (State t) () r
succ State t
t' Pos
pos' More
more' ()
succ' :: State t -> Pos -> More -> p -> IResult t r
succ' State t
t' Pos
pos' More
more' p
_a = Failure t (State t) r
lose State t
t' Pos
pos' More
more' [] String
"endOfInput"
in forall i a.
Parser i a
-> forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r
runParser forall t. Chunk t => Parser t ()
demandInput State t
t Pos
pos More
more forall {p} {p}. State t -> Pos -> More -> p -> p -> IResult t r
lose' forall {p}. State t -> Pos -> More -> p -> IResult t r
succ'
{-# SPECIALIZE endOfInput :: Parser ByteString () #-}
{-# SPECIALIZE endOfInput :: Parser Text () #-}
atEnd :: Chunk t => Parser t Bool
atEnd :: forall t. Chunk t => Parser t Bool
atEnd = Bool -> Bool
not forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> forall t. Chunk t => Parser t Bool
wantInput
{-# INLINE atEnd #-}
satisfySuspended :: forall t r . Chunk t
=> (ChunkElem t -> Bool)
-> State t -> Pos -> More
-> Failure t (State t) r
-> Success t (State t) (ChunkElem t) r
-> IResult t r
satisfySuspended :: forall t r.
Chunk t =>
(ChunkElem t -> Bool)
-> State t
-> Pos
-> More
-> Failure t (State t) r
-> Success t (State t) (ChunkElem t) r
-> IResult t r
satisfySuspended ChunkElem t -> Bool
p State t
t Pos
pos More
more Failure t (State t) r
lose Success t (State t) (ChunkElem t) r
succ =
forall i a.
Parser i a
-> forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r
runParser (forall t. Chunk t => Parser t ()
demandInput forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> Parser t (ChunkElem t)
go) State t
t Pos
pos More
more Failure t (State t) r
lose Success t (State t) (ChunkElem t) r
succ
where go :: Parser t (ChunkElem t)
go = forall i a.
(forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r)
-> Parser i a
Parser forall a b. (a -> b) -> a -> b
$ \State t
t' Pos
pos' More
more' Failure t (State t) r
lose' Success t (State t) (ChunkElem t) r
succ' ->
case forall c.
Chunk c =>
c -> Pos -> State c -> Maybe (ChunkElem c, Int)
bufferElemAt (forall a. HasCallStack => a
undefined :: t) Pos
pos' State t
t' of
Just (ChunkElem t
e, Int
l) | ChunkElem t -> Bool
p ChunkElem t
e -> Success t (State t) (ChunkElem t) r
succ' State t
t' (Pos
pos' forall a. Num a => a -> a -> a
+ Int -> Pos
Pos Int
l) More
more' ChunkElem t
e
| Bool
otherwise -> Failure t (State t) r
lose' State t
t' Pos
pos' More
more' [] String
"satisfyElem"
Maybe (ChunkElem t, Int)
Nothing -> forall i a.
Parser i a
-> forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r
runParser (forall t. Chunk t => Parser t ()
demandInput forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> Parser t (ChunkElem t)
go) State t
t' Pos
pos' More
more' Failure t (State t) r
lose' Success t (State t) (ChunkElem t) r
succ'
{-# SPECIALIZE satisfySuspended :: (ChunkElem ByteString -> Bool)
-> State ByteString -> Pos -> More
-> Failure ByteString (State ByteString) r
-> Success ByteString (State ByteString)
(ChunkElem ByteString) r
-> IResult ByteString r #-}
{-# SPECIALIZE satisfySuspended :: (ChunkElem Text -> Bool)
-> State Text -> Pos -> More
-> Failure Text (State Text) r
-> Success Text (State Text)
(ChunkElem Text) r
-> IResult Text r #-}
satisfyElem :: forall t . Chunk t
=> (ChunkElem t -> Bool) -> Parser t (ChunkElem t)
satisfyElem :: forall t.
Chunk t =>
(ChunkElem t -> Bool) -> Parser t (ChunkElem t)
satisfyElem ChunkElem t -> Bool
p = forall i a.
(forall r.
State i
-> Pos
-> More
-> Failure i (State i) r
-> Success i (State i) a r
-> IResult i r)
-> Parser i a
Parser forall a b. (a -> b) -> a -> b
$ \State t
t Pos
pos More
more Failure t (State t) r
lose Success t (State t) (ChunkElem t) r
succ ->
case forall c.
Chunk c =>
c -> Pos -> State c -> Maybe (ChunkElem c, Int)
bufferElemAt (forall a. HasCallStack => a
undefined :: t) Pos
pos State t
t of
Just (ChunkElem t
e, Int
l) | ChunkElem t -> Bool
p ChunkElem t
e -> Success t (State t) (ChunkElem t) r
succ State t
t (Pos
pos forall a. Num a => a -> a -> a
+ Int -> Pos
Pos Int
l) More
more ChunkElem t
e
| Bool
otherwise -> Failure t (State t) r
lose State t
t Pos
pos More
more [] String
"satisfyElem"
Maybe (ChunkElem t, Int)
Nothing -> forall t r.
Chunk t =>
(ChunkElem t -> Bool)
-> State t
-> Pos
-> More
-> Failure t (State t) r
-> Success t (State t) (ChunkElem t) r
-> IResult t r
satisfySuspended ChunkElem t -> Bool
p State t
t Pos
pos More
more Failure t (State t) r
lose Success t (State t) (ChunkElem t) r
succ
{-# INLINE satisfyElem #-}
concatReverse :: Monoid m => [m] -> m
concatReverse :: forall m. Monoid m => [m] -> m
concatReverse [m
x] = m
x
concatReverse [m]
xs = forall m. Monoid m => [m] -> m
mconcat (forall a. [a] -> [a]
reverse [m]
xs)
{-# INLINE concatReverse #-}