23 unstable releases

0.14.1 Oct 13, 2024
0.14.0 Jun 7, 2024
0.13.3 Nov 29, 2023
0.11.2 May 15, 2023
0.2.0 Mar 24, 2021

#1537 in Procedural macros

Download history 19008/week @ 2024-10-04 18807/week @ 2024-10-11 21286/week @ 2024-10-18 19041/week @ 2024-10-25 16903/week @ 2024-11-01 17911/week @ 2024-11-08 19716/week @ 2024-11-15 19766/week @ 2024-11-22 19563/week @ 2024-11-29 18051/week @ 2024-12-06 18319/week @ 2024-12-13 12331/week @ 2024-12-20 7511/week @ 2024-12-27 16707/week @ 2025-01-03 20415/week @ 2025-01-10 16209/week @ 2025-01-17

62,002 downloads per month
Used in 160 crates (3 directly)

MIT license

240KB
6.5K SLoC

binrw_derive

Quick start for adding a new directive to binrw

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

  1. Add a keyword for the new directive in binrw::parser::keywords.
  2. Define the meta-type of the new directive in binrw::parser::attrs. If you need a new meta-type, add it to meta_types along with tests.
  3. If the new directive needs a special final type (e.g. CondEndian), add that to a new binrw::parser::types module and export it from binrw::parser::types. New types must ultimately implement binrw::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 binrw::parser::top_level_attrs and binrw::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 binrw::codegen::read_options and binrw::codegen::write_options.
  7. Add new integration tests in the binrw 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 binrw::parser::tests (in mod.rs) and add identical trybuild tests to the binrw crate’s tests/ui directory. (A nightly compiler is required to run the trybuild tests; see the comment in binrw::tests::ui for more detail.)

Dependencies

~1.5MB
~39K SLoC