2021-10-09 20:09:21 +00:00
|
|
|
# Formaty
|
2022-04-09 19:53:14 +00:00
|
|
|
A simple configurable binary data parser. Data structures are described using TOML files.
|
2021-10-09 20:09:21 +00:00
|
|
|
|
2022-04-09 19:53:14 +00:00
|
|
|
## Formats
|
|
|
|
All formats in [formats](./formats) are included in the `formaty` binary. See [formats.md](./formats/formats.md) for
|
|
|
|
more info.
|
2021-10-09 20:09:21 +00:00
|
|
|
|
2022-04-10 16:42:05 +00:00
|
|
|
### Configuration
|
|
|
|
|
|
|
|
#### Format
|
|
|
|
A format is a collection of fields that describe the structure of data, so it can be parsed
|
|
|
|
|
|
|
|
Members:
|
|
|
|
* `name` - name of the format, used as the argument when selecting the format to parse the data as
|
|
|
|
* `bit_flip` - should individual bytes have their bits flipped within, individual fields can override this
|
|
|
|
* `fields` - 1 or more fields to describe the structure of the data
|
|
|
|
|
|
|
|
#### Field
|
|
|
|
A field is a collection of bits that make up some sort of data. Formaty supports `Int`/`Uint` of arbitrary size,
|
2022-05-04 02:12:54 +00:00
|
|
|
`Float`, `Double`, `Strings` and `Bytes`. This data does not need to be byte aligned.
|
2022-04-10 16:42:05 +00:00
|
|
|
|
|
|
|
Members:
|
|
|
|
* `name` - the name of the field, used while displaying data
|
|
|
|
* `field_type` - the type of the field and associated data
|
|
|
|
* `print_type` - how to print the data, if not provided it uses the default print for a type
|
|
|
|
* `bit_flip` - overrides the global bit flip field, defaults to false if not provided
|
|
|
|
|
|
|
|
#### Field Types
|
|
|
|
* `UInt`/`Int`: standard integer types. Unsigned or signed respectively. Can be 1 or more bits.
|
|
|
|
* `bit_width`: number of bits composing the integer
|
|
|
|
* `endianess`: byte ordering of the field
|
|
|
|
* `Float`/`Double`: Standard float point types of 32-bit or 64-bit width
|
|
|
|
* `endianess`: byte ordering of the field
|
|
|
|
* `String`: Collection of bytes ended by a null character '\0'
|
|
|
|
* `max_len`: max length of the data
|
|
|
|
* `endianess`: byte ordering of the field
|
|
|
|
* `Bytes`: Collection of bytes with no termination
|
|
|
|
* `max_len`: max number of bytes
|
|
|
|
* `endianess`: byte ordering of the field
|
2022-06-19 20:08:37 +00:00
|
|
|
* `Format`: Allows formats to include other formats
|
|
|
|
* `format_name`: Format definition to use
|
2022-04-10 16:42:05 +00:00
|
|
|
|
|
|
|
#### Example Config
|
|
|
|
[Example](./formats/example.toml)
|
|
|
|
|
2022-04-09 19:53:14 +00:00
|
|
|
## Example
|
2021-10-09 20:09:21 +00:00
|
|
|
```bash
|
2022-04-09 19:53:14 +00:00
|
|
|
./formaty ccsds "[0xe0, 0xa1, 0xc0, 0x00, 0x00, 0x05, 0x01, 0x02, 0x03, 0x04, 0x05]"
|
2021-10-09 20:09:21 +00:00
|
|
|
````
|
|
|
|
|
|
|
|
Output:
|
|
|
|
```
|
|
|
|
Version Number: 0
|
2022-04-09 19:53:14 +00:00
|
|
|
Packet Type: 1
|
2021-10-09 20:09:21 +00:00
|
|
|
Secondary Header Flag: 0
|
2022-04-09 19:53:14 +00:00
|
|
|
APID: 0x200
|
|
|
|
Sequence Flags: 3
|
|
|
|
Packet Sequence Count: 0
|
2021-10-09 20:09:21 +00:00
|
|
|
Data Length: 5
|
|
|
|
Data: [1, 2, 3, 4, 5]
|
|
|
|
```
|
|
|
|
|
|
|
|
## Help
|
|
|
|
```
|
|
|
|
Formaty 0.1.0
|
|
|
|
Arbitrary Binary Data Formatting
|
|
|
|
|
|
|
|
USAGE:
|
2022-05-08 00:35:06 +00:00
|
|
|
formaty [FLAGS] [OPTIONS] <format> [data]...
|
2021-10-09 20:09:21 +00:00
|
|
|
|
|
|
|
FLAGS:
|
2022-04-22 01:53:02 +00:00
|
|
|
-h, --help Prints help information
|
2022-05-08 00:35:06 +00:00
|
|
|
-s, --stdin Input data from stdin
|
2022-04-22 01:53:02 +00:00
|
|
|
-V, --version Prints version information
|
2021-10-09 20:09:21 +00:00
|
|
|
|
2022-04-09 19:53:14 +00:00
|
|
|
OPTIONS:
|
2022-05-04 02:11:54 +00:00
|
|
|
-b, --base <base> Base of the input values
|
|
|
|
-c, --config <config> Path to the format config [env: FORMATY_CONFIG=]
|
|
|
|
-g, --global_config <global-config> Path to the global config directory [env: FORMATY_GLOBAL_CONFIG=]
|
2022-05-08 00:35:06 +00:00
|
|
|
-f, --file <input-file> Input data from file
|
2022-05-04 02:11:54 +00:00
|
|
|
-i, --input_type <input-type> Input data type [default: array]
|
2022-04-09 19:53:14 +00:00
|
|
|
|
2021-10-09 20:09:21 +00:00
|
|
|
ARGS:
|
2022-04-22 01:53:02 +00:00
|
|
|
<format> Format to parse data as
|
|
|
|
<data>... Raw data
|
2021-10-09 20:09:21 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
## License
|
|
|
|
[License](./LICENSE)
|