From 605a7a4124ac45214d2678a241d86677ee7c0975 Mon Sep 17 00:00:00 2001 From: Jeremy Ruston Date: Sun, 18 Nov 2012 13:43:06 +0000 Subject: [PATCH] Fixed problem with missing macros throwing an error --- .../parsers/wikitextparser/rules/macro.js | 31 +++++++++---------- 1 file changed, 14 insertions(+), 17 deletions(-) diff --git a/core/modules/parsers/wikitextparser/rules/macro.js b/core/modules/parsers/wikitextparser/rules/macro.js index 48fd3f322..c7f9f15c2 100644 --- a/core/modules/parsers/wikitextparser/rules/macro.js +++ b/core/modules/parsers/wikitextparser/rules/macro.js @@ -3,15 +3,7 @@ title: $:/core/modules/parsers/wikitextparser/rules/macro.js type: application/javascript module-type: wikitextrule -Wiki text run rule for pretty links. For example: - -{{{ -<> - -<< -A macro with a bunch of content inside it. The content can include //formatting//. ->> -}}} +Wiki text rule for macros \*/ (function(){ @@ -52,14 +44,19 @@ exports.parse = function(match,isBlock) { content = this.parseRun(/(>>)/mg); } } - var macroNode = $tw.Tree.Macro(match[1] || match[2],{ - srcParams: match[3], - content: content, - isBlock: isBlock, - wiki: this.wiki - }); - this.dependencies.mergeDependencies(macroNode.dependencies); - return [macroNode]; + var macroName = match[1] || match[2]; + if(macroName in $tw.wiki.macros) { + var macroNode = $tw.Tree.Macro(match[1] || match[2],{ + srcParams: match[3], + content: content, + isBlock: isBlock, + wiki: this.wiki + }); + this.dependencies.mergeDependencies(macroNode.dependencies); + return [macroNode]; + } else { + console.log("Missing macro '" + macroName + "'"); + } } return []; };