2017-07-04 09:09:36 -04:00
|
|
|
package site
|
2017-07-03 10:39:55 -04:00
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
2017-07-07 12:24:00 -04:00
|
|
|
"github.com/osteele/gojekyll/pages"
|
2017-07-03 10:39:55 -04:00
|
|
|
"github.com/osteele/gojekyll/templates"
|
2017-07-05 11:35:20 -04:00
|
|
|
"github.com/osteele/liquid/evaluator"
|
2017-07-03 10:39:55 -04:00
|
|
|
)
|
|
|
|
|
|
|
|
// ToLiquid returns the site variable for template evaluation.
|
|
|
|
func (s *Site) ToLiquid() interface{} {
|
2017-07-09 14:05:46 -04:00
|
|
|
// double-checked lock is okay here, since it's okay if this is
|
|
|
|
// computed and set twice
|
2017-07-03 10:39:55 -04:00
|
|
|
if len(s.drop) == 0 {
|
2017-07-05 11:18:32 -04:00
|
|
|
s.Lock()
|
|
|
|
defer s.Unlock()
|
|
|
|
if len(s.drop) == 0 {
|
|
|
|
s.initializeDrop()
|
|
|
|
}
|
2017-07-03 10:39:55 -04:00
|
|
|
}
|
|
|
|
return s.drop
|
|
|
|
}
|
|
|
|
|
|
|
|
// MarshalYAML is part of the yaml.Marshaler interface
|
|
|
|
// The variables subcommand uses this.
|
|
|
|
func (s *Site) MarshalYAML() (interface{}, error) {
|
|
|
|
return s.ToLiquid(), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Site) initializeDrop() {
|
|
|
|
vars := templates.MergeVariableMaps(s.config.Variables, map[string]interface{}{
|
2017-07-07 15:48:31 -04:00
|
|
|
"data": s.data,
|
|
|
|
"documents": s.docs,
|
2017-07-09 14:05:46 -04:00
|
|
|
"html_files": s.htmlFiles(),
|
2017-07-07 12:24:00 -04:00
|
|
|
"html_pages": s.htmlPages(),
|
2017-07-05 12:44:38 -04:00
|
|
|
"pages": s.Pages(),
|
2017-07-09 14:05:46 -04:00
|
|
|
"static_files": s.staticFiles(),
|
2017-07-07 15:48:31 -04:00
|
|
|
// TODO read time from _config, if it's available
|
|
|
|
"time": time.Now(),
|
2017-07-03 10:39:55 -04:00
|
|
|
})
|
|
|
|
collections := []interface{}{}
|
|
|
|
for _, c := range s.Collections {
|
|
|
|
vars[c.Name] = c.Pages()
|
|
|
|
collections = append(collections, c.ToLiquid())
|
|
|
|
}
|
2017-07-05 11:35:20 -04:00
|
|
|
evaluator.SortByProperty(collections, "label", true)
|
2017-07-03 10:39:55 -04:00
|
|
|
vars["collections"] = collections
|
|
|
|
s.drop = vars
|
|
|
|
s.setPostVariables()
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Site) setPageContent() error {
|
|
|
|
for _, c := range s.Collections {
|
|
|
|
if err := c.SetPageContent(s); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2017-07-07 12:24:00 -04:00
|
|
|
|
2017-07-09 14:05:46 -04:00
|
|
|
// The following functions are only used in the drop, therefore they're
|
|
|
|
// non-public and they're listed here.
|
|
|
|
//
|
|
|
|
// Since the drop is cached, there's no effort to cache these too.
|
|
|
|
|
|
|
|
func (s *Site) htmlFiles() (out []*pages.StaticFile) {
|
|
|
|
for _, p := range s.staticFiles() {
|
|
|
|
if p.OutputExt() == ".html" {
|
|
|
|
out = append(out, p)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2017-07-07 12:24:00 -04:00
|
|
|
func (s *Site) htmlPages() (out []pages.Page) {
|
|
|
|
for _, p := range s.Pages() {
|
|
|
|
if p.OutputExt() == ".html" {
|
|
|
|
out = append(out, p)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|
2017-07-09 14:05:46 -04:00
|
|
|
|
|
|
|
func (s *Site) staticFiles() (out []*pages.StaticFile) {
|
|
|
|
for _, d := range s.docs {
|
|
|
|
if sd, ok := d.(*pages.StaticFile); ok {
|
|
|
|
out = append(out, sd)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return
|
|
|
|
}
|