Crates.io | rusticata-macros |
lib.rs | rusticata-macros |
version | 4.1.0 |
source | src |
created_at | 2017-02-20 20:19:04.799102 |
updated_at | 2022-02-07 10:59:17.467859 |
description | Helper macros for Rusticata |
homepage | https://github.com/rusticata/rusticata-macros |
repository | https://github.com/rusticata/rusticata-macros.git |
max_upload_size | |
id | 8606 |
size | 38,358 |
Helper macros for the rusticata project.
This crate contains some additions to nom.
For example, the [combinator::cond_else
] function allows to apply the first parser if the
condition is true, and the second if the condition is false:
use rusticata_macros::combinator::cond_else;
let r: IResult<_, _, ()> = cond_else(
|| s.len() > 1,
be_u16,
map(be_u8, u16::from)
)(s);
See the documentation for more details and examples.
Different versions of this crate are available, depending on nom version.
rusticata-macros
4.x depends on nom 7rusticata-macros
3.x depends on nom 6rusticata-macros
2.x depends on nom 5Crate is documented, do running cargo doc
will crate the offline documentation.
Reference documentation can be found here
slice_fixed
be_var_u64
and le_var_u64
Serialize
for structures serializationq
(quote) and align32
upgrade_error
and upgrade_error_to
custom_check
flat_take
newtype_enum
parse_uint24
as deprecatedLicensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.