Rollup merge of #73373 - lzutao:bug-trackcaller, r=Amanieu
Use track caller for bug! macro
This commit is contained in:
commit
94105c2da3
@ -39,8 +39,7 @@ pub struct PanicInfo<'a> {
|
||||
impl<'a> PanicInfo<'a> {
|
||||
#[unstable(
|
||||
feature = "panic_internals",
|
||||
reason = "internal details of the implementation of the `panic!` \
|
||||
and related macros",
|
||||
reason = "internal details of the implementation of the `panic!` and related macros",
|
||||
issue = "none"
|
||||
)]
|
||||
#[doc(hidden)]
|
||||
@ -55,8 +54,7 @@ impl<'a> PanicInfo<'a> {
|
||||
|
||||
#[unstable(
|
||||
feature = "panic_internals",
|
||||
reason = "internal details of the implementation of the `panic!` \
|
||||
and related macros",
|
||||
reason = "internal details of the implementation of the `panic!` and related macros",
|
||||
issue = "none"
|
||||
)]
|
||||
#[doc(hidden)]
|
||||
@ -244,8 +242,7 @@ impl<'a> Location<'a> {
|
||||
impl<'a> Location<'a> {
|
||||
#![unstable(
|
||||
feature = "panic_internals",
|
||||
reason = "internal details of the implementation of the `panic!` \
|
||||
and related macros",
|
||||
reason = "internal details of the implementation of the `panic!` and related macros",
|
||||
issue = "none"
|
||||
)]
|
||||
#[doc(hidden)]
|
||||
|
@ -22,8 +22,7 @@
|
||||
#![allow(dead_code, missing_docs)]
|
||||
#![unstable(
|
||||
feature = "core_panic",
|
||||
reason = "internal details of the implementation of the `panic!` \
|
||||
and related macros",
|
||||
reason = "internal details of the implementation of the `panic!` and related macros",
|
||||
issue = "none"
|
||||
)]
|
||||
|
||||
|
@ -1,16 +1,20 @@
|
||||
#[macro_export]
|
||||
macro_rules! bug {
|
||||
() => ( bug!("impossible case reached") );
|
||||
($($message:tt)*) => ({
|
||||
$crate::util::bug::bug_fmt(file!(), line!(), format_args!($($message)*))
|
||||
})
|
||||
() => ( $crate::bug!("impossible case reached") );
|
||||
($msg:expr) => ({ $crate::util::bug::bug_fmt(::std::format_args!($msg)) });
|
||||
($msg:expr,) => ({ $crate::bug!($msg) });
|
||||
($fmt:expr, $($arg:tt)+) => ({
|
||||
$crate::util::bug::bug_fmt(::std::format_args!($fmt, $($arg)+))
|
||||
});
|
||||
}
|
||||
|
||||
#[macro_export]
|
||||
macro_rules! span_bug {
|
||||
($span:expr, $($message:tt)*) => ({
|
||||
$crate::util::bug::span_bug_fmt(file!(), line!(), $span, format_args!($($message)*))
|
||||
})
|
||||
($span:expr, $msg:expr) => ({ $crate::util::bug::span_bug_fmt($span, ::std::format_args!($msg)) });
|
||||
($span:expr, $msg:expr,) => ({ $crate::span_bug!($span, $msg) });
|
||||
($span:expr, $fmt:expr, $($arg:tt)+) => ({
|
||||
$crate::util::bug::span_bug_fmt($span, ::std::format_args!($fmt, $($arg)+))
|
||||
});
|
||||
}
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////
|
||||
|
@ -189,8 +189,7 @@ fn validate_hir_id_for_typeck_tables(
|
||||
if hir_id.owner != hir_owner {
|
||||
ty::tls::with(|tcx| {
|
||||
bug!(
|
||||
"node {} with HirId::owner {:?} cannot be placed in \
|
||||
TypeckTables with hir_owner {:?}",
|
||||
"node {} with HirId::owner {:?} cannot be placed in TypeckTables with hir_owner {:?}",
|
||||
tcx.hir().node_to_string(hir_id),
|
||||
hir_id.owner,
|
||||
hir_owner
|
||||
|
@ -3,34 +3,31 @@
|
||||
use crate::ty::{tls, TyCtxt};
|
||||
use rustc_span::{MultiSpan, Span};
|
||||
use std::fmt;
|
||||
use std::panic::Location;
|
||||
|
||||
#[cold]
|
||||
#[inline(never)]
|
||||
pub fn bug_fmt(file: &'static str, line: u32, args: fmt::Arguments<'_>) -> ! {
|
||||
#[track_caller]
|
||||
pub fn bug_fmt(args: fmt::Arguments<'_>) -> ! {
|
||||
// this wrapper mostly exists so I don't have to write a fully
|
||||
// qualified path of None::<Span> inside the bug!() macro definition
|
||||
opt_span_bug_fmt(file, line, None::<Span>, args);
|
||||
opt_span_bug_fmt(None::<Span>, args, Location::caller());
|
||||
}
|
||||
|
||||
#[cold]
|
||||
#[inline(never)]
|
||||
pub fn span_bug_fmt<S: Into<MultiSpan>>(
|
||||
file: &'static str,
|
||||
line: u32,
|
||||
span: S,
|
||||
args: fmt::Arguments<'_>,
|
||||
) -> ! {
|
||||
opt_span_bug_fmt(file, line, Some(span), args);
|
||||
#[track_caller]
|
||||
pub fn span_bug_fmt<S: Into<MultiSpan>>(span: S, args: fmt::Arguments<'_>) -> ! {
|
||||
opt_span_bug_fmt(Some(span), args, Location::caller());
|
||||
}
|
||||
|
||||
fn opt_span_bug_fmt<S: Into<MultiSpan>>(
|
||||
file: &'static str,
|
||||
line: u32,
|
||||
span: Option<S>,
|
||||
args: fmt::Arguments<'_>,
|
||||
location: &Location<'_>,
|
||||
) -> ! {
|
||||
tls::with_opt(move |tcx| {
|
||||
let msg = format!("{}:{}: {}", file, line, args);
|
||||
let msg = format!("{}: {}", location, args);
|
||||
match (tcx, span) {
|
||||
(Some(tcx), Some(span)) => tcx.sess.diagnostic().span_bug(span, &msg),
|
||||
(Some(tcx), None) => tcx.sess.diagnostic().bug(&msg),
|
||||
|
@ -201,8 +201,7 @@ fn default_hook(info: &PanicInfo<'_>) {
|
||||
if FIRST_PANIC.swap(false, Ordering::SeqCst) {
|
||||
let _ = writeln!(
|
||||
err,
|
||||
"note: run with `RUST_BACKTRACE=1` \
|
||||
environment variable to display a backtrace"
|
||||
"note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace"
|
||||
);
|
||||
}
|
||||
}
|
||||
@ -454,10 +453,7 @@ fn rust_panic_with_hook(
|
||||
// process real quickly as we don't want to try calling it again as it'll
|
||||
// probably just panic again.
|
||||
if panics > 2 {
|
||||
util::dumb_print(format_args!(
|
||||
"thread panicked while processing \
|
||||
panic. aborting.\n"
|
||||
));
|
||||
util::dumb_print(format_args!("thread panicked while processing panic. aborting.\n"));
|
||||
intrinsics::abort()
|
||||
}
|
||||
|
||||
@ -489,10 +485,7 @@ fn rust_panic_with_hook(
|
||||
// have limited options. Currently our preference is to
|
||||
// just abort. In the future we may consider resuming
|
||||
// unwinding or otherwise exiting the thread cleanly.
|
||||
util::dumb_print(format_args!(
|
||||
"thread panicked while panicking. \
|
||||
aborting.\n"
|
||||
));
|
||||
util::dumb_print(format_args!("thread panicked while panicking. aborting.\n"));
|
||||
intrinsics::abort()
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user