pub(crate) struct InferCtxtUndoLogs<'tcx> {
logs: Vec<UndoLog<'tcx>>,
num_open_snapshots: usize,
}
Expand description
The combined undo log for all the various unification tables. For each change to the storage for any kind of inference variable, we record an UndoLog entry in the vector here.
Fields§
§logs: Vec<UndoLog<'tcx>>
§num_open_snapshots: usize
Implementations§
source§impl<'tcx> InferCtxtUndoLogs<'tcx>
impl<'tcx> InferCtxtUndoLogs<'tcx>
pub(crate) fn start_snapshot(&mut self) -> Snapshot<'tcx>
pub(crate) fn region_constraints_in_snapshot( &self, s: &Snapshot<'tcx>, ) -> impl Iterator<Item = &UndoLog<'tcx>> + Clone
pub(crate) fn opaque_types_in_snapshot(&self, s: &Snapshot<'tcx>) -> bool
fn assert_open_snapshot(&self, snapshot: &Snapshot<'tcx>)
Trait Implementations§
source§impl<'tcx> Clone for InferCtxtUndoLogs<'tcx>
impl<'tcx> Clone for InferCtxtUndoLogs<'tcx>
source§fn clone(&self) -> InferCtxtUndoLogs<'tcx>
fn clone(&self) -> InferCtxtUndoLogs<'tcx>
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl<'tcx> Default for InferCtxtUndoLogs<'tcx>
impl<'tcx> Default for InferCtxtUndoLogs<'tcx>
source§fn default() -> InferCtxtUndoLogs<'tcx>
fn default() -> InferCtxtUndoLogs<'tcx>
Returns the “default value” for a type. Read more
source§impl<'tcx> Index<usize> for InferCtxtUndoLogs<'tcx>
impl<'tcx> Index<usize> for InferCtxtUndoLogs<'tcx>
source§impl<'tcx> IndexMut<usize> for InferCtxtUndoLogs<'tcx>
impl<'tcx> IndexMut<usize> for InferCtxtUndoLogs<'tcx>
source§impl<'tcx, T> UndoLogs<T> for InferCtxtUndoLogs<'tcx>
impl<'tcx, T> UndoLogs<T> for InferCtxtUndoLogs<'tcx>
The UndoLogs trait defines how we undo a particular kind of action (of type T). We can undo any action that is convertible into an UndoLog (per the From impls above).
source§fn num_open_snapshots(&self) -> usize
fn num_open_snapshots(&self) -> usize
How many open snapshots this undo log currently has
source§fn push(&mut self, undo: T)
fn push(&mut self, undo: T)
Pushes a new “undo item” onto the undo log. This method is invoked when some action is taken
(e.g., a variable is unified). It records the info needed to reverse that action should an
enclosing snapshot be rolled back.
source§fn extend<J>(&mut self, undos: J)where
Self: Sized,
J: IntoIterator<Item = T>,
fn extend<J>(&mut self, undos: J)where
Self: Sized,
J: IntoIterator<Item = T>,
Extends the undo log with many undos.
source§fn in_snapshot(&self) -> bool
fn in_snapshot(&self) -> bool
True if a snapshot has started, false otherwise
Auto Trait Implementations§
impl<'tcx> Freeze for InferCtxtUndoLogs<'tcx>
impl<'tcx> !RefUnwindSafe for InferCtxtUndoLogs<'tcx>
impl<'tcx> !Send for InferCtxtUndoLogs<'tcx>
impl<'tcx> !Sync for InferCtxtUndoLogs<'tcx>
impl<'tcx> Unpin for InferCtxtUndoLogs<'tcx>
impl<'tcx> !UnwindSafe for InferCtxtUndoLogs<'tcx>
Blanket Implementations§
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
Mutably borrows from an owned value. Read more
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
🔬This is a nightly-only experimental API. (
clone_to_uninit
)source§impl<T, R> CollectAndApply<T, R> for T
impl<T, R> CollectAndApply<T, R> for T
source§impl<T> Filterable for T
impl<T> Filterable for T
source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(_: DataRequest<'_>) -> bool>
Creates a filterable data provider with the given name for debugging. Read more
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
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>
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 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>
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 moresource§impl<P> IntoQueryParam<P> for P
impl<P> IntoQueryParam<P> for P
fn into_query_param(self) -> P
source§impl<T> MaybeResult<T> for T
impl<T> MaybeResult<T> for T
source§impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
impl<I, T, U> Upcast<I, U> for Twhere
U: UpcastFrom<I, T>,
source§impl<I, T> UpcastFrom<I, T> for T
impl<I, T> UpcastFrom<I, T> for T
fn upcast_from(from: T, _tcx: I) -> T
source§impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
impl<Tcx, T> Value<Tcx> for Twhere
Tcx: DepContext,
default fn from_cycle_error( tcx: Tcx, cycle_error: &CycleError, _guar: ErrorGuaranteed, ) -> T
source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
source§fn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
impl<'a, T> Captures<'a> for Twhere
T: ?Sized,
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> MaybeSendSync for T
Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 32 bytes