Created
April 2, 2019 22:46
-
-
Save chessai/9c402f1dedbb4d87ca86669df73bc840 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
type Message = ([String],String) | |
parse :: Monad m | |
=> AB.Parser a | |
-> Stream (Of ByteString) m r | |
-> m (Either a Message, Stream (Of ByteString) m r) | |
parse parser bs = do | |
(e,rest) <- apply parser bs | |
pure (either Right Left e, rest) | |
apply :: Monad m | |
=> AB.Parser a | |
-> Stream (Of ByteString) m r | |
-> m (Either Message a, Stream (Of ByteString) m r) | |
apply parser = begin where | |
begin = \case | |
Effect m -> m >>= begin | |
Return r -> step id (AB.parse parser mempty) (pure r) | |
Step (bs :> rest) -> if B.null bs -- attoparsec understands "" as eof. | |
then begin rest | |
else step (S.yield bs >>) (AB.parse parser bs) rest | |
step diff res p0 = case res of | |
AB.Fail _ c m -> pure (Left (c,m), diff p0) | |
AB.Done a b -> pure (Right b, S.yield a >> p0) | |
AB.Partial k -> do | |
let clean = \case -- inspect for null chunks before | |
Effect m -> m >>= clean -- feeding attoparsec | |
Return r -> step diff (k mempty) (pure r) | |
Step (bs :> rest) -> if B.null bs | |
then clean rest | |
else step (diff . (S.yield bs >>)) (k bs) rest | |
clean p0 |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment