Skip to content

Commit

Permalink
inline: fix label of empty multi-line ref links
Browse files Browse the repository at this point in the history
e.g.

    [some
    text][]

    [some text]: url
  • Loading branch information
hellux committed Jul 11, 2023
1 parent 965b00b commit d8bee95
Show file tree
Hide file tree
Showing 2 changed files with 59 additions and 24 deletions.
43 changes: 19 additions & 24 deletions src/inline.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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 =
Expand Down
40 changes: 40 additions & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -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!(
Expand Down

0 comments on commit d8bee95

Please sign in to comment.