pub struct Ruler<M, T> { /* private fields */ }Expand description
Ruler allows you to implement a plugin system with dependency management and ensure that your dependencies are called in the correct order.
You can use it like this:
use markdown_it::common::ruler::Ruler;
// this example prints "[ hello, world! ]",
// where each token is printed by separate closure
let mut chain = Ruler::<&str, fn (&mut String)>::new();
// define rules printing "hello" and "world"
chain.add("hello", |s| s.push_str("hello"));
chain.add("world", |s| s.push_str("world"));
// open bracket should be before "hello", and closing one after "world"
chain.add("open_bracket", |s| s.push_str("[ ")).before("hello");
chain.add("close_bracket", |s| s.push_str(" ]")).after("world");
// between "hello" and "world" we shall have a comma
chain.add("comma", |s| s.push_str(", ")).after("hello").before("world");
// after "world" we should have "!" as a first rule, but ensure "world" exists first
chain.add("bang", |s| s.push_str("!")).require("world").after("world").before_all();
// now we run this chain
let mut result = String::new();
for f in chain.iter() { f(&mut result); }
assert_eq!(result, "[ hello, world! ]");This data structure contains any number of elements (M, T), where T is any type and M (mark) is its identifier.
-
Mis used for ordering and dependency checking, it must implementEq + Copy + Hash + Debug. Common choices forMareu32,&'static str, or a specialSymboltype designed for this purpose. -
Tis any user-defined type. It’s usually a function or boxed trait.
Implementations
Trait Implementations
Auto Trait Implementations
impl<M, T> RefUnwindSafe for Ruler<M, T>where
M: RefUnwindSafe,
T: UnwindSafe + RefUnwindSafe,
impl<M, T> Send for Ruler<M, T>where
M: Send,
T: Send,
impl<M, T> Sync for Ruler<M, T>where
M: Sync,
T: Send + Sync,
impl<M, T> Unpin for Ruler<M, T>where
M: Unpin,
T: Unpin,
impl<M, T> UnwindSafe for Ruler<M, T>where
M: UnwindSafe,
T: UnwindSafe,
Blanket Implementations
sourceimpl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
sourcefn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait. Read more
sourcefn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait. Read more
sourcefn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s. Read more
sourcefn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s. Read more