forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Move write! and writeln! temporaries test to check-fail
- Loading branch information
1 parent
9a95c05
commit eb5fb32
Showing
3 changed files
with
93 additions
and
16 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
// check-fail | ||
|
||
use std::fmt::{self, Display}; | ||
|
||
struct Mutex; | ||
|
||
impl Mutex { | ||
fn lock(&self) -> MutexGuard { | ||
MutexGuard(self) | ||
} | ||
} | ||
|
||
struct MutexGuard<'a>(&'a Mutex); | ||
|
||
impl<'a> Drop for MutexGuard<'a> { | ||
fn drop(&mut self) { | ||
// Empty but this is a necessary part of the repro. Otherwise borrow | ||
// checker is fine with 'a dangling at the time that MutexGuard goes out | ||
// of scope. | ||
} | ||
} | ||
|
||
struct Out; | ||
|
||
impl Out { | ||
fn write_fmt(&self, _args: fmt::Arguments) {} | ||
} | ||
|
||
impl<'a> Display for MutexGuard<'a> { | ||
fn fmt(&self, _formatter: &mut fmt::Formatter) -> fmt::Result { | ||
Ok(()) | ||
} | ||
} | ||
|
||
fn main() { | ||
// FIXME(dtolnay): We actually want both of these to work. I think it's | ||
// sadly unimplementable today though. | ||
|
||
let _write = { | ||
let mutex = Mutex; | ||
write!(Out, "{}", mutex.lock()) /* no semicolon */ | ||
//~^ ERROR `mutex` does not live long enough | ||
}; | ||
|
||
let _writeln = { | ||
let mutex = Mutex; | ||
writeln!(Out, "{}", mutex.lock()) /* no semicolon */ | ||
//~^ ERROR `mutex` does not live long enough | ||
}; | ||
} |
43 changes: 43 additions & 0 deletions
43
src/test/ui/macros/format-args-temporaries-in-write.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,43 @@ | ||
error[E0597]: `mutex` does not live long enough | ||
--> $DIR/format-args-temporaries-in-write.rs:41:27 | ||
| | ||
LL | write!(Out, "{}", mutex.lock()) /* no semicolon */ | ||
| ^^^^^^^^^^^^ | ||
| | | ||
| borrowed value does not live long enough | ||
| a temporary with access to the borrow is created here ... | ||
LL | | ||
LL | }; | ||
| -- ... and the borrow might be used here, when that temporary is dropped and runs the `Drop` code for type `MutexGuard` | ||
| | | ||
| `mutex` dropped here while still borrowed | ||
| | ||
help: consider adding semicolon after the expression so its temporaries are dropped sooner, before the local variables declared by the block are dropped | ||
--> $SRC_DIR/core/src/macros/mod.rs:LL:COL | ||
| | ||
LL | $dst.write_fmt($crate::format_args!($($arg)*)); | ||
| + | ||
|
||
error[E0597]: `mutex` does not live long enough | ||
--> $DIR/format-args-temporaries-in-write.rs:47:29 | ||
| | ||
LL | writeln!(Out, "{}", mutex.lock()) /* no semicolon */ | ||
| ^^^^^^^^^^^^ | ||
| | | ||
| borrowed value does not live long enough | ||
| a temporary with access to the borrow is created here ... | ||
LL | | ||
LL | }; | ||
| -- ... and the borrow might be used here, when that temporary is dropped and runs the `Drop` code for type `MutexGuard` | ||
| | | ||
| `mutex` dropped here while still borrowed | ||
| | ||
help: consider adding semicolon after the expression so its temporaries are dropped sooner, before the local variables declared by the block are dropped | ||
--> $SRC_DIR/core/src/macros/mod.rs:LL:COL | ||
| | ||
LL | $dst.write_fmt($crate::format_args_nl!($($arg)*)); | ||
| + | ||
|
||
error: aborting due to 2 previous errors | ||
|
||
For more information about this error, try `rustc --explain E0597`. |
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