Add lint pass for doc keyword
This commit is contained in:
parent
c7cff213e9
commit
56c64f871e
2 changed files with 48 additions and 1 deletions
|
@ -10,7 +10,7 @@ use rustc_hir::{GenericArg, HirId, MutTy, Mutability, Path, PathSegment, QPath,
|
||||||
use rustc_middle::ty;
|
use rustc_middle::ty;
|
||||||
use rustc_session::{declare_lint_pass, declare_tool_lint, impl_lint_pass};
|
use rustc_session::{declare_lint_pass, declare_tool_lint, impl_lint_pass};
|
||||||
use rustc_span::hygiene::{ExpnKind, MacroKind};
|
use rustc_span::hygiene::{ExpnKind, MacroKind};
|
||||||
use rustc_span::symbol::{sym, Ident, Symbol};
|
use rustc_span::symbol::{kw, sym, Ident, Symbol};
|
||||||
|
|
||||||
declare_tool_lint! {
|
declare_tool_lint! {
|
||||||
pub rustc::DEFAULT_HASH_TYPES,
|
pub rustc::DEFAULT_HASH_TYPES,
|
||||||
|
@ -267,3 +267,47 @@ impl EarlyLintPass for LintPassImpl {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
declare_tool_lint! {
|
||||||
|
pub rustc::EXISTING_DOC_KEYWORD,
|
||||||
|
Deny,
|
||||||
|
"Check that documented keywords in std and core actually exist",
|
||||||
|
report_in_external_macro: true
|
||||||
|
}
|
||||||
|
|
||||||
|
declare_lint_pass!(ExistingDocKeyword => [EXISTING_DOC_KEYWORD]);
|
||||||
|
|
||||||
|
fn is_doc_keyword(s: Symbol) -> bool {
|
||||||
|
s <= kw::Union
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'tcx> LateLintPass<'tcx> for ExistingDocKeyword {
|
||||||
|
fn check_item(&mut self, cx: &LateContext<'_>, item: &rustc_hir::Item<'_>) {
|
||||||
|
for attr in item.attrs {
|
||||||
|
if !attr.has_name(sym::doc) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if let Some(list) = attr.meta_item_list() {
|
||||||
|
for nested in list {
|
||||||
|
if nested.has_name(sym::keyword) {
|
||||||
|
let v = nested
|
||||||
|
.value_str()
|
||||||
|
.expect("#[doc(keyword = \"...\")] expected a value!");
|
||||||
|
if is_doc_keyword(v) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
cx.struct_span_lint(EXISTING_DOC_KEYWORD, attr.span, |lint| {
|
||||||
|
lint.build(&format!(
|
||||||
|
"Found non-existing keyword `{}` used in \
|
||||||
|
`#[doc(keyword = \"...\")]`",
|
||||||
|
v,
|
||||||
|
))
|
||||||
|
.help("only existing keywords are allowed in core/std")
|
||||||
|
.emit();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -463,6 +463,8 @@ fn register_internals(store: &mut LintStore) {
|
||||||
store.register_early_pass(|| box DefaultHashTypes::new());
|
store.register_early_pass(|| box DefaultHashTypes::new());
|
||||||
store.register_lints(&LintPassImpl::get_lints());
|
store.register_lints(&LintPassImpl::get_lints());
|
||||||
store.register_early_pass(|| box LintPassImpl);
|
store.register_early_pass(|| box LintPassImpl);
|
||||||
|
store.register_lints(&ExistingDocKeyword::get_lints());
|
||||||
|
store.register_late_pass(|| box ExistingDocKeyword);
|
||||||
store.register_lints(&TyTyKind::get_lints());
|
store.register_lints(&TyTyKind::get_lints());
|
||||||
store.register_late_pass(|| box TyTyKind);
|
store.register_late_pass(|| box TyTyKind);
|
||||||
store.register_group(
|
store.register_group(
|
||||||
|
@ -475,6 +477,7 @@ fn register_internals(store: &mut LintStore) {
|
||||||
LintId::of(LINT_PASS_IMPL_WITHOUT_MACRO),
|
LintId::of(LINT_PASS_IMPL_WITHOUT_MACRO),
|
||||||
LintId::of(TY_PASS_BY_REFERENCE),
|
LintId::of(TY_PASS_BY_REFERENCE),
|
||||||
LintId::of(USAGE_OF_QUALIFIED_TY),
|
LintId::of(USAGE_OF_QUALIFIED_TY),
|
||||||
|
LintId::of(EXISTING_DOC_KEYWORD),
|
||||||
],
|
],
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue