From: Bjørn Erik Pedersen Date: Thu, 28 Jun 2018 14:06:16 +0000 (+0200) Subject: hugolib: Allow forward slash in shortcode names X-Git-Tag: v0.43~28 X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=de37455ec73cffd039b44e8f6c62d2884b1d6bbd;p=brevno-suite%2Fhugo hugolib: Allow forward slash in shortcode names Fixes #4886 --- diff --git a/hugolib/shortcodeparser.go b/hugolib/shortcodeparser.go index c57ff9b3..32aa8b47 100644 --- a/hugolib/shortcodeparser.go +++ b/hugolib/shortcodeparser.go @@ -464,6 +464,8 @@ Loop: for { switch r := l.next(); { case isAlphaNumericOrHyphen(r): + // Allow forward slash inside names to make it possible to create namespaces. + case r == '/': default: l.backup() word := l.input[l.start:l.pos] diff --git a/hugolib/shortcodeparser_test.go b/hugolib/shortcodeparser_test.go index 45cf69ba..532c8e73 100644 --- a/hugolib/shortcodeparser_test.go +++ b/hugolib/shortcodeparser_test.go @@ -33,6 +33,7 @@ var ( tstSC1 = item{tScName, 0, "sc1"} tstSC2 = item{tScName, 0, "sc2"} tstSC3 = item{tScName, 0, "sc3"} + tstSCSlash = item{tScName, 0, "sc/sub"} tstParam1 = item{tScParam, 0, "param1"} tstParam2 = item{tScParam, 0, "param2"} tstVal = item{tScParamVal, 0, "Hello World"} @@ -45,6 +46,8 @@ var shortCodeLexerTests = []shortCodeLexerTest{ {"no markup", `{{< sc1 >}}`, []item{tstLeftNoMD, tstSC1, tstRightNoMD, tstEOF}}, {"with EOL", "{{< sc1 \n >}}", []item{tstLeftNoMD, tstSC1, tstRightNoMD, tstEOF}}, + {"forward slash inside name", `{{< sc/sub >}}`, []item{tstLeftNoMD, tstSCSlash, tstRightNoMD, tstEOF}}, + {"simple with markup", `{{% sc1 %}}`, []item{tstLeftMD, tstSC1, tstRightMD, tstEOF}}, {"with spaces", `{{< sc1 >}}`, []item{tstLeftNoMD, tstSC1, tstRightNoMD, tstEOF}}, {"mismatched rightDelim", `{{< sc1 %}}`, []item{tstLeftNoMD, tstSC1,