From e4198ed70dce5a361901c009299b566541fc628e Mon Sep 17 00:00:00 2001 From: Tony Brix Date: Sat, 14 Dec 2024 19:19:01 -0700 Subject: [PATCH] fix: fix list with no items looping forever (#3560) * fix: fix list with no items looping forever * add test --- src/Tokenizer.ts | 3 +++ test/unit/marked.test.js | 14 ++++++++++++++ 2 files changed, 17 insertions(+) diff --git a/src/Tokenizer.ts b/src/Tokenizer.ts index a71879546d..08ee396636 100644 --- a/src/Tokenizer.ts +++ b/src/Tokenizer.ts @@ -418,6 +418,9 @@ export class _Tokenizer { if (lastItem) { lastItem.raw = lastItem.raw.trimEnd(); lastItem.text = lastItem.text.trimEnd(); + } else { + // not a list since there were no items + return; } list.raw = list.raw.trimEnd(); diff --git a/test/unit/marked.test.js b/test/unit/marked.test.js index 294bdf2930..40622968c6 100644 --- a/test/unit/marked.test.js +++ b/test/unit/marked.test.js @@ -127,6 +127,20 @@ describe('marked unit', () => { assert.strictEqual(html, '

Not Underlined A

\nUnderlined B\n

Not Underlined C\n:Not Underlined D

\n'); }); + it('should not return list if no items', () => { + const noHr = { + tokenizer: { + hr() { + return undefined; + }, + }, + }; + marked.use(noHr); + const markdown = '- - -'; + const html = marked.parse(markdown); + assert.strictEqual(html, '

- - -

\n'); + }); + it('should use custom inline tokenizer + renderer extensions', () => { const underline = { name: 'underline',