tmpl-resolver 0.0.14

A lightweight template resolution engine with conditional logic support
Documentation
use crate::{
  TemplateResolver,
  resolver::{OrderedAST, TemplateAST},
};

impl TemplateResolver {
  /// Converts the resolver into a BTreeMap.
  ///
  /// An ordered BTreeMap is useful when you need to serialize the
  /// TemplateResolver to a configuration file or a binary file.
  ///
  /// ## Example
  ///
  /// ```
  /// use tmpl_resolver::TemplateResolver;
  ///
  /// let resolver = TemplateResolver::default();
  /// let _map = resolver.into_btree_map();
  /// ```
  pub fn into_btree_map(self) -> OrderedAST {
    self.into()
  }

  /// Takes ownership of the Self and returns the inner data
  /// (template AST)
  ///
  /// ## Example
  ///
  /// ```
  /// use tmpl_resolver::TemplateResolver;
  ///
  /// let resolver = TemplateResolver::default();
  /// let _inner_data = resolver.into_inner();
  /// ```
  pub fn into_inner(self) -> TemplateAST {
    self.0
  }
}

/// Converts the resolver into an ordered abstract syntax tree (AST)
/// representation.
///
/// ## Feature-dependent Behavior
///
/// - ​**With `std` feature**: Converts internal storage to a
///   [`alloc::collections::BTreeMap`]-backed ordered AST through iterative
///   collection. This guarantees deterministic ordering.
/// - ​**Without `std` feature**: Directly returns the pre-ordered AST structure
///   without conversion, optimized for no_std environments.
impl From<TemplateResolver> for OrderedAST {
  fn from(value: TemplateResolver) -> Self {
    #[cfg(feature = "std")]
    {
      value
        .into_inner()
        .into_iter()
        .collect()
    }

    #[cfg(not(feature = "std"))]
    {
      value.into_inner()
    }
  }
}