[−][src]Struct rustc_data_structures::transitive_relation::TransitiveRelation  
Methods
impl<T: Clone + Debug + Eq + Hash> TransitiveRelation<T>[src]
pub fn is_empty(&self) -> bool[src]
pub fn maybe_map<F, U>(&self, f: F) -> Option<TransitiveRelation<U>> where
    F: FnMut(&T) -> Option<U>,
    U: Clone + Debug + Eq + Hash + Clone, [src]
F: FnMut(&T) -> Option<U>,
U: Clone + Debug + Eq + Hash + Clone,
Applies the (partial) function to each edge and returns a new
relation. If f returns None for any end-point, returns
None.
pub fn add(&mut self, a: T, b: T)[src]
Indicate that a < b (where < is this relation)
pub fn contains(&self, a: &T, b: &T) -> bool[src]
Checks whether a < target (transitively)
pub fn reachable_from(&self, a: &T) -> Vec<&T>[src]
Thinking of x R y as an edge x -> y in a graph, this
returns all things reachable from a.
Really this probably ought to be impl Iterator<Item = &T>, but
I'm too lazy to make that work, and -- given the caching
strategy -- it'd be a touch tricky anyhow.
pub fn postdom_upper_bound(&self, a: &T, b: &T) -> Option<&T>[src]
Picks what I am referring to as the "postdominating"
upper-bound for a and b. This is usually the least upper
bound, but in cases where there is no single least upper
bound, it is the "mutual immediate postdominator", if you
imagine a graph where a < b means a -> b.
This function is needed because region inference currently requires that we produce a single "UB", and there is no best choice for the LUB. Rather than pick arbitrarily, I pick a less good, but predictable choice. This should help ensure that region inference yields predictable results (though it itself is not fully sufficient).
Examples are probably clearer than any prose I could write
(there are corresponding tests below, btw). In each case,
the query is postdom_upper_bound(a, b):
// Returns Some(x), which is also LUB.
a -> a1 -> x
           ^
           |
b -> b1 ---+
// Returns `Some(x)`, which is not LUB (there is none)
// diagonal edges run left-to-right.
a -> a1 -> x
  \/       ^
  /\       |
b -> b1 ---+
// Returns `None`.
a -> a1
b -> b1
pub fn mutual_immediate_postdominator<'a>(
    &'a self, 
    mubs: Vec<&'a T>
) -> Option<&'a T>[src]
&'a self,
mubs: Vec<&'a T>
) -> Option<&'a T>
Viewing the relation as a graph, computes the "mutual
immediate postdominator" of a set of points (if one
exists). See postdom_upper_bound for details.
pub fn minimal_upper_bounds(&self, a: &T, b: &T) -> Vec<&T>[src]
Returns the set of bounds X such that:
- a < Xand- b < X
- there is no Y != Xsuch thata < YandY < X- except for the case where X < a(i.e., a strongly connected component in the graph). In that case, the smallest representative of the SCC is returned (as determined by the internal indices).
 
- except for the case where 
Note that this set can, in principle, have any size.
pub fn parents(&self, a: &T) -> Vec<&T>[src]
Given an element A, returns the maximal set {B} of elements B such that
- A != B
- A R B is true
- for each i, j: B[i] R B[j] does not hold
The intuition is that this moves "one step up" through a lattice
(where the relation is encoding the <= relation for the lattice).
So e.g., if the relation is -> and we have
a -> b -> d -> f | ^ +--> c -> e ---+
then parents(a) returns [b, c]. The postdom_parent function
would further reduce this to just f.
pub fn postdom_parent(&self, a: &T) -> Option<&T>[src]
A "best" parent in some sense. See parents and
postdom_upper_bound for more details.
Trait Implementations
impl<CTX, T> HashStable<CTX> for TransitiveRelation<T> where
    T: HashStable<CTX> + Eq + Debug + Clone + Hash, [src]
T: HashStable<CTX> + Eq + Debug + Clone + Hash,
fn hash_stable<W: StableHasherResult>(
    &self, 
    hcx: &mut CTX, 
    hasher: &mut StableHasher<W>
)[src]
&self,
hcx: &mut CTX,
hasher: &mut StableHasher<W>
)
impl<T: Clone + Debug + Eq + Hash> Default for TransitiveRelation<T>[src]
impl<T: Clone + Clone + Debug + Eq + Hash> Clone for TransitiveRelation<T>[src]
fn clone(&self) -> TransitiveRelation<T>[src]
fn clone_from(&mut self, source: &Self)1.0.0[src]
Performs copy-assignment from source. Read more
impl<T: Debug + Clone + Debug + Eq + Hash> Debug for TransitiveRelation<T>[src]
impl<T> Encodable for TransitiveRelation<T> where
    T: Clone + Encodable + Debug + Eq + Hash + Clone, [src]
T: Clone + Encodable + Debug + Eq + Hash + Clone,
impl<T> Decodable for TransitiveRelation<T> where
    T: Clone + Decodable + Debug + Eq + Hash + Clone, [src]
T: Clone + Decodable + Debug + Eq + Hash + Clone,
Auto Trait Implementations
impl<T> Send for TransitiveRelation<T> where
    T: Send, 
T: Send,
impl<T> !Sync for TransitiveRelation<T>
Blanket Implementations
impl<T> Erased for T[src]
impl<T> Send for T where
    T: ?Sized, [src]
T: ?Sized,
impl<T> Sync for T where
    T: ?Sized, [src]
T: ?Sized,
impl<T, U> Into for T where
    U: From<T>, [src]
U: From<T>,
impl<T> ToOwned for T where
    T: Clone, [src]
T: Clone,
impl<T> From for T[src]
impl<T, U> TryFrom for T where
    U: Into<T>, [src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
impl<T> Borrow for T where
    T: ?Sized, [src]
T: ?Sized,
impl<T> BorrowMut for T where
    T: ?Sized, [src]
T: ?Sized,
ⓘImportant traits for &'_ mut Ifn borrow_mut(&mut self) -> &mut T[src]
impl<T, U> TryInto for T where
    U: TryFrom<T>, [src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]
impl<T> Any for T where
    T: 'static + ?Sized, [src]
T: 'static + ?Sized,
impl<T> Encodable for T where
    T: UseSpecializedEncodable + ?Sized, [src]
T: UseSpecializedEncodable + ?Sized,
impl<T> Decodable for T where
    T: UseSpecializedDecodable, [src]
T: UseSpecializedDecodable,