1
0
Fork 0
mirror of https://git.sr.ht/~adnano/kiln synced 2024-06-10 01:56:07 +02:00
kiln/config.go

94 lines
2.6 KiB
Go
Raw Normal View History

2020-11-20 18:07:38 +01:00
package main
import (
"fmt"
2021-05-10 17:06:55 +02:00
htemplate "html/template"
2020-11-20 18:07:38 +01:00
"os"
"strings"
2021-05-10 17:06:55 +02:00
"text/template"
2020-11-20 18:07:38 +01:00
2021-03-21 04:54:55 +01:00
"github.com/BurntSushi/toml"
2020-11-20 18:07:38 +01:00
)
// Config contains site configuration.
type Config 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-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
2021-05-09 02:27:13 +02:00
templates *Templates
2020-11-20 18:07:38 +01:00
}
// Task represents a site build task.
type Task struct {
2021-04-12 00:42:55 +02:00
InputExt string `toml:"input_ext"` // input file extension
OutputExt string `toml:"output_ext"` // output file extension
TemplateExt string `toml:"template_ext"` // template file extension
PreProcess string `toml:"preprocess"` // preprocess command
2021-04-12 00:42:55 +02:00
PostProcess string `toml:"postprocess"` // postprocess command
StaticDir string `toml:"static_dir"` // static file directory
OutputDir string `toml:"output_dir"` // output directory
2021-05-10 06:44:25 +02:00
UglyURLs bool `toml:"ugly_urls"` // whether to use ugly URLs
}
// LoadConfig loads the configuration from the provided path.
func LoadConfig(path string) (*Config, error) {
2020-11-20 18:07:38 +01:00
f, err := os.Open(path)
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
2021-04-20 22:16:12 +02:00
c := &Config{}
2021-03-21 04:54:55 +01:00
if _, err := toml.DecodeReader(f, c); err != nil {
2021-03-20 07:02:36 +01:00
return nil, err
}
2021-05-10 17:06:55 +02:00
// Parse permalinks
c.permalinks = map[string]*template.Template{}
for s := range c.Permalinks {
t, err := template.New("permalink " + s).Parse(c.Permalinks[s])
if err != nil {
return nil, err
}
c.permalinks[s] = t
}
2020-11-20 18:07:38 +01:00
// Site contains site metadata passed to templates
type Site struct {
Title string
2020-11-28 00:24:31 +01:00
URLs []string
2020-11-20 18:07:38 +01:00
}
2021-05-10 01:28:09 +02:00
// Initialize templates
2021-05-09 02:27:13 +02:00
c.templates = NewTemplates()
c.templates.Funcs(map[string]interface{}{
2020-11-20 18:07:38 +01:00
"site": func() Site {
return Site{
Title: c.Title,
2020-11-28 00:24:31 +01:00
URLs: c.URLs,
2020-11-20 18:07:38 +01:00
}
},
"partial": func(name string, data interface{}) (interface{}, error) {
2021-05-09 02:27:13 +02:00
t, ok := c.templates.FindPartial(name)
if !ok {
return "", fmt.Errorf("Error: partial %q not found", name)
}
var b strings.Builder
if err := t.Execute(&b, data); err != nil {
return "", err
}
return b.String(), nil
},
2021-05-10 17:06:55 +02:00
"safeHTML": func(s string) htemplate.HTML { return htemplate.HTML(s) },
"safeHTMLAttr": func(s string) htemplate.HTMLAttr { return htemplate.HTMLAttr(s) },
"safeCSS": func(s string) htemplate.CSS { return htemplate.CSS(s) },
"safeJS": func(s string) htemplate.JS { return htemplate.JS(s) },
"safeURL": func(s string) htemplate.URL { return htemplate.URL(s) },
2020-11-20 18:07:38 +01:00
})
2021-05-10 01:28:09 +02:00
return c, nil
}