Skip to content

Commit

Permalink
Merge pull request rust-lang#1167 from dalance/fix_summary_comment
Browse files Browse the repository at this point in the history
Fix SUMMARY's parse_numbered with comment
  • Loading branch information
ehuss authored Mar 18, 2020
2 parents a56f94b + 408106f commit 5f2b764
Showing 1 changed file with 31 additions and 0 deletions.
31 changes: 31 additions & 0 deletions src/book/summary.rs
Original file line number Diff line number Diff line change
Expand Up @@ -377,6 +377,10 @@ impl<'a> SummaryParser<'a> {
items.push(item);
}
Some(Event::Start(Tag::List(..))) => {
// Skip this tag after comment bacause it is not nested.
if items.is_empty() {
continue;
}
// recurse to parse the nested list
let (_, last_item) = get_last_link(&mut items)?;
let last_item_number = last_item
Expand Down Expand Up @@ -696,6 +700,33 @@ mod tests {
assert_eq!(got, should_be);
}

#[test]
fn parse_numbered_chapters_separated_by_comment() {
let src = "- [First](./first.md)\n<!-- this is a comment -->\n- [Second](./second.md)";

let should_be = vec![
SummaryItem::Link(Link {
name: String::from("First"),
location: PathBuf::from("./first.md"),
number: Some(SectionNumber(vec![1])),
nested_items: Vec::new(),
}),
SummaryItem::Link(Link {
name: String::from("Second"),
location: PathBuf::from("./second.md"),
number: Some(SectionNumber(vec![2])),
nested_items: Vec::new(),
}),
];

let mut parser = SummaryParser::new(src);
let _ = parser.stream.next();

let got = parser.parse_numbered().unwrap();

assert_eq!(got, should_be);
}

/// This test ensures the book will continue to pass because it breaks the
/// `SUMMARY.md` up using level 2 headers ([example]).
///
Expand Down

0 comments on commit 5f2b764

Please sign in to comment.