shithub: hugo

ref: 0e013b529141f228f07bb1de0093644a04146dde
dir: /hugolib/metadata.go/

View raw version
package hugolib

import (
	"errors"
	"fmt"
	"os"
	"strconv"
	"time"
)

func interfaceToTime(i interface{}) time.Time {
	switch s := i.(type) {
	case time.Time:
		return s
	case string:
		d, e := stringToDate(s)
		if e == nil {
			return d
		}
		errorf("Invalid Time/Date format")
	default:
		errorf("Only Time is supported for this key")
	}

	return *new(time.Time)
}

func interfaceToStringToDate(i interface{}) time.Time {
	s := interfaceToString(i)

	if d, e := stringToDate(s); e == nil {
		return d
	}

	return time.Unix(0, 0)
}

func stringToDate(s string) (time.Time, error) {
	return parseDateWith(s, []string{
		time.RFC3339,
		time.RFC1123Z,
		time.RFC1123,
		time.RFC822Z,
		time.RFC822,
		time.ANSIC,
		time.UnixDate,
		time.RubyDate,
		"2006-01-02 15:04:05Z07:00",
		"02 Jan 06 15:04 MST",
		"2006-01-02",
		"02 Jan 2006",
	})
}

// TODO remove this and return a proper error.
func errorf(str string, a ...interface{}) {
	fmt.Fprintln(os.Stderr, str, a)
}

func parseDateWith(s string, dates []string) (d time.Time, e error) {
	for _, dateType := range dates {
		if d, e = time.Parse(dateType, s); e == nil {
			return
		}
	}
	return d, errors.New(fmt.Sprintf("Unable to parse date: %s", s))
}

func interfaceToBool(i interface{}) bool {
	switch b := i.(type) {
	case bool:
		return b
	default:
		errorf("Only Boolean values are supported for this YAML key")
	}

	return false

}

func interfaceArrayToStringArray(i interface{}) []string {
	var a []string

	switch vv := i.(type) {
	case []interface{}:
		for _, u := range vv {
			a = append(a, interfaceToString(u))
		}
	}

	return a
}

func interfaceToFloat64(i interface{}) float64 {
	switch s := i.(type) {
	case float64:
		return s
	case float32:
		return float64(s)

	case string:
		v, err := strconv.ParseFloat(s, 64)
		if err == nil {
			return float64(v)
		} else {
			errorf("Only Floats are supported for this key\nErr:", err)
		}

	default:
		errorf("Only Floats are supported for this key")
	}

	return 0.0
}

func interfaceToInt(i interface{}) int {
	switch s := i.(type) {
	case int:
		return s
	case int64:
		return int(s)
	case int32:
		return int(s)
	case int16:
		return int(s)
	case int8:
		return int(s)
	case string:
		v, err := strconv.ParseInt(s, 0, 0)
		if err == nil {
			return int(v)
		} else {
			errorf("Only Ints are supported for this key\nErr:", err)
		}
	default:
		errorf("Only Ints are supported for this key")
	}

	return 0
}

func interfaceToString(i interface{}) string {
	switch s := i.(type) {
	case string:
		return s
	default:
		errorf("Only Strings are supported for this key")
	}

	return ""
}