Auto merge of #103217 - mejrs:track, r=eholk
Track where diagnostics were created. This implements the `-Ztrack-diagnostics` flag, which uses `#[track_caller]` to track where diagnostics are created. It is meant as a debugging tool much like `-Ztreat-err-as-bug`. For example, the following code... ```rust struct A; struct B; fn main(){ let _: A = B; } ``` ...now emits the following error message: ``` error[E0308]: mismatched types --> src\main.rs:5:16 | 5 | let _: A = B; | - ^ expected struct `A`, found struct `B` | | | expected due to this -Ztrack-diagnostics: created at compiler\rustc_infer\src\infer\error_reporting\mod.rs:2275:31 ```
This commit is contained in:
commit
11ebe6512b
42 changed files with 385 additions and 8 deletions
|
@ -1200,6 +1200,7 @@ pub fn report_ice(info: &panic::PanicInfo<'_>, bug_report_url: &str) {
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
));
|
));
|
||||||
let handler = rustc_errors::Handler::with_emitter(true, None, emitter);
|
let handler = rustc_errors::Handler::with_emitter(true, None, emitter);
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,7 @@ use rustc_span::{Span, DUMMY_SP};
|
||||||
use std::borrow::Cow;
|
use std::borrow::Cow;
|
||||||
use std::fmt;
|
use std::fmt;
|
||||||
use std::hash::{Hash, Hasher};
|
use std::hash::{Hash, Hasher};
|
||||||
|
use std::panic::Location;
|
||||||
|
|
||||||
/// Error type for `Diagnostic`'s `suggestions` field, indicating that
|
/// Error type for `Diagnostic`'s `suggestions` field, indicating that
|
||||||
/// `.disable_suggestions()` was called on the `Diagnostic`.
|
/// `.disable_suggestions()` was called on the `Diagnostic`.
|
||||||
|
@ -107,6 +108,31 @@ pub struct Diagnostic {
|
||||||
/// If diagnostic is from Lint, custom hash function ignores notes
|
/// If diagnostic is from Lint, custom hash function ignores notes
|
||||||
/// otherwise hash is based on the all the fields
|
/// otherwise hash is based on the all the fields
|
||||||
pub is_lint: bool,
|
pub is_lint: bool,
|
||||||
|
|
||||||
|
/// With `-Ztrack_diagnostics` enabled,
|
||||||
|
/// we print where in rustc this error was emitted.
|
||||||
|
pub emitted_at: DiagnosticLocation,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Debug, Encodable, Decodable)]
|
||||||
|
pub struct DiagnosticLocation {
|
||||||
|
file: Cow<'static, str>,
|
||||||
|
line: u32,
|
||||||
|
col: u32,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl DiagnosticLocation {
|
||||||
|
#[track_caller]
|
||||||
|
fn caller() -> Self {
|
||||||
|
let loc = Location::caller();
|
||||||
|
DiagnosticLocation { file: loc.file().into(), line: loc.line(), col: loc.column() }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl fmt::Display for DiagnosticLocation {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
||||||
|
write!(f, "{}:{}:{}", self.file, self.line, self.col)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug, PartialEq, Eq, Hash, Encodable, Decodable)]
|
#[derive(Clone, Debug, PartialEq, Eq, Hash, Encodable, Decodable)]
|
||||||
|
@ -173,10 +199,12 @@ impl StringPart {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Diagnostic {
|
impl Diagnostic {
|
||||||
|
#[track_caller]
|
||||||
pub fn new<M: Into<DiagnosticMessage>>(level: Level, message: M) -> Self {
|
pub fn new<M: Into<DiagnosticMessage>>(level: Level, message: M) -> Self {
|
||||||
Diagnostic::new_with_code(level, None, message)
|
Diagnostic::new_with_code(level, None, message)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn new_with_code<M: Into<DiagnosticMessage>>(
|
pub fn new_with_code<M: Into<DiagnosticMessage>>(
|
||||||
level: Level,
|
level: Level,
|
||||||
code: Option<DiagnosticId>,
|
code: Option<DiagnosticId>,
|
||||||
|
@ -192,6 +220,7 @@ impl Diagnostic {
|
||||||
args: Default::default(),
|
args: Default::default(),
|
||||||
sort_span: DUMMY_SP,
|
sort_span: DUMMY_SP,
|
||||||
is_lint: false,
|
is_lint: false,
|
||||||
|
emitted_at: DiagnosticLocation::caller(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -133,6 +133,7 @@ mod sealed_level_is_error {
|
||||||
impl<'a> DiagnosticBuilder<'a, ErrorGuaranteed> {
|
impl<'a> DiagnosticBuilder<'a, ErrorGuaranteed> {
|
||||||
/// Convenience function for internal use, clients should use one of the
|
/// Convenience function for internal use, clients should use one of the
|
||||||
/// `struct_*` methods on [`Handler`].
|
/// `struct_*` methods on [`Handler`].
|
||||||
|
#[track_caller]
|
||||||
pub(crate) fn new_guaranteeing_error<M: Into<DiagnosticMessage>, const L: Level>(
|
pub(crate) fn new_guaranteeing_error<M: Into<DiagnosticMessage>, const L: Level>(
|
||||||
handler: &'a Handler,
|
handler: &'a Handler,
|
||||||
message: M,
|
message: M,
|
||||||
|
@ -196,6 +197,7 @@ impl EmissionGuarantee for ErrorGuaranteed {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
fn make_diagnostic_builder(
|
fn make_diagnostic_builder(
|
||||||
handler: &Handler,
|
handler: &Handler,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -209,6 +211,7 @@ impl EmissionGuarantee for ErrorGuaranteed {
|
||||||
impl<'a> DiagnosticBuilder<'a, ()> {
|
impl<'a> DiagnosticBuilder<'a, ()> {
|
||||||
/// Convenience function for internal use, clients should use one of the
|
/// Convenience function for internal use, clients should use one of the
|
||||||
/// `struct_*` methods on [`Handler`].
|
/// `struct_*` methods on [`Handler`].
|
||||||
|
#[track_caller]
|
||||||
pub(crate) fn new<M: Into<DiagnosticMessage>>(
|
pub(crate) fn new<M: Into<DiagnosticMessage>>(
|
||||||
handler: &'a Handler,
|
handler: &'a Handler,
|
||||||
level: Level,
|
level: Level,
|
||||||
|
@ -220,6 +223,7 @@ impl<'a> DiagnosticBuilder<'a, ()> {
|
||||||
|
|
||||||
/// Creates a new `DiagnosticBuilder` with an already constructed
|
/// Creates a new `DiagnosticBuilder` with an already constructed
|
||||||
/// diagnostic.
|
/// diagnostic.
|
||||||
|
#[track_caller]
|
||||||
pub(crate) fn new_diagnostic(handler: &'a Handler, diagnostic: Diagnostic) -> Self {
|
pub(crate) fn new_diagnostic(handler: &'a Handler, diagnostic: Diagnostic) -> Self {
|
||||||
debug!("Created new diagnostic");
|
debug!("Created new diagnostic");
|
||||||
Self {
|
Self {
|
||||||
|
@ -308,6 +312,7 @@ impl EmissionGuarantee for Noted {
|
||||||
impl<'a> DiagnosticBuilder<'a, !> {
|
impl<'a> DiagnosticBuilder<'a, !> {
|
||||||
/// Convenience function for internal use, clients should use one of the
|
/// Convenience function for internal use, clients should use one of the
|
||||||
/// `struct_*` methods on [`Handler`].
|
/// `struct_*` methods on [`Handler`].
|
||||||
|
#[track_caller]
|
||||||
pub(crate) fn new_fatal(handler: &'a Handler, message: impl Into<DiagnosticMessage>) -> Self {
|
pub(crate) fn new_fatal(handler: &'a Handler, message: impl Into<DiagnosticMessage>) -> Self {
|
||||||
let diagnostic = Diagnostic::new_with_code(Level::Fatal, None, message);
|
let diagnostic = Diagnostic::new_with_code(Level::Fatal, None, message);
|
||||||
Self::new_diagnostic_fatal(handler, diagnostic)
|
Self::new_diagnostic_fatal(handler, diagnostic)
|
||||||
|
|
|
@ -16,10 +16,10 @@ use crate::snippet::{Annotation, AnnotationType, Line, MultilineAnnotation, Styl
|
||||||
use crate::styled_buffer::StyledBuffer;
|
use crate::styled_buffer::StyledBuffer;
|
||||||
use crate::translation::{to_fluent_args, Translate};
|
use crate::translation::{to_fluent_args, Translate};
|
||||||
use crate::{
|
use crate::{
|
||||||
CodeSuggestion, Diagnostic, DiagnosticId, DiagnosticMessage, FluentBundle, Handler,
|
diagnostic::DiagnosticLocation, CodeSuggestion, Diagnostic, DiagnosticId, DiagnosticMessage,
|
||||||
LazyFallbackBundle, Level, MultiSpan, SubDiagnostic, SubstitutionHighlight, SuggestionStyle,
|
FluentBundle, Handler, LazyFallbackBundle, Level, MultiSpan, SubDiagnostic,
|
||||||
|
SubstitutionHighlight, SuggestionStyle,
|
||||||
};
|
};
|
||||||
|
|
||||||
use rustc_lint_defs::pluralize;
|
use rustc_lint_defs::pluralize;
|
||||||
|
|
||||||
use rustc_data_structures::fx::{FxHashMap, FxIndexMap};
|
use rustc_data_structures::fx::{FxHashMap, FxIndexMap};
|
||||||
|
@ -64,6 +64,7 @@ impl HumanReadableErrorType {
|
||||||
teach: bool,
|
teach: bool,
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
) -> EmitterWriter {
|
) -> EmitterWriter {
|
||||||
let (short, color_config) = self.unzip();
|
let (short, color_config) = self.unzip();
|
||||||
let color = color_config.suggests_using_colors();
|
let color = color_config.suggests_using_colors();
|
||||||
|
@ -77,6 +78,7 @@ impl HumanReadableErrorType {
|
||||||
color,
|
color,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -557,6 +559,7 @@ impl Emitter for EmitterWriter {
|
||||||
&primary_span,
|
&primary_span,
|
||||||
&children,
|
&children,
|
||||||
&suggestions,
|
&suggestions,
|
||||||
|
self.track_diagnostics.then_some(&diag.emitted_at),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -650,6 +653,7 @@ pub struct EmitterWriter {
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
|
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
|
@ -669,6 +673,7 @@ impl EmitterWriter {
|
||||||
teach: bool,
|
teach: bool,
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
) -> EmitterWriter {
|
) -> EmitterWriter {
|
||||||
let dst = Destination::from_stderr(color_config);
|
let dst = Destination::from_stderr(color_config);
|
||||||
EmitterWriter {
|
EmitterWriter {
|
||||||
|
@ -681,6 +686,7 @@ impl EmitterWriter {
|
||||||
ui_testing: false,
|
ui_testing: false,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -694,6 +700,7 @@ impl EmitterWriter {
|
||||||
colored: bool,
|
colored: bool,
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
) -> EmitterWriter {
|
) -> EmitterWriter {
|
||||||
EmitterWriter {
|
EmitterWriter {
|
||||||
dst: Raw(dst, colored),
|
dst: Raw(dst, colored),
|
||||||
|
@ -705,6 +712,7 @@ impl EmitterWriter {
|
||||||
ui_testing: false,
|
ui_testing: false,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1327,6 +1335,7 @@ impl EmitterWriter {
|
||||||
level: &Level,
|
level: &Level,
|
||||||
max_line_num_len: usize,
|
max_line_num_len: usize,
|
||||||
is_secondary: bool,
|
is_secondary: bool,
|
||||||
|
emitted_at: Option<&DiagnosticLocation>,
|
||||||
) -> io::Result<()> {
|
) -> io::Result<()> {
|
||||||
let mut buffer = StyledBuffer::new();
|
let mut buffer = StyledBuffer::new();
|
||||||
|
|
||||||
|
@ -1377,7 +1386,6 @@ impl EmitterWriter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
let mut annotated_files = FileWithAnnotatedLines::collect_annotations(self, args, msp);
|
let mut annotated_files = FileWithAnnotatedLines::collect_annotations(self, args, msp);
|
||||||
|
|
||||||
// Make sure our primary file comes first
|
// Make sure our primary file comes first
|
||||||
|
@ -1653,6 +1661,12 @@ impl EmitterWriter {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if let Some(tracked) = emitted_at {
|
||||||
|
let track = format!("-Ztrack-diagnostics: created at {tracked}");
|
||||||
|
let len = buffer.num_lines();
|
||||||
|
buffer.append(len, &track, Style::NoStyle);
|
||||||
|
}
|
||||||
|
|
||||||
// final step: take our styled buffer, render it, then output it
|
// final step: take our styled buffer, render it, then output it
|
||||||
emit_to_destination(&buffer.render(), level, &mut self.dst, self.short_message)?;
|
emit_to_destination(&buffer.render(), level, &mut self.dst, self.short_message)?;
|
||||||
|
|
||||||
|
@ -1977,6 +1991,7 @@ impl EmitterWriter {
|
||||||
span: &MultiSpan,
|
span: &MultiSpan,
|
||||||
children: &[SubDiagnostic],
|
children: &[SubDiagnostic],
|
||||||
suggestions: &[CodeSuggestion],
|
suggestions: &[CodeSuggestion],
|
||||||
|
emitted_at: Option<&DiagnosticLocation>,
|
||||||
) {
|
) {
|
||||||
let max_line_num_len = if self.ui_testing {
|
let max_line_num_len = if self.ui_testing {
|
||||||
ANONYMIZED_LINE_NUM.len()
|
ANONYMIZED_LINE_NUM.len()
|
||||||
|
@ -1985,7 +2000,16 @@ impl EmitterWriter {
|
||||||
num_decimal_digits(n)
|
num_decimal_digits(n)
|
||||||
};
|
};
|
||||||
|
|
||||||
match self.emit_message_default(span, message, args, code, level, max_line_num_len, false) {
|
match self.emit_message_default(
|
||||||
|
span,
|
||||||
|
message,
|
||||||
|
args,
|
||||||
|
code,
|
||||||
|
level,
|
||||||
|
max_line_num_len,
|
||||||
|
false,
|
||||||
|
emitted_at,
|
||||||
|
) {
|
||||||
Ok(()) => {
|
Ok(()) => {
|
||||||
if !children.is_empty()
|
if !children.is_empty()
|
||||||
|| suggestions.iter().any(|s| s.style != SuggestionStyle::CompletelyHidden)
|
|| suggestions.iter().any(|s| s.style != SuggestionStyle::CompletelyHidden)
|
||||||
|
@ -2014,6 +2038,7 @@ impl EmitterWriter {
|
||||||
&child.level,
|
&child.level,
|
||||||
max_line_num_len,
|
max_line_num_len,
|
||||||
true,
|
true,
|
||||||
|
None,
|
||||||
) {
|
) {
|
||||||
panic!("failed to emit error: {}", err);
|
panic!("failed to emit error: {}", err);
|
||||||
}
|
}
|
||||||
|
@ -2030,6 +2055,7 @@ impl EmitterWriter {
|
||||||
&Level::Help,
|
&Level::Help,
|
||||||
max_line_num_len,
|
max_line_num_len,
|
||||||
true,
|
true,
|
||||||
|
None,
|
||||||
) {
|
) {
|
||||||
panic!("failed to emit error: {}", e);
|
panic!("failed to emit error: {}", e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -45,6 +45,7 @@ pub struct JsonEmitter {
|
||||||
json_rendered: HumanReadableErrorType,
|
json_rendered: HumanReadableErrorType,
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl JsonEmitter {
|
impl JsonEmitter {
|
||||||
|
@ -57,6 +58,7 @@ impl JsonEmitter {
|
||||||
json_rendered: HumanReadableErrorType,
|
json_rendered: HumanReadableErrorType,
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
) -> JsonEmitter {
|
) -> JsonEmitter {
|
||||||
JsonEmitter {
|
JsonEmitter {
|
||||||
dst: Box::new(io::BufWriter::new(io::stderr())),
|
dst: Box::new(io::BufWriter::new(io::stderr())),
|
||||||
|
@ -69,6 +71,7 @@ impl JsonEmitter {
|
||||||
json_rendered,
|
json_rendered,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -79,6 +82,7 @@ impl JsonEmitter {
|
||||||
fallback_bundle: LazyFallbackBundle,
|
fallback_bundle: LazyFallbackBundle,
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
) -> JsonEmitter {
|
) -> JsonEmitter {
|
||||||
let file_path_mapping = FilePathMapping::empty();
|
let file_path_mapping = FilePathMapping::empty();
|
||||||
JsonEmitter::stderr(
|
JsonEmitter::stderr(
|
||||||
|
@ -90,6 +94,7 @@ impl JsonEmitter {
|
||||||
json_rendered,
|
json_rendered,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,6 +108,7 @@ impl JsonEmitter {
|
||||||
json_rendered: HumanReadableErrorType,
|
json_rendered: HumanReadableErrorType,
|
||||||
diagnostic_width: Option<usize>,
|
diagnostic_width: Option<usize>,
|
||||||
macro_backtrace: bool,
|
macro_backtrace: bool,
|
||||||
|
track_diagnostics: bool,
|
||||||
) -> JsonEmitter {
|
) -> JsonEmitter {
|
||||||
JsonEmitter {
|
JsonEmitter {
|
||||||
dst,
|
dst,
|
||||||
|
@ -115,6 +121,7 @@ impl JsonEmitter {
|
||||||
json_rendered,
|
json_rendered,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -350,6 +357,7 @@ impl Diagnostic {
|
||||||
false,
|
false,
|
||||||
je.diagnostic_width,
|
je.diagnostic_width,
|
||||||
je.macro_backtrace,
|
je.macro_backtrace,
|
||||||
|
je.track_diagnostics,
|
||||||
)
|
)
|
||||||
.ui_testing(je.ui_testing)
|
.ui_testing(je.ui_testing)
|
||||||
.emit_diagnostic(diag);
|
.emit_diagnostic(diag);
|
||||||
|
|
|
@ -59,6 +59,7 @@ fn test_positions(code: &str, span: (u32, u32), expected_output: SpanTestData) {
|
||||||
HumanReadableErrorType::Short(ColorConfig::Never),
|
HumanReadableErrorType::Short(ColorConfig::Never),
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
);
|
);
|
||||||
|
|
||||||
let span = Span::with_root_ctxt(BytePos(span.0), BytePos(span.1));
|
let span = Span::with_root_ctxt(BytePos(span.0), BytePos(span.1));
|
||||||
|
|
|
@ -492,6 +492,8 @@ pub struct HandlerFlags {
|
||||||
pub macro_backtrace: bool,
|
pub macro_backtrace: bool,
|
||||||
/// If true, identical diagnostics are reported only once.
|
/// If true, identical diagnostics are reported only once.
|
||||||
pub deduplicate_diagnostics: bool,
|
pub deduplicate_diagnostics: bool,
|
||||||
|
/// Track where errors are created. Enabled with `-Ztrack-diagnostics`.
|
||||||
|
pub track_diagnostics: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Drop for HandlerInner {
|
impl Drop for HandlerInner {
|
||||||
|
@ -559,6 +561,7 @@ impl Handler {
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
flags.macro_backtrace,
|
flags.macro_backtrace,
|
||||||
|
flags.track_diagnostics,
|
||||||
));
|
));
|
||||||
Self::with_emitter_and_flags(emitter, flags)
|
Self::with_emitter_and_flags(emitter, flags)
|
||||||
}
|
}
|
||||||
|
@ -664,6 +667,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder with the `msg` at the level appropriate for the specific `EmissionGuarantee`.
|
/// Construct a builder with the `msg` at the level appropriate for the specific `EmissionGuarantee`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_diagnostic<G: EmissionGuarantee>(
|
pub fn struct_diagnostic<G: EmissionGuarantee>(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -677,6 +681,7 @@ impl Handler {
|
||||||
/// * `can_emit_warnings` is `true`
|
/// * `can_emit_warnings` is `true`
|
||||||
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_warn(
|
pub fn struct_span_warn(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -693,6 +698,7 @@ impl Handler {
|
||||||
/// Attempting to `.emit()` the builder will only emit if either:
|
/// Attempting to `.emit()` the builder will only emit if either:
|
||||||
/// * `can_emit_warnings` is `true`
|
/// * `can_emit_warnings` is `true`
|
||||||
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_warn_with_expectation(
|
pub fn struct_span_warn_with_expectation(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -706,6 +712,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Allow` level at the given `span` and with the `msg`.
|
/// Construct a builder at the `Allow` level at the given `span` and with the `msg`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_allow(
|
pub fn struct_span_allow(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -719,6 +726,7 @@ impl Handler {
|
||||||
/// Construct a builder at the `Warning` level at the given `span` and with the `msg`.
|
/// Construct a builder at the `Warning` level at the given `span` and with the `msg`.
|
||||||
/// Also include a code.
|
/// Also include a code.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_warn_with_code(
|
pub fn struct_span_warn_with_code(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -736,6 +744,7 @@ impl Handler {
|
||||||
/// * `can_emit_warnings` is `true`
|
/// * `can_emit_warnings` is `true`
|
||||||
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_warn(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
pub fn struct_warn(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
||||||
DiagnosticBuilder::new(self, Level::Warning(None), msg)
|
DiagnosticBuilder::new(self, Level::Warning(None), msg)
|
||||||
}
|
}
|
||||||
|
@ -746,6 +755,7 @@ impl Handler {
|
||||||
/// Attempting to `.emit()` the builder will only emit if either:
|
/// Attempting to `.emit()` the builder will only emit if either:
|
||||||
/// * `can_emit_warnings` is `true`
|
/// * `can_emit_warnings` is `true`
|
||||||
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
/// * `is_force_warn` was set in `DiagnosticId::Lint`
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_warn_with_expectation(
|
pub fn struct_warn_with_expectation(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -756,12 +766,14 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Allow` level with the `msg`.
|
/// Construct a builder at the `Allow` level with the `msg`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_allow(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
pub fn struct_allow(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
||||||
DiagnosticBuilder::new(self, Level::Allow, msg)
|
DiagnosticBuilder::new(self, Level::Allow, msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Construct a builder at the `Expect` level with the `msg`.
|
/// Construct a builder at the `Expect` level with the `msg`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_expect(
|
pub fn struct_expect(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -772,6 +784,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Error` level at the given `span` and with the `msg`.
|
/// Construct a builder at the `Error` level at the given `span` and with the `msg`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_err(
|
pub fn struct_span_err(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -784,6 +797,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Error` level at the given `span`, with the `msg`, and `code`.
|
/// Construct a builder at the `Error` level at the given `span`, with the `msg`, and `code`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_err_with_code(
|
pub fn struct_span_err_with_code(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -798,6 +812,7 @@ impl Handler {
|
||||||
/// Construct a builder at the `Error` level with the `msg`.
|
/// Construct a builder at the `Error` level with the `msg`.
|
||||||
// FIXME: This method should be removed (every error should have an associated error code).
|
// FIXME: This method should be removed (every error should have an associated error code).
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_err(
|
pub fn struct_err(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -807,12 +822,14 @@ impl Handler {
|
||||||
|
|
||||||
/// This should only be used by `rustc_middle::lint::struct_lint_level`. Do not use it for hard errors.
|
/// This should only be used by `rustc_middle::lint::struct_lint_level`. Do not use it for hard errors.
|
||||||
#[doc(hidden)]
|
#[doc(hidden)]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_err_lint(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
pub fn struct_err_lint(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
||||||
DiagnosticBuilder::new(self, Level::Error { lint: true }, msg)
|
DiagnosticBuilder::new(self, Level::Error { lint: true }, msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Construct a builder at the `Error` level with the `msg` and the `code`.
|
/// Construct a builder at the `Error` level with the `msg` and the `code`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_err_with_code(
|
pub fn struct_err_with_code(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -825,6 +842,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Warn` level with the `msg` and the `code`.
|
/// Construct a builder at the `Warn` level with the `msg` and the `code`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_warn_with_code(
|
pub fn struct_warn_with_code(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -837,6 +855,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Fatal` level at the given `span` and with the `msg`.
|
/// Construct a builder at the `Fatal` level at the given `span` and with the `msg`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_fatal(
|
pub fn struct_span_fatal(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -849,6 +868,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Fatal` level at the given `span`, with the `msg`, and `code`.
|
/// Construct a builder at the `Fatal` level at the given `span`, with the `msg`, and `code`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_fatal_with_code(
|
pub fn struct_span_fatal_with_code(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -862,6 +882,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Error` level with the `msg`.
|
/// Construct a builder at the `Error` level with the `msg`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_fatal(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, !> {
|
pub fn struct_fatal(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, !> {
|
||||||
DiagnosticBuilder::new_fatal(self, msg)
|
DiagnosticBuilder::new_fatal(self, msg)
|
||||||
}
|
}
|
||||||
|
@ -874,6 +895,7 @@ impl Handler {
|
||||||
|
|
||||||
/// Construct a builder at the `Note` level with the `msg`.
|
/// Construct a builder at the `Note` level with the `msg`.
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_note_without_error(
|
pub fn struct_note_without_error(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -882,12 +904,14 @@ impl Handler {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_fatal(&self, span: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) -> ! {
|
pub fn span_fatal(&self, span: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) -> ! {
|
||||||
self.emit_diag_at_span(Diagnostic::new(Fatal, msg), span);
|
self.emit_diag_at_span(Diagnostic::new(Fatal, msg), span);
|
||||||
FatalError.raise()
|
FatalError.raise()
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_fatal_with_code(
|
pub fn span_fatal_with_code(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -899,6 +923,7 @@ impl Handler {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_err(
|
pub fn span_err(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -908,6 +933,7 @@ impl Handler {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_err_with_code(
|
pub fn span_err_with_code(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -921,11 +947,13 @@ impl Handler {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_warn(&self, span: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) {
|
pub fn span_warn(&self, span: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) {
|
||||||
self.emit_diag_at_span(Diagnostic::new(Warning(None), msg), span);
|
self.emit_diag_at_span(Diagnostic::new(Warning(None), msg), span);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_warn_with_code(
|
pub fn span_warn_with_code(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -954,10 +982,12 @@ impl Handler {
|
||||||
self.inner.borrow_mut().delay_good_path_bug(msg)
|
self.inner.borrow_mut().delay_good_path_bug(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn span_bug_no_panic(&self, span: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) {
|
pub fn span_bug_no_panic(&self, span: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) {
|
||||||
self.emit_diag_at_span(Diagnostic::new(Bug, msg), span);
|
self.emit_diag_at_span(Diagnostic::new(Bug, msg), span);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn span_note_without_error(
|
pub fn span_note_without_error(
|
||||||
&self,
|
&self,
|
||||||
span: impl Into<MultiSpan>,
|
span: impl Into<MultiSpan>,
|
||||||
|
@ -966,6 +996,7 @@ impl Handler {
|
||||||
self.emit_diag_at_span(Diagnostic::new(Note, msg), span);
|
self.emit_diag_at_span(Diagnostic::new(Note, msg), span);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn span_note_diag(
|
pub fn span_note_diag(
|
||||||
&self,
|
&self,
|
||||||
span: Span,
|
span: Span,
|
||||||
|
@ -1452,6 +1483,7 @@ impl HandlerInner {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
fn span_bug(&mut self, sp: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) -> ! {
|
fn span_bug(&mut self, sp: impl Into<MultiSpan>, msg: impl Into<DiagnosticMessage>) -> ! {
|
||||||
self.emit_diag_at_span(Diagnostic::new(Bug, msg), sp);
|
self.emit_diag_at_span(Diagnostic::new(Bug, msg), sp);
|
||||||
panic::panic_any(ExplicitBug);
|
panic::panic_any(ExplicitBug);
|
||||||
|
|
|
@ -151,6 +151,7 @@ fn test_harness(file_text: &str, span_labels: Vec<SpanLabel>, expected_output: &
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
);
|
);
|
||||||
let handler = Handler::with_emitter(true, None, Box::new(emitter));
|
let handler = Handler::with_emitter(true, None, Box::new(emitter));
|
||||||
handler.span_err(msp, "foo");
|
handler.span_err(msp, "foo");
|
||||||
|
|
|
@ -156,6 +156,7 @@ pub struct MissingTypeParams {
|
||||||
|
|
||||||
// Manual implementation of `IntoDiagnostic` to be able to call `span_to_snippet`.
|
// Manual implementation of `IntoDiagnostic` to be able to call `span_to_snippet`.
|
||||||
impl<'a> IntoDiagnostic<'a> for MissingTypeParams {
|
impl<'a> IntoDiagnostic<'a> for MissingTypeParams {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(self, handler: &'a Handler) -> DiagnosticBuilder<'a, ErrorGuaranteed> {
|
fn into_diagnostic(self, handler: &'a Handler) -> DiagnosticBuilder<'a, ErrorGuaranteed> {
|
||||||
let mut err = handler.struct_span_err_with_code(
|
let mut err = handler.struct_span_err_with_code(
|
||||||
self.span,
|
self.span,
|
||||||
|
|
|
@ -690,6 +690,7 @@ fn test_unstable_options_tracking_hash() {
|
||||||
untracked!(time_llvm_passes, true);
|
untracked!(time_llvm_passes, true);
|
||||||
untracked!(time_passes, true);
|
untracked!(time_passes, true);
|
||||||
untracked!(trace_macros, true);
|
untracked!(trace_macros, true);
|
||||||
|
untracked!(track_diagnostics, true);
|
||||||
untracked!(trim_diagnostic_paths, false);
|
untracked!(trim_diagnostic_paths, false);
|
||||||
untracked!(ui_testing, true);
|
untracked!(ui_testing, true);
|
||||||
untracked!(unpretty, Some("expanded".to_string()));
|
untracked!(unpretty, Some("expanded".to_string()));
|
||||||
|
|
|
@ -69,6 +69,8 @@ impl<'a> DiagnosticDerive<'a> {
|
||||||
for @Self
|
for @Self
|
||||||
where G: rustc_errors::EmissionGuarantee
|
where G: rustc_errors::EmissionGuarantee
|
||||||
{
|
{
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
#handler: &'__diagnostic_handler_sess rustc_errors::Handler
|
#handler: &'__diagnostic_handler_sess rustc_errors::Handler
|
||||||
|
@ -133,6 +135,7 @@ impl<'a> LintDiagnosticDerive<'a> {
|
||||||
let diag = &builder.diag;
|
let diag = &builder.diag;
|
||||||
structure.gen_impl(quote! {
|
structure.gen_impl(quote! {
|
||||||
gen impl<'__a> rustc_errors::DecorateLint<'__a, ()> for @Self {
|
gen impl<'__a> rustc_errors::DecorateLint<'__a, ()> for @Self {
|
||||||
|
#[track_caller]
|
||||||
fn decorate_lint<'__b>(
|
fn decorate_lint<'__b>(
|
||||||
self,
|
self,
|
||||||
#diag: &'__b mut rustc_errors::DiagnosticBuilder<'__a, ()>
|
#diag: &'__b mut rustc_errors::DiagnosticBuilder<'__a, ()>
|
||||||
|
|
|
@ -603,6 +603,7 @@ pub struct InvalidMetadataFiles {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnostic<'_> for InvalidMetadataFiles {
|
impl IntoDiagnostic<'_> for InvalidMetadataFiles {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &'_ rustc_errors::Handler,
|
handler: &'_ rustc_errors::Handler,
|
||||||
|
@ -631,6 +632,7 @@ pub struct CannotFindCrate {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnostic<'_> for CannotFindCrate {
|
impl IntoDiagnostic<'_> for CannotFindCrate {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &'_ rustc_errors::Handler,
|
handler: &'_ rustc_errors::Handler,
|
||||||
|
|
|
@ -39,6 +39,7 @@ pub struct UnusedGenericParams {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnostic<'_> for UnusedGenericParams {
|
impl IntoDiagnostic<'_> for UnusedGenericParams {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &'_ rustc_errors::Handler,
|
handler: &'_ rustc_errors::Handler,
|
||||||
|
|
|
@ -918,6 +918,7 @@ pub(crate) struct ExpectedIdentifier {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, G: EmissionGuarantee> IntoDiagnostic<'a, G> for ExpectedIdentifier {
|
impl<'a, G: EmissionGuarantee> IntoDiagnostic<'a, G> for ExpectedIdentifier {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &'a rustc_errors::Handler,
|
handler: &'a rustc_errors::Handler,
|
||||||
|
@ -963,6 +964,7 @@ pub(crate) struct ExpectedSemi {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a, G: EmissionGuarantee> IntoDiagnostic<'a, G> for ExpectedSemi {
|
impl<'a, G: EmissionGuarantee> IntoDiagnostic<'a, G> for ExpectedSemi {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &'a rustc_errors::Handler,
|
handler: &'a rustc_errors::Handler,
|
||||||
|
|
|
@ -736,6 +736,7 @@ pub struct InvalidAttrAtCrateLevel {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnostic<'_> for InvalidAttrAtCrateLevel {
|
impl IntoDiagnostic<'_> for InvalidAttrAtCrateLevel {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &'_ rustc_errors::Handler,
|
handler: &'_ rustc_errors::Handler,
|
||||||
|
@ -868,6 +869,7 @@ pub struct BreakNonLoop<'a> {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> IntoDiagnostic<'_> for BreakNonLoop<'a> {
|
impl<'a> IntoDiagnostic<'_> for BreakNonLoop<'a> {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &rustc_errors::Handler,
|
handler: &rustc_errors::Handler,
|
||||||
|
@ -1005,6 +1007,7 @@ pub struct NakedFunctionsAsmBlock {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnostic<'_> for NakedFunctionsAsmBlock {
|
impl IntoDiagnostic<'_> for NakedFunctionsAsmBlock {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &rustc_errors::Handler,
|
handler: &rustc_errors::Handler,
|
||||||
|
@ -1128,6 +1131,7 @@ pub struct NoMainErr {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> IntoDiagnostic<'a> for NoMainErr {
|
impl<'a> IntoDiagnostic<'a> for NoMainErr {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &'a rustc_errors::Handler,
|
handler: &'a rustc_errors::Handler,
|
||||||
|
@ -1188,6 +1192,7 @@ pub struct DuplicateLangItem {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnostic<'_> for DuplicateLangItem {
|
impl IntoDiagnostic<'_> for DuplicateLangItem {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &rustc_errors::Handler,
|
handler: &rustc_errors::Handler,
|
||||||
|
|
|
@ -794,6 +794,7 @@ impl UnstableOptions {
|
||||||
report_delayed_bugs: self.report_delayed_bugs,
|
report_delayed_bugs: self.report_delayed_bugs,
|
||||||
macro_backtrace: self.macro_backtrace,
|
macro_backtrace: self.macro_backtrace,
|
||||||
deduplicate_diagnostics: self.deduplicate_diagnostics,
|
deduplicate_diagnostics: self.deduplicate_diagnostics,
|
||||||
|
track_diagnostics: self.track_diagnostics,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1587,6 +1587,8 @@ options! {
|
||||||
"choose the TLS model to use (`rustc --print tls-models` for details)"),
|
"choose the TLS model to use (`rustc --print tls-models` for details)"),
|
||||||
trace_macros: bool = (false, parse_bool, [UNTRACKED],
|
trace_macros: bool = (false, parse_bool, [UNTRACKED],
|
||||||
"for every macro invocation, print its name and arguments (default: no)"),
|
"for every macro invocation, print its name and arguments (default: no)"),
|
||||||
|
track_diagnostics: bool = (false, parse_bool, [UNTRACKED],
|
||||||
|
"tracks where in rustc a diagnostic was emitted"),
|
||||||
// Diagnostics are considered side-effects of a query (see `QuerySideEffects`) and are saved
|
// Diagnostics are considered side-effects of a query (see `QuerySideEffects`) and are saved
|
||||||
// alongside query results and changes to translation options can affect diagnostics - so
|
// alongside query results and changes to translation options can affect diagnostics - so
|
||||||
// translation options should be tracked.
|
// translation options should be tracked.
|
||||||
|
|
|
@ -97,6 +97,7 @@ pub fn feature_err<'a>(
|
||||||
///
|
///
|
||||||
/// This variant allows you to control whether it is a library or language feature.
|
/// This variant allows you to control whether it is a library or language feature.
|
||||||
/// Almost always, you want to use this for a language feature. If so, prefer `feature_err`.
|
/// Almost always, you want to use this for a language feature. If so, prefer `feature_err`.
|
||||||
|
#[track_caller]
|
||||||
pub fn feature_err_issue<'a>(
|
pub fn feature_err_issue<'a>(
|
||||||
sess: &'a ParseSess,
|
sess: &'a ParseSess,
|
||||||
feature: Symbol,
|
feature: Symbol,
|
||||||
|
@ -332,6 +333,7 @@ impl ParseSess {
|
||||||
self.proc_macro_quoted_spans.lock().clone()
|
self.proc_macro_quoted_spans.lock().clone()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn create_err<'a>(
|
pub fn create_err<'a>(
|
||||||
&'a self,
|
&'a self,
|
||||||
err: impl IntoDiagnostic<'a>,
|
err: impl IntoDiagnostic<'a>,
|
||||||
|
@ -339,10 +341,12 @@ impl ParseSess {
|
||||||
err.into_diagnostic(&self.span_diagnostic)
|
err.into_diagnostic(&self.span_diagnostic)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn emit_err<'a>(&'a self, err: impl IntoDiagnostic<'a>) -> ErrorGuaranteed {
|
pub fn emit_err<'a>(&'a self, err: impl IntoDiagnostic<'a>) -> ErrorGuaranteed {
|
||||||
self.create_err(err).emit()
|
self.create_err(err).emit()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn create_warning<'a>(
|
pub fn create_warning<'a>(
|
||||||
&'a self,
|
&'a self,
|
||||||
warning: impl IntoDiagnostic<'a, ()>,
|
warning: impl IntoDiagnostic<'a, ()>,
|
||||||
|
@ -350,6 +354,7 @@ impl ParseSess {
|
||||||
warning.into_diagnostic(&self.span_diagnostic)
|
warning.into_diagnostic(&self.span_diagnostic)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn emit_warning<'a>(&'a self, warning: impl IntoDiagnostic<'a, ()>) {
|
pub fn emit_warning<'a>(&'a self, warning: impl IntoDiagnostic<'a, ()>) {
|
||||||
self.create_warning(warning).emit()
|
self.create_warning(warning).emit()
|
||||||
}
|
}
|
||||||
|
@ -377,6 +382,7 @@ impl ParseSess {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_err(
|
pub fn struct_err(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
|
|
@ -286,6 +286,7 @@ impl Session {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_warn<S: Into<MultiSpan>>(
|
pub fn struct_span_warn<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -294,6 +295,7 @@ impl Session {
|
||||||
self.diagnostic().struct_span_warn(sp, msg)
|
self.diagnostic().struct_span_warn(sp, msg)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_warn_with_expectation<S: Into<MultiSpan>>(
|
pub fn struct_span_warn_with_expectation<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -303,6 +305,7 @@ impl Session {
|
||||||
self.diagnostic().struct_span_warn_with_expectation(sp, msg, id)
|
self.diagnostic().struct_span_warn_with_expectation(sp, msg, id)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_warn_with_code<S: Into<MultiSpan>>(
|
pub fn struct_span_warn_with_code<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -312,10 +315,12 @@ impl Session {
|
||||||
self.diagnostic().struct_span_warn_with_code(sp, msg, code)
|
self.diagnostic().struct_span_warn_with_code(sp, msg, code)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_warn(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
pub fn struct_warn(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
||||||
self.diagnostic().struct_warn(msg)
|
self.diagnostic().struct_warn(msg)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_warn_with_expectation(
|
pub fn struct_warn_with_expectation(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -324,6 +329,7 @@ impl Session {
|
||||||
self.diagnostic().struct_warn_with_expectation(msg, id)
|
self.diagnostic().struct_warn_with_expectation(msg, id)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_allow<S: Into<MultiSpan>>(
|
pub fn struct_span_allow<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -332,10 +338,12 @@ impl Session {
|
||||||
self.diagnostic().struct_span_allow(sp, msg)
|
self.diagnostic().struct_span_allow(sp, msg)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_allow(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
pub fn struct_allow(&self, msg: impl Into<DiagnosticMessage>) -> DiagnosticBuilder<'_, ()> {
|
||||||
self.diagnostic().struct_allow(msg)
|
self.diagnostic().struct_allow(msg)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_expect(
|
pub fn struct_expect(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -344,6 +352,7 @@ impl Session {
|
||||||
self.diagnostic().struct_expect(msg, id)
|
self.diagnostic().struct_expect(msg, id)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_err<S: Into<MultiSpan>>(
|
pub fn struct_span_err<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -352,6 +361,7 @@ impl Session {
|
||||||
self.diagnostic().struct_span_err(sp, msg)
|
self.diagnostic().struct_span_err(sp, msg)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_err_with_code<S: Into<MultiSpan>>(
|
pub fn struct_span_err_with_code<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -362,12 +372,14 @@ impl Session {
|
||||||
}
|
}
|
||||||
// FIXME: This method should be removed (every error should have an associated error code).
|
// FIXME: This method should be removed (every error should have an associated error code).
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_err(
|
pub fn struct_err(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
) -> DiagnosticBuilder<'_, ErrorGuaranteed> {
|
) -> DiagnosticBuilder<'_, ErrorGuaranteed> {
|
||||||
self.parse_sess.struct_err(msg)
|
self.parse_sess.struct_err(msg)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
pub fn struct_err_with_code(
|
pub fn struct_err_with_code(
|
||||||
&self,
|
&self,
|
||||||
|
@ -377,6 +389,7 @@ impl Session {
|
||||||
self.diagnostic().struct_err_with_code(msg, code)
|
self.diagnostic().struct_err_with_code(msg, code)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_warn_with_code(
|
pub fn struct_warn_with_code(
|
||||||
&self,
|
&self,
|
||||||
msg: impl Into<DiagnosticMessage>,
|
msg: impl Into<DiagnosticMessage>,
|
||||||
|
@ -385,6 +398,7 @@ impl Session {
|
||||||
self.diagnostic().struct_warn_with_code(msg, code)
|
self.diagnostic().struct_warn_with_code(msg, code)
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn struct_span_fatal<S: Into<MultiSpan>>(
|
pub fn struct_span_fatal<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -407,6 +421,7 @@ impl Session {
|
||||||
}
|
}
|
||||||
|
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_fatal<S: Into<MultiSpan>>(&self, sp: S, msg: impl Into<DiagnosticMessage>) -> ! {
|
pub fn span_fatal<S: Into<MultiSpan>>(&self, sp: S, msg: impl Into<DiagnosticMessage>) -> ! {
|
||||||
self.diagnostic().span_fatal(sp, msg)
|
self.diagnostic().span_fatal(sp, msg)
|
||||||
}
|
}
|
||||||
|
@ -424,6 +439,7 @@ impl Session {
|
||||||
self.diagnostic().fatal(msg).raise()
|
self.diagnostic().fatal(msg).raise()
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_err_or_warn<S: Into<MultiSpan>>(
|
pub fn span_err_or_warn<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
is_warning: bool,
|
is_warning: bool,
|
||||||
|
@ -437,6 +453,7 @@ impl Session {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#[rustc_lint_diagnostics]
|
#[rustc_lint_diagnostics]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_err<S: Into<MultiSpan>>(
|
pub fn span_err<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -457,12 +474,14 @@ impl Session {
|
||||||
pub fn err(&self, msg: impl Into<DiagnosticMessage>) -> ErrorGuaranteed {
|
pub fn err(&self, msg: impl Into<DiagnosticMessage>) -> ErrorGuaranteed {
|
||||||
self.diagnostic().err(msg)
|
self.diagnostic().err(msg)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn create_err<'a>(
|
pub fn create_err<'a>(
|
||||||
&'a self,
|
&'a self,
|
||||||
err: impl IntoDiagnostic<'a>,
|
err: impl IntoDiagnostic<'a>,
|
||||||
) -> DiagnosticBuilder<'a, ErrorGuaranteed> {
|
) -> DiagnosticBuilder<'a, ErrorGuaranteed> {
|
||||||
self.parse_sess.create_err(err)
|
self.parse_sess.create_err(err)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn create_feature_err<'a>(
|
pub fn create_feature_err<'a>(
|
||||||
&'a self,
|
&'a self,
|
||||||
err: impl IntoDiagnostic<'a>,
|
err: impl IntoDiagnostic<'a>,
|
||||||
|
@ -475,33 +494,40 @@ impl Session {
|
||||||
add_feature_diagnostics(&mut err, &self.parse_sess, feature);
|
add_feature_diagnostics(&mut err, &self.parse_sess, feature);
|
||||||
err
|
err
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn emit_err<'a>(&'a self, err: impl IntoDiagnostic<'a>) -> ErrorGuaranteed {
|
pub fn emit_err<'a>(&'a self, err: impl IntoDiagnostic<'a>) -> ErrorGuaranteed {
|
||||||
self.parse_sess.emit_err(err)
|
self.parse_sess.emit_err(err)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn create_warning<'a>(
|
pub fn create_warning<'a>(
|
||||||
&'a self,
|
&'a self,
|
||||||
err: impl IntoDiagnostic<'a, ()>,
|
err: impl IntoDiagnostic<'a, ()>,
|
||||||
) -> DiagnosticBuilder<'a, ()> {
|
) -> DiagnosticBuilder<'a, ()> {
|
||||||
self.parse_sess.create_warning(err)
|
self.parse_sess.create_warning(err)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn emit_warning<'a>(&'a self, warning: impl IntoDiagnostic<'a, ()>) {
|
pub fn emit_warning<'a>(&'a self, warning: impl IntoDiagnostic<'a, ()>) {
|
||||||
self.parse_sess.emit_warning(warning)
|
self.parse_sess.emit_warning(warning)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn create_note<'a>(
|
pub fn create_note<'a>(
|
||||||
&'a self,
|
&'a self,
|
||||||
note: impl IntoDiagnostic<'a, Noted>,
|
note: impl IntoDiagnostic<'a, Noted>,
|
||||||
) -> DiagnosticBuilder<'a, Noted> {
|
) -> DiagnosticBuilder<'a, Noted> {
|
||||||
self.parse_sess.create_note(note)
|
self.parse_sess.create_note(note)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn emit_note<'a>(&'a self, note: impl IntoDiagnostic<'a, Noted>) -> Noted {
|
pub fn emit_note<'a>(&'a self, note: impl IntoDiagnostic<'a, Noted>) -> Noted {
|
||||||
self.parse_sess.emit_note(note)
|
self.parse_sess.emit_note(note)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn create_fatal<'a>(
|
pub fn create_fatal<'a>(
|
||||||
&'a self,
|
&'a self,
|
||||||
fatal: impl IntoDiagnostic<'a, !>,
|
fatal: impl IntoDiagnostic<'a, !>,
|
||||||
) -> DiagnosticBuilder<'a, !> {
|
) -> DiagnosticBuilder<'a, !> {
|
||||||
self.parse_sess.create_fatal(fatal)
|
self.parse_sess.create_fatal(fatal)
|
||||||
}
|
}
|
||||||
|
#[track_caller]
|
||||||
pub fn emit_fatal<'a>(&'a self, fatal: impl IntoDiagnostic<'a, !>) -> ! {
|
pub fn emit_fatal<'a>(&'a self, fatal: impl IntoDiagnostic<'a, !>) -> ! {
|
||||||
self.parse_sess.emit_fatal(fatal)
|
self.parse_sess.emit_fatal(fatal)
|
||||||
}
|
}
|
||||||
|
@ -541,6 +567,7 @@ impl Session {
|
||||||
}
|
}
|
||||||
#[allow(rustc::untranslatable_diagnostic)]
|
#[allow(rustc::untranslatable_diagnostic)]
|
||||||
#[allow(rustc::diagnostic_outside_of_impl)]
|
#[allow(rustc::diagnostic_outside_of_impl)]
|
||||||
|
#[track_caller]
|
||||||
pub fn span_warn<S: Into<MultiSpan>>(&self, sp: S, msg: impl Into<DiagnosticMessage>) {
|
pub fn span_warn<S: Into<MultiSpan>>(&self, sp: S, msg: impl Into<DiagnosticMessage>) {
|
||||||
self.diagnostic().span_warn(sp, msg)
|
self.diagnostic().span_warn(sp, msg)
|
||||||
}
|
}
|
||||||
|
@ -587,6 +614,8 @@ impl Session {
|
||||||
pub fn note_without_error(&self, msg: impl Into<DiagnosticMessage>) {
|
pub fn note_without_error(&self, msg: impl Into<DiagnosticMessage>) {
|
||||||
self.diagnostic().note_without_error(msg)
|
self.diagnostic().note_without_error(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[track_caller]
|
||||||
pub fn span_note_without_error<S: Into<MultiSpan>>(
|
pub fn span_note_without_error<S: Into<MultiSpan>>(
|
||||||
&self,
|
&self,
|
||||||
sp: S,
|
sp: S,
|
||||||
|
@ -1213,6 +1242,7 @@ fn default_emitter(
|
||||||
fallback_bundle: LazyFallbackBundle,
|
fallback_bundle: LazyFallbackBundle,
|
||||||
) -> Box<dyn Emitter + sync::Send> {
|
) -> Box<dyn Emitter + sync::Send> {
|
||||||
let macro_backtrace = sopts.unstable_opts.macro_backtrace;
|
let macro_backtrace = sopts.unstable_opts.macro_backtrace;
|
||||||
|
let track_diagnostics = sopts.unstable_opts.track_diagnostics;
|
||||||
match sopts.error_format {
|
match sopts.error_format {
|
||||||
config::ErrorOutputType::HumanReadable(kind) => {
|
config::ErrorOutputType::HumanReadable(kind) => {
|
||||||
let (short, color_config) = kind.unzip();
|
let (short, color_config) = kind.unzip();
|
||||||
|
@ -1236,6 +1266,7 @@ fn default_emitter(
|
||||||
sopts.unstable_opts.teach,
|
sopts.unstable_opts.teach,
|
||||||
sopts.diagnostic_width,
|
sopts.diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
);
|
);
|
||||||
Box::new(emitter.ui_testing(sopts.unstable_opts.ui_testing))
|
Box::new(emitter.ui_testing(sopts.unstable_opts.ui_testing))
|
||||||
}
|
}
|
||||||
|
@ -1250,6 +1281,7 @@ fn default_emitter(
|
||||||
json_rendered,
|
json_rendered,
|
||||||
sopts.diagnostic_width,
|
sopts.diagnostic_width,
|
||||||
macro_backtrace,
|
macro_backtrace,
|
||||||
|
track_diagnostics,
|
||||||
)
|
)
|
||||||
.ui_testing(sopts.unstable_opts.ui_testing),
|
.ui_testing(sopts.unstable_opts.ui_testing),
|
||||||
),
|
),
|
||||||
|
@ -1552,11 +1584,18 @@ fn early_error_handler(output: config::ErrorOutputType) -> rustc_errors::Handler
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
config::ErrorOutputType::Json { pretty, json_rendered } => {
|
config::ErrorOutputType::Json { pretty, json_rendered } => Box::new(JsonEmitter::basic(
|
||||||
Box::new(JsonEmitter::basic(pretty, json_rendered, None, fallback_bundle, None, false))
|
pretty,
|
||||||
}
|
json_rendered,
|
||||||
|
None,
|
||||||
|
fallback_bundle,
|
||||||
|
None,
|
||||||
|
false,
|
||||||
|
false,
|
||||||
|
)),
|
||||||
};
|
};
|
||||||
rustc_errors::Handler::with_emitter(true, None, emitter)
|
rustc_errors::Handler::with_emitter(true, None, emitter)
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,6 +67,7 @@ pub struct NegativePositiveConflict<'a> {
|
||||||
}
|
}
|
||||||
|
|
||||||
impl IntoDiagnostic<'_> for NegativePositiveConflict<'_> {
|
impl IntoDiagnostic<'_> for NegativePositiveConflict<'_> {
|
||||||
|
#[track_caller]
|
||||||
fn into_diagnostic(
|
fn into_diagnostic(
|
||||||
self,
|
self,
|
||||||
handler: &Handler,
|
handler: &Handler,
|
||||||
|
|
|
@ -166,6 +166,7 @@ pub(crate) fn new_handler(
|
||||||
unstable_opts.teach,
|
unstable_opts.teach,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
false,
|
false,
|
||||||
|
unstable_opts.track_diagnostics,
|
||||||
)
|
)
|
||||||
.ui_testing(unstable_opts.ui_testing),
|
.ui_testing(unstable_opts.ui_testing),
|
||||||
)
|
)
|
||||||
|
@ -184,6 +185,7 @@ pub(crate) fn new_handler(
|
||||||
json_rendered,
|
json_rendered,
|
||||||
diagnostic_width,
|
diagnostic_width,
|
||||||
false,
|
false,
|
||||||
|
unstable_opts.track_diagnostics,
|
||||||
)
|
)
|
||||||
.ui_testing(unstable_opts.ui_testing),
|
.ui_testing(unstable_opts.ui_testing),
|
||||||
)
|
)
|
||||||
|
|
|
@ -551,6 +551,7 @@ pub(crate) fn make_test(
|
||||||
false,
|
false,
|
||||||
Some(80),
|
Some(80),
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
)
|
)
|
||||||
.supports_color();
|
.supports_color();
|
||||||
|
|
||||||
|
@ -564,6 +565,7 @@ pub(crate) fn make_test(
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
);
|
);
|
||||||
|
|
||||||
// FIXME(misdreavus): pass `-Z treat-err-as-bug` to the doctest parser
|
// FIXME(misdreavus): pass `-Z treat-err-as-bug` to the doctest parser
|
||||||
|
@ -748,6 +750,7 @@ fn check_if_attr_is_complete(source: &str, edition: Edition) -> bool {
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
);
|
);
|
||||||
|
|
||||||
let handler = Handler::with_emitter(false, None, Box::new(emitter));
|
let handler = Handler::with_emitter(false, None, Box::new(emitter));
|
||||||
|
|
10
src/test/rustdoc-ui/track-diagnostics.rs
Normal file
10
src/test/rustdoc-ui/track-diagnostics.rs
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
// Normalize the emitted location so this doesn't need
|
||||||
|
// updating everytime someone adds or removes a line.
|
||||||
|
// normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
||||||
|
|
||||||
|
struct A;
|
||||||
|
struct B;
|
||||||
|
const S: A = B;
|
10
src/test/rustdoc-ui/track-diagnostics.stderr
Normal file
10
src/test/rustdoc-ui/track-diagnostics.stderr
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
error[E0308]: mismatched types
|
||||||
|
--> $DIR/track-diagnostics.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | const S: A = B;
|
||||||
|
| ^ expected struct `A`, found struct `B`
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_infer/src/infer/error_reporting/mod.rs:LL:CC
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0308`.
|
|
@ -171,6 +171,7 @@
|
||||||
-Z time-passes=val -- measure time of each rustc pass (default: no)
|
-Z time-passes=val -- measure time of each rustc pass (default: no)
|
||||||
-Z tls-model=val -- choose the TLS model to use (`rustc --print tls-models` for details)
|
-Z tls-model=val -- choose the TLS model to use (`rustc --print tls-models` for details)
|
||||||
-Z trace-macros=val -- for every macro invocation, print its name and arguments (default: no)
|
-Z trace-macros=val -- for every macro invocation, print its name and arguments (default: no)
|
||||||
|
-Z track-diagnostics=val -- tracks where in rustc a diagnostic was emitted
|
||||||
-Z translate-additional-ftl=val -- additional fluent translation to preferentially use (for testing translation)
|
-Z translate-additional-ftl=val -- additional fluent translation to preferentially use (for testing translation)
|
||||||
-Z translate-directionality-markers=val -- emit directionality isolation markers in translated diagnostics
|
-Z translate-directionality-markers=val -- emit directionality isolation markers in translated diagnostics
|
||||||
-Z translate-lang=val -- language identifier for diagnostic output
|
-Z translate-lang=val -- language identifier for diagnostic output
|
||||||
|
|
11
src/test/ui/track-diagnostics/track.rs
Normal file
11
src/test/ui/track-diagnostics/track.rs
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
// Normalize the emitted location so this doesn't need
|
||||||
|
// updating everytime someone adds or removes a line.
|
||||||
|
// normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
||||||
|
// normalize-stderr-test "note: rustc .+ running on .+" -> "note: rustc $$VERSION running on $$TARGET"
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
break rust
|
||||||
|
}
|
26
src/test/ui/track-diagnostics/track.stderr
Normal file
26
src/test/ui/track-diagnostics/track.stderr
Normal file
|
@ -0,0 +1,26 @@
|
||||||
|
error[E0425]: cannot find value `rust` in this scope
|
||||||
|
--> $DIR/track.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | break rust
|
||||||
|
| ^^^^ not found in this scope
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_resolve/src/late/diagnostics.rs:LL:CC
|
||||||
|
|
||||||
|
error[E0268]: `break` outside of a loop
|
||||||
|
--> $DIR/track.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | break rust
|
||||||
|
| ^^^^^^^^^^ cannot `break` outside of a loop
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_passes/src/loops.rs:LL:CC
|
||||||
|
|
||||||
|
error: internal compiler error: It looks like you're trying to break rust; would you like some ICE?
|
||||||
|
|
||||||
|
note: the compiler expectedly panicked. this is a feature.
|
||||||
|
|
||||||
|
note: we would appreciate a joke overview: https://github.com/rust-lang/rust/issues/43162#issuecomment-320764675
|
||||||
|
|
||||||
|
note: rustc $VERSION running on $TARGET
|
||||||
|
|
||||||
|
error: aborting due to 3 previous errors
|
||||||
|
|
||||||
|
Some errors have detailed explanations: E0268, E0425.
|
||||||
|
For more information about an error, try `rustc --explain E0268`.
|
10
src/test/ui/track-diagnostics/track2.rs
Normal file
10
src/test/ui/track-diagnostics/track2.rs
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
// Normalize the emitted location so this doesn't need
|
||||||
|
// updating everytime someone adds or removes a line.
|
||||||
|
// normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let _moved @ _from = String::from("foo");
|
||||||
|
}
|
13
src/test/ui/track-diagnostics/track2.stderr
Normal file
13
src/test/ui/track-diagnostics/track2.stderr
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
error[E0382]: use of moved value
|
||||||
|
--> $DIR/track2.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | let _moved @ _from = String::from("foo");
|
||||||
|
| ^^^^^^ ----- ------------------- move occurs because value has type `String`, which does not implement the `Copy` trait
|
||||||
|
| | |
|
||||||
|
| | value moved here
|
||||||
|
| value used here after move
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_borrowck/src/borrowck_errors.rs:LL:CC
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0382`.
|
10
src/test/ui/track-diagnostics/track3.rs
Normal file
10
src/test/ui/track-diagnostics/track3.rs
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
// Normalize the emitted location so this doesn't need
|
||||||
|
// updating everytime someone adds or removes a line.
|
||||||
|
// normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
let _unimported = Blah { field: u8 };
|
||||||
|
}
|
18
src/test/ui/track-diagnostics/track3.stderr
Normal file
18
src/test/ui/track-diagnostics/track3.stderr
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
error[E0422]: cannot find struct, variant or union type `Blah` in this scope
|
||||||
|
--> $DIR/track3.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | let _unimported = Blah { field: u8 };
|
||||||
|
| ^^^^ not found in this scope
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_resolve/src/late/diagnostics.rs:LL:CC
|
||||||
|
|
||||||
|
error[E0423]: expected value, found builtin type `u8`
|
||||||
|
--> $DIR/track3.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | let _unimported = Blah { field: u8 };
|
||||||
|
| ^^ not a value
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_resolve/src/late/diagnostics.rs:LL:CC
|
||||||
|
|
||||||
|
error: aborting due to 2 previous errors
|
||||||
|
|
||||||
|
Some errors have detailed explanations: E0422, E0423.
|
||||||
|
For more information about an error, try `rustc --explain E0422`.
|
13
src/test/ui/track-diagnostics/track4.rs
Normal file
13
src/test/ui/track-diagnostics/track4.rs
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
// Normalize the emitted location so this doesn't need
|
||||||
|
// updating everytime someone adds or removes a line.
|
||||||
|
// normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
||||||
|
|
||||||
|
pub onion {
|
||||||
|
Owo(u8),
|
||||||
|
Uwu(i8),
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {}
|
14
src/test/ui/track-diagnostics/track4.stderr
Normal file
14
src/test/ui/track-diagnostics/track4.stderr
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
error: missing `struct` for struct definition
|
||||||
|
--> $DIR/track4.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | pub onion {
|
||||||
|
| ^
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_parse/src/parser/diagnostics.rs:LL:CC
|
||||||
|
|
|
||||||
|
help: add `struct` here to parse `onion` as a public struct
|
||||||
|
|
|
||||||
|
LL | pub struct onion {
|
||||||
|
| ++++++
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
8
src/test/ui/track-diagnostics/track5.rs
Normal file
8
src/test/ui/track-diagnostics/track5.rs
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
// Normalize the emitted location so this doesn't need
|
||||||
|
// updating everytime someone adds or removes a line.
|
||||||
|
// normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
||||||
|
|
||||||
|
}
|
9
src/test/ui/track-diagnostics/track5.stderr
Normal file
9
src/test/ui/track-diagnostics/track5.stderr
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
error: unexpected closing delimiter: `}`
|
||||||
|
--> $DIR/track5.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | }
|
||||||
|
| ^ unexpected closing delimiter
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_parse/src/lexer/tokentrees.rs:LL:CC
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
14
src/test/ui/track-diagnostics/track6.rs
Normal file
14
src/test/ui/track-diagnostics/track6.rs
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
pub trait Foo {
|
||||||
|
fn bar();
|
||||||
|
}
|
||||||
|
|
||||||
|
impl <T> Foo for T {
|
||||||
|
default fn bar() {}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {}
|
13
src/test/ui/track-diagnostics/track6.stderr
Normal file
13
src/test/ui/track-diagnostics/track6.stderr
Normal file
|
@ -0,0 +1,13 @@
|
||||||
|
error[E0658]: specialization is unstable
|
||||||
|
--> $DIR/track6.rs:11:5
|
||||||
|
|
|
||||||
|
LL | default fn bar() {}
|
||||||
|
| ^^^^^^^^^^^^^^^^^^^
|
||||||
|
-Ztrack-diagnostics: created at $COMPILER_DIR/rustc_session/src/parse.rs:93:5
|
||||||
|
|
|
||||||
|
= note: see issue #31844 <https://github.com/rust-lang/rust/issues/31844> for more information
|
||||||
|
= help: add `#![feature(specialization)]` to the crate attributes to enable
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0658`.
|
|
@ -691,6 +691,7 @@ fn check_code(cx: &LateContext<'_>, text: &str, edition: Edition, span: Span) {
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
);
|
);
|
||||||
let handler = Handler::with_emitter(false, None, Box::new(emitter));
|
let handler = Handler::with_emitter(false, None, Box::new(emitter));
|
||||||
let sess = ParseSess::with_span_handler(handler, sm);
|
let sess = ParseSess::with_span_handler(handler, sm);
|
||||||
|
|
|
@ -179,6 +179,7 @@ fn report_clippy_ice(info: &panic::PanicInfo<'_>, bug_report_url: &str) {
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
));
|
));
|
||||||
let handler = rustc_errors::Handler::with_emitter(true, None, emitter);
|
let handler = rustc_errors::Handler::with_emitter(true, None, emitter);
|
||||||
|
|
||||||
|
|
12
src/tools/clippy/tests/ui/track-diagnostics.rs
Normal file
12
src/tools/clippy/tests/ui/track-diagnostics.rs
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
// compile-flags: -Z track-diagnostics
|
||||||
|
// error-pattern: created at
|
||||||
|
|
||||||
|
// Normalize the emitted location so this doesn't need
|
||||||
|
// updating everytime someone adds or removes a line.
|
||||||
|
// normalize-stderr-test ".rs:\d+:\d+" -> ".rs:LL:CC"
|
||||||
|
|
||||||
|
struct A;
|
||||||
|
struct B;
|
||||||
|
const S: A = B;
|
||||||
|
|
||||||
|
fn main() {}
|
10
src/tools/clippy/tests/ui/track-diagnostics.stderr
Normal file
10
src/tools/clippy/tests/ui/track-diagnostics.stderr
Normal file
|
@ -0,0 +1,10 @@
|
||||||
|
error[E0308]: mismatched types
|
||||||
|
--> $DIR/track-diagnostics.rs:LL:CC
|
||||||
|
|
|
||||||
|
LL | const S: A = B;
|
||||||
|
| ^ expected struct `A`, found struct `B`
|
||||||
|
-Ztrack-diagnostics: created at compiler/rustc_infer/src/infer/error_reporting/mod.rs:LL:CC
|
||||||
|
|
||||||
|
error: aborting due to previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0308`.
|
|
@ -134,6 +134,7 @@ fn default_handler(
|
||||||
false,
|
false,
|
||||||
None,
|
None,
|
||||||
false,
|
false,
|
||||||
|
false,
|
||||||
))
|
))
|
||||||
};
|
};
|
||||||
Handler::with_emitter(
|
Handler::with_emitter(
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue