1
0
mirror of https://github.com/danog/gojekyll.git synced 2024-11-26 23:24:39 +01:00
gojekyll/collections/collection.go

95 lines
2.7 KiB
Go
Raw Normal View History

package collections
2017-06-13 15:01:20 +02:00
import (
"fmt"
"os"
"path/filepath"
"strings"
"github.com/osteele/gojekyll/constants"
2017-06-22 17:02:32 +02:00
"github.com/osteele/gojekyll/pages"
"github.com/osteele/gojekyll/templates"
2017-06-13 15:01:20 +02:00
)
// Collection is a Jekyll collection https://jekyllrb.com/docs/collections/.
2017-06-13 15:01:20 +02:00
type Collection struct {
Name string
Metadata templates.VariableMap
2017-06-22 23:53:46 +02:00
pages []pages.Page
2017-06-13 15:01:20 +02:00
}
2017-06-22 23:53:46 +02:00
// NewCollection creates a new Collection
func NewCollection(ctx pages.Context, name string, metadata templates.VariableMap) *Collection {
2017-06-13 15:01:20 +02:00
return &Collection{
Name: name,
2017-06-22 23:53:46 +02:00
Metadata: metadata,
2017-06-13 15:01:20 +02:00
}
}
2017-06-15 13:19:49 +02:00
// IsPosts returns true if the collection is the special "posts" collection.
func (c *Collection) IsPostsCollection() bool { return c.Name == "posts" }
2017-06-22 16:37:31 +02:00
// Output returns a bool indicating whether files in this collection should be written.
func (c *Collection) Output() bool { return c.Metadata.Bool("output", false) }
2017-06-13 15:01:20 +02:00
// PathPrefix returns the collection's directory prefix, e.g. "_posts/"
2017-06-22 16:37:31 +02:00
func (c *Collection) PathPrefix() string { return filepath.FromSlash("_" + c.Name + "/") }
2017-06-17 02:19:46 +02:00
2017-06-22 17:55:58 +02:00
// Pages is a list of pages.
func (c *Collection) Pages() []pages.Page {
return c.pages
}
2017-06-22 16:37:31 +02:00
// TemplateVariable returns an array of page objects, for use as the template variable
// value of the collection.
2017-06-22 18:56:08 +02:00
func (c *Collection) TemplateVariable() []templates.VariableMap {
2017-06-22 17:55:58 +02:00
d := []templates.VariableMap{}
for _, p := range c.Pages() {
d = append(d, p.PageVariables())
2017-06-22 16:37:31 +02:00
}
2017-06-22 17:55:58 +02:00
return d
2017-06-13 15:01:20 +02:00
}
// ReadPages scans the file system for collection pages, and adds them to c.Pages.
func (c *Collection) ReadPages(ctx pages.Context, sitePath string, frontMatterDefaults func(string, string) templates.VariableMap) error {
pageDefaults := templates.VariableMap{
"collection": c.Name,
"permalink": constants.DefaultCollectionPermalinkPattern,
}
if c.IsPostsCollection() {
pageDefaults["permalink"] = constants.DefaultPostsCollectionPermalinkPattern
}
2017-06-13 15:01:20 +02:00
2017-06-22 16:37:31 +02:00
walkFn := func(filename string, info os.FileInfo, err error) error {
2017-06-13 15:01:20 +02:00
if err != nil {
2017-06-14 23:41:15 +02:00
// if the issue is simply that the directory doesn't exist, warn instead of error
2017-06-13 15:01:20 +02:00
if os.IsNotExist(err) {
if !c.IsPostsCollection() {
fmt.Printf("Missing collection directory: _%s\n", c.Name)
2017-06-13 15:01:20 +02:00
}
return nil
}
return err
}
relname, err := filepath.Rel(sitePath, filename)
2017-06-13 15:01:20 +02:00
switch {
case strings.HasPrefix(filepath.Base(relname), "."):
return nil
2017-06-13 15:01:20 +02:00
case err != nil:
return err
case info.IsDir():
return nil
}
defaults := templates.MergeVariableMaps(pageDefaults, frontMatterDefaults(relname, ""))
p, err := pages.NewPageFromFile(ctx, c, filename, relname, defaults)
2017-06-13 15:01:20 +02:00
switch {
case err != nil:
return err
case p.Published():
c.pages = append(c.pages, p)
2017-06-13 15:01:20 +02:00
}
return nil
}
return filepath.Walk(filepath.Join(sitePath, c.PathPrefix()), walkFn)
2017-06-13 15:01:20 +02:00
}