pub struct Map(pub Option<&'static Expr>);
Expand description
A struct representing a mapping configuration for expressions.
This structure contains a single field, an optional reference to a static Expr
instance.
The Option
type encapsulates the possibility of this reference being None
, indicating that the mapping may or may not point to a valid expression at any given time.
This flexibility allows for dynamic adjustments within the synthesis process, where certain mappings might be deferred or omitted based on the current context or requirements.
Tuple Fields§
§0: Option<&'static Expr>
Implementations§
Source§impl Map
impl Map
Sourcepub fn from_config(config: &Config) -> Self
pub fn from_config(config: &Config) -> Self
Creates a Map
instance using the provided configuration.
It retrieves an expression associated with the key "f"
from the given Config
object, which may be None
if the key is not found, and wraps this expression in a Map
.
This function assists in initializing a Map
based on pre-defined configurations, facilitating customizable synthesis processes.
Sourcepub fn name() -> &'static str
pub fn name() -> &'static str
Provides a method to retrieve the name associated with the Map
.
It returns a static string slice representing the operation’s name within the context of the Synthphonia module, specifically identifying the list.map
functionality.
This method is likely used to ensure consistency and readability when referring to the mapping operation internally or in debug outputs.
Trait Implementations§
Source§impl Default for Map
impl Default for Map
Source§fn default() -> Self
fn default() -> Self
Creates a default instance of the type by invoking the from_config
method with a default configuration.
This method serves as a convenient way to generate an instance with standard settings, ensuring that if no specific configuration is provided, the type is still initialized in a consistent manner using default parameters.
Source§impl Display for Map
impl Display for Map
Source§fn fmt(&self, f: &mut Formatter<'_>) -> Result
fn fmt(&self, f: &mut Formatter<'_>) -> Result
Formats the Map
structure for output.
The function checks if the Map
contains an Expr
and, if so, formats the output to include the expression with a “list.map” prefix decorated by the expression’s debug representation.
If no expression is present, the output simply includes “list.map”.
This functionality is useful for logging or debugging when visual representation of the mapping operation is required.
Source§impl Enumerator1 for Map
impl Enumerator1 for Map
Source§fn enumerate(
&self,
this: &'static Op1Enum,
exec: &'static Executor,
opnt: [usize; 1],
) -> Result<(), ()>
fn enumerate( &self, this: &'static Op1Enum, exec: &'static Executor, opnt: [usize; 1], ) -> Result<(), ()>
Provides a method for the Map
structure to perform enumeration with given parameters, but currently returns a placeholder result.
This method, enumerate
, takes as parameters a reference to an instance of Op1Enum
, a static reference to an Executor
, and an array of one usize operand.
However, in its current implementation, it performs no actual enumeration or transformation logic and immediately returns a successful Result
wrapped in Ok(())
with an empty tuple as the error state.
This suggests that further enhancements or a use-case-specific implementation might be forthcoming for this structure within the application’s context.
Source§impl Hash for Map
impl Hash for Map
Source§fn hash<H: Hasher>(&self, state: &mut H)
fn hash<H: Hasher>(&self, state: &mut H)
Provides a method to calculate the hash of the Map
structure.
The method takes a mutable reference to a generic hasher H
and computes the hash by first accessing the internal Option<&'static Expr>
value.
If the Option
is Some
, it maps the contained expression reference to a raw pointer and incorporates it into the hash calculation.
This ensures that the hashing process uniquely accounts for the memory address of the expression’s reference, enhancing the precision of hash-based collections or algorithms using Map
instances.
Source§impl Op1 for Map
impl Op1 for Map
Source§fn cost(&self) -> usize
fn cost(&self) -> usize
Calculates and returns the cost of the operation as a constant value.
In this implementation, the method consistently returns 1
, indicating a fixed cost for any instance of the struct, regardless of the contents of the Option<&'static Expr>
field.
This could be useful for basic cost computation scenarios where each Map
instance contributes a uniform cost in the overall synthesis process.
Source§fn try_eval(&self, a1: Value) -> (bool, Value)
fn try_eval(&self, a1: Value) -> (bool, Value)
Provides a method to evaluate an expression contained within a Map
structure using a given Value
.
If the input Value
is of the type ListStr
, it iterates over the list, creating a context for each string element that includes the length of the string and the string itself.
The expression is then evaluated within this context, converting the result to a string.
The output Value
is adjusted to be a collection of these string results, and the method returns a tuple indicating success with a true
boolean and the resultant Value
.
If the input Value
is not a ListStr
, the method returns false
and a Null
Value
.
impl Copy for Map
impl Eq for Map
impl StructuralPartialEq for Map
Auto Trait Implementations§
impl Freeze for Map
impl RefUnwindSafe for Map
impl Send for Map
impl Sync for Map
impl Unpin for Map
impl UnwindSafe for Map
Blanket Implementations§
Source§impl<T> AllocForAny<T> for T
impl<T> AllocForAny<T> for T
Source§fn galloc(self) -> &'static T
fn galloc(self) -> &'static T
Provides a method to allocate an instance of T
on the heap with a static lifetime.
This implementation of galloc
takes ownership of the T
instance and uses the alloc
function to place it in a location with a static lifetime, presumably managing it in a way that ensures its persistence for the duration of the program.
This can be particularly useful for scenarios where a static lifetime is required, such as when interfacing with systems or patterns that necessitate global state or long-lived data.
Source§fn galloc_mut(self) -> &'static T
fn galloc_mut(self) -> &'static T
Provides a method that moves the instance and returns a reference to it allocated with a static lifetime.
This method utilizes alloc_mut
to perform the allocation, likely involving allocating the resource in a manner that ensures it lives for the entire duration of the application.
These semantics allow the user to safely assume that the reference will not expire during the program’s execution, making it suitable for long-lived data structures or operations that require such guarantees.
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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