From fdcf854bb9b03ff9f8c60c824f0c6709a38269d0 Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Sun, 24 Nov 2019 12:44:49 -0800 Subject: [PATCH] tidy: Accommodate rustfmt's preferred layout of stability attributes Previously tidy would require that the `feature = "name_of_feature"` part of the stability attribute was on the same line as the `#[stable(` / `#[unstable(` opening part of the attribute, and that `)]` was on the same line as the last key-value pair. That didn't work with rustfmt's preferred layout of long attributes, which is like: #[unstable( feature = "c_variadic", reason = "the `c_variadic` feature has not been properly tested on \ all supported platforms", issue = "44930" )] --- src/tools/tidy/src/features.rs | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/tools/tidy/src/features.rs b/src/tools/tidy/src/features.rs index a824546d436..defe85ef46a 100644 --- a/src/tools/tidy/src/features.rs +++ b/src/tools/tidy/src/features.rs @@ -397,7 +397,8 @@ fn map_lib_features(base_src_path: &Path, } let mut becoming_feature: Option<(&str, Feature)> = None; - for (i, line) in contents.lines().enumerate() { + let mut iter_lines = contents.lines().enumerate().peekable(); + while let Some((i, line)) = iter_lines.next() { macro_rules! err { ($msg:expr) => {{ mf(Err($msg), file, i + 1); @@ -411,7 +412,7 @@ macro_rules! err { } if line.ends_with(']') { mf(Ok((name, f.clone())), file, i + 1); - } else if !line.ends_with(',') && !line.ends_with('\\') { + } else if !line.ends_with(',') && !line.ends_with('\\') && !line.ends_with('"') { // We need to bail here because we might have missed the // end of a stability attribute above because the ']' // might not have been at the end of the line. @@ -450,7 +451,9 @@ macro_rules! err { } else { continue; }; - let feature_name = match find_attr_val(line, "feature") { + let feature_name = match find_attr_val(line, "feature") + .or_else(|| iter_lines.peek().and_then(|next| find_attr_val(next.1, "feature"))) + { Some(name) => name, None => err!("malformed stability attribute: missing `feature` key"), }; -- 2.44.0