Struct FunctionOverloads

Source
pub struct FunctionOverloads<T>(/* private fields */);
Expand description

Collection of function overloads grouped by argument kinds.

FunctionOverloads<T> manages multiple function overloads that share the same name but have different argument signatures. This allows CEL to support function overloading based on argument types, similar to many programming languages.

§Type Parameters

  • T: The type of function stored (implementation, declaration, or either)

§Examples

use cel_cxx::function::{FunctionOverloads, FunctionDeclOrImpl};

let mut overloads = FunctionOverloads::<FunctionDeclOrImpl>::new();
// Add different overloads for the same function name

Implementations§

Source§

impl<T: FunctionTypeOverload> FunctionOverloads<T>

Source

pub fn new() -> Self

Creates a new empty function overload collection.

Source

pub fn find( &self, member: bool, kinds: &[Kind], ) -> Option<&FunctionKindOverload<T>>

Finds a function overload by member type and argument kinds.

§Parameters
  • member: Whether to find member functions (true) or global functions (false)
  • kinds: Argument kinds to match
§Returns

Returns Some(&FunctionKindOverload) if found, None otherwise

Source

pub fn find_mut( &mut self, member: bool, kinds: &[Kind], ) -> Option<&mut FunctionKindOverload<T>>
where T: Send + Sync,

Finds a mutable reference to a function overload by member flag and argument kinds.

§Parameters
  • member: Whether to search for member functions
  • kinds: Argument kinds to match
§Returns

Mutable reference to the matching overload, or None if not found

Source

pub fn entries(&self) -> impl Iterator<Item = &FunctionKindOverload<T>>

Returns an iterator over all function overloads.

§Examples
use cel_cxx::function::{FunctionOverloads, FunctionDeclOrImpl};

let overloads = FunctionOverloads::<FunctionDeclOrImpl<'_>>::new();
for overload in overloads.entries() {
    // Process each overload
}
Source

pub fn entries_mut( &mut self, ) -> impl Iterator<Item = &mut FunctionKindOverload<T>>

Returns a mutable iterator over all function overloads.

Source

pub fn clear(&mut self)

Clears all function overloads.

Source

pub fn remove<I, K>(&mut self, member: bool, args: I) -> Result<(), Error>
where I: IntoIterator<Item = K>, K: Into<Kind>,

Removes a function overload by member flag and argument kinds.

§Parameters
  • member: Whether to remove member functions
  • args: Argument kinds to match for removal
§Returns

Ok(()) if removal was successful, Err(Error) if not found

Source§

impl<'f> FunctionOverloads<FunctionDeclOrImpl<'f>>

Source

pub fn add_impl( &mut self, member: bool, f: Function<'f>, ) -> Result<&mut Self, Error>

Adds a function implementation to the overloads.

This method adds a concrete function implementation to the appropriate overload group based on its signature. If no matching overload exists, a new one is created.

§Arguments
  • member - Whether this is a member function
  • f - The function implementation to add
§Returns

Ok(&mut Self) for method chaining, or Err(Error) if addition fails

§Errors

Returns error if the function signature conflicts with existing registrations.

Source

pub fn add_decl( &mut self, member: bool, f: FunctionType, ) -> Result<&mut Self, Error>

Adds a function declaration to the overloads.

This method adds a function type signature (declaration) to the appropriate overload group. Declarations provide type information for compile-time checking without requiring an implementation.

§Arguments
  • member - Whether this is a member function declaration
  • f - The function type signature to add
§Returns

Ok(&mut Self) for method chaining, or Err(Error) if addition fails

§Errors

Returns error if the function signature conflicts with existing registrations.

Source§

impl<'f> FunctionOverloads<Function<'f>>

Source

pub fn add(&mut self, member: bool, f: Function<'f>) -> Result<&mut Self, Error>

Adds a function to the overloads.

This method adds a function to the appropriate overload group based on its signature. This is used when working with pure function implementations without separate declarations.

§Arguments
  • member - Whether this is a member function
  • f - The function to add
§Returns

Ok(&mut Self) for method chaining, or Err(Error) if addition fails

§Errors

Returns error if the function signature conflicts with existing registrations.

Trait Implementations§

Source§

impl<T: Clone> Clone for FunctionOverloads<T>

Source§

fn clone(&self) -> FunctionOverloads<T>

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

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

Performs copy-assignment from source. Read more
Source§

impl<T: Debug> Debug for FunctionOverloads<T>

Source§

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

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

impl<T: Default> Default for FunctionOverloads<T>

Source§

fn default() -> FunctionOverloads<T>

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

Auto Trait Implementations§

§

impl<T> Freeze for FunctionOverloads<T>

§

impl<T> RefUnwindSafe for FunctionOverloads<T>
where T: RefUnwindSafe,

§

impl<T> Send for FunctionOverloads<T>
where T: Send,

§

impl<T> Sync for FunctionOverloads<T>
where T: Sync,

§

impl<T> Unpin for FunctionOverloads<T>
where T: Unpin,

§

impl<T> UnwindSafe for FunctionOverloads<T>
where T: UnwindSafe,

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> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

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

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

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.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
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> WithSubscriber for T

Source§

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
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

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