1
0
mirror of https://github.com/danog/gojekyll.git synced 2024-11-30 10:19:03 +01:00
gojekyll/sites/site.go

129 lines
3.3 KiB
Go
Raw Normal View History

package sites
import (
"io/ioutil"
"os"
"path/filepath"
"strings"
2017-06-19 20:44:34 +02:00
"github.com/osteele/gojekyll/collections"
"github.com/osteele/gojekyll/config"
2017-06-17 02:11:52 +02:00
"github.com/osteele/gojekyll/helpers"
2017-06-18 11:59:12 +02:00
"github.com/osteele/gojekyll/liquid"
2017-06-22 17:02:32 +02:00
"github.com/osteele/gojekyll/pages"
"github.com/osteele/gojekyll/templates"
)
// Site is a Jekyll site.
type Site struct {
2017-06-19 04:24:10 +02:00
ConfigFile *string
Source string
Destination string
UseRemoteLiquidEngine bool
Collections []*collections.Collection
Variables templates.VariableMap
2017-06-23 21:27:13 +02:00
Paths map[string]pages.Page // URL path -> Page, only for output pages
config config.Config
2017-06-18 11:59:12 +02:00
liquidEngine liquid.Engine
2017-06-23 21:27:13 +02:00
pages []pages.Page // all pages, output or not
2017-06-18 11:59:12 +02:00
sassTempDir string
}
2017-06-23 21:27:13 +02:00
// Pages returns a slice of pages.
func (s *Site) Pages() []pages.Page { return s.pages }
2017-06-22 16:37:31 +02:00
// PathPrefix returns the relative directory prefix.
func (s *Site) PathPrefix() string { return "" }
2017-06-16 04:31:36 +02:00
// NewSite creates a new site record, initialized with the site defaults.
2017-06-13 18:00:14 +02:00
func NewSite() *Site {
return &Site{config: config.Default()}
}
// NewSiteFromDirectory reads the configuration file, if it exists.
func NewSiteFromDirectory(source string) (*Site, error) {
s := NewSite()
configPath := filepath.Join(source, "_config.yml")
2017-06-13 18:00:14 +02:00
bytes, err := ioutil.ReadFile(configPath)
switch {
case err != nil && os.IsNotExist(err):
// ok
case err != nil:
return nil, err
default:
err = config.Unmarshal(bytes, &s.config)
if err != nil {
return nil, err
}
2017-06-13 18:00:14 +02:00
s.Source = filepath.Join(source, s.config.Source)
s.ConfigFile = &configPath
}
s.Destination = filepath.Join(s.Source, s.config.Destination)
return s, nil
}
2017-06-13 23:19:05 +02:00
// KeepFile returns a boolean indicating that clean should leave the file in the destination directory.
func (s *Site) KeepFile(path string) bool {
// TODO
return false
}
2017-06-22 16:37:31 +02:00
// RelPathPage returns a Page, give a file path relative to site source directory.
2017-06-22 17:02:32 +02:00
func (s *Site) RelPathPage(relpath string) (pages.Page, bool) {
for _, p := range s.Paths {
2017-06-22 16:37:31 +02:00
if p.SiteRelPath() == relpath {
return p, true
}
}
2017-06-22 16:37:31 +02:00
return nil, false
}
2017-06-22 16:37:31 +02:00
// RelPathURL returns a page's relative URL, give a file path relative to the site source directory.
func (s *Site) RelPathURL(relpath string) (string, bool) {
var url string
p, found := s.RelPathPage(relpath)
if found {
url = p.Permalink()
}
2017-06-22 16:37:31 +02:00
return url, found
}
2017-06-22 16:37:31 +02:00
// URLPage returns the page that will be served at URL
2017-06-22 17:02:32 +02:00
func (s *Site) URLPage(urlpath string) (p pages.Page, found bool) {
p, found = s.Paths[urlpath]
if !found {
p, found = s.Paths[filepath.Join(urlpath, "index.html")]
}
if !found {
p, found = s.Paths[filepath.Join(urlpath, "index.htm")]
}
return
}
2017-06-13 23:19:05 +02:00
// Exclude returns a boolean indicating that the site excludes a file.
func (s *Site) Exclude(path string) bool {
// TODO exclude based on glob, not exact match
inclusionMap := helpers.StringArrayToMap(s.config.Include)
exclusionMap := helpers.StringArrayToMap(s.config.Exclude)
base := filepath.Base(path)
switch {
2017-06-13 18:38:06 +02:00
case inclusionMap[path]:
return false
case path == ".":
return false
case exclusionMap[path]:
return true
case strings.HasPrefix(base, "."), strings.HasPrefix(base, "_"):
return true
default:
return false
}
}
// LayoutsDir returns the path to the layouts directory.
func (s *Site) LayoutsDir() string {
return filepath.Join(s.Source, s.config.LayoutsDir)
}