module Codec.ByteString.Parser (
Parser
, runParser
, runParserState
, choice
, expect
, skip
, lookAhead
, lookAheadM
, lookAheadE
, bytesRead
, getBytes
, remaining
, isEmpty
, satisfy
, getString
, getStringNul
, string
, getWord8
, getInt8
, word8
, int8
, getByteString
, getLazyByteString
, getLazyByteStringNul
, getRemainingLazyByteString
, getWord16be
, word16be
, getWord24be
, word24be
, getWord32be
, word32be
, getWord64be
, word64be
, getInt16be
, int16be
, getInt32be
, int32be
, getInt64be
, int64be
, getWord16le
, word16le
, getWord24le
, word24le
, getWord32le
, word32le
, getWord64le
, word64le
, getInt16le
, int16le
, getInt32le
, int32le
, getInt64le
, int64le
, getWordHost
, wordHost
, getWord16host
, word16host
, getWord32host
, word32host
, getWord64host
, word64host
, getVarLenBe
, varLenBe
, getVarLenLe
, varLenLe
) where
import qualified Data.ByteString as B
import qualified Data.ByteString.Lazy as L
import qualified Data.ByteString.Internal as B
import qualified Data.ByteString.Lazy.Internal as L
import Prelude hiding (fail)
import Foreign.Storable (Storable, peek, sizeOf)
import Foreign.Ptr (plusPtr, castPtr)
import Foreign.ForeignPtr (withForeignPtr)
import Control.Monad.ST (runST)
import Control.Monad.ST.Unsafe (unsafeInterleaveST)
import Control.Monad.Fail
import Control.Monad hiding (fail)
import Control.Applicative
import Data.STRef
import Data.Word
import Data.Int
import Data.Bits
import Data.Maybe
import System.IO.Unsafe (unsafePerformIO)
data S = S {-# UNPACK #-} !B.ByteString
L.ByteString
{-# UNPACK #-} !Int64
newtype Parser a = Parser { Parser a -> S -> Either String (a, S)
unParser :: S -> Either String (a, S) }
instance Functor Parser where
fmap :: (a -> b) -> Parser a -> Parser b
fmap a -> b
f Parser a
m = (S -> Either String (b, S)) -> Parser b
forall a. (S -> Either String (a, S)) -> Parser a
Parser ((S -> Either String (b, S)) -> Parser b)
-> (S -> Either String (b, S)) -> Parser b
forall a b. (a -> b) -> a -> b
$ \S
s -> case Parser a -> S -> Either String (a, S)
forall a. Parser a -> S -> Either String (a, S)
unParser Parser a
m S
s of
Left String
e -> String -> Either String (b, S)
forall a b. a -> Either a b
Left String
e
Right (a
a, S
s') -> (b, S) -> Either String (b, S)
forall a b. b -> Either a b
Right (a -> b
f a
a, S
s')
instance Monad Parser where
return :: a -> Parser a
return a
a = (S -> Either String (a, S)) -> Parser a
forall a. (S -> Either String (a, S)) -> Parser a
Parser (\S
s -> (a, S) -> Either String (a, S)
forall a b. b -> Either a b
Right (a
a, S
s))
Parser a
m >>= :: Parser a -> (a -> Parser b) -> Parser b
>>= a -> Parser b
k = (S -> Either String (b, S)) -> Parser b
forall a. (S -> Either String (a, S)) -> Parser a
Parser ((S -> Either String (b, S)) -> Parser b)
-> (S -> Either String (b, S)) -> Parser b
forall a b. (a -> b) -> a -> b
$ \S
s -> case (Parser a -> S -> Either String (a, S)
forall a. Parser a -> S -> Either String (a, S)
unParser Parser a
m) S
s of
Left String
e -> String -> Either String (b, S)
forall a b. a -> Either a b
Left String
e
Right (a
a, S
s') -> (Parser b -> S -> Either String (b, S)
forall a. Parser a -> S -> Either String (a, S)
unParser (a -> Parser b
k a
a)) S
s'
instance MonadPlus Parser where
mzero :: Parser a
mzero = (S -> Either String (a, S)) -> Parser a
forall a. (S -> Either String (a, S)) -> Parser a
Parser ((S -> Either String (a, S)) -> Parser a)
-> (S -> Either String (a, S)) -> Parser a
forall a b. (a -> b) -> a -> b
$ \S
_ -> String -> Either String (a, S)
forall a b. a -> Either a b
Left []
mplus :: Parser a -> Parser a -> Parser a
mplus Parser a
p1 Parser a
p2 = (S -> Either String (a, S)) -> Parser a
forall a. (S -> Either String (a, S)) -> Parser a
Parser ((S -> Either String (a, S)) -> Parser a)
-> (S -> Either String (a, S)) -> Parser a
forall a b. (a -> b) -> a -> b
$ \S
s -> case (Parser a -> S -> Either String (a, S)
forall a. Parser a -> S -> Either String (a, S)
unParser Parser a
p1 S
s) of
Left String
e1 -> case (Parser a -> S -> Either String (a, S)
forall a. Parser a -> S -> Either String (a, S)
unParser Parser a
p2 S
s) of
Left String
e2 -> String -> Either String (a, S)
forall a b. a -> Either a b
Left (String
e1 String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
"\n" String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
e2)
Either String (a, S)
ok -> Either String (a, S)
ok
Either String (a, S)
ok -> Either String (a, S)
ok
instance MonadFail Parser where
fail :: String -> Parser a
fail String
err = (S -> Either String (a, S)) -> Parser a
forall a. (S -> Either String (a, S)) -> Parser a
Parser ((S -> Either String (a, S)) -> Parser a)
-> (S -> Either String (a, S)) -> Parser a
forall a b. (a -> b) -> a -> b
$ \(S ByteString
_ ByteString
_ Int64
bytes) ->
String -> Either String (a, S)
forall a b. a -> Either a b
Left (String
err String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
". Failed reading at byte position " String -> String -> String
forall a. [a] -> [a] -> [a]
++ Int64 -> String
forall a. Show a => a -> String
show Int64
bytes)
instance Applicative Parser where
pure :: a -> Parser a
pure = a -> Parser a
forall (m :: * -> *) a. Monad m => a -> m a
return
<*> :: Parser (a -> b) -> Parser a -> Parser b
(<*>) = Parser (a -> b) -> Parser a -> Parser b
forall (m :: * -> *) a b. Monad m => m (a -> b) -> m a -> m b
ap
instance Alternative Parser where
empty :: Parser a
empty = Parser a
forall (m :: * -> *) a. MonadPlus m => m a
mzero
<|> :: Parser a -> Parser a -> Parser a
(<|>) = Parser a -> Parser a -> Parser a
forall (m :: * -> *) a. MonadPlus m => m a -> m a -> m a
mplus
get :: Parser S
get :: Parser S
get = (S -> Either String (S, S)) -> Parser S
forall a. (S -> Either String (a, S)) -> Parser a
Parser ((S -> Either String (S, S)) -> Parser S)
-> (S -> Either String (S, S)) -> Parser S
forall a b. (a -> b) -> a -> b
$ \S
s -> (S, S) -> Either String (S, S)
forall a b. b -> Either a b
Right (S
s, S
s)
put :: S -> Parser ()
put :: S -> Parser ()
put S
s = (S -> Either String ((), S)) -> Parser ()
forall a. (S -> Either String (a, S)) -> Parser a
Parser ((S -> Either String ((), S)) -> Parser ())
-> (S -> Either String ((), S)) -> Parser ()
forall a b. (a -> b) -> a -> b
$ \S
_ -> ((), S) -> Either String ((), S)
forall a b. b -> Either a b
Right ((), S
s)
initState :: L.ByteString -> S
initState :: ByteString -> S
initState ByteString
xs = ByteString -> Int64 -> S
mkState ByteString
xs Int64
0
mkState :: L.ByteString -> Int64 -> S
mkState :: ByteString -> Int64 -> S
mkState ByteString
l = case ByteString
l of
ByteString
L.Empty -> ByteString -> ByteString -> Int64 -> S
S ByteString
B.empty ByteString
L.empty
L.Chunk ByteString
x ByteString
xs -> ByteString -> ByteString -> Int64 -> S
S ByteString
x ByteString
xs
runParser :: Parser a -> L.ByteString -> Either String a
runParser :: Parser a -> ByteString -> Either String a
runParser Parser a
m ByteString
str = case Parser a -> S -> Either String (a, S)
forall a. Parser a -> S -> Either String (a, S)
unParser Parser a
m (ByteString -> S
initState ByteString
str) of
Left String
e -> String -> Either String a
forall a b. a -> Either a b
Left String
e
Right (a
a, S
_) -> a -> Either String a
forall a b. b -> Either a b
Right a
a
runParserState :: Parser a -> L.ByteString -> Int64 -> Either String (a, L.ByteString, Int64)
runParserState :: Parser a
-> ByteString -> Int64 -> Either String (a, ByteString, Int64)
runParserState Parser a
m ByteString
str Int64
off =
case Parser a -> S -> Either String (a, S)
forall a. Parser a -> S -> Either String (a, S)
unParser Parser a
m (ByteString -> Int64 -> S
mkState ByteString
str Int64
off) of
Left String
e -> String -> Either String (a, ByteString, Int64)
forall a b. a -> Either a b
Left String
e
Right (a
a, ~(S ByteString
s ByteString
ss Int64
newOff)) -> (a, ByteString, Int64) -> Either String (a, ByteString, Int64)
forall a b. b -> Either a b
Right (a
a, ByteString
s ByteString -> ByteString -> ByteString
`bsJoin` ByteString
ss, Int64
newOff)
choice :: [Parser a] -> Parser a
choice :: [Parser a] -> Parser a
choice = (Parser a -> Parser a -> Parser a)
-> Parser a -> [Parser a] -> Parser a
forall (t :: * -> *) b a.
Foldable t =>
(b -> a -> b) -> b -> t a -> b
foldl Parser a -> Parser a -> Parser a
forall (f :: * -> *) a. Alternative f => f a -> f a -> f a
(<|>) Parser a
forall (m :: * -> *) a. MonadPlus m => m a
mzero
skip :: Word64 -> Parser ()
skip :: Word64 -> Parser ()
skip Word64
n = Int -> (ByteString -> ()) -> Parser ()
forall a. Int -> (ByteString -> a) -> Parser a
readN (Word64 -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral Word64
n) (() -> ByteString -> ()
forall a b. a -> b -> a
const ())
lookAhead :: Parser a -> Parser a
lookAhead :: Parser a -> Parser a
lookAhead Parser a
ga = do
S
s <- Parser S
get
a
a <- Parser a
ga
S -> Parser ()
put S
s
a -> Parser a
forall (m :: * -> *) a. Monad m => a -> m a
return a
a
lookAheadM :: Parser (Maybe a) -> Parser (Maybe a)
lookAheadM :: Parser (Maybe a) -> Parser (Maybe a)
lookAheadM Parser (Maybe a)
gma = do
S
s <- Parser S
get
Maybe a
ma <- Parser (Maybe a)
gma
Bool -> Parser () -> Parser ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Maybe a -> Bool
forall a. Maybe a -> Bool
isNothing Maybe a
ma) (Parser () -> Parser ()) -> Parser () -> Parser ()
forall a b. (a -> b) -> a -> b
$ S -> Parser ()
put S
s
Maybe a -> Parser (Maybe a)
forall (m :: * -> *) a. Monad m => a -> m a
return Maybe a
ma
lookAheadE :: Parser (Either a b) -> Parser (Either a b)
lookAheadE :: Parser (Either a b) -> Parser (Either a b)
lookAheadE Parser (Either a b)
gea = do
S
s <- Parser S
get
Either a b
ea <- Parser (Either a b)
gea
case Either a b
ea of
Left a
_ -> S -> Parser ()
put S
s
Either a b
_ -> () -> Parser ()
forall (m :: * -> *) a. Monad m => a -> m a
return ()
Either a b -> Parser (Either a b)
forall (m :: * -> *) a. Monad m => a -> m a
return Either a b
ea
expect :: (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect :: (a -> Bool) -> Parser a -> Parser a
expect a -> Bool
f Parser a
p = do
a
v <- Parser a
p
Bool -> Parser () -> Parser ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (Bool -> Bool
not (Bool -> Bool) -> Bool -> Bool
forall a b. (a -> b) -> a -> b
$ a -> Bool
f a
v) (Parser () -> Parser ()) -> Parser () -> Parser ()
forall a b. (a -> b) -> a -> b
$ String -> Parser ()
forall (m :: * -> *) a. MonadFail m => String -> m a
fail (String -> Parser ()) -> String -> Parser ()
forall a b. (a -> b) -> a -> b
$ a -> String
forall a. Show a => a -> String
show a
v String -> String -> String
forall a. [a] -> [a] -> [a]
++ String
" was not expected."
a -> Parser a
forall (m :: * -> *) a. Monad m => a -> m a
return a
v
getString :: Int -> Parser String
getString :: Int -> Parser String
getString Int
l = do
ByteString
bs <- Int64 -> Parser ByteString
getLazyByteString (Int -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int
l)
String -> Parser String
forall (m :: * -> *) a. Monad m => a -> m a
return (String -> Parser String) -> String -> Parser String
forall a b. (a -> b) -> a -> b
$! (Word8 -> Char) -> [Word8] -> String
forall a b. (a -> b) -> [a] -> [b]
map Word8 -> Char
B.w2c (ByteString -> [Word8]
L.unpack ByteString
bs)
getStringNul :: Parser String
getStringNul :: Parser String
getStringNul = do
ByteString
bs <- Parser ByteString
getLazyByteStringNul
String -> Parser String
forall (m :: * -> *) a. Monad m => a -> m a
return (String -> Parser String) -> String -> Parser String
forall a b. (a -> b) -> a -> b
$! (Word8 -> Char) -> [Word8] -> String
forall a b. (a -> b) -> [a] -> [b]
map Word8 -> Char
B.w2c (ByteString -> [Word8]
L.unpack ByteString
bs)
string :: String -> Parser String
string :: String -> Parser String
string String
s = (String -> Bool) -> Parser String -> Parser String
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (String
s String -> String -> Bool
forall a. Eq a => a -> a -> Bool
==) (Int -> Parser String
getString (Int -> Parser String) -> Int -> Parser String
forall a b. (a -> b) -> a -> b
$ String -> Int
forall (t :: * -> *) a. Foldable t => t a -> Int
length String
s)
bytesRead :: Parser Int64
bytesRead :: Parser Int64
bytesRead = do
S ByteString
_ ByteString
_ Int64
b <- Parser S
get
Int64 -> Parser Int64
forall (m :: * -> *) a. Monad m => a -> m a
return Int64
b
remaining :: Parser Int64
remaining :: Parser Int64
remaining = do
S ByteString
s ByteString
ss Int64
_ <- Parser S
get
Int64 -> Parser Int64
forall (m :: * -> *) a. Monad m => a -> m a
return (Int64 -> Parser Int64) -> Int64 -> Parser Int64
forall a b. (a -> b) -> a -> b
$! (Int -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString -> Int
B.length ByteString
s) Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
+ ByteString -> Int64
L.length ByteString
ss)
isEmpty :: Parser Bool
isEmpty :: Parser Bool
isEmpty = do
S ByteString
s ByteString
ss Int64
_ <- Parser S
get
Bool -> Parser Bool
forall (m :: * -> *) a. Monad m => a -> m a
return (Bool -> Parser Bool) -> Bool -> Parser Bool
forall a b. (a -> b) -> a -> b
$! (ByteString -> Bool
B.null ByteString
s Bool -> Bool -> Bool
&& ByteString -> Bool
L.null ByteString
ss)
getByteString :: Int -> Parser B.ByteString
getByteString :: Int -> Parser ByteString
getByteString Int
n = Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
n ByteString -> ByteString
forall a. a -> a
id
getLazyByteString :: Int64 -> Parser L.ByteString
getLazyByteString :: Int64 -> Parser ByteString
getLazyByteString Int64
n = do
S ByteString
s ByteString
ss Int64
bytes <- Parser S
get
let big :: ByteString
big = ByteString
s ByteString -> ByteString -> ByteString
`bsJoin` ByteString
ss
case Int64 -> ByteString -> (ByteString, ByteString)
splitAtST Int64
n ByteString
big of
(ByteString
consume, ByteString
rest) -> do S -> Parser ()
put (S -> Parser ()) -> S -> Parser ()
forall a b. (a -> b) -> a -> b
$ ByteString -> Int64 -> S
mkState ByteString
rest (Int64
bytes Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
+ Int64
n)
ByteString -> Parser ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return ByteString
consume
getLazyByteStringNul :: Parser L.ByteString
getLazyByteStringNul :: Parser ByteString
getLazyByteStringNul = do
S ByteString
s ByteString
ss Int64
bytes <- Parser S
get
let big :: ByteString
big = ByteString
s ByteString -> ByteString -> ByteString
`bsJoin` ByteString
ss
(ByteString
consume, ByteString
t) = (Word8 -> Bool) -> ByteString -> (ByteString, ByteString)
L.break (Word8 -> Word8 -> Bool
forall a. Eq a => a -> a -> Bool
== Word8
0) ByteString
big
(ByteString
h, ByteString
rest) = Int64 -> ByteString -> (ByteString, ByteString)
L.splitAt Int64
1 ByteString
t
Bool -> Parser () -> Parser ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (ByteString -> Bool
L.null ByteString
h) (Parser () -> Parser ()) -> Parser () -> Parser ()
forall a b. (a -> b) -> a -> b
$ String -> Parser ()
forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"too few bytes"
S -> Parser ()
put (S -> Parser ()) -> S -> Parser ()
forall a b. (a -> b) -> a -> b
$ ByteString -> Int64 -> S
mkState ByteString
rest (Int64
bytes Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
+ ByteString -> Int64
L.length ByteString
consume Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
+ Int64
1)
ByteString -> Parser ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return ByteString
consume
getRemainingLazyByteString :: Parser L.ByteString
getRemainingLazyByteString :: Parser ByteString
getRemainingLazyByteString = do
S ByteString
s ByteString
ss Int64
_ <- Parser S
get
ByteString -> Parser ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return (ByteString -> Parser ByteString)
-> ByteString -> Parser ByteString
forall a b. (a -> b) -> a -> b
$! (ByteString
s ByteString -> ByteString -> ByteString
`bsJoin` ByteString
ss)
getBytes :: Int -> Parser B.ByteString
getBytes :: Int -> Parser ByteString
getBytes Int
n = do
S ByteString
s ByteString
ss Int64
bytes <- Parser S
get
if Int
n Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
<= ByteString -> Int
B.length ByteString
s
then do let (ByteString
consume,ByteString
rest) = Int -> ByteString -> (ByteString, ByteString)
B.splitAt Int
n ByteString
s
S -> Parser ()
put (S -> Parser ()) -> S -> Parser ()
forall a b. (a -> b) -> a -> b
$! ByteString -> ByteString -> Int64 -> S
S ByteString
rest ByteString
ss (Int64
bytes Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
+ Int -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int
n)
ByteString -> Parser ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return (ByteString -> Parser ByteString)
-> ByteString -> Parser ByteString
forall a b. (a -> b) -> a -> b
$! ByteString
consume
else
case Int64 -> ByteString -> (ByteString, ByteString)
L.splitAt (Int -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int
n) (ByteString
s ByteString -> ByteString -> ByteString
`bsJoin` ByteString
ss) of
(ByteString
consuming, ByteString
rest) ->
do let now :: ByteString
now = [ByteString] -> ByteString
B.concat ([ByteString] -> ByteString)
-> (ByteString -> [ByteString]) -> ByteString -> ByteString
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ByteString -> [ByteString]
L.toChunks (ByteString -> ByteString) -> ByteString -> ByteString
forall a b. (a -> b) -> a -> b
$ ByteString
consuming
S -> Parser ()
put (S -> Parser ()) -> S -> Parser ()
forall a b. (a -> b) -> a -> b
$! ByteString -> Int64 -> S
mkState ByteString
rest (Int64
bytes Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
+ Int -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int
n)
Bool -> Parser () -> Parser ()
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (ByteString -> Int
B.length ByteString
now Int -> Int -> Bool
forall a. Ord a => a -> a -> Bool
< Int
n) (Parser () -> Parser ()) -> Parser () -> Parser ()
forall a b. (a -> b) -> a -> b
$ String -> Parser ()
forall (m :: * -> *) a. MonadFail m => String -> m a
fail String
"too few bytes"
ByteString -> Parser ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return ByteString
now
bsJoin :: B.ByteString -> L.ByteString -> L.ByteString
bsJoin :: ByteString -> ByteString -> ByteString
bsJoin ByteString
bb ByteString
lb
| ByteString -> Bool
B.null ByteString
bb = ByteString
lb
| Bool
otherwise = ByteString -> ByteString -> ByteString
L.Chunk ByteString
bb ByteString
lb
splitAtST :: Int64 -> L.ByteString -> (L.ByteString, L.ByteString)
splitAtST :: Int64 -> ByteString -> (ByteString, ByteString)
splitAtST Int64
i ByteString
ps | Int64
i Int64 -> Int64 -> Bool
forall a. Ord a => a -> a -> Bool
<= Int64
0 = (ByteString
L.empty, ByteString
ps)
splitAtST Int64
i ByteString
ps = (forall s. ST s (ByteString, ByteString))
-> (ByteString, ByteString)
forall a. (forall s. ST s a) -> a
runST (
do STRef s ByteString
r <- ByteString -> ST s (STRef s ByteString)
forall a s. a -> ST s (STRef s a)
newSTRef ByteString
forall a. HasCallStack => a
undefined
ByteString
xs <- STRef s ByteString -> Int64 -> ByteString -> ST s ByteString
forall s.
STRef s ByteString -> Int64 -> ByteString -> ST s ByteString
first STRef s ByteString
r Int64
i ByteString
ps
ByteString
ys <- ST s ByteString -> ST s ByteString
forall s a. ST s a -> ST s a
unsafeInterleaveST (STRef s ByteString -> ST s ByteString
forall s a. STRef s a -> ST s a
readSTRef STRef s ByteString
r)
(ByteString, ByteString) -> ST s (ByteString, ByteString)
forall (m :: * -> *) a. Monad m => a -> m a
return (ByteString
xs, ByteString
ys))
where
first :: STRef s ByteString -> Int64 -> ByteString -> ST s ByteString
first STRef s ByteString
r Int64
0 xs :: ByteString
xs@(L.Chunk ByteString
_ ByteString
_) = STRef s ByteString -> ByteString -> ST s ()
forall s a. STRef s a -> a -> ST s ()
writeSTRef STRef s ByteString
r ByteString
xs ST s () -> ST s ByteString -> ST s ByteString
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> ByteString -> ST s ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return ByteString
L.Empty
first STRef s ByteString
r Int64
_ ByteString
L.Empty = STRef s ByteString -> ByteString -> ST s ()
forall s a. STRef s a -> a -> ST s ()
writeSTRef STRef s ByteString
r ByteString
L.Empty ST s () -> ST s ByteString -> ST s ByteString
forall (m :: * -> *) a b. Monad m => m a -> m b -> m b
>> ByteString -> ST s ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return ByteString
L.Empty
first STRef s ByteString
r Int64
n (L.Chunk ByteString
x ByteString
xs)
| Int64
n Int64 -> Int64 -> Bool
forall a. Ord a => a -> a -> Bool
< Int64
l = do STRef s ByteString -> ByteString -> ST s ()
forall s a. STRef s a -> a -> ST s ()
writeSTRef STRef s ByteString
r (ByteString -> ByteString -> ByteString
L.Chunk (Int -> ByteString -> ByteString
B.drop (Int64 -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int64
n) ByteString
x) ByteString
xs)
ByteString -> ST s ByteString
forall (m :: * -> *) a. Monad m => a -> m a
return (ByteString -> ST s ByteString) -> ByteString -> ST s ByteString
forall a b. (a -> b) -> a -> b
$! ByteString -> ByteString -> ByteString
L.Chunk (Int -> ByteString -> ByteString
B.take (Int64 -> Int
forall a b. (Integral a, Num b) => a -> b
fromIntegral Int64
n) ByteString
x) ByteString
L.Empty
| Bool
otherwise = do STRef s ByteString -> ByteString -> ST s ()
forall s a. STRef s a -> a -> ST s ()
writeSTRef STRef s ByteString
r (Int64 -> ByteString -> ByteString
L.drop (Int64
n Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
- Int64
l) ByteString
xs)
(ByteString -> ByteString) -> ST s ByteString -> ST s ByteString
forall (m :: * -> *) a1 r. Monad m => (a1 -> r) -> m a1 -> m r
liftM (ByteString -> ByteString -> ByteString
L.Chunk ByteString
x) (ST s ByteString -> ST s ByteString)
-> ST s ByteString -> ST s ByteString
forall a b. (a -> b) -> a -> b
$ ST s ByteString -> ST s ByteString
forall s a. ST s a -> ST s a
unsafeInterleaveST (STRef s ByteString -> Int64 -> ByteString -> ST s ByteString
first STRef s ByteString
r (Int64
n Int64 -> Int64 -> Int64
forall a. Num a => a -> a -> a
- Int64
l) ByteString
xs)
where l :: Int64
l = Int -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString -> Int
B.length ByteString
x)
readN :: Int -> (B.ByteString -> a) -> Parser a
readN :: Int -> (ByteString -> a) -> Parser a
readN Int
n ByteString -> a
f = (ByteString -> a) -> Parser ByteString -> Parser a
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap ByteString -> a
f (Parser ByteString -> Parser a) -> Parser ByteString -> Parser a
forall a b. (a -> b) -> a -> b
$ Int -> Parser ByteString
getBytes Int
n
getPtr :: Storable a => Int -> Parser a
getPtr :: Int -> Parser a
getPtr Int
n = do
(ForeignPtr Word8
fp,Int
o,Int
_) <- Int
-> (ByteString -> (ForeignPtr Word8, Int, Int))
-> Parser (ForeignPtr Word8, Int, Int)
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
n ByteString -> (ForeignPtr Word8, Int, Int)
B.toForeignPtr
a -> Parser a
forall (m :: * -> *) a. Monad m => a -> m a
return (a -> Parser a) -> (IO a -> a) -> IO a -> Parser a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. IO a -> a
forall a. IO a -> a
unsafePerformIO (IO a -> Parser a) -> IO a -> Parser a
forall a b. (a -> b) -> a -> b
$ ForeignPtr Word8 -> (Ptr Word8 -> IO a) -> IO a
forall a b. ForeignPtr a -> (Ptr a -> IO b) -> IO b
withForeignPtr ForeignPtr Word8
fp ((Ptr Word8 -> IO a) -> IO a) -> (Ptr Word8 -> IO a) -> IO a
forall a b. (a -> b) -> a -> b
$ \Ptr Word8
p -> Ptr a -> IO a
forall a. Storable a => Ptr a -> IO a
peek (Ptr Any -> Ptr a
forall a b. Ptr a -> Ptr b
castPtr (Ptr Any -> Ptr a) -> Ptr Any -> Ptr a
forall a b. (a -> b) -> a -> b
$ Ptr Word8
p Ptr Word8 -> Int -> Ptr Any
forall a b. Ptr a -> Int -> Ptr b
`plusPtr` Int
o)
satisfy :: (Word8 -> Bool) -> Parser Word8
satisfy :: (Word8 -> Bool) -> Parser Word8
satisfy Word8 -> Bool
f = do
Word8
w <- Parser Word8
getWord8
Bool -> Parser ()
forall (f :: * -> *). Alternative f => Bool -> f ()
guard (Word8 -> Bool
f Word8
w)
Word8 -> Parser Word8
forall (m :: * -> *) a. Monad m => a -> m a
return Word8
w
getWord8 :: Parser Word8
getWord8 :: Parser Word8
getWord8 = Int -> Parser Word8
forall a. Storable a => Int -> Parser a
getPtr (Word8 -> Int
forall a. Storable a => a -> Int
sizeOf (Word8
forall a. HasCallStack => a
undefined :: Word8))
word8 :: Word8 -> Parser Word8
word8 :: Word8 -> Parser Word8
word8 Word8
w = (Word8 -> Bool) -> Parser Word8 -> Parser Word8
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word8
w Word8 -> Word8 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word8
getWord8
getWord16be :: Parser Word16
getWord16be :: Parser Word16
getWord16be = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
2 ByteString -> ByteString
forall a. a -> a
id
Word16 -> Parser Word16
forall (m :: * -> *) a. Monad m => a -> m a
return (Word16 -> Parser Word16) -> Word16 -> Parser Word16
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word16
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) Word16 -> Int -> Word16
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word16 -> Word16 -> Word16
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word16
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1))
word16be :: Word16 -> Parser Word16
word16be :: Word16 -> Parser Word16
word16be Word16
w = (Word16 -> Bool) -> Parser Word16 -> Parser Word16
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word16
w Word16 -> Word16 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word16
getWord16be
getWord16le :: Parser Word16
getWord16le :: Parser Word16
getWord16le = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
2 ByteString -> ByteString
forall a. a -> a
id
Word16 -> Parser Word16
forall (m :: * -> *) a. Monad m => a -> m a
return (Word16 -> Parser Word16) -> Word16 -> Parser Word16
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word16
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1) Word16 -> Int -> Word16
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word16 -> Word16 -> Word16
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word16
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) )
word16le :: Word16 -> Parser Word16
word16le :: Word16 -> Parser Word16
word16le Word16
w = (Word16 -> Bool) -> Parser Word16 -> Parser Word16
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word16
w Word16 -> Word16 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word16
getWord16le
getWord24be :: Parser Word32
getWord24be :: Parser Word32
getWord24be = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
3 ByteString -> ByteString
forall a. a -> a
id
Word32 -> Parser Word32
forall (m :: * -> *) a. Monad m => a -> m a
return (Word32 -> Parser Word32) -> Word32 -> Parser Word32
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
16) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
2) )
word24be :: Word32 -> Parser Word32
word24be :: Word32 -> Parser Word32
word24be Word32
w = (Word32 -> Bool) -> Parser Word32 -> Parser Word32
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word32
w Word32 -> Word32 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word32
getWord24be
getWord24le :: Parser Word32
getWord24le :: Parser Word32
getWord24le = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
3 ByteString -> ByteString
forall a. a -> a
id
Word32 -> Parser Word32
forall (m :: * -> *) a. Monad m => a -> m a
return (Word32 -> Parser Word32) -> Word32 -> Parser Word32
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
2) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
16) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) )
word24le :: Word32 -> Parser Word32
word24le :: Word32 -> Parser Word32
word24le Word32
w = (Word32 -> Bool) -> Parser Word32 -> Parser Word32
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word32
w Word32 -> Word32 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word32
getWord24le
getWord32be :: Parser Word32
getWord32be :: Parser Word32
getWord32be = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
4 ByteString -> ByteString
forall a. a -> a
id
Word32 -> Parser Word32
forall (m :: * -> *) a. Monad m => a -> m a
return (Word32 -> Parser Word32) -> Word32 -> Parser Word32
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
24) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
16) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
2) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
3) )
word32be :: Word32 -> Parser Word32
word32be :: Word32 -> Parser Word32
word32be Word32
w = (Word32 -> Bool) -> Parser Word32 -> Parser Word32
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word32
w Word32 -> Word32 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word32
getWord32be
getWord32le :: Parser Word32
getWord32le :: Parser Word32
getWord32le = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
4 ByteString -> ByteString
forall a. a -> a
id
Word32 -> Parser Word32
forall (m :: * -> *) a. Monad m => a -> m a
return (Word32 -> Parser Word32) -> Word32 -> Parser Word32
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
3) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
24) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
2) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
16) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1) Word32 -> Int -> Word32
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word32 -> Word32 -> Word32
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word32
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) )
word32le :: Word32 -> Parser Word32
word32le :: Word32 -> Parser Word32
word32le Word32
w = (Word32 -> Bool) -> Parser Word32 -> Parser Word32
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word32
w Word32 -> Word32 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word32
getWord32le
getWord64be :: Parser Word64
getWord64be :: Parser Word64
getWord64be = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
8 ByteString -> ByteString
forall a. a -> a
id
Word64 -> Parser Word64
forall (m :: * -> *) a. Monad m => a -> m a
return (Word64 -> Parser Word64) -> Word64 -> Parser Word64
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
56) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
48) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
2) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
40) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
3) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
32) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
4) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
24) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
5) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
16) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
6) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
7) )
word64be :: Word64 -> Parser Word64
word64be :: Word64 -> Parser Word64
word64be Word64
w = (Word64 -> Bool) -> Parser Word64 -> Parser Word64
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word64
w Word64 -> Word64 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word64
getWord64be
getWord64le :: Parser Word64
getWord64le :: Parser Word64
getWord64le = do
ByteString
s <- Int -> (ByteString -> ByteString) -> Parser ByteString
forall a. Int -> (ByteString -> a) -> Parser a
readN Int
8 ByteString -> ByteString
forall a. a -> a
id
Word64 -> Parser Word64
forall (m :: * -> *) a. Monad m => a -> m a
return (Word64 -> Parser Word64) -> Word64 -> Parser Word64
forall a b. (a -> b) -> a -> b
$! (Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
7) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
56) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
6) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
48) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
5) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
40) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
4) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
32) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
3) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
24) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
2) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
16) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
1) Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
`shiftL` Int
8) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|.
(Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral (ByteString
s ByteString -> Int -> Word8
`B.index` Int
0) )
word64le :: Word64 -> Parser Word64
word64le :: Word64 -> Parser Word64
word64le Word64
w = (Word64 -> Bool) -> Parser Word64 -> Parser Word64
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word64
w Word64 -> Word64 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word64
getWord64le
getInt8 :: Parser Int8
getInt8 :: Parser Int8
getInt8 = Parser Word8
getWord8 Parser Word8 -> (Word8 -> Parser Int8) -> Parser Int8
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Int8 -> Parser Int8
forall (m :: * -> *) a. Monad m => a -> m a
return (Int8 -> Parser Int8) -> (Word8 -> Int8) -> Word8 -> Parser Int8
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word8 -> Int8
forall a b. (Integral a, Num b) => a -> b
fromIntegral
int8 :: Int8 -> Parser Int8
int8 :: Int8 -> Parser Int8
int8 Int8
i = (Int8 -> Bool) -> Parser Int8 -> Parser Int8
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Int8
i Int8 -> Int8 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Int8
getInt8
getInt16le :: Parser Int16
getInt16le :: Parser Int16
getInt16le = Parser Word16
getWord16le Parser Word16 -> (Word16 -> Parser Int16) -> Parser Int16
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Int16 -> Parser Int16
forall (m :: * -> *) a. Monad m => a -> m a
return (Int16 -> Parser Int16)
-> (Word16 -> Int16) -> Word16 -> Parser Int16
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word16 -> Int16
forall a b. (Integral a, Num b) => a -> b
fromIntegral
int16le :: Int16 -> Parser Int16
int16le :: Int16 -> Parser Int16
int16le Int16
i = (Int16 -> Bool) -> Parser Int16 -> Parser Int16
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Int16
i Int16 -> Int16 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Int16
getInt16le
getInt16be :: Parser Int16
getInt16be :: Parser Int16
getInt16be = Parser Word16
getWord16be Parser Word16 -> (Word16 -> Parser Int16) -> Parser Int16
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Int16 -> Parser Int16
forall (m :: * -> *) a. Monad m => a -> m a
return (Int16 -> Parser Int16)
-> (Word16 -> Int16) -> Word16 -> Parser Int16
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word16 -> Int16
forall a b. (Integral a, Num b) => a -> b
fromIntegral
int16be :: Int16 -> Parser Int16
int16be :: Int16 -> Parser Int16
int16be Int16
i = (Int16 -> Bool) -> Parser Int16 -> Parser Int16
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Int16
i Int16 -> Int16 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Int16
getInt16be
getInt32le :: Parser Int32
getInt32le :: Parser Int32
getInt32le = Parser Word32
getWord32le Parser Word32 -> (Word32 -> Parser Int32) -> Parser Int32
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Int32 -> Parser Int32
forall (m :: * -> *) a. Monad m => a -> m a
return (Int32 -> Parser Int32)
-> (Word32 -> Int32) -> Word32 -> Parser Int32
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word32 -> Int32
forall a b. (Integral a, Num b) => a -> b
fromIntegral
int32le :: Int32 -> Parser Int32
int32le :: Int32 -> Parser Int32
int32le Int32
i = (Int32 -> Bool) -> Parser Int32 -> Parser Int32
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Int32
i Int32 -> Int32 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Int32
getInt32le
getInt32be :: Parser Int32
getInt32be :: Parser Int32
getInt32be = Parser Word32
getWord32be Parser Word32 -> (Word32 -> Parser Int32) -> Parser Int32
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Int32 -> Parser Int32
forall (m :: * -> *) a. Monad m => a -> m a
return (Int32 -> Parser Int32)
-> (Word32 -> Int32) -> Word32 -> Parser Int32
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word32 -> Int32
forall a b. (Integral a, Num b) => a -> b
fromIntegral
int32be :: Int32 -> Parser Int32
int32be :: Int32 -> Parser Int32
int32be Int32
i = (Int32 -> Bool) -> Parser Int32 -> Parser Int32
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Int32
i Int32 -> Int32 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Int32
getInt32be
getInt64le :: Parser Int64
getInt64le :: Parser Int64
getInt64le = Parser Word64
getWord64le Parser Word64 -> (Word64 -> Parser Int64) -> Parser Int64
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Int64 -> Parser Int64
forall (m :: * -> *) a. Monad m => a -> m a
return (Int64 -> Parser Int64)
-> (Word64 -> Int64) -> Word64 -> Parser Int64
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word64 -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral
int64le :: Int64 -> Parser Int64
int64le :: Int64 -> Parser Int64
int64le Int64
i = (Int64 -> Bool) -> Parser Int64 -> Parser Int64
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Int64
i Int64 -> Int64 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Int64
getInt64le
getInt64be :: Parser Int64
getInt64be :: Parser Int64
getInt64be = Parser Word64
getWord64be Parser Word64 -> (Word64 -> Parser Int64) -> Parser Int64
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Int64 -> Parser Int64
forall (m :: * -> *) a. Monad m => a -> m a
return (Int64 -> Parser Int64)
-> (Word64 -> Int64) -> Word64 -> Parser Int64
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word64 -> Int64
forall a b. (Integral a, Num b) => a -> b
fromIntegral
int64be :: Int64 -> Parser Int64
int64be :: Int64 -> Parser Int64
int64be Int64
i = (Int64 -> Bool) -> Parser Int64 -> Parser Int64
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Int64
i Int64 -> Int64 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Int64
getInt64be
getWordHost :: Parser Word
getWordHost :: Parser Word
getWordHost = Int -> Parser Word
forall a. Storable a => Int -> Parser a
getPtr (Word -> Int
forall a. Storable a => a -> Int
sizeOf (Word
forall a. HasCallStack => a
undefined :: Word))
wordHost :: Word -> Parser Word
wordHost :: Word -> Parser Word
wordHost Word
w = (Word -> Bool) -> Parser Word -> Parser Word
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word
w Word -> Word -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word
getWordHost
getWord16host :: Parser Word16
getWord16host :: Parser Word16
getWord16host = Int -> Parser Word16
forall a. Storable a => Int -> Parser a
getPtr (Word16 -> Int
forall a. Storable a => a -> Int
sizeOf (Word16
forall a. HasCallStack => a
undefined :: Word16))
word16host :: Word16 -> Parser Word16
word16host :: Word16 -> Parser Word16
word16host Word16
w = (Word16 -> Bool) -> Parser Word16 -> Parser Word16
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word16
w Word16 -> Word16 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word16
getWord16host
getWord32host :: Parser Word32
getWord32host :: Parser Word32
getWord32host = Int -> Parser Word32
forall a. Storable a => Int -> Parser a
getPtr (Word32 -> Int
forall a. Storable a => a -> Int
sizeOf (Word32
forall a. HasCallStack => a
undefined :: Word32))
word32host :: Word32 -> Parser Word32
word32host :: Word32 -> Parser Word32
word32host Word32
w = (Word32 -> Bool) -> Parser Word32 -> Parser Word32
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word32
w Word32 -> Word32 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word32
getWord32host
getWord64host :: Parser Word64
getWord64host :: Parser Word64
getWord64host = Int -> Parser Word64
forall a. Storable a => Int -> Parser a
getPtr (Word64 -> Int
forall a. Storable a => a -> Int
sizeOf (Word64
forall a. HasCallStack => a
undefined :: Word64))
word64host :: Word64 -> Parser Word64
word64host :: Word64 -> Parser Word64
word64host Word64
w = (Word64 -> Bool) -> Parser Word64 -> Parser Word64
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word64
w Word64 -> Word64 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word64
getWord64host
getVarLenBe :: Parser Word64
getVarLenBe :: Parser Word64
getVarLenBe = Word64 -> Parser Word64
f Word64
0
where
f :: Word64 -> Parser Word64
f :: Word64 -> Parser Word64
f Word64
acc = do
Word64
w <- Parser Word8
getWord8 Parser Word8 -> (Word8 -> Parser Word64) -> Parser Word64
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Word64 -> Parser Word64
forall (m :: * -> *) a. Monad m => a -> m a
return (Word64 -> Parser Word64)
-> (Word8 -> Word64) -> Word8 -> Parser Word64
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral
if Word64 -> Int -> Bool
forall a. Bits a => a -> Int -> Bool
testBit Word64
w Int
7
then Word64 -> Parser Word64
f (Word64 -> Parser Word64) -> Word64 -> Parser Word64
forall a b. (a -> b) -> a -> b
$! (Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
shiftL Word64
acc Int
7) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|. (Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
clearBit Word64
w Int
7)
else Word64 -> Parser Word64
forall (m :: * -> *) a. Monad m => a -> m a
return (Word64 -> Parser Word64) -> Word64 -> Parser Word64
forall a b. (a -> b) -> a -> b
$! (Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
shiftL Word64
acc Int
7) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|. Word64
w
varLenBe :: Word64 -> Parser Word64
varLenBe :: Word64 -> Parser Word64
varLenBe Word64
a = (Word64 -> Bool) -> Parser Word64 -> Parser Word64
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word64
a Word64 -> Word64 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word64
getVarLenBe
getVarLenLe :: Parser Word64
getVarLenLe :: Parser Word64
getVarLenLe = do
Word64
w <- Parser Word8
getWord8 Parser Word8 -> (Word8 -> Parser Word64) -> Parser Word64
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Word64 -> Parser Word64
forall (m :: * -> *) a. Monad m => a -> m a
return (Word64 -> Parser Word64)
-> (Word8 -> Word64) -> Word8 -> Parser Word64
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Word8 -> Word64
forall a b. (Integral a, Num b) => a -> b
fromIntegral
if Word64 -> Int -> Bool
forall a. Bits a => a -> Int -> Bool
testBit Word64
w Int
7
then do
Word64
w' <- Parser Word64
getVarLenLe
Word64 -> Parser Word64
forall (m :: * -> *) a. Monad m => a -> m a
return (Word64 -> Parser Word64) -> Word64 -> Parser Word64
forall a b. (a -> b) -> a -> b
$! (Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
clearBit Word64
w Int
7) Word64 -> Word64 -> Word64
forall a. Bits a => a -> a -> a
.|. (Word64 -> Int -> Word64
forall a. Bits a => a -> Int -> a
shiftL Word64
w' Int
7)
else Word64 -> Parser Word64
forall (m :: * -> *) a. Monad m => a -> m a
return (Word64 -> Parser Word64) -> Word64 -> Parser Word64
forall a b. (a -> b) -> a -> b
$! Word64
w
varLenLe :: Word64 -> Parser Word64
varLenLe :: Word64 -> Parser Word64
varLenLe Word64
a = (Word64 -> Bool) -> Parser Word64 -> Parser Word64
forall a. (Show a, Eq a) => (a -> Bool) -> Parser a -> Parser a
expect (Word64
a Word64 -> Word64 -> Bool
forall a. Eq a => a -> a -> Bool
==) Parser Word64
getVarLenLe