aboutsummaryrefslogtreecommitdiffhomepage
path: root/hugolib/config.go
diff options
context:
space:
mode:
Diffstat (limited to 'hugolib/config.go')
-rw-r--r--hugolib/config.go126
1 files changed, 64 insertions, 62 deletions
diff --git a/hugolib/config.go b/hugolib/config.go
index 983aa254f..9c2cc6892 100644
--- a/hugolib/config.go
+++ b/hugolib/config.go
@@ -14,11 +14,11 @@
package hugolib
import (
- "launchpad.net/goyaml"
- "github.com/BurntSushi/toml"
"encoding/json"
"fmt"
+ "github.com/BurntSushi/toml"
"io/ioutil"
+ "launchpad.net/goyaml"
"os"
"path"
"path/filepath"
@@ -29,11 +29,11 @@ import (
type Config struct {
SourceDir, PublishDir, BaseUrl, StaticDir string
Path, CacheDir, LayoutDir, DefaultLayout string
- ConfigFile string
- Title string
+ ConfigFile string
+ Title string
Indexes map[string]string // singular, plural
ProcessFilters map[string][]string
- BuildDrafts bool
+ BuildDrafts, UglyUrls, Verbose bool
}
var c Config
@@ -42,8 +42,8 @@ var c Config
func SetupConfig(cfgfile *string, path *string) *Config {
c.setPath(*path)
- cfg , err := c.findConfigFile(*cfgfile)
- c.ConfigFile = cfg
+ cfg, err := c.findConfigFile(*cfgfile)
+ c.ConfigFile = cfg
if err != nil {
fmt.Printf("%v", err)
@@ -57,8 +57,10 @@ func SetupConfig(cfgfile *string, path *string) *Config {
c.StaticDir = "static"
c.DefaultLayout = "post"
c.BuildDrafts = false
+ c.UglyUrls = false
+ c.Verbose = false
- c.readInConfig()
+ c.readInConfig()
// set index defaults if none provided
if len(c.Indexes) == 0 {
@@ -67,36 +69,36 @@ func SetupConfig(cfgfile *string, path *string) *Config {
c.Indexes["category"] = "categories"
}
- if !strings.HasSuffix(c.BaseUrl, "/") {
- c.BaseUrl = c.BaseUrl + "/"
- }
+ if !strings.HasSuffix(c.BaseUrl, "/") {
+ c.BaseUrl = c.BaseUrl + "/"
+ }
return &c
}
func (c *Config) readInConfig() {
- file, err := ioutil.ReadFile(c.ConfigFile)
- if err == nil {
- switch path.Ext(c.ConfigFile) {
- case ".yaml":
- if err := goyaml.Unmarshal(file, &c); err != nil {
- fmt.Printf("Error parsing config: %s", err)
- os.Exit(1)
- }
-
- case ".json":
- if err := json.Unmarshal(file, &c); err != nil {
- fmt.Printf("Error parsing config: %s", err)
- os.Exit(1)
- }
-
- case ".toml":
- if _, err := toml.Decode(string(file), &c); err != nil {
- fmt.Printf("Error parsing config: %s", err)
- os.Exit(1)
- }
- }
- }
+ file, err := ioutil.ReadFile(c.ConfigFile)
+ if err == nil {
+ switch path.Ext(c.ConfigFile) {
+ case ".yaml":
+ if err := goyaml.Unmarshal(file, &c); err != nil {
+ fmt.Printf("Error parsing config: %s", err)
+ os.Exit(1)
+ }
+
+ case ".json":
+ if err := json.Unmarshal(file, &c); err != nil {
+ fmt.Printf("Error parsing config: %s", err)
+ os.Exit(1)
+ }
+
+ case ".toml":
+ if _, err := toml.Decode(string(file), &c); err != nil {
+ fmt.Printf("Error parsing config: %s", err)
+ os.Exit(1)
+ }
+ }
+ }
}
func (c *Config) setPath(p string) {
@@ -156,33 +158,33 @@ func (c *Config) GetAbsPath(name string) string {
func (c *Config) findConfigFile(configFileName string) (string, error) {
- if configFileName == "" { // config not specified, let's search
- if b, _ := exists(c.GetAbsPath("config.json")); b {
- return c.GetAbsPath("config.json"), nil
- }
-
- if b, _ := exists(c.GetAbsPath("config.toml")); b {
- return c.GetAbsPath("config.toml"), nil
- }
-
- if b, _ := exists(c.GetAbsPath("config.yaml")); b {
- return c.GetAbsPath("config.yaml"), nil
- }
-
- return "", fmt.Errorf("config file not found in: %s", c.GetPath())
-
- } else {
- // If the full path is given, just use that
- if path.IsAbs(configFileName) {
- return configFileName, nil
- }
-
- // Else check the local directory
- t := c.GetAbsPath(configFileName)
- if b, _ := exists(t); b {
- return t, nil
- } else {
- return "", fmt.Errorf("config file not found at: %s", t)
- }
- }
+ if configFileName == "" { // config not specified, let's search
+ if b, _ := exists(c.GetAbsPath("config.json")); b {
+ return c.GetAbsPath("config.json"), nil
+ }
+
+ if b, _ := exists(c.GetAbsPath("config.toml")); b {
+ return c.GetAbsPath("config.toml"), nil
+ }
+
+ if b, _ := exists(c.GetAbsPath("config.yaml")); b {
+ return c.GetAbsPath("config.yaml"), nil
+ }
+
+ return "", fmt.Errorf("config file not found in: %s", c.GetPath())
+
+ } else {
+ // If the full path is given, just use that
+ if path.IsAbs(configFileName) {
+ return configFileName, nil
+ }
+
+ // Else check the local directory
+ t := c.GetAbsPath(configFileName)
+ if b, _ := exists(t); b {
+ return t, nil
+ } else {
+ return "", fmt.Errorf("config file not found at: %s", t)
+ }
+ }
}