# pa-field-parser A small library for “vertical parsing” of values. Traditional parsers are “horizontal” parsers, they take a flat list of tokens and produce structure:
[ token1 token2 token3 token4 token5 ]
----> horizontal parser
result:
- token1
|
`-- token2
|
`-- token3
|
`-- token 4 -- token 5
A `FieldParser` is a “vertical” parser. Once you have some low-level type in hand, usually you want to do some more checks, to “upgrade” it so to say:
Integer
^
| signedDecimal
|
Text
^
| utf8
|
ByteString
As a `FieldParser`, this would look like:
```haskell
utf8 :: FieldParser ByteString Text
signedDecimal :: FieldParser Text Integer
(utf8 >>> signedDecimal) :: FieldParser ByteString Integer
```
`>>>` is from `Control.Category`, but `Profunctor` is also available to map over the left and right arguments.
When run, this produces either a value or a helpful error message.
They can be freely combined with other libraries, and act as a nice adapter between them. For example, the JSON-related functions integrate with `aeson-better-errors` and any `FieldParser Value a` can be converted to a `FromJSON` instance for `aeson`. `attoparsec` is also available to easily turn bytes or text parsers into `FieldParser`s.
You can use this library as-is, but the design is easily adaptable to your codebase, the idea is very simple. Feel free to copy and paste what you need.