ref: 025a37df2f829a1799a2995ef8e49d591e96bee3
parent: 05b76dcb6fb02fdaa7e8b99cd5cb123bdae8881e
author: Dato Simó <[email protected]>
date: Sat May 10 21:27:49 EDT 2014
Fix permalink functionality, which was broken in 62dd1d4. Viper stores Permalinks as a map[string]interface{}, so the type assertion to PermalinkOverrides (map[string]PathPattern) will always fail. We can, however, get Permalinks as a map[string]string, and convert each value to a PathPattern.
--- a/hugolib/site.go
+++ b/hugolib/site.go
@@ -265,9 +265,9 @@
params = make(map[string]interface{})
}
- permalinks, ok := viper.Get("Permalinks").(PermalinkOverrides)
- if !ok {
- permalinks = make(PermalinkOverrides)
+ permalinks := make(PermalinkOverrides)
+ for k, v := range viper.GetStringMapString("Permalinks") {
+ permalinks[k] = PathPattern(v)
}
s.Info = SiteInfo{
--- a/hugolib/siteinfo_test.go
+++ b/hugolib/siteinfo_test.go
@@ -30,3 +30,15 @@
t.Errorf("Expected FOOBAR_PARAM: got %s", buf.String())
}
}
+
+func TestSiteInfoPermalinks (t *testing.T) {
+ viper.Set("Permalinks", map[string]interface{}{"section": "/:title"})
+ s := &Site{}
+
+ s.initialize()
+ permalink := s.Info.Permalinks["section"]
+
+ if permalink != "/:title" {
+ t.Errorf("Could not set permalink (%#v)", permalink)
+ }
+}