1
0
Fork 0
mirror of https://git.sr.ht/~adnano/kiln synced 2024-06-02 06:26:06 +02:00
kiln/site.go

137 lines
3.5 KiB
Go
Raw Normal View History

2020-11-20 18:07:38 +01:00
package main
import (
"fmt"
"log"
2020-11-20 18:07:38 +01:00
"os"
"path"
"strings"
2021-05-10 17:06:55 +02:00
"text/template"
2020-11-20 18:07:38 +01:00
2021-05-10 18:15:58 +02:00
"github.com/pelletier/go-toml"
2020-11-20 18:07:38 +01:00
)
// Site represents a site.
type Site struct {
2021-05-10 06:44:25 +02:00
Title string `toml:"title"`
URLs []string `toml:"urls"`
2021-05-10 16:26:12 +02:00
Tasks []*Task `toml:"tasks"`
2021-05-10 17:06:55 +02:00
Feeds map[string]string `toml:"feeds"`
2021-06-26 08:09:55 +02:00
Params map[string]string `toml:"params"`
2021-05-10 06:44:25 +02:00
Permalinks map[string]string `toml:"permalinks"`
2021-05-10 17:06:55 +02:00
permalinks map[string]*template.Template
templates Templates
root *Dir
2020-11-20 18:07:38 +01:00
}
// Task represents a site build task.
type Task struct {
2021-05-10 18:23:27 +02:00
Input []string `toml:"input"` // input file suffixes
OutputExt string `toml:"output"` // output file suffix
TemplateExt string `toml:"template"` // template file suffix
Preprocess map[string]string `toml:"preprocess"` // preprocess commands
Postprocess string `toml:"postprocess"` // postprocess command
StaticDir string `toml:"static_dir"` // static file directory
OutputDir string `toml:"output_dir"` // output directory
UglyURLs bool `toml:"ugly_urls"` // whether to use ugly URLs
Feeds []Feed `toml:"feeds"`
feeds map[string][]Feed
}
type Feed struct {
InputDir string `toml:"input_dir"`
Title string `toml:"title"`
Template string `toml:"template"`
Output string `toml:"output"`
2021-05-10 18:23:27 +02:00
}
func (t *Task) Match(ext string) bool {
for i := range t.Input {
if t.Input[i] == ext {
return true
}
}
return false
}
// LoadSite loads the site with the given configuration file.
func LoadSite(config string) (*Site, error) {
f, err := os.Open(config)
2020-11-20 18:07:38 +01:00
if err != nil {
2021-03-20 07:02:36 +01:00
return nil, err
2020-11-20 18:07:38 +01:00
}
2021-03-20 07:02:36 +01:00
defer f.Close()
2020-11-20 18:07:38 +01:00
site := &Site{}
if err := toml.NewDecoder(f).Decode(site); err != nil {
2021-03-20 07:02:36 +01:00
return nil, err
}
funcs := site.funcs()
2021-05-10 17:06:55 +02:00
// Parse permalinks
site.permalinks = map[string]*template.Template{}
for path := range site.Permalinks {
t := template.New(fmt.Sprintf("permalink %q", path)).Funcs(funcs)
_, err := t.Parse(site.Permalinks[path])
2021-05-10 17:06:55 +02:00
if err != nil {
return nil, err
}
site.permalinks[path] = t
2020-11-20 18:07:38 +01:00
}
// Load templates
templateExts := []string{}
for _, task := range site.Tasks {
if task.TemplateExt != "" {
templateExts = append(templateExts, task.TemplateExt)
}
}
site.templates.Funcs(funcs)
if err := site.templates.Load("templates", templateExts); err != nil {
return nil, err
}
// Populate task feeds map
for _, task := range site.Tasks {
task.feeds = map[string][]Feed{}
for _, feed := range task.Feeds {
task.feeds[feed.InputDir] = append(task.feeds[feed.InputDir], feed)
}
}
// deprecate [feeds]
if len(site.Feeds) > 0 {
log.Println("The [feeds] configuration is deprecated")
for _, task := range site.Tasks {
if len(task.Feeds) > 0 {
log.Println("and can't be used along [[tasks.feeds]]")
return nil, fmt.Errorf("please remove (or rename) the [feeds] category")
}
}
log.Println("Please replace it with [[tasks.feeds]] in every task needing feeds:")
for permalink, title := range site.Feeds {
dir := strings.Trim(permalink, "/")
output := path.Join(dir, "atom.xml")
fmt.Fprintf(log.Writer(), `[[tasks.feeds]]
input_dir = %q
title = %q
template = "atom.xml"
output = %q
`, dir, title, output)
}
log.Println("You will also need to change .Entries to .Pages in \"atom.xml\"")
}
return site, nil
}
func (s *Site) dir(path string) *Dir {
return s.root.getDir(path)
}
2021-05-10 01:28:09 +02:00
func (s *Site) page(path string) *Page {
return s.root.getPage(path)
2021-05-10 01:28:09 +02:00
}