Fix for page.GetParam() for JSON and TOML maps
authorAnthony Fok <foka@debian.org>
Sat, 24 Jan 2015 11:44:35 +0000 (04:44 -0700)
committerbep <bjorn.erik.pedersen@gmail.com>
Sat, 24 Jan 2015 14:25:44 +0000 (15:25 +0100)
Setting per-page Blackfriday angledQuotes did not work
with TOML or JSON front matter, but it does work with YAML.

It turns out that page.Params("blackfriday") returns
type map[interface{}]interface{} for YAML, but
type map[string]interface{} for JSON and TOML.

This patch updates page.GetParam() to catch the latter,
with an error message if page.GetParam() does not recognize
a type.  A test is also added.

hugolib/page.go
hugolib/page_test.go

index 395462d84296b3056b3e744f9c2020cfc741b47c..eadf6eb3d0266ed6216ac99e1db1e4d8a55c652a 100644 (file)
@@ -19,6 +19,7 @@ import (
        "fmt"
        "github.com/spf13/hugo/helpers"
        "github.com/spf13/hugo/parser"
+       "reflect"
 
        "github.com/spf13/cast"
        "github.com/spf13/hugo/hugofs"
@@ -522,9 +523,13 @@ func (page *Page) GetParam(key string) interface{} {
                return cast.ToTime(v)
        case []string:
                return helpers.SliceToLower(v.([]string))
-       case map[interface{}]interface{}:
+       case map[string]interface{}: // JSON and TOML
+               return v
+       case map[interface{}]interface{}: // YAML
                return v
        }
+
+       jww.ERROR.Printf("GetParam(\"%s\"): Unknown type %s\n", key, reflect.TypeOf(v))
        return nil
 }
 
index 887bd1016221e9d9bc86442e822ba9c6073fb437..d4ce7a0a0f7a8b15e02988901f2f42f4a072b854 100644 (file)
@@ -3,10 +3,12 @@ package hugolib
 import (
        "html/template"
        "path/filepath"
+       "reflect"
        "strings"
        "testing"
        "time"
 
+       "github.com/spf13/cast"
        "github.com/spf13/hugo/helpers"
 )
 
@@ -219,6 +221,9 @@ an_integer = 1
 a_float = 1.3
 a_bool = false
 a_date = 1979-05-27T07:32:00Z
+
+[a_table]
+a_key = "a_value"
 +++
 Front Matter with various frontmatter types`
 
@@ -499,6 +504,13 @@ func TestDifferentFrontMatterVarTypes(t *testing.T) {
        if page.GetParam("a_date") != dateval {
                t.Errorf("frontmatter not handling dates correctly should be %s, got: %s", dateval, page.GetParam("a_date"))
        }
+       param := page.GetParam("a_table")
+       if param == nil {
+               t.Errorf("frontmatter not handling tables correctly should be type of %v, got: type of %v", reflect.TypeOf(page.Params["a_table"]), reflect.TypeOf(param))
+       }
+       if cast.ToStringMap(param)["a_key"] != "a_value" {
+               t.Errorf("frontmatter not handling values inside a table correctly should be %s, got: %s", "a_value", cast.ToStringMap(page.Params["a_table"])["a_key"])
+       }
 }
 
 func TestDegenerateInvalidFrontMatterLeadingWhitespace(t *testing.T) {