12 stable releases

2.1.0 Aug 25, 2021
2.0.0 Mar 18, 2021
1.4.3 Jan 12, 2021
1.4.2 Nov 29, 2020
1.0.2 Jun 26, 2020

#6 in #attrs

Download history 13322/week @ 2024-07-24 11381/week @ 2024-07-31 11378/week @ 2024-08-07 11702/week @ 2024-08-14 13627/week @ 2024-08-21 12712/week @ 2024-08-28 12718/week @ 2024-09-04 12396/week @ 2024-09-11 10410/week @ 2024-09-18 11157/week @ 2024-09-25 11935/week @ 2024-10-02 10625/week @ 2024-10-09 11991/week @ 2024-10-16 12071/week @ 2024-10-23 11783/week @ 2024-10-30 8820/week @ 2024-11-06

46,645 downloads per month
Used in 257 crates (via binread)

MIT license

98KB
3K SLoC

binread_derive

Quick start for adding a new directive to BinRead

In all cases, look to existing directives to follow established code and test conventions.

  1. Add a keyword for the new directive in parser::keywords.
  2. Define the meta-type of the new directive in parser::attrs. If you need a new meta-type, add it to parser::meta_types along with tests.
  3. If the new directive needs a special final type (e.g. CondEndian), add that to a new parser::types module and export it from parser::types. New types must ultimately implement parser::TrySet, but can sometimes do so more simply (using trait generic impls) by implementing From or TryFrom instead.
  4. Add the new directive as a field to the relevant structs in parser::top_level_attrs and parser::field_level_attrs.
  5. If the new directive combines with other directives in ways that may be invalid, and the relationship cannot be expressed using an enum type (e.g. ReadMode), add validation in either FromInput::push_field (if the validation can occur immediately after the field is constructed) or FromInput::validate (if it can only be validated after the entire struct has been parsed).
  6. Use the new fields to emit code in the appropriate places in codegen::read_options.
  7. Add new integration tests in the binread crate’s tests directory.
  8. If the new directive generates new errors (e.g. from validation), add unit tests to validate those code paths in parser::tests (in mod.rs) and add identical trybuild tests to the binread crate’s tests/ui directory. (A nightly compiler is required to run the trybuild tests; see the comment in binread::tests::ui for more detail.)

Dependencies

~1.5MB
~37K SLoC