Add unstable --print=crate-root-lint-levels
This commit is contained in:
parent
69cb0a9e15
commit
df18de57a5
11 changed files with 186 additions and 5 deletions
|
@ -691,6 +691,34 @@ fn print_crate_info(
|
|||
};
|
||||
println_info!("{}", passes::get_crate_name(sess, attrs));
|
||||
}
|
||||
CrateRootLintLevels => {
|
||||
let Some(attrs) = attrs.as_ref() else {
|
||||
// no crate attributes, print out an error and exit
|
||||
return Compilation::Continue;
|
||||
};
|
||||
let crate_name = passes::get_crate_name(sess, attrs);
|
||||
let lint_store = crate::unerased_lint_store(sess);
|
||||
let registered_tools = rustc_resolve::registered_tools_ast(sess.dcx(), attrs);
|
||||
let features = rustc_expand::config::features(sess, attrs, crate_name);
|
||||
let lint_levels = rustc_lint::LintLevelsBuilder::crate_root(
|
||||
sess,
|
||||
&features,
|
||||
true,
|
||||
lint_store,
|
||||
®istered_tools,
|
||||
attrs,
|
||||
);
|
||||
for lint in lint_store.get_lints() {
|
||||
if let Some(feature_symbol) = lint.feature_gate
|
||||
&& !features.enabled(feature_symbol)
|
||||
{
|
||||
// lint is unstable and feature gate isn't active, don't print
|
||||
continue;
|
||||
}
|
||||
let level = lint_levels.lint_level(lint).0;
|
||||
println_info!("{}={}", lint.name_lower(), level.as_str());
|
||||
}
|
||||
}
|
||||
Cfg => {
|
||||
let mut cfgs = sess
|
||||
.psess
|
||||
|
|
|
@ -50,6 +50,7 @@ pub const PRINT_KINDS: &[(&str, PrintKind)] = &[
|
|||
("check-cfg", PrintKind::CheckCfg),
|
||||
("code-models", PrintKind::CodeModels),
|
||||
("crate-name", PrintKind::CrateName),
|
||||
("crate-root-lint-levels", PrintKind::CrateRootLintLevels),
|
||||
("deployment-target", PrintKind::DeploymentTarget),
|
||||
("file-names", PrintKind::FileNames),
|
||||
("host-tuple", PrintKind::HostTuple),
|
||||
|
@ -881,6 +882,7 @@ pub enum PrintKind {
|
|||
CheckCfg,
|
||||
CodeModels,
|
||||
CrateName,
|
||||
CrateRootLintLevels,
|
||||
DeploymentTarget,
|
||||
FileNames,
|
||||
HostTuple,
|
||||
|
@ -2067,6 +2069,7 @@ fn check_print_request_stability(
|
|||
match print_kind {
|
||||
PrintKind::AllTargetSpecsJson
|
||||
| PrintKind::CheckCfg
|
||||
| PrintKind::CrateRootLintLevels
|
||||
| PrintKind::SupportedCrateTypes
|
||||
| PrintKind::TargetSpecJson
|
||||
if !unstable_opts.unstable_options =>
|
||||
|
|
|
@ -0,0 +1,23 @@
|
|||
# `print=crate-root-lint-levels`
|
||||
|
||||
The tracking issue for this feature is: [#139180](https://github.com/rust-lang/rust/issues/139180).
|
||||
|
||||
------------------------
|
||||
|
||||
This option of the `--print` flag print the list of lints with print out all the lints and their associated levels (`allow`, `warn`, `deny`, `forbid`) based on the regular Rust rules at crate root, that is *(roughly)*:
|
||||
- command line args (`-W`, `-A`, `--force-warn`, `--cap-lints`, ...)
|
||||
- crate root attributes (`#![allow]`, `#![warn]`, `#[expect]`, ...)
|
||||
- *the special `warnings` lint group*
|
||||
- the default lint level
|
||||
|
||||
The output format is `LINT_NAME=LINT_LEVEL`, e.g.:
|
||||
```text
|
||||
unknown_lint=warn
|
||||
arithmetic_overflow=deny
|
||||
```
|
||||
|
||||
To be used like this:
|
||||
|
||||
```bash
|
||||
rustc --print=crate-root-lint-levels -Zunstable-options lib.rs
|
||||
```
|
5
tests/run-make/print-crate-root-lint-levels/lib.rs
Normal file
5
tests/run-make/print-crate-root-lint-levels/lib.rs
Normal file
|
@ -0,0 +1,5 @@
|
|||
#![allow(unexpected_cfgs)]
|
||||
#![expect(unused_mut)]
|
||||
|
||||
#[deny(unknown_lints)]
|
||||
mod my_mod {}
|
118
tests/run-make/print-crate-root-lint-levels/rmake.rs
Normal file
118
tests/run-make/print-crate-root-lint-levels/rmake.rs
Normal file
|
@ -0,0 +1,118 @@
|
|||
//! This checks the output of `--print=crate-root-lint-levels`
|
||||
|
||||
extern crate run_make_support;
|
||||
|
||||
use std::collections::HashSet;
|
||||
use std::iter::FromIterator;
|
||||
|
||||
use run_make_support::rustc;
|
||||
|
||||
struct CrateRootLintLevels {
|
||||
args: &'static [&'static str],
|
||||
contains: Contains,
|
||||
}
|
||||
|
||||
struct Contains {
|
||||
contains: &'static [&'static str],
|
||||
doesnt_contain: &'static [&'static str],
|
||||
}
|
||||
|
||||
fn main() {
|
||||
check(CrateRootLintLevels {
|
||||
args: &[],
|
||||
contains: Contains {
|
||||
contains: &[
|
||||
"unexpected_cfgs=allow",
|
||||
"unused_mut=expect",
|
||||
"warnings=warn",
|
||||
"stable_features=warn",
|
||||
"unknown_lints=warn",
|
||||
],
|
||||
doesnt_contain: &["unexpected_cfgs=warn", "unused_mut=warn"],
|
||||
},
|
||||
});
|
||||
check(CrateRootLintLevels {
|
||||
args: &["-Wunexpected_cfgs"],
|
||||
contains: Contains {
|
||||
contains: &["unexpected_cfgs=allow", "warnings=warn"],
|
||||
doesnt_contain: &["unexpected_cfgs=warn"],
|
||||
},
|
||||
});
|
||||
check(CrateRootLintLevels {
|
||||
args: &["-Dwarnings"],
|
||||
contains: Contains {
|
||||
contains: &[
|
||||
"unexpected_cfgs=allow",
|
||||
"warnings=deny",
|
||||
"stable_features=deny",
|
||||
"unknown_lints=deny",
|
||||
],
|
||||
doesnt_contain: &["warnings=warn"],
|
||||
},
|
||||
});
|
||||
check(CrateRootLintLevels {
|
||||
args: &["-Dstable_features"],
|
||||
contains: Contains {
|
||||
contains: &["warnings=warn", "stable_features=deny", "unexpected_cfgs=allow"],
|
||||
doesnt_contain: &["warnings=deny"],
|
||||
},
|
||||
});
|
||||
check(CrateRootLintLevels {
|
||||
args: &["-Dwarnings", "--force-warn=stable_features"],
|
||||
contains: Contains {
|
||||
contains: &["warnings=deny", "stable_features=force-warn", "unknown_lints=deny"],
|
||||
doesnt_contain: &["warnings=warn"],
|
||||
},
|
||||
});
|
||||
check(CrateRootLintLevels {
|
||||
args: &["-Dwarnings", "--cap-lints=warn"],
|
||||
contains: Contains {
|
||||
contains: &[
|
||||
"unexpected_cfgs=allow",
|
||||
"warnings=warn",
|
||||
"stable_features=warn",
|
||||
"unknown_lints=warn",
|
||||
],
|
||||
doesnt_contain: &["warnings=deny"],
|
||||
},
|
||||
});
|
||||
}
|
||||
|
||||
#[track_caller]
|
||||
fn check(CrateRootLintLevels { args, contains }: CrateRootLintLevels) {
|
||||
let output = rustc()
|
||||
.input("lib.rs")
|
||||
.arg("-Zunstable-options")
|
||||
.print("crate-root-lint-levels")
|
||||
.args(args)
|
||||
.run();
|
||||
|
||||
let stdout = output.stdout_utf8();
|
||||
|
||||
let mut found = HashSet::<String>::new();
|
||||
|
||||
for l in stdout.lines() {
|
||||
assert!(l == l.trim());
|
||||
if let Some((left, right)) = l.split_once('=') {
|
||||
assert!(!left.contains("\""));
|
||||
assert!(!right.contains("\""));
|
||||
} else {
|
||||
assert!(l.contains('='));
|
||||
}
|
||||
assert!(found.insert(l.to_string()), "{}", &l);
|
||||
}
|
||||
|
||||
let Contains { contains, doesnt_contain } = contains;
|
||||
|
||||
{
|
||||
let should_found = HashSet::<String>::from_iter(contains.iter().map(|s| s.to_string()));
|
||||
let diff: Vec<_> = should_found.difference(&found).collect();
|
||||
assert!(diff.is_empty(), "should found: {:?}, didn't found {:?}", &should_found, &diff);
|
||||
}
|
||||
{
|
||||
let should_not_find =
|
||||
HashSet::<String>::from_iter(doesnt_contain.iter().map(|s| s.to_string()));
|
||||
let diff: Vec<_> = should_not_find.intersection(&found).collect();
|
||||
assert!(diff.is_empty(), "should not find {:?}, did found {:?}", &should_not_find, &diff);
|
||||
}
|
||||
}
|
|
@ -29,7 +29,7 @@ Options:
|
|||
--emit [asm|llvm-bc|llvm-ir|obj|metadata|link|dep-info|mir]
|
||||
Comma separated list of types of output for the
|
||||
compiler to emit
|
||||
--print [all-target-specs-json|calling-conventions|cfg|check-cfg|code-models|crate-name|deployment-target|file-names|host-tuple|link-args|native-static-libs|relocation-models|split-debuginfo|stack-protector-strategies|supported-crate-types|sysroot|target-cpus|target-features|target-libdir|target-list|target-spec-json|tls-models]
|
||||
--print [all-target-specs-json|calling-conventions|cfg|check-cfg|code-models|crate-name|crate-root-lint-levels|deployment-target|file-names|host-tuple|link-args|native-static-libs|relocation-models|split-debuginfo|stack-protector-strategies|supported-crate-types|sysroot|target-cpus|target-features|target-libdir|target-list|target-spec-json|tls-models]
|
||||
Compiler information to print on stdout
|
||||
-g Equivalent to -C debuginfo=2
|
||||
-O Equivalent to -C opt-level=3
|
||||
|
|
|
@ -29,7 +29,7 @@ Options:
|
|||
--emit [asm|llvm-bc|llvm-ir|obj|metadata|link|dep-info|mir]
|
||||
Comma separated list of types of output for the
|
||||
compiler to emit
|
||||
--print [all-target-specs-json|calling-conventions|cfg|check-cfg|code-models|crate-name|deployment-target|file-names|host-tuple|link-args|native-static-libs|relocation-models|split-debuginfo|stack-protector-strategies|supported-crate-types|sysroot|target-cpus|target-features|target-libdir|target-list|target-spec-json|tls-models]
|
||||
--print [all-target-specs-json|calling-conventions|cfg|check-cfg|code-models|crate-name|crate-root-lint-levels|deployment-target|file-names|host-tuple|link-args|native-static-libs|relocation-models|split-debuginfo|stack-protector-strategies|supported-crate-types|sysroot|target-cpus|target-features|target-libdir|target-list|target-spec-json|tls-models]
|
||||
Compiler information to print on stdout
|
||||
-g Equivalent to -C debuginfo=2
|
||||
-O Equivalent to -C opt-level=3
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
error: Argument to option 'print' missing
|
||||
Usage:
|
||||
--print [all-target-specs-json|calling-conventions|cfg|check-cfg|code-models|crate-name|deployment-target|file-names|host-tuple|link-args|native-static-libs|relocation-models|split-debuginfo|stack-protector-strategies|supported-crate-types|sysroot|target-cpus|target-features|target-libdir|target-list|target-spec-json|tls-models]
|
||||
--print [all-target-specs-json|calling-conventions|cfg|check-cfg|code-models|crate-name|crate-root-lint-levels|deployment-target|file-names|host-tuple|link-args|native-static-libs|relocation-models|split-debuginfo|stack-protector-strategies|supported-crate-types|sysroot|target-cpus|target-features|target-libdir|target-list|target-spec-json|tls-models]
|
||||
Compiler information to print on stdout
|
||||
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
error: unknown print request: `yyyy`
|
||||
|
|
||||
= help: valid print requests are: `all-target-specs-json`, `calling-conventions`, `cfg`, `check-cfg`, `code-models`, `crate-name`, `deployment-target`, `file-names`, `host-tuple`, `link-args`, `native-static-libs`, `relocation-models`, `split-debuginfo`, `stack-protector-strategies`, `supported-crate-types`, `sysroot`, `target-cpus`, `target-features`, `target-libdir`, `target-list`, `target-spec-json`, `tls-models`
|
||||
= help: valid print requests are: `all-target-specs-json`, `calling-conventions`, `cfg`, `check-cfg`, `code-models`, `crate-name`, `crate-root-lint-levels`, `deployment-target`, `file-names`, `host-tuple`, `link-args`, `native-static-libs`, `relocation-models`, `split-debuginfo`, `stack-protector-strategies`, `supported-crate-types`, `sysroot`, `target-cpus`, `target-features`, `target-libdir`, `target-list`, `target-spec-json`, `tls-models`
|
||||
= help: for more information, see the rustc book: https://doc.rust-lang.org/rustc/command-line-arguments.html#--print-print-compiler-information
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
error: unknown print request: `lints`
|
||||
|
|
||||
= help: valid print requests are: `all-target-specs-json`, `calling-conventions`, `cfg`, `check-cfg`, `code-models`, `crate-name`, `deployment-target`, `file-names`, `host-tuple`, `link-args`, `native-static-libs`, `relocation-models`, `split-debuginfo`, `stack-protector-strategies`, `supported-crate-types`, `sysroot`, `target-cpus`, `target-features`, `target-libdir`, `target-list`, `target-spec-json`, `tls-models`
|
||||
= help: valid print requests are: `all-target-specs-json`, `calling-conventions`, `cfg`, `check-cfg`, `code-models`, `crate-name`, `crate-root-lint-levels`, `deployment-target`, `file-names`, `host-tuple`, `link-args`, `native-static-libs`, `relocation-models`, `split-debuginfo`, `stack-protector-strategies`, `supported-crate-types`, `sysroot`, `target-cpus`, `target-features`, `target-libdir`, `target-list`, `target-spec-json`, `tls-models`
|
||||
= help: use `-Whelp` to print a list of lints
|
||||
= help: for more information, see the rustc book: https://doc.rust-lang.org/rustc/command-line-arguments.html#--print-print-compiler-information
|
||||
|
||||
|
|
|
@ -18,6 +18,10 @@
|
|||
//@[all_target_specs_json] compile-flags: --print=all-target-specs-json
|
||||
//@[all_target_specs_json] error-pattern: the `-Z unstable-options` flag must also be passed
|
||||
|
||||
//@ revisions: crate_root_lint_levels
|
||||
//@[crate_root_lint_levels] compile-flags: --print=crate-root-lint-levels
|
||||
//@[crate_root_lint_levels] error-pattern: the `-Z unstable-options` flag must also be passed
|
||||
|
||||
//@ revisions: check_cfg
|
||||
//@[check_cfg] compile-flags: --print=check-cfg
|
||||
//@[check_cfg] error-pattern: the `-Z unstable-options` flag must also be passed
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue