-
Notifications
You must be signed in to change notification settings - Fork 12.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Rollup merge of #126811 - compiler-errors:tidy-ftl, r=estebank
Add a tidy rule to check that fluent messages and attrs don't end in `.` This adds a new dependency on `fluent-parse` to `tidy` -- we already rely on it in rustc so I feel like it's not that big of a deal. This PR also adjusts many error messages that currently end in `.`; not all of them since I added an `ALLOWLIST`, excluded `rustc_codegen_*` ftl files, and `.teach_note` attributes. r? ``@estebank`` ``@oli-obk``
- Loading branch information
Showing
29 changed files
with
149 additions
and
62 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
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
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
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
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,84 @@ | ||
//! Checks that no Fluent messages or attributes end in periods (except ellipses) | ||
use fluent_syntax::ast::{Entry, PatternElement}; | ||
|
||
use crate::walk::{filter_dirs, walk}; | ||
use std::path::Path; | ||
|
||
fn filter_fluent(path: &Path) -> bool { | ||
if let Some(ext) = path.extension() { ext.to_str() != Some("ftl") } else { true } | ||
} | ||
|
||
/// Messages allowed to have `.` at their end. | ||
/// | ||
/// These should probably be reworked eventually. | ||
const ALLOWLIST: &[&str] = &[ | ||
"const_eval_long_running", | ||
"const_eval_validation_failure_note", | ||
"driver_impl_ice", | ||
"incremental_corrupt_file", | ||
"mir_build_pointer_pattern", | ||
]; | ||
|
||
fn check_period(filename: &str, contents: &str, bad: &mut bool) { | ||
if filename.contains("codegen") { | ||
// FIXME: Too many codegen messages have periods right now... | ||
return; | ||
} | ||
|
||
let (Ok(parse) | Err((parse, _))) = fluent_syntax::parser::parse(contents); | ||
for entry in &parse.body { | ||
if let Entry::Message(m) = entry { | ||
if ALLOWLIST.contains(&m.id.name) { | ||
continue; | ||
} | ||
|
||
if let Some(pat) = &m.value { | ||
if let Some(PatternElement::TextElement { value }) = pat.elements.last() { | ||
// We don't care about ellipses. | ||
if value.ends_with(".") && !value.ends_with("...") { | ||
let ll = find_line(contents, *value); | ||
let name = m.id.name; | ||
tidy_error!(bad, "{filename}:{ll}: message `{name}` ends in a period"); | ||
} | ||
} | ||
} | ||
|
||
for attr in &m.attributes { | ||
// Teach notes usually have long messages. | ||
if attr.id.name == "teach_note" { | ||
continue; | ||
} | ||
|
||
if let Some(PatternElement::TextElement { value }) = attr.value.elements.last() { | ||
if value.ends_with(".") && !value.ends_with("...") { | ||
let ll = find_line(contents, *value); | ||
let name = attr.id.name; | ||
tidy_error!(bad, "{filename}:{ll}: attr `{name}` ends in a period"); | ||
} | ||
} | ||
} | ||
} | ||
} | ||
} | ||
|
||
/// Evil cursed bad hack. Requires that `value` be a substr (in memory) of `contents`. | ||
fn find_line(haystack: &str, needle: &str) -> usize { | ||
for (ll, line) in haystack.lines().enumerate() { | ||
if line.as_ptr() > needle.as_ptr() { | ||
return ll; | ||
} | ||
} | ||
|
||
1 | ||
} | ||
|
||
pub fn check(path: &Path, bad: &mut bool) { | ||
walk( | ||
path, | ||
|path, is_dir| filter_dirs(path) || (!is_dir && filter_fluent(path)), | ||
&mut |ent, contents| { | ||
check_period(ent.path().to_str().unwrap(), contents, bad); | ||
}, | ||
); | ||
} |
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
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
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
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.