Skip to content

Commit

Permalink
Revert "fix: harden again manufactured input which could previously t…
Browse files Browse the repository at this point in the history
…rigger assertion failures. (#91)"

This reverts commit a368f0f.
  • Loading branch information
cip999 committed Dec 14, 2024
1 parent aefd5cb commit a442910
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 60 deletions.
59 changes: 25 additions & 34 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -470,6 +470,7 @@ where
classes,
attrs,
} => {
assert_eq!(state.current_heading, None);
state.current_heading = Some(self::Heading {
id: id.as_ref().map(|id| id.clone().into()),
classes: classes.iter().map(|class| class.clone().into()).collect(),
Expand Down Expand Up @@ -553,40 +554,34 @@ where
}
}
End(tag) => match tag {
TagEnd::Link => {
let Some(category) = state.link_stack.pop() else {
// This should always be present, but people can provide any kind of event stream.
return Ok(());
};
match category {
LinkCategory::AngleBracketed => formatter.write_char('>'),
LinkCategory::Reference { uri, title, id } => {
TagEnd::Link => match state.link_stack.pop().unwrap() {
LinkCategory::AngleBracketed => formatter.write_char('>'),
LinkCategory::Reference { uri, title, id } => {
state
.shortcuts
.push((id.to_string(), uri.to_string(), title.to_string()));
formatter.write_str("][")?;
formatter.write_str(&id)?;
formatter.write_char(']')
}
LinkCategory::Collapsed { uri, title } => {
if let Some(shortcut_text) = state.current_shortcut_text.take() {
state
.shortcuts
.push((id.to_string(), uri.to_string(), title.to_string()));
formatter.write_str("][")?;
formatter.write_str(&id)?;
formatter.write_char(']')
}
LinkCategory::Collapsed { uri, title } => {
if let Some(shortcut_text) = state.current_shortcut_text.take() {
state
.shortcuts
.push((shortcut_text, uri.to_string(), title.to_string()));
}
formatter.write_str("][]")
.push((shortcut_text, uri.to_string(), title.to_string()));
}
LinkCategory::Shortcut { uri, title } => {
if let Some(shortcut_text) = state.current_shortcut_text.take() {
state
.shortcuts
.push((shortcut_text, uri.to_string(), title.to_string()));
}
formatter.write_char(']')
formatter.write_str("][]")
}
LinkCategory::Shortcut { uri, title } => {
if let Some(shortcut_text) = state.current_shortcut_text.take() {
state
.shortcuts
.push((shortcut_text, uri.to_string(), title.to_string()));
}
LinkCategory::Other { uri, title } => close_link(&uri, &title, formatter, LinkType::Inline),
formatter.write_char(']')
}
}
LinkCategory::Other { uri, title } => close_link(&uri, &title, formatter, LinkType::Inline),
},
TagEnd::Image => match state.image_stack.pop().unwrap() {
ImageLink::Reference { uri, title, id } => {
state
Expand Down Expand Up @@ -619,15 +614,11 @@ where
TagEnd::Emphasis => formatter.write_char(options.emphasis_token),
TagEnd::Strong => formatter.write_str(options.strong_token),
TagEnd::Heading(_) => {
let Some(heading) = state.current_heading.take() else {
// Harden against manufactured input.
return Ok(());
};
let self::Heading {
id,
classes,
attributes,
} = heading;
} = state.current_heading.take().unwrap();
let emit_braces = id.is_some() || !classes.is_empty() || !attributes.is_empty();
if emit_braces {
formatter.write_str(" {")?;
Expand Down
26 changes: 0 additions & 26 deletions tests/integrate/main.rs
Original file line number Diff line number Diff line change
@@ -1,32 +1,6 @@
mod display;
mod fmt;
mod spec;
mod fuzzed {
use pulldown_cmark::{Event, HeadingLevel, Tag, TagEnd};
use pulldown_cmark_to_cmark::cmark_resume;

#[test]
fn cmark_resume_with_options_does_not_panic() {
let events = [
Event::Start(Tag::Heading {
level: HeadingLevel::H2,
id: None,
classes: vec![],
attrs: vec![],
}),
Event::Start(Tag::Heading {
level: HeadingLevel::H2,
id: None,
classes: vec![],
attrs: vec![],
}),
Event::Text(pulldown_cmark::CowStr::Borrowed("(")),
Event::End(TagEnd::Heading(HeadingLevel::H2)),
Event::End(TagEnd::Heading(HeadingLevel::H2)),
];
let _ = cmark_resume(events.iter(), String::new(), None);
}
}

#[cfg(test)]
mod calculate_code_block_token_count {
Expand Down

0 comments on commit a442910

Please sign in to comment.