caa564bea3
This makes edge cases in which the `Iterator` trait was not in scope and/or `Option` or its variants were not in scope work properly. This breaks code that looks like: struct MyStruct { ... } impl MyStruct { fn next(&mut self) -> Option<int> { ... } } for x in MyStruct { ... } { ... } Change ad-hoc `next` methods like the above to implementations of the `Iterator` trait. For example: impl Iterator<int> for MyStruct { fn next(&mut self) -> Option<int> { ... } } Closes #15392. [breaking-change]
27 lines
857 B
Rust
27 lines
857 B
Rust
// Copyright 2014 The Rust Project Developers. See the COPYRIGHT
|
|
// file at the top-level directory of this distribution and at
|
|
// http://rust-lang.org/COPYRIGHT.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
|
|
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
|
|
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
|
|
// option. This file may not be copied, modified, or distributed
|
|
// except according to those terms.
|
|
|
|
// macro f should not be able to inject a reference to 'n'.
|
|
//
|
|
// Ignored because `for` loops are not hygienic yet; they will require special
|
|
// handling since they introduce a new pattern binding position.
|
|
|
|
// ignore-test
|
|
|
|
#![feature(macro_rules)]
|
|
|
|
macro_rules! f(() => (n))
|
|
|
|
fn main() -> (){
|
|
for n in range(0i, 1) {
|
|
println!("{}", f!()); //~ ERROR unresolved name `n`
|
|
}
|
|
}
|