forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 6
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of rust-lang#88783 - Mark-Simulacrum:beta-next, r=Mark-Sim…
…ulacrum [beta] bootstrap bump and backports This bumps the beta bootstrap compiler to the released 1.55.0, and backports the following PRs: * Drop 1.56 stabilizations from 1.55 release notes rust-lang#88694 * 2229: Don't move out of drop type rust-lang#88477 * Work around CI issue with windows sdk 10.0.20348.0. rust-lang#88797 Cargo update: 1 commits in 18751dd3f238d94d384a7fe967abfac06cbfe0b9..d199d817e4bb70facc710716e73b5dddf80bc055 2021-09-01 14:26:00 +0000 to 2021-09-09 14:08:56 +0000 - [beta] Fix `cargo fix --edition` on stable. (rust-lang/cargo#9891) r? `@Mark-Simulacrum`
- Loading branch information
Showing
13 changed files
with
265 additions
and
19 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,62 @@ | ||
// edition:2021 | ||
|
||
#![feature(rustc_attrs)] | ||
|
||
// Test that we can't move out of struct that impls `Drop`. | ||
|
||
|
||
use std::rc::Rc; | ||
|
||
// Test that we restrict precision when moving not-`Copy` types, if any of the parent paths | ||
// implement `Drop`. This is to ensure that we don't move out of a type that implements Drop. | ||
pub fn test1() { | ||
struct Foo(Rc<i32>); | ||
|
||
impl Drop for Foo { | ||
fn drop(self: &mut Foo) {} | ||
} | ||
|
||
let f = Foo(Rc::new(1)); | ||
let x = #[rustc_capture_analysis] move || { | ||
//~^ ERROR: attributes on expressions are experimental | ||
//~| NOTE: see issue #15701 <https://github.com/rust-lang/rust/issues/15701> | ||
//~| ERROR: First Pass analysis includes: | ||
//~| ERROR: Min Capture analysis includes: | ||
println!("{:?}", f.0); | ||
//~^ NOTE: Capturing f[(0, 0)] -> ImmBorrow | ||
//~| NOTE: Min Capture f[] -> ByValue | ||
}; | ||
|
||
x(); | ||
} | ||
|
||
// Test that we don't restrict precision when moving `Copy` types(i.e. when copying), | ||
// even if any of the parent paths implement `Drop`. | ||
fn test2() { | ||
struct Character { | ||
hp: u32, | ||
name: String, | ||
} | ||
|
||
impl Drop for Character { | ||
fn drop(&mut self) {} | ||
} | ||
|
||
let character = Character { hp: 100, name: format!("A") }; | ||
|
||
let c = #[rustc_capture_analysis] move || { | ||
//~^ ERROR: attributes on expressions are experimental | ||
//~| NOTE: see issue #15701 <https://github.com/rust-lang/rust/issues/15701> | ||
//~| ERROR: First Pass analysis includes: | ||
//~| ERROR: Min Capture analysis includes: | ||
println!("{}", character.hp) | ||
//~^ NOTE: Capturing character[(0, 0)] -> ImmBorrow | ||
//~| NOTE: Min Capture character[(0, 0)] -> ByValue | ||
}; | ||
|
||
c(); | ||
|
||
println!("{}", character.name); | ||
} | ||
|
||
fn main() {} |
97 changes: 97 additions & 0 deletions
97
src/test/ui/closures/2229_closure_analysis/issue-88476.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
error[E0658]: attributes on expressions are experimental | ||
--> $DIR/issue-88476.rs:20:13 | ||
| | ||
LL | let x = #[rustc_capture_analysis] move || { | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
| | ||
= note: see issue #15701 <https://github.com/rust-lang/rust/issues/15701> for more information | ||
= help: add `#![feature(stmt_expr_attributes)]` to the crate attributes to enable | ||
|
||
error[E0658]: attributes on expressions are experimental | ||
--> $DIR/issue-88476.rs:47:13 | ||
| | ||
LL | let c = #[rustc_capture_analysis] move || { | ||
| ^^^^^^^^^^^^^^^^^^^^^^^^^ | ||
| | ||
= note: see issue #15701 <https://github.com/rust-lang/rust/issues/15701> for more information | ||
= help: add `#![feature(stmt_expr_attributes)]` to the crate attributes to enable | ||
|
||
error: First Pass analysis includes: | ||
--> $DIR/issue-88476.rs:20:39 | ||
| | ||
LL | let x = #[rustc_capture_analysis] move || { | ||
| _______________________________________^ | ||
LL | | | ||
LL | | | ||
LL | | | ||
... | | ||
LL | | | ||
LL | | }; | ||
| |_____^ | ||
| | ||
note: Capturing f[(0, 0)] -> ImmBorrow | ||
--> $DIR/issue-88476.rs:25:26 | ||
| | ||
LL | println!("{:?}", f.0); | ||
| ^^^ | ||
|
||
error: Min Capture analysis includes: | ||
--> $DIR/issue-88476.rs:20:39 | ||
| | ||
LL | let x = #[rustc_capture_analysis] move || { | ||
| _______________________________________^ | ||
LL | | | ||
LL | | | ||
LL | | | ||
... | | ||
LL | | | ||
LL | | }; | ||
| |_____^ | ||
| | ||
note: Min Capture f[] -> ByValue | ||
--> $DIR/issue-88476.rs:25:26 | ||
| | ||
LL | println!("{:?}", f.0); | ||
| ^^^ | ||
|
||
error: First Pass analysis includes: | ||
--> $DIR/issue-88476.rs:47:39 | ||
| | ||
LL | let c = #[rustc_capture_analysis] move || { | ||
| _______________________________________^ | ||
LL | | | ||
LL | | | ||
LL | | | ||
... | | ||
LL | | | ||
LL | | }; | ||
| |_____^ | ||
| | ||
note: Capturing character[(0, 0)] -> ImmBorrow | ||
--> $DIR/issue-88476.rs:52:24 | ||
| | ||
LL | println!("{}", character.hp) | ||
| ^^^^^^^^^^^^ | ||
|
||
error: Min Capture analysis includes: | ||
--> $DIR/issue-88476.rs:47:39 | ||
| | ||
LL | let c = #[rustc_capture_analysis] move || { | ||
| _______________________________________^ | ||
LL | | | ||
LL | | | ||
LL | | | ||
... | | ||
LL | | | ||
LL | | }; | ||
| |_____^ | ||
| | ||
note: Min Capture character[(0, 0)] -> ByValue | ||
--> $DIR/issue-88476.rs:52:24 | ||
| | ||
LL | println!("{}", character.hp) | ||
| ^^^^^^^^^^^^ | ||
|
||
error: aborting due to 6 previous errors | ||
|
||
For more information about this error, try `rustc --explain E0658`. |
47 changes: 47 additions & 0 deletions
47
src/test/ui/closures/2229_closure_analysis/run_pass/issue-88476.rs
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
// check-pass | ||
// edition:2021 | ||
|
||
use std::rc::Rc; | ||
|
||
// Test that we restrict precision when moving not-`Copy` types, if any of the parent paths | ||
// implement `Drop`. This is to ensure that we don't move out of a type that implements Drop. | ||
pub fn test1() { | ||
struct Foo(Rc<i32>); | ||
|
||
impl Drop for Foo { | ||
fn drop(self: &mut Foo) {} | ||
} | ||
|
||
let f = Foo(Rc::new(1)); | ||
let x = move || { | ||
println!("{:?}", f.0); | ||
}; | ||
|
||
x(); | ||
} | ||
|
||
|
||
// Test that we don't restrict precision when moving `Copy` types(i.e. when copying), | ||
// even if any of the parent paths implement `Drop`. | ||
pub fn test2() { | ||
struct Character { | ||
hp: u32, | ||
name: String, | ||
} | ||
|
||
impl Drop for Character { | ||
fn drop(&mut self) {} | ||
} | ||
|
||
let character = Character { hp: 100, name: format!("A") }; | ||
|
||
let c = move || { | ||
println!("{}", character.hp) | ||
}; | ||
|
||
c(); | ||
|
||
println!("{}", character.name); | ||
} | ||
|
||
fn main() {} |