enum_coder

Crates.ioenum_coder
lib.rsenum_coder
version0.0.1
sourcesrc
created_at2019-05-29 19:02:08.899432
updated_at2021-12-31 08:42:14.680909
descriptionEnum coder macro. A syntancic sugar for generating lists of instructions, intermediate representations for compilers etc.
homepage
repositoryhttps://github.com/pczarn/enum_coder/
max_upload_size
id137742
size28,361
Peter Blackson (pczarn)

documentation

https://docs.rs/enum_coder/latest/enum_coder/

README

enum_coder

Enum coder macro. A syntancic sugar for generating lists of instructions, intermediate representations for compilers etc.

Input for the macro consists of one enum definition, followed by function definitions.

Attributes generate_list makes a generator of enum values. The function signature is fn f() -> Vec<T>.

Attribute missing_field marks the computation of default values for fields. Alternatively, the attribute can be written as missing_field(args, ...). Then, function signature is fn f(args, field_name: &str).

See examples for more.

enum_coder! {
    enum Instruction {
        Push(String),
        Concat(usize),
        ConcatSeparated(usize, String),
        Dup,
        Test,
        ConcatRef {
            ref_a: usize,
            ref_b: usize,
        },
    }

    #[generate_list]
    fn make_instructions() -> Vec<Instruction> {
        Push("hello".to_string());
        Push("world!".to_string());
        // ConcatSeparated(2, ", ".to_string());
        // or
        ConcatRef {
            ref_a: 0,
            ref_b: 1,
        };
        for _ in 0..10 {
            Dup()
        }
        Test();
        Concat(10 + 1)
    }
}

Documentation is available here: https://docs.rs/enum_coder/latest/enum_coder/

Commit count: 5

cargo fmt