Skip to main content

Templates

Struct Templates 

Source
pub struct Templates(/* private fields */);
Expand description

Structure holding string templates to replace in rules. Templating mechanism allow to define once complex regex and use them at multiple places in rules, making rule maintenance easier.

§Example

use gene::Compiler;

let mut c = Compiler::new();

/// loading template from string
c.load_templates_from_str(
    r#"
some_template: hello world
"#,
)
.unwrap();

c.load_rules_from_str(
    r#"
name: test
matches:
    $m: .data.path == '{{some_template}}'
"#,
).unwrap();

/// we verify our template has been replaced
assert_eq!(
    c.rules()
        .unwrap()
        .first()
        .unwrap()
        .matches
        .as_ref()
        .unwrap()
        .get("$m")
        .unwrap(),
    &String::from(".data.path == 'hello world'")
);

Implementations§

Source§

impl Templates

Source

pub fn new() -> Self

Creates a new, empty template collection.

Returns a Templates instance with no template variables defined. This is equivalent to calling Templates::default().

Source

pub fn insert(&mut self, name: String, template: String) -> Result<(), Error>

Inserts a new template variable into this collection.

Adds a name-template pair that can be used for substitution in rule match expressions. Template placeholders in the format {{name}} will be replaced with the provided template value when the rule is processed.

§Errors

Returns Error::Duplicate if a template with the same name already exists in this collection. This prevents accidental overwrites of existing templates.

Source

pub fn extend(&mut self, o: &Self) -> Result<(), Error>

Extends this template collection with templates from another collection.

Merges all templates from the provided collection into this one. If any template names conflict, an error is returned and no templates are added.

This method is useful for composing template collections from multiple sources or applying base templates with overrides.

§Errors

Returns Error::Duplicate if any template name in the source collection already exists in this collection. The operation is atomic - if any duplicate is found, no templates are added.

Source

pub fn replace(&self, r: &mut Rule)

Replaces template placeholders in a rule’s match expressions.

Iterates through all match expressions in the rule and replaces any template placeholders (in the format {{name}}) with their corresponding values from this collection. This allows for dynamic rule configuration through templates.

§Behavior
  • Only affects the matches section of the rule
  • Placeholders are replaced in-place in the match expressions
  • If a template name is not found, the placeholder remains unchanged
  • Multiple occurrences of the same template are all replaced
§Examples
use gene::Templates;
use gene::rules::Rule;

let mut rule: Rule = serde_yaml::from_str(
    "name: test\nmatches:\n  $a: .path == \"{{path}}\"\ncondition: $a"
).unwrap();

let mut templates = Templates::new();
templates.insert("path".to_string(), "/var/log/".to_string()).unwrap();

templates.replace(&mut rule);
// rule.matches now contains ".path == \"/var/log/\""
Source

pub fn len(&self) -> usize

Returns the number of template variables in this collection.

This method returns the count of key-value pairs stored in the templates. It provides a way to determine how many template variables are available for substitution in rules.

Source

pub fn is_empty(&self) -> bool

Returns true if this collection contains no template variables.

This is a convenience method that checks if the number of templates is zero. It’s equivalent to self.len() == 0 but may be more readable in some contexts.

Trait Implementations§

Source§

impl Clone for Templates

Source§

fn clone(&self) -> Templates

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Templates

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Templates

Source§

fn default() -> Templates

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for Templates

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl From<HashMap<String, String>> for Templates

Source§

fn from(value: HashMap<String, String>) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,