ref: 280df4e380798d336826e9ce5446640e881d2b06
parent: e98f0014f2f46ff4b342d5eb3062d4fb1e6d4184
	author: Phil Pennock <pdp@spodhuis.org>
	date: Tue May 13 08:56:06 EDT 2014
	
Fix Viperized .Site.Params
git bisect identified 62dd1d4 as the breaking commit; when
github.com/spf13/viper was introduced, the Params field was always
empty.
Given a map in YAML in Viper, the return type is
`map[interface{}]interface{}`, _not_ `map[string]interface{}`, even if
`.SetDefault()` has been called with an item of
`map[string]interface{}{}` so the cast assertion on the `.Get("Params")`
always failed.
--- a/hugolib/site.go
+++ b/hugolib/site.go
@@ -260,9 +260,17 @@
}
 func (s *Site) initializeSiteInfo() {-	params, ok := viper.Get("Params").(map[string]interface{})+	paramsV, ok := viper.Get("Params").(map[interface{}]interface{})+	// Warning: viper.Get(map_item) returns map[interface{}]interface{}+	// even if .SetDefault called with a map[string]interface{} 	if !ok {-		params = make(map[string]interface{})+		paramsV = make(map[interface{}]interface{})+ }
+	params := make(map[string]interface{}, len(paramsV))+	for k, v := range paramsV {+		if s, ok := k.(string); ok {+ params[s] = v
+ }
}
permalinks := make(PermalinkOverrides)
--
⑨