diff --git a/src/test/compile-fail/generator/invalid-positions.rs b/src/test/compile-fail/generator/invalid-positions.rs new file mode 100644 index 000000000000..c2f5b20d5758 --- /dev/null +++ b/src/test/compile-fail/generator/invalid-positions.rs @@ -0,0 +1,23 @@ +// Copyright 2017 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 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +#![feature(generators)] + +const A: u8 = { yield 3u8; gen arg; 3u8}; +//~^ ERROR yield statement outside +//~| ERROR gen arg expression outside + +static B: u8 = { yield 3u8; gen arg; 3u8}; +//~^ ERROR yield statement outside +//~| ERROR gen arg expression outside + +fn main() { yield; gen arg; } +//~^ ERROR yield statement outside +//~| ERROR gen arg expression outside diff --git a/src/test/compile-fail/generator/const-yield.rs b/src/test/compile-fail/generator/no-arguments-on-generators.rs similarity index 72% rename from src/test/compile-fail/generator/const-yield.rs rename to src/test/compile-fail/generator/no-arguments-on-generators.rs index fa99e8553a0b..9c68fe4ceda8 100644 --- a/src/test/compile-fail/generator/const-yield.rs +++ b/src/test/compile-fail/generator/no-arguments-on-generators.rs @@ -10,7 +10,8 @@ #![feature(generators)] -const A: u8 = { yield 3u8; 3u8}; //~ ERROR yield statement outside of function body -static B: u8 = { yield 3u8; 3u8}; //~ ERROR yield statement outside of function body - -fn main() {} \ No newline at end of file +fn main() { + let gen = |start| { //~ ERROR generators cannot have explicit arguments + yield; + }; +} \ No newline at end of file diff --git a/src/test/compile-fail/generator/generator-not-fnmut.rs b/src/test/run-pass/generator/implicit-argument-dead-when-suspended.rs similarity index 64% rename from src/test/compile-fail/generator/generator-not-fnmut.rs rename to src/test/run-pass/generator/implicit-argument-dead-when-suspended.rs index 460db8e38199..722ec2477efb 100644 --- a/src/test/compile-fail/generator/generator-not-fnmut.rs +++ b/src/test/run-pass/generator/implicit-argument-dead-when-suspended.rs @@ -10,16 +10,24 @@ #![feature(generators)] -fn main() { - let mut a = Vec::::new(); +use std::cell::Cell; - let mut test = || { - let _: () = gen arg; - yield 3; - a.push(true); - 2 +struct Flag<'a>(&'a Cell); + +impl<'a> Drop for Flag<'a> { + fn drop(&mut self) { + self.0.set(false) + } +} + +fn main() { + let alive = Cell::new(true); + + let gen = || { + yield; }; - let a1 = test(); - let a2 = test(); //~ ERROR use of moved value + gen.resume(Flag(&alive)); + + assert_eq!(alive.get(), false); }