Switch the primary diagnostic to unknown_lints
This also affects the `non_exhaustive_omitted_patterns` and `must_not_suspend` lints as they are not stable. This also changes the diagnostic level to pull from `unknown_lints` instead of always being allow or deny.
This commit is contained in:
parent
8852752078
commit
2677eca237
21 changed files with 310 additions and 142 deletions
|
@ -17,7 +17,7 @@ use rustc_session::lint::{
|
|||
builtin::{self, FORBIDDEN_LINT_GROUPS},
|
||||
Level, Lint, LintExpectationId, LintId,
|
||||
};
|
||||
use rustc_session::parse::feature_err;
|
||||
use rustc_session::parse::{add_feature_diagnostics, feature_err};
|
||||
use rustc_session::Session;
|
||||
use rustc_span::symbol::{sym, Symbol};
|
||||
use rustc_span::{source_map::MultiSpan, Span, DUMMY_SP};
|
||||
|
@ -104,10 +104,8 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
fn process_command_line(&mut self, sess: &Session, store: &LintStore) {
|
||||
self.sets.lint_cap = sess.opts.lint_cap.unwrap_or(Level::Forbid);
|
||||
|
||||
self.cur = self.sets.list.push(LintSet {
|
||||
specs: FxHashMap::default(),
|
||||
parent: COMMAND_LINE,
|
||||
});
|
||||
self.cur =
|
||||
self.sets.list.push(LintSet { specs: FxHashMap::default(), parent: COMMAND_LINE });
|
||||
for &(ref lint_name, level) in &sess.opts.lint_opts {
|
||||
store.check_lint_name_cmdline(sess, &lint_name, level, self.registered_tools);
|
||||
let orig_level = level;
|
||||
|
@ -134,11 +132,7 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
/// Attempts to insert the `id` to `level_src` map entry. If unsuccessful
|
||||
/// (e.g. if a forbid was already inserted on the same scope), then emits a
|
||||
/// diagnostic with no change to `specs`.
|
||||
fn insert_spec(
|
||||
&mut self,
|
||||
id: LintId,
|
||||
(level, src): LevelAndSource,
|
||||
) {
|
||||
fn insert_spec(&mut self, id: LintId, (level, src): LevelAndSource) {
|
||||
let (old_level, old_src) =
|
||||
self.sets.get_lint_level(id.lint, self.cur, Some(self.current_specs()), &self.sess);
|
||||
// Setting to a non-forbid level is an error if the lint previously had
|
||||
|
@ -163,7 +157,10 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
};
|
||||
debug!(
|
||||
"fcw_warning={:?}, specs.get(&id) = {:?}, old_src={:?}, id_name={:?}",
|
||||
fcw_warning, self.current_specs(), old_src, id_name
|
||||
fcw_warning,
|
||||
self.current_specs(),
|
||||
old_src,
|
||||
id_name
|
||||
);
|
||||
|
||||
let decorate_diag = |diag: &mut Diagnostic| {
|
||||
|
@ -249,10 +246,8 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
source_hir_id: Option<HirId>,
|
||||
) -> BuilderPush {
|
||||
let prev = self.cur;
|
||||
self.cur = self.sets.list.push(LintSet {
|
||||
specs: FxHashMap::default(),
|
||||
parent: prev,
|
||||
});
|
||||
self.cur = self.sets.list.push(LintSet { specs: FxHashMap::default(), parent: prev });
|
||||
|
||||
let sess = self.sess;
|
||||
let bad_attr = |span| struct_span_err!(sess, span, E0452, "malformed lint attribute input");
|
||||
for (attr_index, attr) in attrs.iter().enumerate() {
|
||||
|
@ -391,8 +386,12 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
}
|
||||
Err((Some(ids), ref new_lint_name)) => {
|
||||
let lint = builtin::RENAMED_AND_REMOVED_LINTS;
|
||||
let (lvl, src) =
|
||||
self.sets.get_lint_level(lint, self.cur, Some(self.current_specs()), &sess);
|
||||
let (lvl, src) = self.sets.get_lint_level(
|
||||
lint,
|
||||
self.cur,
|
||||
Some(self.current_specs()),
|
||||
&sess,
|
||||
);
|
||||
struct_lint_level(
|
||||
self.sess,
|
||||
lint,
|
||||
|
@ -462,8 +461,12 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
|
||||
CheckLintNameResult::Warning(msg, renamed) => {
|
||||
let lint = builtin::RENAMED_AND_REMOVED_LINTS;
|
||||
let (renamed_lint_level, src) =
|
||||
self.sets.get_lint_level(lint, self.cur, Some(self.current_specs()), &sess);
|
||||
let (renamed_lint_level, src) = self.sets.get_lint_level(
|
||||
lint,
|
||||
self.cur,
|
||||
Some(self.current_specs()),
|
||||
&sess,
|
||||
);
|
||||
struct_lint_level(
|
||||
self.sess,
|
||||
lint,
|
||||
|
@ -486,8 +489,12 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
}
|
||||
CheckLintNameResult::NoLint(suggestion) => {
|
||||
let lint = builtin::UNKNOWN_LINTS;
|
||||
let (level, src) =
|
||||
self.sets.get_lint_level(lint, self.cur, Some(self.current_specs()), self.sess);
|
||||
let (level, src) = self.sets.get_lint_level(
|
||||
lint,
|
||||
self.cur,
|
||||
Some(self.current_specs()),
|
||||
self.sess,
|
||||
);
|
||||
struct_lint_level(self.sess, lint, level, src, Some(sp.into()), |lint| {
|
||||
let name = if let Some(tool_ident) = tool_ident {
|
||||
format!("{}::{}", tool_ident.name, name)
|
||||
|
@ -594,16 +601,14 @@ impl<'s> LintLevelsBuilder<'s> {
|
|||
fn check_gated_lint(&self, lint_id: LintId, span: Span) -> bool {
|
||||
if let Some(feature) = lint_id.lint.feature_gate {
|
||||
if !self.sess.features_untracked().enabled(feature) {
|
||||
let (unknown_lints_level, _) = self.lint_level(builtin::UNKNOWN_LINTS);
|
||||
if unknown_lints_level != Level::Allow {
|
||||
feature_err(
|
||||
&self.sess.parse_sess,
|
||||
feature,
|
||||
span,
|
||||
&format!("the `{}` lint is unstable", lint_id.lint.name_lower()),
|
||||
)
|
||||
.emit();
|
||||
}
|
||||
let (level, src) = self.lint_level(builtin::UNKNOWN_LINTS);
|
||||
struct_lint_level(self.sess, lint_id.lint, level, src, Some(span.into()), |lint| {
|
||||
let mut db =
|
||||
lint.build(&format!("unknown lint: `{}`", lint_id.lint.name_lower()));
|
||||
db.note(&format!("the `{}` lint is unstable", lint_id.lint.name_lower(),));
|
||||
add_feature_diagnostics(&mut db, &self.sess.parse_sess, feature);
|
||||
db.emit();
|
||||
});
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue