Skip to content

Commit

Permalink
Auto merge of #31144 - jseyfried:remove_import_ordering_restriction, …
Browse files Browse the repository at this point in the history
…r=nrc

We no longer require `use` and `extern crate` items to precede other items in modules thanks to [RFC #385](rust-lang/rfcs#385), but we still require `use` and `extern crate` items to precede statements in blocks (other items can appear anywhere in a block).

I think that this is a needless distinction between imports and other items that contradicts the intent of the RFC.
  • Loading branch information
bors committed Jan 29, 2016
2 parents 33b73e9 + f05bc16 commit f030d1f
Show file tree
Hide file tree
Showing 3 changed files with 0 additions and 25 deletions.
23 changes: 0 additions & 23 deletions src/librustc_resolve/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2516,29 +2516,6 @@ impl<'a, 'tcx> Resolver<'a, 'tcx> {
self.value_ribs.push(Rib::new(NormalRibKind));
}

// Check for imports appearing after non-item statements.
let mut found_non_item = false;
for statement in &block.stmts {
if let hir::StmtDecl(ref declaration, _) = statement.node {
if let hir::DeclItem(i) = declaration.node {
let i = self.ast_map.expect_item(i.id);
match i.node {
ItemExternCrate(_) | ItemUse(_) if found_non_item => {
span_err!(self.session,
i.span,
E0154,
"imports are not allowed after non-item statements");
}
_ => {}
}
} else {
found_non_item = true
}
} else {
found_non_item = true;
}
}

// Descend into the block.
intravisit::walk_block(self, block);

Expand Down
1 change: 0 additions & 1 deletion src/test/compile-fail/blind-item-block-middle.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,5 +14,4 @@ fn main() {
let bar = 5;
//~^ ERROR declaration of `bar` shadows an enum variant or unit-like struct in scope
use foo::bar;
//~^ ERROR imports are not allowed after non-item statements
}
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,5 @@ mod bar {
fn main() {
let foo = || false;
use bar::foo;
//~^ ERROR imports are not allowed after non-item statements
assert_eq!(foo(), false);
}

0 comments on commit f030d1f

Please sign in to comment.