Skip to content

Commit fe0a373

Browse files
committed
---
yaml --- r: 274687 b: refs/heads/stable c: 030b237 h: refs/heads/master i: 274685: 1ac22a5 274683: 43f1b9d 274679: bfe2211 274671: 27cacb2 274655: 7a7dfc2 274623: e686104 274559: 77e3eb3 274431: c19f067
1 parent a219a74 commit fe0a373

File tree

7 files changed

+37
-23
lines changed

7 files changed

+37
-23
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,7 @@ refs/heads/tmp: e06d2ad9fcd5027bcaac5b08fc9aa39a49d0ecd3
2929
refs/tags/1.0.0-alpha.2: 4c705f6bc559886632d3871b04f58aab093bfa2f
3030
refs/tags/homu-tmp: c0221c8897db309a79990367476177b1230bb264
3131
refs/tags/1.0.0-beta: 8cbb92b53468ee2b0c2d3eeb8567005953d40828
32-
refs/heads/stable: 41c892f5e141a4bd34252ec46f3b9debc3cdafdd
32+
refs/heads/stable: 030b237476e1aef16dc01f3efef12d0dba765c07
3333
refs/tags/1.0.0: 55bd4f8ff2b323f317ae89e254ce87162d52a375
3434
refs/tags/1.1.0: bc3c16f09287e5545c1d3f76b7abd54f2eca868b
3535
refs/tags/1.2.0: f557861f822c34f07270347b94b5280de20a597e

branches/stable/src/librustc/lib.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -126,6 +126,7 @@ pub mod mir {
126126
pub mod repr;
127127
pub mod tcx;
128128
pub mod visit;
129+
pub mod transform;
129130
pub mod mir_map;
130131
}
131132

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,16 @@
1+
// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
use mir::repr::Mir;
12+
use middle::ty::ctxt;
13+
14+
pub trait MirPass {
15+
fn run_on_mir<'tcx>(&mut self, mir: &mut Mir<'tcx>, tcx: &ctxt<'tcx>);
16+
}

branches/stable/src/librustc_mir/mir_map.rs

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -22,12 +22,13 @@ extern crate rustc_front;
2222
use build;
2323
use graphviz;
2424
use pretty;
25-
use transform::{simplify_cfg, MirPass};
25+
use transform::simplify_cfg;
2626
use rustc::dep_graph::DepNode;
2727
use rustc::mir::repr::Mir;
2828
use hair::cx::Cx;
2929
use std::fs::File;
3030

31+
use rustc::mir::transform::MirPass;
3132
use rustc::mir::mir_map::MirMap;
3233
use rustc::middle::infer;
3334
use rustc::middle::region::CodeExtentData;
@@ -147,7 +148,7 @@ impl<'a, 'm, 'tcx> Visitor<'tcx> for InnerDump<'a,'m,'tcx> {
147148

148149
match build_mir(Cx::new(&infcx), implicit_arg_tys, id, span, decl, body) {
149150
Ok(mut mir) => {
150-
simplify_cfg::SimplifyCfg::new().run_on_mir(&mut mir);
151+
simplify_cfg::SimplifyCfg::new().run_on_mir(&mut mir, self.tcx);
151152

152153
let meta_item_list = self.attr
153154
.iter()

branches/stable/src/librustc_mir/transform/erase_regions.rs

Lines changed: 13 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -15,24 +15,26 @@
1515
use rustc::middle::ty;
1616
use rustc::mir::repr::*;
1717
use rustc::mir::visit::MutVisitor;
18-
use transform::MirPass;
1918
use rustc::mir::mir_map::MirMap;
19+
use rustc::mir::transform::MirPass;
2020

2121
pub fn erase_regions<'tcx>(tcx: &ty::ctxt<'tcx>, mir_map: &mut MirMap<'tcx>) {
22-
let mut eraser = EraseRegions::new(tcx);
22+
let mut eraser = EraseRegions;
2323

24-
eraser.run_on_mir(mir);
2524
for (_, mir) in &mut mir_map.map {
25+
eraser.run_on_mir(mir, tcx);
2626
}
2727
}
2828

29-
pub struct EraseRegions<'a, 'tcx: 'a> {
29+
pub struct EraseRegions;
30+
31+
struct EraseRegionsVisitor<'a, 'tcx: 'a> {
3032
tcx: &'a ty::ctxt<'tcx>,
3133
}
3234

33-
impl<'a, 'tcx> EraseRegions<'a, 'tcx> {
34-
pub fn new(tcx: &'a ty::ctxt<'tcx>) -> EraseRegions<'a, 'tcx> {
35-
EraseRegions {
35+
impl<'a, 'tcx> EraseRegionsVisitor<'a, 'tcx> {
36+
pub fn new(tcx: &'a ty::ctxt<'tcx>) -> Self {
37+
EraseRegionsVisitor {
3638
tcx: tcx
3739
}
3840
}
@@ -56,13 +58,13 @@ impl<'a, 'tcx> EraseRegions<'a, 'tcx> {
5658
}
5759
}
5860

59-
impl<'a, 'tcx> MirPass<'tcx> for EraseRegions<'a, 'tcx> {
60-
fn run_on_mir(&mut self, mir: &mut Mir<'tcx>) {
61-
self.visit_mir(mir);
61+
impl MirPass for EraseRegions {
62+
fn run_on_mir<'tcx>(&mut self, mir: &mut Mir<'tcx>, tcx: &ty::ctxt<'tcx>) {
63+
EraseRegionsVisitor::new(tcx).visit_mir(mir);
6264
}
6365
}
6466

65-
impl<'a, 'tcx> MutVisitor<'tcx> for EraseRegions<'a, 'tcx> {
67+
impl<'a, 'tcx> MutVisitor<'tcx> for EraseRegionsVisitor<'a, 'tcx> {
6668
fn visit_mir(&mut self, mir: &mut Mir<'tcx>) {
6769
self.erase_regions_return_ty(&mut mir.return_ty);
6870
self.erase_regions_tys(mir.var_decls.iter_mut().map(|d| &mut d.ty));

branches/stable/src/librustc_mir/transform/mod.rs

Lines changed: 0 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -11,9 +11,3 @@
1111
pub mod simplify_cfg;
1212
pub mod erase_regions;
1313
mod util;
14-
15-
use rustc::mir::repr::Mir;
16-
17-
pub trait MirPass<'tcx> {
18-
fn run_on_mir(&mut self, mir: &mut Mir<'tcx>);
19-
}

branches/stable/src/librustc_mir/transform/simplify_cfg.rs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@
1111
use rustc::middle::const_eval::ConstVal;
1212
use rustc::mir::repr::*;
1313
use transform::util;
14-
use transform::MirPass;
14+
use rustc::mir::transform::MirPass;
1515

1616
pub struct SimplifyCfg;
1717

@@ -118,8 +118,8 @@ impl SimplifyCfg {
118118
}
119119
}
120120

121-
impl<'tcx> MirPass<'tcx> for SimplifyCfg {
122-
fn run_on_mir(&mut self, mir: &mut Mir<'tcx>) {
121+
impl MirPass for SimplifyCfg {
122+
fn run_on_mir<'tcx>(&mut self, mir: &mut Mir<'tcx>, _: &::rustc::middle::ty::ctxt<'tcx>) {
123123
let mut changed = true;
124124
while changed {
125125
changed = self.simplify_branches(mir);

0 commit comments

Comments
 (0)