mirror of
https://github.com/gohugoio/hugo.git
synced 2024-12-30 19:50:46 +00:00
a574469797
Fixes #5555
59 lines
1.5 KiB
Go
59 lines
1.5 KiB
Go
package transform
|
|
|
|
import (
|
|
"bytes"
|
|
"strings"
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
"github.com/gohugoio/hugo/parser"
|
|
"github.com/gohugoio/hugo/parser/metadecoders"
|
|
"github.com/spf13/cast"
|
|
)
|
|
|
|
// Remarshal is used in the Hugo documentation to convert configuration
|
|
// examples from YAML to JSON, TOML (and possibly the other way around).
|
|
// The is primarily a helper for the Hugo docs site.
|
|
// It is not a general purpose YAML to TOML converter etc., and may
|
|
// change without notice if it serves a purpose in the docs.
|
|
// Format is one of json, yaml or toml.
|
|
func (ns *Namespace) Remarshal(format string, data interface{}) (string, error) {
|
|
from, err := cast.ToStringE(data)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
from = strings.TrimSpace(from)
|
|
format = strings.TrimSpace(strings.ToLower(format))
|
|
|
|
if from == "" {
|
|
return "", nil
|
|
}
|
|
|
|
mark, err := toFormatMark(format)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
fromFormat := metadecoders.Default.FormatFromContentString(from)
|
|
if fromFormat == "" {
|
|
return "", errors.New("failed to detect format from content")
|
|
}
|
|
|
|
meta, err := metadecoders.Default.UnmarshalToMap([]byte(from), fromFormat)
|
|
|
|
var result bytes.Buffer
|
|
if err := parser.InterfaceToConfig(meta, mark, &result); err != nil {
|
|
return "", err
|
|
}
|
|
|
|
return result.String(), nil
|
|
}
|
|
|
|
func toFormatMark(format string) (metadecoders.Format, error) {
|
|
if f := metadecoders.FormatFromString(format); f != "" {
|
|
return f, nil
|
|
}
|
|
|
|
return "", errors.New("failed to detect target data serialization format")
|
|
}
|