From: Bjørn Erik Pedersen Date: Tue, 27 Sep 2016 19:11:34 +0000 (+0200) Subject: Fix half-broken self-closing shortcodes X-Git-Tag: v0.17~26 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=59df7db764d011b6e082d11d4660e9c8833a3b75;p=brevno-suite%2Fhugo Fix half-broken self-closing shortcodes Fixes #2498 --- diff --git a/hugolib/shortcodeparser.go b/hugolib/shortcodeparser.go index a15b057a..027d661c 100644 --- a/hugolib/shortcodeparser.go +++ b/hugolib/shortcodeparser.go @@ -345,6 +345,7 @@ func lexShortcodeComment(l *pagelexer) stateFunc { } func lexShortcodeRightDelim(l *pagelexer) stateFunc { + l.closingState = 0 l.pos += pos(len(l.currentRightShortcodeDelim())) l.emit(l.currentRightShortcodeDelimItem()) return lexTextOutsideShortcodes diff --git a/hugolib/shortcodeparser_test.go b/hugolib/shortcodeparser_test.go index a5d7453c..662ce0f6 100644 --- a/hugolib/shortcodeparser_test.go +++ b/hugolib/shortcodeparser_test.go @@ -81,6 +81,18 @@ var shortCodeLexerTests = []shortCodeLexerTest{ // issue #934 {"self-closing", `{{< sc1 />}}`, []item{ tstLeftNoMD, tstSC1, tstSCClose, tstRightNoMD, tstEOF}}, + // Issue 2498 + {"multiple self-closing", `{{< sc1 />}}{{< sc1 />}}`, []item{ + tstLeftNoMD, tstSC1, tstSCClose, tstRightNoMD, + tstLeftNoMD, tstSC1, tstSCClose, tstRightNoMD, tstEOF}}, + {"self-closing with param", `{{< sc1 param1 />}}`, []item{ + tstLeftNoMD, tstSC1, tstParam1, tstSCClose, tstRightNoMD, tstEOF}}, + {"multiple self-closing with param", `{{< sc1 param1 />}}{{< sc1 param1 />}}`, []item{ + tstLeftNoMD, tstSC1, tstParam1, tstSCClose, tstRightNoMD, + tstLeftNoMD, tstSC1, tstParam1, tstSCClose, tstRightNoMD, tstEOF}}, + {"multiple different self-closing with param", `{{< sc1 param1 />}}{{< sc2 param1 />}}`, []item{ + tstLeftNoMD, tstSC1, tstParam1, tstSCClose, tstRightNoMD, + tstLeftNoMD, tstSC2, tstParam1, tstSCClose, tstRightNoMD, tstEOF}}, {"nested simple", `{{< sc1 >}}{{< sc2 >}}{{< /sc1 >}}`, []item{ tstLeftNoMD, tstSC1, tstRightNoMD, tstLeftNoMD, tstSC2, tstRightNoMD, @@ -140,11 +152,10 @@ var shortCodeLexerTests = []shortCodeLexerTest{ } func TestShortcodeLexer(t *testing.T) { - for _, test := range shortCodeLexerTests { - + for i, test := range shortCodeLexerTests { items := collect(&test) if !equal(items, test.items) { - t.Errorf("%s: got\n\t%v\nexpected\n\t%v", test.name, items, test.items) + t.Errorf("[%d] %s: got\n\t%v\nexpected\n\t%v", i, test.name, items, test.items) } } }