mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-13 03:45:37 +00:00
b9c3ff6f0a
* convert file ext to lowercase for format detection To ensure proper file format detection with case-insensitive file systems. * use filepath.Ext for more reliable file ext detection especially for paths like index.js/foo * add a test for file ext based format detection
183 lines
4.5 KiB
Go
183 lines
4.5 KiB
Go
package yqlib
|
|
|
|
import (
|
|
"fmt"
|
|
"path/filepath"
|
|
"strings"
|
|
)
|
|
|
|
type EncoderFactoryFunction func() Encoder
|
|
type DecoderFactoryFunction func() Decoder
|
|
|
|
type Format struct {
|
|
FormalName string
|
|
Names []string
|
|
EncoderFactory EncoderFactoryFunction
|
|
DecoderFactory DecoderFactoryFunction
|
|
}
|
|
|
|
var YamlFormat = &Format{"yaml", []string{"y", "yml"},
|
|
func() Encoder { return NewYamlEncoder(ConfiguredYamlPreferences) },
|
|
func() Decoder { return NewYamlDecoder(ConfiguredYamlPreferences) },
|
|
}
|
|
|
|
var JSONFormat = &Format{"json", []string{"j"},
|
|
func() Encoder { return NewJSONEncoder(ConfiguredJSONPreferences) },
|
|
func() Decoder { return NewJSONDecoder() },
|
|
}
|
|
|
|
var PropertiesFormat = &Format{"props", []string{"p", "properties"},
|
|
func() Encoder { return NewPropertiesEncoder(ConfiguredPropertiesPreferences) },
|
|
func() Decoder { return NewPropertiesDecoder() },
|
|
}
|
|
|
|
var CSVFormat = &Format{"csv", []string{"c"},
|
|
func() Encoder { return NewCsvEncoder(ConfiguredCsvPreferences) },
|
|
func() Decoder { return NewCSVObjectDecoder(ConfiguredCsvPreferences) },
|
|
}
|
|
|
|
var TSVFormat = &Format{"tsv", []string{"t"},
|
|
func() Encoder { return NewCsvEncoder(ConfiguredTsvPreferences) },
|
|
func() Decoder { return NewCSVObjectDecoder(ConfiguredTsvPreferences) },
|
|
}
|
|
|
|
var XMLFormat = &Format{"xml", []string{"x"},
|
|
func() Encoder { return NewXMLEncoder(ConfiguredXMLPreferences) },
|
|
func() Decoder { return NewXMLDecoder(ConfiguredXMLPreferences) },
|
|
}
|
|
|
|
var Base64Format = &Format{"base64", []string{},
|
|
func() Encoder { return NewBase64Encoder() },
|
|
func() Decoder { return NewBase64Decoder() },
|
|
}
|
|
|
|
var UriFormat = &Format{"uri", []string{},
|
|
func() Encoder { return NewUriEncoder() },
|
|
func() Decoder { return NewUriDecoder() },
|
|
}
|
|
|
|
var ShFormat = &Format{"", nil,
|
|
func() Encoder { return NewShEncoder() },
|
|
nil,
|
|
}
|
|
|
|
var TomlFormat = &Format{"toml", []string{},
|
|
func() Encoder { return NewTomlEncoder() },
|
|
func() Decoder { return NewTomlDecoder() },
|
|
}
|
|
|
|
var ShellVariablesFormat = &Format{"shell", []string{"s", "sh"},
|
|
func() Encoder { return NewShellVariablesEncoder() },
|
|
nil,
|
|
}
|
|
|
|
var LuaFormat = &Format{"lua", []string{"l"},
|
|
func() Encoder { return NewLuaEncoder(ConfiguredLuaPreferences) },
|
|
func() Decoder { return NewLuaDecoder(ConfiguredLuaPreferences) },
|
|
}
|
|
|
|
var Formats = []*Format{
|
|
YamlFormat,
|
|
JSONFormat,
|
|
PropertiesFormat,
|
|
CSVFormat,
|
|
TSVFormat,
|
|
XMLFormat,
|
|
Base64Format,
|
|
UriFormat,
|
|
ShFormat,
|
|
TomlFormat,
|
|
ShellVariablesFormat,
|
|
LuaFormat,
|
|
}
|
|
|
|
func (f *Format) MatchesName(name string) bool {
|
|
if f.FormalName == name {
|
|
return true
|
|
}
|
|
for _, n := range f.Names {
|
|
if n == name {
|
|
return true
|
|
}
|
|
}
|
|
return false
|
|
}
|
|
|
|
func (f *Format) GetConfiguredEncoder() Encoder {
|
|
return f.EncoderFactory()
|
|
}
|
|
|
|
func FormatStringFromFilename(filename string) string {
|
|
if filename != "" {
|
|
GetLogger().Debugf("checking filename '%s' for auto format detection", filename)
|
|
ext := filepath.Ext(filename)
|
|
if ext != "" && ext[0] == '.' {
|
|
format := strings.ToLower(ext[1:])
|
|
GetLogger().Debugf("detected format '%s'", format)
|
|
return format
|
|
}
|
|
}
|
|
|
|
GetLogger().Debugf("using default inputFormat 'yaml'")
|
|
return "yaml"
|
|
}
|
|
|
|
func FormatFromString(format string) (*Format, error) {
|
|
if format != "" {
|
|
for _, printerFormat := range Formats {
|
|
if printerFormat.MatchesName(format) {
|
|
return printerFormat, nil
|
|
}
|
|
}
|
|
}
|
|
return nil, fmt.Errorf("unknown format '%v' please use [%v]", format, GetAvailableOutputFormatString())
|
|
}
|
|
|
|
func GetAvailableOutputFormats() []*Format {
|
|
var formats = []*Format{}
|
|
for _, printerFormat := range Formats {
|
|
if printerFormat.EncoderFactory != nil {
|
|
formats = append(formats, printerFormat)
|
|
}
|
|
}
|
|
return formats
|
|
}
|
|
|
|
func GetAvailableOutputFormatString() string {
|
|
var formats = []string{}
|
|
for _, printerFormat := range GetAvailableOutputFormats() {
|
|
|
|
if printerFormat.FormalName != "" {
|
|
formats = append(formats, printerFormat.FormalName)
|
|
}
|
|
if len(printerFormat.Names) >= 1 {
|
|
formats = append(formats, printerFormat.Names[0])
|
|
}
|
|
}
|
|
return strings.Join(formats, "|")
|
|
}
|
|
|
|
func GetAvailableInputFormats() []*Format {
|
|
var formats = []*Format{}
|
|
for _, printerFormat := range Formats {
|
|
if printerFormat.DecoderFactory != nil {
|
|
formats = append(formats, printerFormat)
|
|
}
|
|
}
|
|
return formats
|
|
}
|
|
|
|
func GetAvailableInputFormatString() string {
|
|
var formats = []string{}
|
|
for _, printerFormat := range GetAvailableInputFormats() {
|
|
|
|
if printerFormat.FormalName != "" {
|
|
formats = append(formats, printerFormat.FormalName)
|
|
}
|
|
if len(printerFormat.Names) >= 1 {
|
|
formats = append(formats, printerFormat.Names[0])
|
|
}
|
|
}
|
|
return strings.Join(formats, "|")
|
|
}
|