Add test coverage of more varieties of panic temporaries
This commit is contained in:
parent
0bcfd2d96e
commit
0ebb5cbab6
55
tests/ui/macros/panic-temporaries-2018.rs
Normal file
55
tests/ui/macros/panic-temporaries-2018.rs
Normal file
@ -0,0 +1,55 @@
|
|||||||
|
// check-pass
|
||||||
|
// edition:2018
|
||||||
|
|
||||||
|
#![allow(non_fmt_panics, unreachable_code)]
|
||||||
|
|
||||||
|
use std::fmt::{self, Display};
|
||||||
|
use std::marker::PhantomData;
|
||||||
|
|
||||||
|
struct NotSend {
|
||||||
|
marker: PhantomData<*const u8>,
|
||||||
|
}
|
||||||
|
|
||||||
|
const NOT_SEND: NotSend = NotSend { marker: PhantomData };
|
||||||
|
|
||||||
|
impl Display for NotSend {
|
||||||
|
fn fmt(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
formatter.write_str("this value does not implement Send")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async fn f(_: u8) {}
|
||||||
|
|
||||||
|
// Exercises this matcher in panic_2015:
|
||||||
|
// ($fmt:expr, $($arg:tt)+) => $crate::panicking::panic_fmt(...)
|
||||||
|
async fn panic_fmt() {
|
||||||
|
// Panic returns `!`, so the await is never reached, and in particular the
|
||||||
|
// temporaries inside the formatting machinery are not still alive at the
|
||||||
|
// await point.
|
||||||
|
let todo = "...";
|
||||||
|
f(panic!("not yet implemented: {}", todo)).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Exercises ("{}", $arg:expr) => $crate::panicking::panic_display(&$arg)
|
||||||
|
async fn panic_display() {
|
||||||
|
f(panic!("{}", NOT_SEND)).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Exercises ($msg:expr) => $crate::panicking::panic_str($msg)
|
||||||
|
async fn panic_str() {
|
||||||
|
f(panic!((NOT_SEND, "...").1)).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Exercises ($msg:expr) => $crate::panicking::unreachable_display(&$msg)
|
||||||
|
async fn unreachable_display() {
|
||||||
|
f(unreachable!(NOT_SEND)).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
fn require_send(_: impl Send) {}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
require_send(panic_fmt());
|
||||||
|
require_send(panic_display());
|
||||||
|
require_send(panic_str());
|
||||||
|
require_send(unreachable_display());
|
||||||
|
}
|
@ -3,17 +3,41 @@
|
|||||||
|
|
||||||
#![allow(unreachable_code)]
|
#![allow(unreachable_code)]
|
||||||
|
|
||||||
|
use std::fmt::{self, Display};
|
||||||
|
use std::marker::PhantomData;
|
||||||
|
|
||||||
|
struct NotSend {
|
||||||
|
marker: PhantomData<*const u8>,
|
||||||
|
}
|
||||||
|
|
||||||
|
const NOT_SEND: NotSend = NotSend { marker: PhantomData };
|
||||||
|
|
||||||
|
impl Display for NotSend {
|
||||||
|
fn fmt(&self, formatter: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
formatter.write_str("this value does not implement Send")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
async fn f(_: u8) {}
|
async fn f(_: u8) {}
|
||||||
|
|
||||||
async fn g() {
|
// Exercises this matcher in panic_2021:
|
||||||
// Todo returns `!`, so the await is never reached, and in particular the
|
// ($($t:tt)+) => $crate::panicking::panic_fmt(...)
|
||||||
|
async fn panic_fmt() {
|
||||||
|
// Panic returns `!`, so the await is never reached, and in particular the
|
||||||
// temporaries inside the formatting machinery are not still alive at the
|
// temporaries inside the formatting machinery are not still alive at the
|
||||||
// await point.
|
// await point.
|
||||||
f(todo!("...")).await;
|
let todo = "...";
|
||||||
|
f(panic!("not yet implemented: {}", todo)).await;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Exercises ("{}", $arg:expr) => $crate::panicking::panic_display(&$arg)
|
||||||
|
async fn panic_display() {
|
||||||
|
f(panic!("{}", NOT_SEND)).await;
|
||||||
}
|
}
|
||||||
|
|
||||||
fn require_send(_: impl Send) {}
|
fn require_send(_: impl Send) {}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
require_send(g());
|
require_send(panic_fmt());
|
||||||
|
require_send(panic_display());
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user