From d1ed448450d80279aa954e4c2e1e88099d8e5dcd Mon Sep 17 00:00:00 2001 From: Ignatius Bagus Date: Wed, 17 Jan 2024 19:17:04 +0700 Subject: [PATCH] fix: lazily match delimited title (#121) --- workspace/marqua/src/artisan/marker.js | 2 +- workspace/marqua/src/core/index.js | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/workspace/marqua/src/artisan/marker.js b/workspace/marqua/src/artisan/marker.js index e81a588..210c132 100644 --- a/workspace/marqua/src/artisan/marker.js +++ b/workspace/marqua/src/artisan/marker.js @@ -29,7 +29,7 @@ marker.renderer.rules.heading_open = scope(() => { const [token, text] = [tokens[idx], tokens[idx + 1].content]; const level = +token.tag.slice(-1); if (level > 4) return `<${token.tag}>`; - const [delimited] = text.match(/\$\(.*\)/) || ['']; + const [delimited] = text.match(/\$\(.*?\)/) || ['']; const id = generate.id(delimited.slice(2, -1) || text); if (level === 2) parents = [id]; diff --git a/workspace/marqua/src/core/index.js b/workspace/marqua/src/core/index.js index b939aaa..0c1b609 100644 --- a/workspace/marqua/src/core/index.js +++ b/workspace/marqua/src/core/index.js @@ -34,7 +34,7 @@ export function parse(source) { if (!match) continue; const [, hashes, title] = match; - const [delimited] = title.match(/\$\(.*\)/) || ['']; + const [delimited] = title.match(/\$\(.*?\)/) || ['']; table.push({ id: generate.id(delimited.slice(2, -1) || title),