This method of once-diagnostics doesn't allow nesting

This commit is contained in:
Oliver Schneider 2017-11-20 12:48:08 +01:00
parent 7e07fd3e8d
commit f7361a8870
No known key found for this signature in database
GPG Key ID: A69F8D225B3AD7D9

View File

@ -355,7 +355,6 @@ impl Session {
/// Analogous to calling methods on the given `DiagnosticBuilder`, but /// Analogous to calling methods on the given `DiagnosticBuilder`, but
/// deduplicates on lint ID, span (if any), and message for this `Session` /// deduplicates on lint ID, span (if any), and message for this `Session`
/// if we're not outputting in JSON mode.
fn diag_once<'a, 'b>(&'a self, fn diag_once<'a, 'b>(&'a self,
diag_builder: &'b mut DiagnosticBuilder<'a>, diag_builder: &'b mut DiagnosticBuilder<'a>,
method: DiagnosticBuilderMethod, method: DiagnosticBuilderMethod,
@ -371,20 +370,11 @@ impl Session {
} }
}; };
match self.opts.error_format { let lint_id = DiagnosticMessageId::LintId(lint::LintId::of(lint));
// when outputting JSON for tool consumption, the tool might want let id_span_message = (lint_id, span, message.to_owned());
// the duplicates let fresh = self.one_time_diagnostics.borrow_mut().insert(id_span_message);
config::ErrorOutputType::Json(_) => { if fresh {
do_method() do_method()
},
_ => {
let lint_id = DiagnosticMessageId::LintId(lint::LintId::of(lint));
let id_span_message = (lint_id, span, message.to_owned());
let fresh = self.one_time_diagnostics.borrow_mut().insert(id_span_message);
if fresh {
do_method()
}
}
} }
} }