From b956e72536389c1a722d26f0668c70600f0ff7d4 Mon Sep 17 00:00:00 2001 From: linonetwo Date: Sat, 16 Sep 2023 04:09:21 +0800 Subject: [PATCH] fix: properly match blockId and pass it to ast --- core/modules/parsers/wikiparser/rules/prettylink.js | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/core/modules/parsers/wikiparser/rules/prettylink.js b/core/modules/parsers/wikiparser/rules/prettylink.js index 4d7839979..bfca074f1 100644 --- a/core/modules/parsers/wikiparser/rules/prettylink.js +++ b/core/modules/parsers/wikiparser/rules/prettylink.js @@ -23,8 +23,8 @@ exports.types = {inline: true}; exports.init = function(parser) { this.parser = parser; - // Regexp to match `[[Title^blockId|Alias]]`, the `^blockId` and `|Alias` are optional. - this.matchRegExp = /\[\[(.*?)(?:\^([^|\s^]+))?(?:\|(.*?))?\]\]/mg; + // Regexp to match `[[Alias|Title^blockId]]`, the `Alias|` and `^blockId` are optional. + this.matchRegExp = /\[\[(.*?)(?:\|(.*?)?)?(?:\^([^|\s^]+)?)?\]\]/mg; }; exports.parse = function() { @@ -32,8 +32,8 @@ exports.parse = function() { this.parser.pos = this.matchRegExp.lastIndex; // Process the link var text = this.match[1], - blockId = this.match[2] || "", - link = this.match[3] || text; + link = this.match[2] || text, + blockId = this.match[3] || ""; if($tw.utils.isLinkExternal(link)) { // add back the part after `^` to the ext link, if it happen to has one. if(blockId) { @@ -57,7 +57,7 @@ exports.parse = function() { type: "link", attributes: { to: {type: "string", value: link}, - id: {type: "string", value: blockId}, + toBlockId: {type: "string", value: blockId}, }, children: [{ type: "text", text: text