-
Notifications
You must be signed in to change notification settings - Fork 12.7k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
panic: Use local functions in panic!
whenever possible
#128068
Changes from 8 commits
ca16524
cc107fc
11caff4
f2f77f2
a59b918
af6260f
6a4f226
6cbc3eb
7219ce0
555a033
12e23c4
b8d3c62
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -19,23 +19,56 @@ pub use self::unwind_safe::{AssertUnwindSafe, RefUnwindSafe, UnwindSafe}; | |
|
||
#[doc(hidden)] | ||
#[unstable(feature = "edition_panic", issue = "none", reason = "use panic!() instead")] | ||
#[allow_internal_unstable(panic_internals, const_format_args)] | ||
#[allow_internal_unstable( | ||
panic_internals, | ||
core_intrinsics, | ||
const_dispatch, | ||
const_eval_select, | ||
const_format_args, | ||
rustc_attrs | ||
)] | ||
#[rustc_diagnostic_item = "core_panic_2015_macro"] | ||
#[rustc_macro_transparency = "semitransparent"] | ||
pub macro panic_2015 { | ||
() => ( | ||
$crate::panicking::panic("explicit panic") | ||
), | ||
($msg:literal $(,)?) => ( | ||
$crate::panicking::panic($msg) | ||
), | ||
// For all cases where it is possible, wrap the actual call to the | ||
// internal panic implementation function with a local no-inline | ||
// cold function. This moves the codegen for setting up the | ||
// arguments to the panic implementation function to the | ||
// presumably cold panic path. | ||
() => ({ | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
const fn panic_cold_explicit() -> ! { | ||
$crate::panicking::panic("explicit panic"); | ||
} | ||
panic_cold_explicit(); | ||
}), | ||
// Special-case for string literal. | ||
($msg:literal $(,)?) => ({ | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
const fn panic_cold_literal() -> ! { | ||
$crate::panicking::panic($msg); | ||
} | ||
panic_cold_literal(); | ||
}), | ||
// Use `panic_str_2015` instead of `panic_display::<&str>` for non_fmt_panic lint. | ||
($msg:expr $(,)?) => ({ | ||
$crate::panicking::panic_str_2015($msg); | ||
}), | ||
// Special-case the single-argument case for const_panic. | ||
("{}", $arg:expr $(,)?) => ({ | ||
$crate::panicking::panic_display(&$arg); | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
#[rustc_const_panic_str] // enforce a &&str argument in const-check and hook this by const-eval | ||
#[rustc_do_not_const_check] // hooked by const-eval | ||
const fn panic_cold_display<T: $crate::fmt::Display>(arg: &T) -> ! { | ||
$crate::panicking::panic_display(arg) | ||
} | ||
panic_cold_display(&$arg); | ||
}), | ||
($fmt:expr, $($arg:tt)+) => ({ | ||
// Semicolon to prevent temporaries inside the formatting machinery from | ||
|
@@ -44,27 +77,6 @@ pub macro panic_2015 { | |
}), | ||
} | ||
|
||
#[doc(hidden)] | ||
#[unstable(feature = "edition_panic", issue = "none", reason = "use panic!() instead")] | ||
#[allow_internal_unstable(panic_internals, const_format_args)] | ||
#[rustc_diagnostic_item = "core_panic_2021_macro"] | ||
#[rustc_macro_transparency = "semitransparent"] | ||
#[cfg(feature = "panic_immediate_abort")] | ||
pub macro panic_2021 { | ||
() => ( | ||
$crate::panicking::panic("explicit panic") | ||
), | ||
// Special-case the single-argument case for const_panic. | ||
("{}", $arg:expr $(,)?) => ({ | ||
$crate::panicking::panic_display(&$arg); | ||
}), | ||
($($t:tt)+) => ({ | ||
// Semicolon to prevent temporaries inside the formatting machinery from | ||
// being considered alive in the caller after the panic_fmt call. | ||
$crate::panicking::panic_fmt($crate::const_format_args!($($t)+)); | ||
}), | ||
} | ||
workingjubilee marked this conversation as resolved.
Show resolved
Hide resolved
|
||
|
||
#[doc(hidden)] | ||
#[unstable(feature = "edition_panic", issue = "none", reason = "use panic!() instead")] | ||
#[allow_internal_unstable( | ||
|
@@ -77,8 +89,14 @@ pub macro panic_2021 { | |
)] | ||
#[rustc_diagnostic_item = "core_panic_2021_macro"] | ||
#[rustc_macro_transparency = "semitransparent"] | ||
#[cfg(not(feature = "panic_immediate_abort"))] | ||
pub macro panic_2021 { | ||
// For all cases where it is possible, wrap the actual call to the | ||
// internal panic implementation function with a local no-inline | ||
// cold function. This moves the codegen for setting up the | ||
// arguments to the panic implementation function to the | ||
// presumably cold panic path. | ||
// It would be nice to handle literals here, but there are | ||
// some issues handling embedded format arguments. | ||
() => ({ | ||
// Create a function so that the argument for `track_caller` | ||
// can be moved inside if possible. | ||
|
@@ -111,13 +129,40 @@ pub macro panic_2021 { | |
|
||
#[doc(hidden)] | ||
#[unstable(feature = "edition_panic", issue = "none", reason = "use unreachable!() instead")] | ||
#[allow_internal_unstable(panic_internals)] | ||
#[allow_internal_unstable( | ||
panic_internals, | ||
core_intrinsics, | ||
const_dispatch, | ||
const_eval_select, | ||
const_format_args, | ||
rustc_attrs | ||
)] | ||
#[rustc_diagnostic_item = "unreachable_2015_macro"] | ||
#[rustc_macro_transparency = "semitransparent"] | ||
pub macro unreachable_2015 { | ||
() => ( | ||
$crate::panicking::panic("internal error: entered unreachable code") | ||
), | ||
// For all cases where it is possible, wrap the actual call to the | ||
// internal panic implementation function with a local no-inline | ||
// cold function. This moves the codegen for setting up the | ||
// arguments to the panic implementation function to the | ||
// presumably cold panic path. | ||
() => ({ | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
const fn unreachable_cold_explicit() -> ! { | ||
$crate::panicking::panic("internal error: entered unreachable code"); | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Likewise. |
||
unreachable_cold_explicit(); | ||
}), | ||
($msg:literal $(,)?) => ({ | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
const fn unreachable_cold_literal() -> ! { | ||
$crate::panicking::unreachable_display(&$msg); | ||
} | ||
unreachable_cold_literal(); | ||
}), | ||
// Use of `unreachable_display` for non_fmt_panic lint. | ||
// NOTE: the message ("internal error ...") is embedded directly in unreachable_display | ||
($msg:expr $(,)?) => ({ | ||
|
@@ -130,12 +175,37 @@ pub macro unreachable_2015 { | |
|
||
#[doc(hidden)] | ||
#[unstable(feature = "edition_panic", issue = "none", reason = "use unreachable!() instead")] | ||
#[allow_internal_unstable(panic_internals)] | ||
#[allow_internal_unstable( | ||
panic_internals, | ||
core_intrinsics, | ||
const_dispatch, | ||
const_eval_select, | ||
const_format_args, | ||
rustc_attrs | ||
)] | ||
#[rustc_macro_transparency = "semitransparent"] | ||
pub macro unreachable_2021 { | ||
() => ( | ||
$crate::panicking::panic("internal error: entered unreachable code") | ||
), | ||
() => ({ | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
const fn unreachable_cold_explicit() -> ! { | ||
$crate::panicking::panic("internal error: entered unreachable code"); | ||
} | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. And here. |
||
unreachable_cold_explicit(); | ||
}), | ||
// Special-case the single-argument case for const_panic. | ||
("{}", $arg:expr $(,)?) => ({ | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
#[rustc_const_panic_str] // enforce a &&str argument in const-check and hook this by const-eval | ||
#[rustc_do_not_const_check] // hooked by const-eval | ||
const fn unreachable_cold_display<T: $crate::fmt::Display>(arg: &T) -> ! { | ||
$crate::panicking::unreachable_display(arg) | ||
} | ||
unreachable_cold_display(&$arg); | ||
}), | ||
($($t:tt)+) => ( | ||
$crate::panic!("internal error: entered unreachable code: {}", $crate::format_args!($($t)+)) | ||
), | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -212,19 +212,49 @@ impl fmt::Display for PanicHookInfo<'_> { | |
|
||
#[doc(hidden)] | ||
#[unstable(feature = "edition_panic", issue = "none", reason = "use panic!() instead")] | ||
#[allow_internal_unstable(libstd_sys_internals, const_format_args, panic_internals, rt)] | ||
#[allow_internal_unstable( | ||
libstd_sys_internals, | ||
const_format_args, | ||
panic_internals, | ||
rt, | ||
const_dispatch, | ||
const_eval_select, | ||
rustc_attrs | ||
)] | ||
#[cfg_attr(not(test), rustc_diagnostic_item = "std_panic_2015_macro")] | ||
#[rustc_macro_transparency = "semitransparent"] | ||
pub macro panic_2015 { | ||
// For all cases where it is possible, wrap the actual call to the | ||
// internal panic implementation function with a local no-inline | ||
// cold function. This moves the codegen for setting up the | ||
// arguments to the panic implementation function to the | ||
// presumably cold panic path. | ||
// It would be nice to handle literals here specially with a | ||
// wrapper function, but unfortunately it results in unclear error | ||
// messages when using panic(<non-str>). | ||
() => ({ | ||
$crate::rt::begin_panic("explicit panic") | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
const fn panic_cold_explicit() -> ! { | ||
$crate::rt::begin_panic("explicit panic"); | ||
} | ||
Comment on lines
+236
to
+241
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. You get the point... |
||
panic_cold_explicit(); | ||
}), | ||
($msg:expr $(,)?) => ({ | ||
$crate::rt::begin_panic($msg); | ||
}), | ||
// Special-case the single-argument case for const_panic. | ||
("{}", $arg:expr $(,)?) => ({ | ||
$crate::rt::panic_display(&$arg); | ||
#[cold] | ||
#[track_caller] | ||
#[inline(never)] | ||
#[rustc_const_panic_str] // enforce a &&str argument in const-check and hook this by const-eval | ||
#[rustc_do_not_const_check] // hooked by const-eval | ||
const fn panic_cold_display<T: $crate::fmt::Display>(arg: &T) -> ! { | ||
$crate::rt::panic_display(arg) | ||
} | ||
panic_cold_display(&$arg); | ||
}), | ||
($fmt:expr, $($arg:tt)+) => ({ | ||
// Semicolon to prevent temporaries inside the formatting machinery from | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
As it's the same everywhere, this could be moved to
panicking
.