]> git.lizzy.rs Git - rust.git/commitdiff
Replaced list::each with iter() in get_region
authorBruno de Oliveira Abinader <bruno.d@partner.samsung.com>
Tue, 25 Feb 2014 02:22:11 +0000 (22:22 -0400)
committerBruno de Oliveira Abinader <bruno.d@partner.samsung.com>
Thu, 27 Feb 2014 12:35:18 +0000 (08:35 -0400)
src/librustc/middle/typeck/mod.rs

index c04e4f24b0db0f18f71e08d3fd63567b2204cffb..dda45e839e12af82b89b0e10e1e4e76a05742c3f 100644 (file)
@@ -73,7 +73,6 @@
 use collections::HashMap;
 use std::rc::Rc;
 use collections::List;
-use collections::list;
 use syntax::codemap::Span;
 use syntax::print::pprust::*;
 use syntax::{ast, ast_map, abi};
@@ -311,23 +310,18 @@ pub fn require_same_types(tcx: ty::ctxt,
 // corresponding ty::Region
 pub type isr_alist = @List<(ty::BoundRegion, ty::Region)>;
 
-trait get_and_find_region {
-    fn get(&self, br: ty::BoundRegion) -> ty::Region;
-    fn find(&self, br: ty::BoundRegion) -> Option<ty::Region>;
+trait get_region<'a, T:'static> {
+    fn get(&'a self, br: ty::BoundRegion) -> ty::Region;
 }
 
-impl get_and_find_region for isr_alist {
-    fn get(&self, br: ty::BoundRegion) -> ty::Region {
-        self.find(br).unwrap()
-    }
-
-    fn find(&self, br: ty::BoundRegion) -> Option<ty::Region> {
-        let mut ret = None;
-        list::each(*self, |isr| {
+impl<'a, T:'static> get_region <'a, T> for isr_alist {
+    fn get(&'a self, br: ty::BoundRegion) -> ty::Region {
+        let mut region = None;
+        for isr in self.iter() {
             let (isr_br, isr_r) = *isr;
-            if isr_br == br { ret = Some(isr_r); false } else { true }
-        });
-        ret
+            if isr_br == br { region = Some(isr_r); break; }
+        };
+        region.unwrap()
     }
 }