Remove the UntranslatableDiagnosticTrivial
lint.
It's a specialized form of the `UntranslatableDiagnostic` lint that is deny-by-default. Now that `UntranslatableDiagnostic` has been changed from allow-by-default to deny-by-default, the trivial variant is no longer needed.
This commit is contained in:
parent
ef324565d0
commit
5e29e26b96
4 changed files with 1 additions and 88 deletions
|
@ -4,7 +4,6 @@
|
||||||
use crate::lints::{
|
use crate::lints::{
|
||||||
BadOptAccessDiag, DefaultHashTypesDiag, DiagOutOfImpl, LintPassByHand, NonExistentDocKeyword,
|
BadOptAccessDiag, DefaultHashTypesDiag, DiagOutOfImpl, LintPassByHand, NonExistentDocKeyword,
|
||||||
QueryInstability, SpanUseEqCtxtDiag, TyQualified, TykindDiag, TykindKind, UntranslatableDiag,
|
QueryInstability, SpanUseEqCtxtDiag, TyQualified, TykindDiag, TykindKind, UntranslatableDiag,
|
||||||
UntranslatableDiagnosticTrivial,
|
|
||||||
};
|
};
|
||||||
use crate::{EarlyContext, EarlyLintPass, LateContext, LateLintPass, LintContext};
|
use crate::{EarlyContext, EarlyLintPass, LateContext, LateLintPass, LintContext};
|
||||||
use rustc_ast as ast;
|
use rustc_ast as ast;
|
||||||
|
@ -361,15 +360,7 @@ declare_tool_lint! {
|
||||||
report_in_external_macro: true
|
report_in_external_macro: true
|
||||||
}
|
}
|
||||||
|
|
||||||
declare_tool_lint! {
|
declare_lint_pass!(Diagnostics => [UNTRANSLATABLE_DIAGNOSTIC, DIAGNOSTIC_OUTSIDE_OF_IMPL]);
|
||||||
/// The `untranslatable_diagnostic_trivial` lint detects diagnostics created using only static strings.
|
|
||||||
pub rustc::UNTRANSLATABLE_DIAGNOSTIC_TRIVIAL,
|
|
||||||
Deny,
|
|
||||||
"prevent creation of diagnostics which cannot be translated, which use only static strings",
|
|
||||||
report_in_external_macro: true
|
|
||||||
}
|
|
||||||
|
|
||||||
declare_lint_pass!(Diagnostics => [ UNTRANSLATABLE_DIAGNOSTIC, DIAGNOSTIC_OUTSIDE_OF_IMPL, UNTRANSLATABLE_DIAGNOSTIC_TRIVIAL ]);
|
|
||||||
|
|
||||||
impl LateLintPass<'_> for Diagnostics {
|
impl LateLintPass<'_> for Diagnostics {
|
||||||
fn check_expr(&mut self, cx: &LateContext<'_>, expr: &Expr<'_>) {
|
fn check_expr(&mut self, cx: &LateContext<'_>, expr: &Expr<'_>) {
|
||||||
|
@ -425,78 +416,6 @@ impl LateLintPass<'_> for Diagnostics {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl EarlyLintPass for Diagnostics {
|
|
||||||
#[allow(unused_must_use)]
|
|
||||||
fn check_stmt(&mut self, cx: &EarlyContext<'_>, stmt: &ast::Stmt) {
|
|
||||||
// Looking for a straight chain of method calls from 'struct_span_err' to 'emit'.
|
|
||||||
let ast::StmtKind::Semi(expr) = &stmt.kind else {
|
|
||||||
return;
|
|
||||||
};
|
|
||||||
let ast::ExprKind::MethodCall(meth) = &expr.kind else {
|
|
||||||
return;
|
|
||||||
};
|
|
||||||
if meth.seg.ident.name != sym::emit || !meth.args.is_empty() {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
let mut segments = vec![];
|
|
||||||
let mut cur = &meth.receiver;
|
|
||||||
let fake = &[].into();
|
|
||||||
loop {
|
|
||||||
match &cur.kind {
|
|
||||||
ast::ExprKind::Call(func, args) => {
|
|
||||||
if let ast::ExprKind::Path(_, path) = &func.kind {
|
|
||||||
segments.push((path.segments.last().unwrap().ident.name, args))
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
ast::ExprKind::MethodCall(method) => {
|
|
||||||
segments.push((method.seg.ident.name, &method.args));
|
|
||||||
cur = &method.receiver;
|
|
||||||
}
|
|
||||||
ast::ExprKind::MacCall(mac) => {
|
|
||||||
segments.push((mac.path.segments.last().unwrap().ident.name, fake));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
_ => {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
segments.reverse();
|
|
||||||
if segments.is_empty() {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if segments[0].0.as_str() != "struct_span_err" {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if !segments.iter().all(|(name, args)| {
|
|
||||||
let arg = match name.as_str() {
|
|
||||||
"struct_span_err" | "span_note" | "span_label" | "span_help" if args.len() == 2 => {
|
|
||||||
&args[1]
|
|
||||||
}
|
|
||||||
"note" | "help" if args.len() == 1 => &args[0],
|
|
||||||
_ => {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
if let ast::ExprKind::Lit(lit) = arg.kind
|
|
||||||
&& let ast::token::LitKind::Str = lit.kind
|
|
||||||
{
|
|
||||||
true
|
|
||||||
} else {
|
|
||||||
false
|
|
||||||
}
|
|
||||||
}) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
cx.emit_span_lint(
|
|
||||||
UNTRANSLATABLE_DIAGNOSTIC_TRIVIAL,
|
|
||||||
stmt.span,
|
|
||||||
UntranslatableDiagnosticTrivial,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare_tool_lint! {
|
declare_tool_lint! {
|
||||||
/// The `bad_opt_access` lint detects accessing options by field instead of
|
/// The `bad_opt_access` lint detects accessing options by field instead of
|
||||||
/// the wrapper function.
|
/// the wrapper function.
|
||||||
|
|
|
@ -550,7 +550,6 @@ fn register_internals(store: &mut LintStore) {
|
||||||
store.register_lints(&TyTyKind::get_lints());
|
store.register_lints(&TyTyKind::get_lints());
|
||||||
store.register_late_mod_pass(|_| Box::new(TyTyKind));
|
store.register_late_mod_pass(|_| Box::new(TyTyKind));
|
||||||
store.register_lints(&Diagnostics::get_lints());
|
store.register_lints(&Diagnostics::get_lints());
|
||||||
store.register_early_pass(|| Box::new(Diagnostics));
|
|
||||||
store.register_late_mod_pass(|_| Box::new(Diagnostics));
|
store.register_late_mod_pass(|_| Box::new(Diagnostics));
|
||||||
store.register_lints(&BadOptAccess::get_lints());
|
store.register_lints(&BadOptAccess::get_lints());
|
||||||
store.register_late_mod_pass(|_| Box::new(BadOptAccess));
|
store.register_late_mod_pass(|_| Box::new(BadOptAccess));
|
||||||
|
|
|
@ -923,10 +923,6 @@ pub struct DiagOutOfImpl;
|
||||||
#[diag(lint_untranslatable_diag)]
|
#[diag(lint_untranslatable_diag)]
|
||||||
pub struct UntranslatableDiag;
|
pub struct UntranslatableDiag;
|
||||||
|
|
||||||
#[derive(LintDiagnostic)]
|
|
||||||
#[diag(lint_trivial_untranslatable_diag)]
|
|
||||||
pub struct UntranslatableDiagnosticTrivial;
|
|
||||||
|
|
||||||
#[derive(LintDiagnostic)]
|
#[derive(LintDiagnostic)]
|
||||||
#[diag(lint_bad_opt_access)]
|
#[diag(lint_bad_opt_access)]
|
||||||
pub struct BadOptAccessDiag<'a> {
|
pub struct BadOptAccessDiag<'a> {
|
||||||
|
|
|
@ -6,7 +6,6 @@
|
||||||
clippy::missing_panics_doc,
|
clippy::missing_panics_doc,
|
||||||
rustc::diagnostic_outside_of_impl,
|
rustc::diagnostic_outside_of_impl,
|
||||||
rustc::untranslatable_diagnostic,
|
rustc::untranslatable_diagnostic,
|
||||||
rustc::untranslatable_diagnostic_trivial
|
|
||||||
)]
|
)]
|
||||||
|
|
||||||
extern crate rustc_ast;
|
extern crate rustc_ast;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue