Struct Replace

Source
pub struct Replace(pub usize, pub usize);
Expand description

A struct that represents a string replacement operation.

It includes two public fields, both of type usize, which likely denote positions or lengths in a string where a replacement operation is intended to take place. The straightforward structure of this item suggests it serves as a utility to encapsulate parameters for a replace-like task within a larger synthesis or transformation process.

Tuple Fields§

§0: usize§1: usize

Implementations§

Source§

impl Replace

Source

pub fn from_config(config: &Config) -> Self

Creates a new instance by extracting configuration values.

It fetches the “cost” and “enum_replace_cost” from the given Config object, setting them as the first and second elements respectively. If the configuration values are not present, it defaults to using 1 for “cost” and 3 for “enum_replace_cost”. This approach allows the object to be instantiated with specific costs based on the provided configuration, facilitating customizability within the synthesis framework.

Source

pub fn name() -> &'static str

Returns the name associated with the Replace operation.

This functionality provides a static method that outputs the string "str.replace", serving as an identifier for the operation within the synthesis framework. This is useful for referencing the operation in logs, configuration, or other parts of the system where consistent naming is necessary.

Trait Implementations§

Source§

impl Clone for Replace

Source§

fn clone(&self) -> Replace

Returns a copy 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 Replace

Source§

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

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

impl Default for Replace

Source§

fn default() -> Self

Creates a new instance with default configuration.

This method initializes the instance using the from_config function, passing a default configuration. The implementation implies the Replace structure can be configured with external settings, yet defaults allow creating a baseline instance without specifying particular attributes.

Source§

impl Display for Replace

Source§

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

Formats the Replace instance for display purposes.

This implementation of the fmt function, part of the std::fmt module, uses the name method of the Replace struct itself to provide a formatted representation. The formatted output is directed to a given formatter instance, which integrates the Replace instance into a formatted output stream.

Source§

impl Enumerator3 for Replace

Source§

fn enumerate( &self, this: &'static Op3Enum, exec: &'static Executor, nt: [usize; 3], ) -> Result<(), ()>

Enumerates possible expressions in the context of the synthesis problem.

This function first checks if the executor’s available size meets the minimum cost requirement, terminating early if it does not. It calculates the total allowable size for enumeration and iterates over combinations of sub-expressions e1, e2, and e3 from the executor’s data, constrained by the maximum specified size. Within these loops, it constructs a ternary operation expression with the provided Op3Enum. The function attempts to evaluate this new expression using given values, and if successful, it proceeds to enumerate the expression in the executor with its evaluated value. The process ensures that only valid expressions with feasible evaluations are considered, thus optimizing the string synthesis tasks.

Source§

impl From<Replace> for Op3Enum

Source§

fn from(v: Replace) -> Op3Enum

Converts to this type from the input type.
Source§

impl Hash for Replace

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Op3 for Replace

Source§

fn cost(&self) -> usize

Provides functionality to calculate the cost of a Replace operation.

The cost method, when called on an instance of Replace, returns the first element of the tuple. This represents the operational cost or significance of the replacement process defined by the instance.

Source§

fn try_eval(&self, a1: Value, a2: Value, a3: Value) -> (bool, Value)

Provides a method to attempt the evaluation of a replacement operation within a given context of string values.

This method takes three Value parameters, a1, a2, and a3, assuming they are all strings. It performs a replacement operation using the Rust replacen string method, which replaces the first occurrence of a substring (from a1 and a2 combinations) with a new string (a3). The use of itertools::izip! allows iterating over the characters of the input strings in parallel, applying the replacement on each character triplet. If the inputs match the expected string types, the method returns a tuple indicating success and the resulting string; otherwise, it returns a tuple indicating failure with a Value::Null. The galloc_str and galloc_scollect methods are employed to efficiently handle memory allocation for the resulting strings.

Source§

impl PartialEq for Replace

Source§

fn eq(&self, other: &Replace) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl TryInto<Replace> for Op3Enum

Source§

type Error = &'static str

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

fn try_into(self) -> Result<Replace, <Self as TryInto<Replace>>::Error>

Performs the conversion.
Source§

impl Copy for Replace

Source§

impl Eq for Replace

Source§

impl StructuralPartialEq for Replace

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> AllocForAny<T> for T

Source§

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

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> 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, dst: *mut u8)

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

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
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> 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> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. 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> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V