Struct FunctionRegistry

Source
pub struct FunctionRegistry { /* private fields */ }
Expand description

Registry for managing function handlers.

The function registry maintains a collection of named function handlers that can be called during expression evaluation. It supports both standalone functions and methods called on values.

This registry is a thread-safe singleton that ensures one-time initialization with all built-in functions registered.

Implementations§

Source§

impl FunctionRegistry

Source

pub fn get_instance() -> &'static RwLock<Self>

Get the global singleton instance of the function registry.

This method uses OnceLock to ensure thread-safe one-time initialization of the function registry with all built-in functions registered. Uses RwLock to allow multiple concurrent readers while ensuring exclusive access during writes.

§Returns

Returns a reference to the RwLock-protected singleton function registry.

§Example
use aimx::function_registry::FunctionRegistry;

let registry = FunctionRegistry::get_instance();
// Typically you'd use read_lock() or write_lock() instead of accessing directly
Source

pub fn read_lock() -> Result<RwLockReadGuard<'static, Self>>

Get a read lock on the function registry for function calls.

This is a convenience method that returns a read guard, allowing multiple concurrent function calls without blocking each other.

§Returns

Returns a Result containing the read guard or an error if the lock is poisoned.

§Example
use aimx::function_registry::FunctionRegistry;

let registry = FunctionRegistry::read_lock().unwrap();
// Use registry for function calls
Source

pub fn write_lock() -> Result<RwLockWriteGuard<'static, Self>>

Get a write lock on the function registry for registration.

This is a convenience method that returns a write guard, providing exclusive access for registering new functions.

§Returns

Returns a Result containing the write guard or an error if the lock is poisoned.

§Example
use aimx::{function_registry::FunctionRegistry, define_direct_function};

let mut registry = FunctionRegistry::write_lock().unwrap();
define_direct_function!(
    custom_func,
    args: [f64],
    |x: f64| x * 2.0
)(&mut *registry);
// Drop the lock to allow other threads to access the registry
Source

pub fn register<F>(&mut self, name: String, handler: F)
where F: FunctionHandler + 'static,

Register a function handler with the given name.

§Arguments
  • name - The name to register the function under
  • handler - The function handler implementation
§Example
use aimx::function_registry::{FunctionRegistry, FunctionHandler};
use aimx::{ContextLike, Value, Literal};
use anyhow::Result;

struct CustomHandler;
 
impl FunctionHandler for CustomHandler {
    fn call(&self, context: &mut dyn ContextLike, args: &[Value]) -> Result<Value> {
        Ok(Value::from(42.0))
    }
}
 
// In practice, you would typically register functions through the write_lock() method
// This example shows the trait implementation for documentation purposes
Source

pub fn function_call( &self, context: &mut dyn ContextLike, name: &str, arg: Value, ) -> Result<Value>

Call a standalone function with the given name and argument.

This method handles flattening array arguments into individual arguments before passing them to the function handler.

§Arguments
  • context - The evaluation context for closures
  • name - The name of the function to call
  • arg - The argument(s) to pass to the function (can be Empty, Literal, or Array)
§Returns

Returns a Result<Value> containing the function result or an error if the function is not found or execution fails.

§Example
// Call a function with a single argument
let result = registry.function_call(&mut context, "abs", Value::from(-5.0));

// Call a function with multiple arguments as an array
let args = Value::Array(vec![
    Box::new(Value::from(2.0)),
    Box::new(Value::from(3.0))
]);
let result = registry.function_call(&mut context, "pow", args);
Source

pub fn method_call( &self, context: &mut dyn ContextLike, name: &str, value: Value, arg: Value, ) -> Result<Value>

Call a method on a value with the given name and argument.

This method passes the target value as the first argument to the function handler, followed by any additional arguments.

§Arguments
  • context - The evaluation context for closures
  • name - The name of the method to call
  • value - The value on which to call the method
  • arg - The argument(s) to pass to the method (can be Empty, Literal, or Array)
§Returns

Returns a Result<Value> containing the method result or an error if the method is not found or execution fails.

§Example
// Call a method on an array value
let array_value = Value::Array(vec![
    Box::new(Value::from(1.0)),
    Box::new(Value::from(2.0)),
    Box::new(Value::from(3.0))
]);
let result = registry.method_call(&mut context, "sum", array_value, Value::Array(vec![]));

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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.

§

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

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. 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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> ErasedDestructor for T
where T: 'static,