rust/tests/ui-fulldeps/auxiliary/lint-for-crate.rs

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

44 lines
1.1 KiB
Rust
Raw Normal View History

// force-host
#![feature(rustc_private)]
2019-07-06 12:56:20 -05:00
extern crate rustc_driver;
2020-01-04 22:35:51 -06:00
extern crate rustc_hir;
extern crate rustc_lint;
#[macro_use]
extern crate rustc_session;
extern crate rustc_ast;
2021-09-12 06:19:04 -05:00
extern crate rustc_span;
use rustc_ast::attr;
use rustc_driver::plugin::Registry;
2021-09-12 06:19:04 -05:00
use rustc_lint::{LateContext, LateLintPass, LintContext};
use rustc_span::def_id::CRATE_DEF_ID;
2020-01-01 17:01:07 -06:00
use rustc_span::symbol::Symbol;
declare_lint! {
CRATE_NOT_OKAY,
Warn,
"crate not marked with #![crate_okay]"
}
declare_lint_pass!(Pass => [CRATE_NOT_OKAY]);
impl<'tcx> LateLintPass<'tcx> for Pass {
2021-09-12 06:19:04 -05:00
fn check_crate(&mut self, cx: &LateContext) {
2020-12-05 14:23:37 -06:00
let attrs = cx.tcx.hir().attrs(rustc_hir::CRATE_HIR_ID);
2021-09-12 06:19:04 -05:00
let span = cx.tcx.def_span(CRATE_DEF_ID);
if !attr::contains_name(attrs, Symbol::intern("crate_okay")) {
cx.lint(CRATE_NOT_OKAY, "crate is not marked with #![crate_okay]", |lint| {
lint.set_span(span)
});
}
}
}
#[no_mangle]
fn __rustc_plugin_registrar(reg: &mut Registry) {
2019-10-09 14:41:17 -05:00
reg.lint_store.register_lints(&[&CRATE_NOT_OKAY]);
reg.lint_store.register_late_pass(|_| Box::new(Pass));
}