-
Notifications
You must be signed in to change notification settings - Fork 2.5k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Auto merge of #14025 - Muscraft:document-lints, r=epage
Add tooling to document lints One thing the linting system has been missing is documentation. There is no list of all `cargo`'s lints and their associated documentation, like `clippy` or `rustc` has. To resolve this problem, I wrote a very basic tool that gathers the doc comments for a `Lint` and copies them to a markdown file in the Cargo book. This solution is not perfect but it is a way to work towards a better overall experience.
- Loading branch information
Showing
9 changed files
with
363 additions
and
14 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
[package] | ||
name = "xtask-lint-docs" | ||
version = "0.1.0" | ||
edition.workspace = true | ||
publish = false | ||
|
||
[dependencies] | ||
anyhow.workspace = true | ||
cargo.workspace = true | ||
clap.workspace = true | ||
itertools.workspace = true | ||
|
||
[lints] | ||
workspace = true |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,108 @@ | ||
use cargo::util::command_prelude::{flag, ArgMatchesExt}; | ||
use cargo::util::lints::{Lint, LintLevel}; | ||
use itertools::Itertools; | ||
use std::fmt::Write; | ||
use std::path::PathBuf; | ||
|
||
fn cli() -> clap::Command { | ||
clap::Command::new("xtask-lint-docs").arg(flag("check", "Check that the docs are up-to-date")) | ||
} | ||
|
||
fn main() -> anyhow::Result<()> { | ||
let args = cli().get_matches(); | ||
let check = args.flag("check"); | ||
|
||
let mut allow = Vec::new(); | ||
let mut warn = Vec::new(); | ||
let mut deny = Vec::new(); | ||
let mut forbid = Vec::new(); | ||
|
||
let mut lint_docs = String::new(); | ||
for lint in cargo::util::lints::LINTS | ||
.iter() | ||
.sorted_by_key(|lint| lint.name) | ||
{ | ||
if lint.docs.is_some() { | ||
let sectipn = match lint.default_level { | ||
LintLevel::Allow => &mut allow, | ||
LintLevel::Warn => &mut warn, | ||
LintLevel::Deny => &mut deny, | ||
LintLevel::Forbid => &mut forbid, | ||
}; | ||
sectipn.push(lint.name); | ||
add_lint(lint, &mut lint_docs)?; | ||
} | ||
} | ||
|
||
let mut buf = String::new(); | ||
writeln!(buf, "# Lints\n")?; | ||
writeln!( | ||
buf, | ||
"Note: [Cargo's linting system is unstable](unstable.md#lintscargo) and can only be used on nightly toolchains" | ||
)?; | ||
writeln!(buf)?; | ||
|
||
if !allow.is_empty() { | ||
add_level_section(LintLevel::Allow, &allow, &mut buf)?; | ||
} | ||
if !warn.is_empty() { | ||
add_level_section(LintLevel::Warn, &warn, &mut buf)?; | ||
} | ||
if !deny.is_empty() { | ||
add_level_section(LintLevel::Deny, &deny, &mut buf)?; | ||
} | ||
if !forbid.is_empty() { | ||
add_level_section(LintLevel::Forbid, &forbid, &mut buf)?; | ||
} | ||
|
||
buf.push_str(&lint_docs); | ||
|
||
if check { | ||
let old = std::fs::read_to_string(lint_docs_path())?; | ||
if old != buf { | ||
anyhow::bail!( | ||
"The lints documentation is out-of-date. Run `cargo lint-docs` to update it." | ||
); | ||
} | ||
} else { | ||
std::fs::write(lint_docs_path(), buf)?; | ||
} | ||
Ok(()) | ||
} | ||
|
||
fn add_lint(lint: &Lint, buf: &mut String) -> std::fmt::Result { | ||
writeln!(buf, "## `{}`", lint.name)?; | ||
writeln!(buf, "Set to `{}` by default", lint.default_level)?; | ||
writeln!(buf, "{}\n", lint.docs.as_ref().unwrap()) | ||
} | ||
|
||
fn add_level_section(level: LintLevel, lint_names: &[&str], buf: &mut String) -> std::fmt::Result { | ||
let title = match level { | ||
LintLevel::Allow => "Allowed-by-default", | ||
LintLevel::Warn => "Warn-by-default", | ||
LintLevel::Deny => "Deny-by-default", | ||
LintLevel::Forbid => "Forbid-by-default", | ||
}; | ||
writeln!(buf, "## {title}\n")?; | ||
writeln!( | ||
buf, | ||
"These lints are all set to the '{}' level by default.", | ||
level | ||
)?; | ||
|
||
for name in lint_names { | ||
writeln!(buf, "- [`{}`](#{})", name, name)?; | ||
} | ||
writeln!(buf)?; | ||
Ok(()) | ||
} | ||
|
||
fn lint_docs_path() -> PathBuf { | ||
let pkg_root = env!("CARGO_MANIFEST_DIR"); | ||
let ws_root = PathBuf::from(format!("{pkg_root}/../..")); | ||
let path = { | ||
let path = ws_root.join("src/doc/src/reference/lints.md"); | ||
path.canonicalize().unwrap_or(path) | ||
}; | ||
path | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.