ref: d712d6f3310121b80fa00398af01b4d200e391a0
parent: 9032a228b01906eea7ad92269c5bad109c333418
author: Noah Campbell <[email protected]>
date: Wed Oct 2 13:25:16 EDT 2013
Moving transformation on a per-page level
--- a/hugolib/site.go
+++ b/hugolib/site.go
@@ -539,7 +539,6 @@
}
func (s *Site) render(d interface{}, out string, layouts ...string) (err error) {
- reader, writer := io.Pipe()
layout := s.findFirstLayout(layouts...)
if layout == "" {
@@ -548,14 +547,35 @@
}
return
}
+
+ section := ""
+ page, ok := d.(*Page)
+ if ok {
+ section = page.Section
+ }
+
+ fmt.Println("Section is:", section)
+
+ transformer := transform.NewChain(
+ &transform.AbsURL{BaseURL: s.Config.BaseUrl},
+ &transform.NavActive{Section: section},
+ )
+
+ renderReader, renderWriter := io.Pipe()
go func() {
- err = s.renderThing(d, layout, writer)
+ err = s.renderThing(d, layout, renderWriter)
if err != nil {
panic(err)
}
}()
- return s.WritePublic(out, reader)
+ trReader, trWriter := io.Pipe()
+ go func() {
+ transformer.Apply(trWriter, renderReader)
+ trWriter.Close()
+ }()
+
+ return s.WritePublic(out, trReader)
}
func (s *Site) findFirstLayout(layouts ...string) (layout string) {
@@ -590,24 +610,12 @@
}
}
-func (s *Site) WritePublic(path string, content io.Reader) (err error) {
+func (s *Site) WritePublic(path string, reader io.Reader) (err error) {
s.initTarget()
if s.Config.Verbose {
fmt.Println(path)
}
-
- if s.Transformer == nil {
- s.Transformer = transform.NewChain(
- &transform.AbsURL{BaseURL: s.Config.BaseUrl},
- &transform.NavActive{Section: "tbd"},
- )
- }
- reader, writer := io.Pipe()
- go func() {
- s.Transformer.Apply(writer, content)
- writer.Close()
- }()
return s.Target.Publish(path, reader)
}