From d8bee95eaf4ce1ff65caf1dbe5c7bd072f0abde6 Mon Sep 17 00:00:00 2001 From: Noah Hellman Date: Sun, 25 Jun 2023 18:03:46 +0200 Subject: [PATCH] inline: fix label of empty multi-line ref links e.g. [some text][] [some text]: url --- src/inline.rs | 43 +++++++++++++++++++------------------------ src/lib.rs | 40 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 59 insertions(+), 24 deletions(-) diff --git a/src/inline.rs b/src/inline.rs index cb92020f..f1c71c51 100644 --- a/src/inline.rs +++ b/src/inline.rs @@ -732,41 +732,36 @@ impl<'s> Parser<'s> { image, } => { let span_spec = self.events[e_opener].span.end..self.input.span.start; - let multiline = + let multiline_spec = self.events[e_opener].span.start < self.input.span_line.start; let spec: CowStr = if span_spec.is_empty() && !inline { - let span_spec = self.events[event_span].span.end - ..self.events[e_opener - 1].span.start; let events_text = self .events .iter() .skip(event_span + 1) .take(e_opener - event_span - 2); - if multiline - || events_text.clone().any(|ev| { - !matches!(ev.kind, EventKind::Str | EventKind::Atom(..)) - }) - { - let mut spec = String::new(); - let mut span = 0..0; - for ev in events_text.filter(|ev| { - matches!(ev.kind, EventKind::Str | EventKind::Atom(..)) - }) { - if span.end == ev.span.start { - span.end = ev.span.end; - } else { - spec.push_str(&self.input.src[span.clone()]); - span = ev.span.clone(); - } + let mut spec = String::new(); + let mut span = 0..0; + for ev in events_text.filter(|ev| { + matches!(ev.kind, EventKind::Str | EventKind::Atom(..)) + && !matches!(ev.kind, EventKind::Atom(Escape)) + }) { + if matches!(ev.kind, EventKind::Atom(Softbreak | Hardbreak)) { + spec.push_str(&self.input.src[span.clone()]); + spec.push(' '); + span = ev.span.end..ev.span.end; + } else if span.end == ev.span.start { + span.end = ev.span.end; + } else { + spec.push_str(&self.input.src[span.clone()]); + span = ev.span.clone(); } - spec.push_str(&self.input.src[span]); - spec.into() - } else { - self.input.src[span_spec].into() } - } else if multiline { + spec.push_str(&self.input.src[span]); + spec.into() + } else if multiline_spec { let mut spec = String::new(); let mut first_part = true; let mut span = diff --git a/src/lib.rs b/src/lib.rs index 3319c2aa..a4636166 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1697,6 +1697,46 @@ mod test { ); } + #[test] + fn link_reference_multiline_empty() { + test_parse!( + concat!( + "> [a\n", // + "> b][]\n", // + "> [a\\\n", // + "> b][]\n", // + "\n", // + "[a b]: url\n", // + ), + Start(Blockquote, Attributes::new()), + Start(Paragraph, Attributes::new()), + Start( + Link("url".into(), LinkType::Span(SpanLinkType::Reference)), + Attributes::new() + ), + Str("a".into()), + Softbreak, + Str("b".into()), + End(Link("url".into(), LinkType::Span(SpanLinkType::Reference))), + Softbreak, + Start( + Link("url".into(), LinkType::Span(SpanLinkType::Reference)), + Attributes::new() + ), + Str("a".into()), + Escape, + Hardbreak, + Str("b".into()), + End(Link("url".into(), LinkType::Span(SpanLinkType::Reference))), + End(Paragraph), + End(Blockquote), + Blankline, + Start(LinkDefinition { label: "a b" }, Attributes::new()), + Str("url".into()), + End(LinkDefinition { label: "a b" }), + ); + } + #[test] fn link_definition_multiline() { test_parse!(