ref: 025a37df2f829a1799a2995ef8e49d591e96bee3
parent: 05b76dcb6fb02fdaa7e8b99cd5cb123bdae8881e
author: Dato Simó <dato@net.com.org.es>
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)+ }
+}
--
⑨