Expand description
This crate provides attribute-like macros to override trait methods with other traits for a structs or another trait.
§Install
In Cargo.toml, write this crate as a dependency.
[dependencies]
override_macro = "0.1.1"§Usage
First, by using overridable attribute-macro, collects trait information whose methods
override other trait’s methods and are overridden with methods of other traits.
The argument of this attribute-macro is to specify the module path. This argument is optional but it is better to specify it because the trait name may be conflict to other traits.
Next, by using override_with attribute-macro, adds overridiing methods of the target trait
for a struct or a trait.
The arguments of this attribute-macro are paths of traits having overriding methods. This attribute-macro searches for methods with the same sigunature to the methods in the target trait from the traits passed as the arguments, and then adds these method callings to the target trait.
use override_macro::{overridable, override_with};
#[overridable]
trait Trait0 {
fn method0(&self) -> bool;
fn method1(&self, b: bool) -> u64;
}
mod module_a {
use override_macro::{overridable, override_with};
#[overridable(mod = module_a)]
pub trait Trait1 {
fn method0(&self) -> bool { true }
}
pub mod module_b {
use override_macro::{overridable, override_with};
#[overridable(mod = module_a::module_b)]
pub trait Trait2 {
fn method1(&self, _b: bool) -> u64 { 123 }
}
}
}
struct Struct0;
impl module_a::Trait1 for Struct0 {}
impl module_a::module_b::Trait2 for Struct0 {}
#[override_with(module_a::Trait1, module_a::module_b::Trait2)]
impl Trait0 for Struct0 {
// The following method is added automatically by this attribute-macro
// fn method0(&self) -> bool {
// module_a::Trait1::method0(self)
// }
// fn method1(&self, _b: bool) -> u64 {
// module_a::module_b::Trait1::method1(self, _b)
// }
}Attribute Macros§
- overridable
- Collects trait informations whose methods can override other trait methods, or can be overriden with other trait methods.
- override_
with - Adds methods overridden methods with methods of other traits to the trait implementation.