flatparse-0.5.3.1: High-performance parsing from strict bytestrings
Safe HaskellNone
LanguageHaskell2010

FlatParse.Stateful.Integers

Description

Machine integer parsers.

Synopsis

Native byte order

anyWord8 :: forall (st :: ZeroBitType) r e. ParserT st r e Word8 Source #

Parse any Word8.

anyWord16 :: forall (st :: ZeroBitType) r e. ParserT st r e Word16 Source #

Parse any Word16 (native byte order).

anyWord32 :: forall (st :: ZeroBitType) r e. ParserT st r e Word32 Source #

Parse any Word32 (native byte order).

anyWord64 :: forall (st :: ZeroBitType) r e. ParserT st r e Word64 Source #

Parse any Word64 (native byte order).

anyInt8 :: forall (st :: ZeroBitType) r e. ParserT st r e Int8 Source #

Parse any Int8.

anyInt16 :: forall (st :: ZeroBitType) r e. ParserT st r e Int16 Source #

Parse any Int16 (native byte order).

anyInt32 :: forall (st :: ZeroBitType) r e. ParserT st r e Int32 Source #

Parse any Int32 (native byte order).

anyInt64 :: forall (st :: ZeroBitType) r e. ParserT st r e Int64 Source #

Parse any Int64 (native byte order).

anyWord :: forall (st :: ZeroBitType) r e. ParserT st r e Word Source #

Parse any Word (native size).

anyInt :: forall (st :: ZeroBitType) r e. ParserT st r e Int Source #

Parse any Int (native size).

Explicit endianness

Native endianness parsers are used where possible. For non-native endianness parsers, we parse then use the corresponding byteSwapX function. On x86, this is inlined as a single BSWAP instruction.

anyWord16le :: forall (st :: ZeroBitType) r e. ParserT st r e Word16 Source #

Parse any Word16 (little-endian).

anyWord16be :: forall (st :: ZeroBitType) r e. ParserT st r e Word16 Source #

Parse any Word16 (big-endian).

anyWord32le :: forall (st :: ZeroBitType) r e. ParserT st r e Word32 Source #

Parse any Word32 (little-endian).

anyWord32be :: forall (st :: ZeroBitType) r e. ParserT st r e Word32 Source #

Parse any Word32 (big-endian).

anyWord64le :: forall (st :: ZeroBitType) r e. ParserT st r e Word64 Source #

Parse any Word64 (little-endian).

anyWord64be :: forall (st :: ZeroBitType) r e. ParserT st r e Word64 Source #

Parse any Word64 (big-endian).

anyInt16le :: forall (st :: ZeroBitType) r e. ParserT st r e Int16 Source #

Parse any Int16 (little-endian).

anyInt16be :: forall (st :: ZeroBitType) r e. ParserT st r e Int16 Source #

Parse any Int16 (big-endian).

anyInt32le :: forall (st :: ZeroBitType) r e. ParserT st r e Int32 Source #

Parse any Int32 (little-endian).

anyInt32be :: forall (st :: ZeroBitType) r e. ParserT st r e Int32 Source #

Parse any Int32 (big-endian).

anyInt64le :: forall (st :: ZeroBitType) r e. ParserT st r e Int64 Source #

Parse any Int64 (little-endian).

anyInt64be :: forall (st :: ZeroBitType) r e. ParserT st r e Int64 Source #

Parse any Int64 (big-endian).

Value assertions

word8 :: forall (st :: ZeroBitType) r e. Word8 -> ParserT st r e () Source #

Read the next 1 byte and assert its value as a Word8.

CPS parsers

withAnyWord8 :: forall (st :: ZeroBitType) r e ret. (Word8 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Word8 (CPS).

withAnyWord16 :: forall (st :: ZeroBitType) r e ret. (Word16 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Word16 (native byte order) (CPS).

withAnyWord32 :: forall (st :: ZeroBitType) r e ret. (Word32 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Word32 (native byte order) (CPS).

withAnyWord64 :: forall (st :: ZeroBitType) r e ret. (Word64 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Word64 (native byte order) (CPS).

withAnyInt8 :: forall (st :: ZeroBitType) r e ret. (Int8 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Int8 (CPS).

withAnyInt16 :: forall (st :: ZeroBitType) r e ret. (Int16 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Int16 (native byte order) (CPS).

withAnyInt32 :: forall (st :: ZeroBitType) r e ret. (Int32 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Int32 (native byte order) (CPS).

withAnyInt64 :: forall (st :: ZeroBitType) r e ret. (Int64 -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Int64 (native byte order) (CPS).

withAnyWord :: forall (st :: ZeroBitType) r e ret. (Word -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Word (native size) (CPS).

withAnyInt :: forall (st :: ZeroBitType) r e ret. (Int -> ParserT st r e ret) -> ParserT st r e ret Source #

Parse any Int (native size) (CPS).

Unsafe

These unsafe parsers and helpers may be useful for efficient parsing in special situations e.g. you already know that the input has enough bytes. You should only use them if you can assert their necessary guarantees (see the individual function documentation).

anyWord8Unsafe :: forall (st :: ZeroBitType) r e. ParserT st r e Word8 Source #

Unsafely parse any Word8, without asserting the input is non-empty.

The caller must guarantee that the input has enough bytes.

Value assertions

word8Unsafe :: forall (st :: ZeroBitType) r e. Word8 -> ParserT st r e () Source #

Unsafely read the next 1 byte and assert its value as a Word8.

The caller must guarantee that the input has enough bytes.

word16Unsafe :: forall (st :: ZeroBitType) r e. Word16 -> ParserT st r e () Source #

Unsafely read the next 2 bytes and assert their value as a Word16 (native byte order).

The caller must guarantee that the input has enough bytes.

word32Unsafe :: forall (st :: ZeroBitType) r e. Word32 -> ParserT st r e () Source #

Unsafely read the next 4 bytes and assert their value as a Word32. (native byte order).

The caller must guarantee that the input has enough bytes.

word64Unsafe :: forall (st :: ZeroBitType) r e. Word64 -> ParserT st r e () Source #

Unsafely read the next 8 bytes and assert their value as a Word64. (native byte order).

The caller must guarantee that the input has enough bytes.

Helper definitions

withAnySized# :: forall a (st :: ZeroBitType) r e ret. Int# -> (Addr# -> Int# -> a) -> (a -> ParserT st r e ret) -> ParserT st r e ret Source #

Helper for defining CPS parsers for types of a constant byte size (i.e. machine integers).

Call this with an indexXYZOffAddr primop (e.g. indexWord8OffAddr) and the size in bytes of the type you're parsing.

withAnySizedUnsafe# :: forall a (st :: ZeroBitType) r e ret. Int# -> (Addr# -> Int# -> a) -> (a -> ParserT st r e ret) -> ParserT st r e ret Source #

Unsafe helper for defining CPS parsers for types of a constant byte size (i.e. machine integers).

Is really just syntactic sugar for applying the given parser and shifting the buffer along.

The caller must guarantee that the input has enough bytes.

sizedUnsafe# :: forall a (st :: ZeroBitType) r e. Eq a => Int# -> (Addr# -> Int# -> a) -> a -> ParserT st r e () Source #

Unsafe helper for defining parsers for types of a constant byte size (i.e. machine integers) which assert the parsed value's... value.

Call this with an indexXYZOffAddr primop (e.g. indexWord8OffAddr), the size in bytes of the type you're parsing, and the expected value to test the parsed value against.

The caller must guarantee that the input has enough bytes.