This is a Derive
macro that trys to help reduce code duplication between the front and backend
when using futures-signals and dominator.
When using signals you have to wrap a lot of types in a Mutable
, MutableVec
, and MutableBTreeMap
which you likely don't want to have on your backend code. It will recursively trim away the following types from struct
fields:
Mutable<T>
-> T
MutableVec<T>
-> Vec<T>
MutableBTreeMap<K, V>
-> BTreeMap<K, V>
Rc<T>
-> T
Arc<T>
-> T
See the Container Attributes and Field Attributes section for some configuration options.
```rust use designal::Designal; use futuressignals::signal::Mutable; use futuressignals::signal_vec::MutableVec; use std::rc::Rc;
struct FlavoursSignal(MutableVec
struct TasteSignal {
salt: Mutable
struct HumanSignal {
#[designal(trim_end = "Signal")]
taste: Rc
Generates this code: ```rust
struct Flavours(Vec
struct Taste { salt: u32, sweet: bool, sour: i8, flavours: Flavours, }
struct Human { taste: Taste, name: (String, String), } ```
Every struct will need to have one of the renaming attributes rename
, add_start
, add_end
, trim_start
, or trim_end
.
#[designal(rename = "NewName")]
Renames the struct completely.
#[designal(add_start = "Prefix")]
Renames the struct by adding the string to the start of the struct identifier.
#[designal(add_end = "Postfix")]
Renames the struct by adding the string to the end of the struct identifier.
#[designal(trim_start = "Prefix")]
Renames the struct by removing the string from the start of the struct identifier.
#[designal(trim_end = "Postfix")]
Renames the struct by removing the string from the end of the struct identifier.
#[designal(derive = "Debug")]
Adds a derive attribute to the generated struct.
#[designal(cfg_feature = "your_feature")]
Adds a #[cfg(feature = "your_feature")]
attribute to the generated struct.
#[designal(keep_rc)]
Keeps any Rc
's used on any fields.
#[designal(keep_arc)]
Keeps any Arc
's used on any fields.
#[designal(hashmap)]
If any field is a MutableBTreeMap<K, V>
returns it as a HashMap<K, V>
rather than the default of BTreeMap<K, V>
.
#[designal(rename = "NewName")]
Renames the field's declared type completely.
#[designal(add_start = "Prefix")]
Renames the field's declared type by adding the string to the start of the field's declared type identifier.
#[designal(add_end = "Postfix")]
Renames the field's declared type by adding the string to the end of the field's declared type identifier.
#[designal(trim_start = "Prefix")]
Renames the field's declared type by removing the string from the start of the field's declared type identifier.
#[designal(trim_end = "Postfix")]
Renames the field's declared type by removing the string from the end of the field's declared type identifier.
#[designal(remove)]
Removes the field from the generated struct.
#[designal(ignore)]
Tells designal
to leave the field alone and return it as is.
#[designal(keep_rc)]
Keeps any Rc
's used in the field.
#[designal(keep_arc)]
Keeps any Arc
's used in the field.
#[designal(hashmap)]
If the field is a MutableBTreeMap<K, V>
returns it as a HashMap<K, V>
rather than the default of BTreeMap<K, V>
.