Struct rustc_data_structures::unify::UnificationTable
[−]
[src]
pub struct UnificationTable<K: UnifyKey> { // some fields omitted }
Unstable (
rustc_private
)Table of unification keys and their values.
Methods
impl<K: UnifyKey> UnificationTable<K>
[src]
fn new() -> UnificationTable<K>
fn snapshot(&mut self) -> Snapshot<K>
Unstable (
rustc_private
)Starts a new snapshot. Each snapshot must be either rolled back or committed in a "LIFO" (stack) order.
fn rollback_to(&mut self, snapshot: Snapshot<K>)
Unstable (
rustc_private
)Reverses all changes since the last snapshot. Also removes any keys that have been created since then.
fn commit(&mut self, snapshot: Snapshot<K>)
Unstable (
rustc_private
)Commits all changes since the last snapshot. Of course, they can still be undone if there is a snapshot further out.
fn new_key(&mut self, value: K::Value) -> K
impl<'tcx, K: UnifyKey> UnificationTable<K> where K::Value: Combine
[src]
fn union(&mut self, a_id: K, b_id: K) -> K
fn find(&mut self, id: K) -> K
fn find_value(&mut self, id: K) -> K::Value
fn unioned(&mut self, a_id: K, b_id: K) -> bool
impl<'tcx, K, V> UnificationTable<K> where K: UnifyKey<Value=Option<V>>, V: Clone + PartialEq + Debug
[src]
fn unify_var_var(&mut self, a_id: K, b_id: K) -> Result<K, (V, V)>
fn unify_var_value(&mut self, a_id: K, b: V) -> Result<(), (V, V)>
Unstable (
rustc_private
)Sets the value of the key a_id
to b
. Because simple keys do not have any subtyping
relationships, if a_id
already has a value, it must be the same as b
.