1
0
mirror of https://github.com/danog/gojekyll.git synced 2025-01-23 02:21:16 +01:00

Collections holds a Container, not a RenderingPipeline

This commit is contained in:
Oliver Steele 2017-06-24 12:03:33 -04:00
parent 4426fb2c93
commit 61f92ecd96
3 changed files with 22 additions and 30 deletions

View File

@ -13,29 +13,24 @@ import (
// Collection is a Jekyll collection https://jekyllrb.com/docs/collections/.
type Collection struct {
Name string
Metadata templates.VariableMap
pages []pages.Page
rp pages.RenderingPipeline
Name string
Metadata templates.VariableMap
container pages.Container
pages []pages.Page
}
// NewCollection creates a new Collection
func NewCollection(name string, metadata templates.VariableMap, rp pages.RenderingPipeline) *Collection {
func NewCollection(name string, metadata templates.VariableMap, c pages.Container) *Collection {
return &Collection{
Name: name,
Metadata: metadata,
rp: rp,
Name: name,
Metadata: metadata,
container: c,
}
}
// OutputExt returns the output extension.
func (c *Collection) OutputExt(pathname string) string {
return c.rp.OutputExt(pathname)
}
// RenderingPipeline returns the rendering pipeline.
func (c *Collection) RenderingPipeline() pages.RenderingPipeline {
return c.rp
return c.container.OutputExt(pathname)
}
// IsPostsCollection returns true if the collection is the special "posts" collection.

View File

@ -1,9 +1,6 @@
package collections
import (
"fmt"
"io"
"path"
"testing"
@ -17,24 +14,23 @@ var tests = []struct{ in, out string }{
{"post", ":insertion:post"},
}
type MockContext struct{}
type MockContainer struct{}
func (c MockContext) OutputExt(filename string) string {
return path.Ext(filename)
}
func (c MockContainer) PathPrefix() string { return "" }
func (c MockContainer) OutputExt(filename string) string { return path.Ext(filename) }
func (c MockContext) Render(_ io.Writer, _ []byte, _ string, _ templates.VariableMap) ([]byte, error) {
return nil, fmt.Errorf("unimplemented")
}
// func (c MockPipeline) Render(_ io.Writer, _ []byte, _ string, _ templates.VariableMap) ([]byte, error) {
// return nil, fmt.Errorf("unimplemented")
// }
func (c MockContext) ApplyLayout(_ string, _ []byte, _ templates.VariableMap) ([]byte, error) {
return nil, fmt.Errorf("unimplemented")
}
// func (c MockPipeline) ApplyLayout(_ string, _ []byte, _ templates.VariableMap) ([]byte, error) {
// return nil, fmt.Errorf("unimplemented")
// }
func (c MockContext) SiteVariables() templates.VariableMap { return templates.VariableMap{} }
// func (c MockPipeline) SiteVariables() templates.VariableMap { return templates.VariableMap{} }
func TestNewCollection(t *testing.T) {
ctx := MockContext{}
ctx := MockContainer{}
c1 := NewCollection("c", templates.VariableMap{"output": true}, ctx)
require.Equal(t, true, c1.Output())
@ -45,7 +41,7 @@ func TestNewCollection(t *testing.T) {
}
func TestPermalinkPattern(t *testing.T) {
ctx := MockContext{}
ctx := MockContainer{}
c1 := NewCollection("c", templates.VariableMap{}, ctx)
require.Contains(t, c1.PermalinkPattern(), ":collection")

View File

@ -31,6 +31,7 @@ type RenderingContext interface {
SiteVariables() templates.VariableMap // value of the "site" template variable
}
// RenderingPipeline applies transformations to a document.
type RenderingPipeline interface {
ApplyLayout(string, []byte, templates.VariableMap) ([]byte, error)
OutputExt(pathname string) string