Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Rollup of 10 pull requests #124208

Merged
merged 22 commits into from
Apr 21, 2024
Merged
Changes from 1 commit
Commits
Show all changes
22 commits
Select commit Hold shift + click to select a range
b4a4645
static_mut_refs: use raw pointers to remove the remaining FIXME
RalfJung Apr 15, 2024
89117f8
Use fake libc in core test
ChrisDenton Apr 15, 2024
232eb59
lint-docs: Add redirects for renamed lints.
ehuss Apr 15, 2024
40cfc2d
coverage: Move branch coverage tests into a subdirectory
Zalathar Apr 17, 2024
25b9f84
coverage: Branch coverage tests for lazy boolean operators
Zalathar Apr 17, 2024
4734163
Add llvm-bitcode-linker to build manifest
kjetilkjeka Apr 17, 2024
fdf93bb
Improve std::fs::Metadata Debug representation
dtolnay Apr 18, 2024
61def01
llvm RustWrapper: explain OpBundlesIndirect argument type
RalfJung Apr 18, 2024
912c670
Move pretty-printer FixupContext to a module
dtolnay Apr 20, 2024
debdb72
Give a name to each distinct manipulation of pretty-printer FixupContext
dtolnay Apr 20, 2024
75d0fdd
mir-opt tests: rename unit-test -> test-mir-pass
RalfJung Apr 20, 2024
be564a8
Print note with closure signature on type mismatch
wutchzone Apr 2, 2024
e9e936c
Rollup merge of #123379 - wutchzone:119266, r=compiler-errors
jieyouxu Apr 20, 2024
ccd9880
Rollup merge of #123967 - RalfJung:static_mut_refs, r=Nilstrieb
jieyouxu Apr 20, 2024
a73aabf
Rollup merge of #123976 - ChrisDenton:no-libc-in-std-doc-tests, r=Mar…
jieyouxu Apr 20, 2024
871c3e3
Rollup merge of #123986 - ehuss:lint-renamed, r=Mark-Simulacrum
jieyouxu Apr 20, 2024
f13cd0c
Rollup merge of #124053 - Zalathar:lazy-boolean, r=Mark-Simulacrum
jieyouxu Apr 20, 2024
29ee276
Rollup merge of #124071 - kjetilkjeka:llvm_bitcode_linker_build_manif…
jieyouxu Apr 20, 2024
418a078
Rollup merge of #124103 - dtolnay:metadatadebug, r=Mark-Simulacrum
jieyouxu Apr 20, 2024
726361c
Rollup merge of #124132 - RalfJung:OpBundlesIndirect, r=Mark-Simulacrum
jieyouxu Apr 20, 2024
b3f9117
Rollup merge of #124191 - dtolnay:fixup, r=compiler-errors
jieyouxu Apr 20, 2024
c72cfdd
Rollup merge of #124196 - RalfJung:mir-opt-tests, r=Mark-Simulacrum
jieyouxu Apr 20, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
lint-docs: Add redirects for renamed lints.
  • Loading branch information
ehuss committed Apr 15, 2024
commit 232eb59a8f9f3ae8acc85193d771895e4d93edf7
89 changes: 89 additions & 0 deletions src/tools/lint-docs/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,43 @@ use walkdir::WalkDir;

mod groups;

/// List of lints which have been renamed.
///
/// These will get redirects in the output to the new name. The
/// format is `(level, [(old_name, new_name), ...])`.
///
/// Note: This hard-coded list is a temporary hack. The intent is in the
/// future to have `rustc` expose this information in some way (like a `-Z`
/// flag spitting out JSON). Also, this does not yet support changing the
/// level of the lint, which will be more difficult to support, since rustc
/// currently does not track that historical information.
static RENAMES: &[(Level, &[(&str, &str)])] = &[
(
Level::Allow,
&[
("single-use-lifetime", "single-use-lifetimes"),
("elided-lifetime-in-path", "elided-lifetimes-in-paths"),
("async-idents", "keyword-idents"),
("disjoint-capture-migration", "rust-2021-incompatible-closure-captures"),
("or-patterns-back-compat", "rust-2021-incompatible-or-patterns"),
],
),
(
Level::Warn,
&[
("bare-trait-object", "bare-trait-objects"),
("unstable-name-collision", "unstable-name-collisions"),
("unused-doc-comment", "unused-doc-comments"),
("redundant-semicolon", "redundant-semicolons"),
("overlapping-patterns", "overlapping-range-endpoints"),
("non-fmt-panic", "non-fmt-panics"),
("unused-tuple-struct-fields", "dead-code"),
("static-mut-ref", "static-mut-refs"),
],
),
(Level::Deny, &[("exceeding-bitshifts", "arithmetic-overflow")]),
];

pub struct LintExtractor<'a> {
/// Path to the `src` directory, where it will scan for `.rs` files to
/// find lint declarations.
Expand Down Expand Up @@ -126,6 +163,7 @@ impl<'a> LintExtractor<'a> {
)
})?;
}
add_renamed_lints(&mut lints);
self.save_lints_markdown(&lints)?;
self.generate_group_docs(&lints)?;
Ok(())
Expand Down Expand Up @@ -483,6 +521,7 @@ impl<'a> LintExtractor<'a> {
}
result.push('\n');
}
add_rename_redirect(level, &mut result);
let out_path = self.out_path.join("listing").join(level.doc_filename());
// Delete the output because rustbuild uses hard links in its copies.
let _ = fs::remove_file(&out_path);
Expand All @@ -492,6 +531,56 @@ impl<'a> LintExtractor<'a> {
}
}

/// Adds `Lint`s that have been renamed.
fn add_renamed_lints(lints: &mut Vec<Lint>) {
for (level, names) in RENAMES {
for (from, to) in *names {
lints.push(Lint {
name: from.to_string(),
doc: vec![format!("The lint `{from}` has been renamed to [`{to}`](#{to}).")],
level: *level,
path: PathBuf::new(),
lineno: 0,
});
}
}
}

// This uses DOMContentLoaded instead of running immediately because for some
// reason on Firefox (124 of this writing) doesn't update the `target` CSS
// selector if only the hash changes.
static RENAME_START: &str = "
<script>
document.addEventListener(\"DOMContentLoaded\", (event) => {
var fragments = {
";

static RENAME_END: &str = "\
};
var target = fragments[window.location.hash];
if (target) {
var url = window.location.toString();
var base = url.substring(0, url.lastIndexOf('/'));
window.location.replace(base + \"/\" + target);
}
});
</script>
";

/// Adds the javascript redirection code to the given markdown output.
fn add_rename_redirect(level: Level, output: &mut String) {
for (rename_level, names) in RENAMES {
if *rename_level == level {
let filename = level.doc_filename().replace(".md", ".html");
output.push_str(RENAME_START);
for (from, to) in *names {
write!(output, " \"#{from}\": \"{filename}#{to}\",\n").unwrap();
}
output.push_str(RENAME_END);
}
}
}

/// Extracts the lint name (removing the visibility modifier, and checking validity).
fn lint_name(line: &str) -> Result<String, &'static str> {
// Skip over any potential `pub` visibility.
Expand Down
Loading