From 6f1dce63069c0a688f8e3921cadb538fa4d75829 Mon Sep 17 00:00:00 2001 From: Benni <> Date: Thu, 14 Dec 2023 02:53:02 +0100 Subject: [PATCH] Fix last LineBreakInline source span in multi block scenario --- src/Markdig.Tests/TestSourcePosition.cs | 32 +++++++++++++++++++++++++ src/Markdig/Parsers/InlineProcessor.cs | 4 ++-- 2 files changed, 34 insertions(+), 2 deletions(-) diff --git a/src/Markdig.Tests/TestSourcePosition.cs b/src/Markdig.Tests/TestSourcePosition.cs index 62a5eafbe..28cf19a6e 100644 --- a/src/Markdig.Tests/TestSourcePosition.cs +++ b/src/Markdig.Tests/TestSourcePosition.cs @@ -89,6 +89,38 @@ public void TestParagraphWithEndNewLine() ", trackTrivia: true); } + + [Test] + public void TestMultipleParagraphsWithEndNewLine() + { + Check("0123456789\n\n0123456789\n\n", @" +paragraph ( 0, 0) 0-10 +literal ( 0, 0) 0-9 +linebreak ( 0,10) 10-10 +paragraph ( 2, 0) 12-22 +literal ( 2, 0) 12-21 +linebreak ( 2,10) 22-22 +", trackTrivia: true); + + Check("0123456789\r\r0123456789\r\r", @" +paragraph ( 0, 0) 0-10 +literal ( 0, 0) 0-9 +linebreak ( 0,10) 10-10 +paragraph ( 2, 0) 12-22 +literal ( 2, 0) 12-21 +linebreak ( 2,10) 22-22 +", trackTrivia: true); + + Check("0123456789\r\n\r\n0123456789\r\n\r\n", @" +paragraph ( 0, 0) 0-11 +literal ( 0, 0) 0-9 +linebreak ( 0,10) 10-11 +paragraph ( 2, 0) 14-25 +literal ( 2, 0) 14-23 +linebreak ( 2,10) 24-25 +", trackTrivia: true); + } + [Test] public void TestEmphasis() { diff --git a/src/Markdig/Parsers/InlineProcessor.cs b/src/Markdig/Parsers/InlineProcessor.cs index c60cb1284..2806f1bb5 100644 --- a/src/Markdig/Parsers/InlineProcessor.cs +++ b/src/Markdig/Parsers/InlineProcessor.cs @@ -225,7 +225,7 @@ public void ProcessInlineLeaf(LeafBlock leafBlock) previousLineIndexForSliceOffset = 0; lineOffsets.Clear(); var text = leafBlock.Lines.ToSlice(lineOffsets); - var textEnd = text.Length; + var textEnd = text.End; leafBlock.Lines.Release(); int previousStart = -1; @@ -320,7 +320,7 @@ public void ProcessInlineLeaf(LeafBlock leafBlock) var newLine = leafBlock.NewLine; if (newLine != NewLine.None) { - var position = GetSourcePosition(textEnd, out int line, out int column); + var position = GetSourcePosition(textEnd + 1, out int line, out int column); leafBlock.Inline.AppendChild(new LineBreakInline { NewLine = newLine, Line = line, Column = column, Span = { Start = position, End = position + (newLine == NewLine.CarriageReturnLineFeed ? 1 : 0) } }); } }