]> git.lizzy.rs Git - rust.git/commitdiff
infer: give access to region variable origins
authorNiko Matsakis <niko@alum.mit.edu>
Mon, 6 Nov 2017 09:29:50 +0000 (04:29 -0500)
committerNiko Matsakis <niko@alum.mit.edu>
Thu, 16 Nov 2017 10:57:45 +0000 (05:57 -0500)
src/librustc/infer/mod.rs
src/librustc/infer/region_constraints/mod.rs

index 21f427fa80c1308fd33e15569f479fd0afdcf534..10734802a6d0e4688505b1bdae0bbec46caa8895 100644 (file)
@@ -25,7 +25,7 @@
 use mir::tcx::LvalueTy;
 use ty::subst::{Kind, Subst, Substs};
 use ty::{TyVid, IntVid, FloatVid};
-use ty::{self, Ty, TyCtxt};
+use ty::{self, RegionVid, Ty, TyCtxt};
 use ty::error::{ExpectedFound, TypeError, UnconstrainedNumeric};
 use ty::fold::{TypeFoldable, TypeFolder, TypeVisitor};
 use ty::relate::RelateResult;
@@ -1166,6 +1166,21 @@ pub fn take_and_reset_region_constraints(&self) -> RegionConstraintData<'tcx> {
         self.borrow_region_constraints().take_and_reset_data()
     }
 
+    /// Returns the number of region variables created thus far.
+    pub fn num_region_vars(&self) -> usize {
+        self.borrow_region_constraints().var_origins().len()
+    }
+
+    /// Returns an iterator over all region variables created thus far.
+    pub fn all_region_vars(&self) -> impl Iterator<Item = RegionVid> {
+        self.borrow_region_constraints().var_origins().indices()
+    }
+
+    /// Returns the origin of a given region variable.
+    pub fn region_var_origin(&self, var: RegionVid) -> RegionVariableOrigin {
+        self.borrow_region_constraints().var_origins()[var].clone()
+    }
+
     pub fn ty_to_string(&self, t: Ty<'tcx>) -> String {
         self.resolve_type_vars_if_possible(&t).to_string()
     }
index a9e36a5740fdace9fc283098ed0c889c810530d6..402fdeba56a7e708d825c8fa0fcbdccfe1d3bdb6 100644 (file)
@@ -33,7 +33,7 @@
 
 pub struct RegionConstraintCollector<'tcx> {
     /// For each `RegionVid`, the corresponding `RegionVariableOrigin`.
-    pub var_origins: IndexVec<RegionVid, RegionVariableOrigin>,
+    var_origins: IndexVec<RegionVid, RegionVariableOrigin>,
 
     data: RegionConstraintData<'tcx>,
 
@@ -284,6 +284,10 @@ pub fn new() -> RegionConstraintCollector<'tcx> {
         }
     }
 
+    pub fn var_origins(&self) -> &VarOrigins {
+        &self.var_origins
+    }
+
     /// Once all the constraints have been gathered, extract out the final data.
     ///
     /// Not legal during a snapshot.