Struct Data

Source
pub struct Data(UnsafeCell<AHashMap<Value, MaybeReady<&'static Expr>>>);
Expand description

A Term Dispatcher for Equal

Tuple Fields§

§0: UnsafeCell<AHashMap<Value, MaybeReady<&'static Expr>>>

Implementations§

Source§

impl Data

Source

pub fn new() -> Self

Creates and returns a new instance of the data structure by initializing it with an empty hash map.

Source

pub fn count(&self) -> usize

Return the number of entries stored in the underlying container.

Source

pub fn set(&self, v: Value, e: Expr) -> Option<&'static Expr>

Updates the mapping by setting an associated expression for a given value and returns the updated expression when modifications are made.

Source

pub fn set_ref(&self, v: Value, e: &'static Expr)

Sets the internal mapping for a given key with a new static expression value, and if necessary, triggers a notification to propagate the update.

Source

pub async fn acquire(&self, v: Value) -> &'static Expr

Acquires asynchronously an expression for a given value, waiting for its readiness if necessary.

Source

pub fn is_pending(&self, v: Value) -> bool

Checks whether the synthesis term associated with the provided value is still pending.

Source

pub fn contains(&self, v: Value) -> bool

Checks whether the underlying data structure contains the specified key.

Source

pub fn at(&self, index: Value) -> Option<&'static Expr>

Retrieves an expression reference from the underlying data structure based on a given index.

Source

pub fn get(&self, index: Value) -> &'static Expr

Retrieves a static expression reference corresponding to the provided value by performing an internal lookup.

Methods from Deref<Target = UnsafeCell<HashMap<Value, MaybeReady<&'static Expr>>>>§

Source

pub unsafe fn replace(&self, value: T) -> T

🔬This is a nightly-only experimental API. (unsafe_cell_access)

Replace the value in this UnsafeCell and return the old value.

§Safety

The caller must take care to avoid aliasing and data races.

  • It is Undefined Behavior to allow calls to race with any other access to the wrapped value.
  • It is Undefined Behavior to call this while any other reference(s) to the wrapped value are alive.
§Examples
#![feature(unsafe_cell_access)]
use std::cell::UnsafeCell;

let uc = UnsafeCell::new(5);

let old = unsafe { uc.replace(10) };
assert_eq!(old, 5);
1.0.0 · Source

pub fn get(&self) -> *mut T

Gets a mutable pointer to the wrapped value.

This can be cast to a pointer of any kind. Ensure that the access is unique (no active references, mutable or not) when casting to &mut T, and ensure that there are no mutations or mutable aliases going on when casting to &T

§Examples
use std::cell::UnsafeCell;

let uc = UnsafeCell::new(5);

let five = uc.get();
Source

pub unsafe fn as_ref_unchecked(&self) -> &T

🔬This is a nightly-only experimental API. (unsafe_cell_access)

Get a shared reference to the value within the UnsafeCell.

§Safety
  • It is Undefined Behavior to call this while any mutable reference to the wrapped value is alive.
  • Mutating the wrapped value while the returned reference is alive is Undefined Behavior.
§Examples
#![feature(unsafe_cell_access)]
use std::cell::UnsafeCell;

let uc = UnsafeCell::new(5);

let val = unsafe { uc.as_ref_unchecked() };
assert_eq!(val, &5);
Source

pub unsafe fn as_mut_unchecked(&self) -> &mut T

🔬This is a nightly-only experimental API. (unsafe_cell_access)

Get an exclusive reference to the value within the UnsafeCell.

§Safety
  • It is Undefined Behavior to call this while any other reference(s) to the wrapped value are alive.
  • Mutating the wrapped value through other means while the returned reference is alive is Undefined Behavior.
§Examples
#![feature(unsafe_cell_access)]
use std::cell::UnsafeCell;

let uc = UnsafeCell::new(5);

unsafe { *uc.as_mut_unchecked() += 1; }
assert_eq!(uc.into_inner(), 6);

Trait Implementations§

Source§

impl Default for Data

Source§

fn default() -> Self

Creates a new instance using the default initialization, which internally delegates to the new method.

Source§

impl From<UnsafeCell<AHashMap<Value, MaybeReady<&'static Expr>>>> for Data

Source§

fn from(original: UnsafeCell<HashMap<Value, MaybeReady<&'static Expr>>>) -> Data

Converts to this type from the input type.
Source§

impl Deref for Data

Source§

type Target = UnsafeCell<AHashMap<Value, MaybeReady<&'static Expr>>>

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Self::Target

Dereferences the value.

Auto Trait Implementations§

§

impl !Freeze for Data

§

impl !RefUnwindSafe for Data

§

impl !Send for Data

§

impl !Sync for Data

§

impl Unpin for Data

§

impl !UnwindSafe for Data

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> 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<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
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