Yui

Yui is an attribute reader for Rust.

Features

Attribute structure

Yui provides a derive macro YuiAttribute to create attribute structure by struct, StructStruct, TupleStruct and NoFieldStruct are all supported. ```rust use yui::YuiAttribute;

[derive(YuiAttribute)]

struct NoField;

[derive(YuiAttribute)]

struct Tuple(i32, String);

[derive(YuiAttribute)]

struct Struct { int: i32, float: f64, bool: bool, } ```

Types

```rust use yui::{YuiEnumValue, YuiAttribute};

[derive(YuiAttribute)]

struct Bar;

[derive(YuiEnumValue)]

enum SomeEnum { A, B }

[derive(YuiAttribute)]

struct Foo { pub string: String, pub bool: bool, pub int: i32, // or other integer types like u32 ... pub float: f32, // or other float types like f64 pub object: Bar, // any defined object #[attributefield(enumvalue=true)] pub enumfield: SomeEnum, // have to add enumvalue option pub list: Vec, // nested type of vec can`t be Object, Vec or HashMap pub map: std::collections::HashMap, pub optional: Option // optional field } ```

Options

Enum

Use derive YuiEnumValue on Enum to create a Enum value type. ```rust use yui::YuiEnumValue;

[derive(YuiEnumValue)]

enum SomeEnum { A, B } And then, the enum can be used as a field type. * `variant_value` attribute\ Customize a string corresponding value to variant(default is the snake case of variant name in Rust). rust use yui::YuiEnumValue;

[derive(YuiEnumValue)]

enum SomeEnum { #[variant_value("aaa")] // default is 'a' A, B } ```

Parse attributes with synandquote

yui::AttributeStructs<T> can be used in parse_macro_input! rust let attributes = syn::parse_macro_inpit!(input as yui::AttributeStructs<Foo>); If you want to parse attribute from syn::Meta, use yui::AttributeStruct::from_meta().\ And attribute structure with value can be convert to token automatically. But the visibility of each field must be public. ```rust use proc_macro::TokenStream;

[derive(YuiAttribute)]

struct Foo { #[attribute_field(default = 1024)] pub int32: i32 }

fn derivefn(input: TokenStream) -> TokenStream { let attributes = syn::parsemacro_input!(input as yui::AttributeStructs); let attrs = attributes.attrs;

TokenStream::from(quote::quote! {
    fn get_attrs() -> Vec<Foo> {
        vec![#(#attrs),*]
    }
})

} ```

Generate derive macro

If you want to use builtin reader generator, enable generate-reader feature. Macro generate_reader is used to generate a derive macro. ```rust use yui::generate_reader;

generated_reader!( MyDerive, [StructAttribute1, StructAttribute2], [FieldAttribute1, FieldAttribute2] );

`` The macro will generate a public derive, it can be use to read attributes ofstruct,enumorunion, and record the metadata by generateimpl` block.

Read attributes

Use the generated derive macro on a struct, and you can use the macro has_attribute and get_attributeto process attributes of the struct. The feature require nightly rustc because proc_macro_hygiene is required. ```rust

![feature(procmacrohygiene)]

use yui::{getattribute, hasattribute};

[derive(MyDerive)]

[StructAttribute1("some parameters")]

struct Foo { #[FieldAttribute1("some parameters")] field: i32 }

fn somefn() { assert!(hasattribute!(Foo, StructAttribute1)); assert!(hasattribute!(Foo::field, FieldAttribute1)); let structattr1: Option = getattribute!(Foo, StructAttribute1); let fieldattr1: Option = get_attribute!(Foo::field, StructAttribute1); } ```