Lua output fixes (#1811)

* encoder_lua: Handle explicitly positive infinity

* encoder_lua: Fix inclusion of pre-/suffix when prettyPrinted

It seems certain operations like --prettyPrint or subset selections does
not produce a DocumentNode, which is where the lua pre- and suffix was
printed, causing those to be omitted.

* encoder_lua: Improve Tag handling robustness

Using the method call seems more reliable in case the input parser
forgets to set the tag.
This commit is contained in:
Kim Alvefur 2023-10-12 02:25:26 +02:00 committed by GitHub
parent 610896e5ed
commit 7c78a15b23
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 76 additions and 22 deletions

View File

@ -271,4 +271,43 @@ EOM
assertEquals "$expected" "$X" assertEquals "$expected" "$X"
} }
source ./scripts/shunit2 testLuaOutputPretty() {
cat >test.yml <<EOL
animals:
cat: meow
EOL
read -r -d '' expected << EOM
return {
["animals"] = {
["cat"] = "meow";
};
};
EOM
X=$(./yq e --output-format=lua test.yml)
assertEquals "$expected" "$X"
X=$(./yq e --output-format=lua --prettyPrint test.yml)
assertEquals "$expected" "$X"
}
testLuaOutputSubset() {
cat >test.yml <<EOL
animals:
cat: meow
EOL
read -r -d '' expected << EOM
return {
["cat"] = "meow";
};
EOM
X=$(./yq e --output-format=lua '.animals' test.yml)
assertEquals "$expected" "$X"
}
source ./scripts/shunit2

View File

@ -129,6 +129,8 @@ numbers:
- octal: 0o30 - octal: 0o30
- float: 123.45 - float: 123.45
- infinity: .inf - infinity: .inf
plus_infinity: +.inf
minus_infinity: -.inf
- not: .nan - not: .nan
``` ```
@ -162,6 +164,8 @@ return {
}, },
{ {
["infinity"] = (1/0); ["infinity"] = (1/0);
["plus_infinity"] = (1/0);
["minus_infinity"] = (-1/0);
}, },
{ {
["not"] = (0/0); ["not"] = (0/0);

View File

@ -129,7 +129,7 @@ func (le *luaEncoder) encodeArray(writer io.Writer, node *yaml.Node) error {
if err != nil { if err != nil {
return err return err
} }
err := le.Encode(writer, child) err := le.encodeAny(writer, child)
if err != nil { if err != nil {
return err return err
} }
@ -192,7 +192,7 @@ func (le *luaEncoder) encodeMap(writer io.Writer, node *yaml.Node, global bool)
for i, child := range node.Content { for i, child := range node.Content {
if (i % 2) == 1 { if (i % 2) == 1 {
// value // value
err := le.Encode(writer, child) err := le.encodeAny(writer, child)
if err != nil { if err != nil {
return err return err
} }
@ -270,7 +270,7 @@ func (le *luaEncoder) encodeAny(writer io.Writer, node *yaml.Node) error {
case yaml.MappingNode: case yaml.MappingNode:
return le.encodeMap(writer, node, false) return le.encodeMap(writer, node, false)
case yaml.ScalarNode: case yaml.ScalarNode:
switch node.Tag { switch node.ShortTag() {
case "!!str": case "!!str":
return le.encodeString(writer, node) return le.encodeString(writer, node)
case "!!null": case "!!null":
@ -292,7 +292,7 @@ func (le *luaEncoder) encodeAny(writer io.Writer, node *yaml.Node) error {
return writeString(writer, strings.ToLower(node.Value)) return writeString(writer, strings.ToLower(node.Value))
case "!!float": case "!!float":
switch strings.ToLower(node.Value) { switch strings.ToLower(node.Value) {
case ".inf": case ".inf", "+.inf":
return writeString(writer, "(1/0)") return writeString(writer, "(1/0)")
case "-.inf": case "-.inf":
return writeString(writer, "(-1/0)") return writeString(writer, "(-1/0)")
@ -305,26 +305,33 @@ func (le *luaEncoder) encodeAny(writer io.Writer, node *yaml.Node) error {
return fmt.Errorf("Lua encoder NYI -- %s", node.ShortTag()) return fmt.Errorf("Lua encoder NYI -- %s", node.ShortTag())
} }
case yaml.DocumentNode: case yaml.DocumentNode:
if le.globals { return le.encodeAny(writer, node.Content[0])
if node.Content[0].Kind != yaml.MappingNode {
return fmt.Errorf("--lua-global requires a top level MappingNode")
}
return le.encodeMap(writer, node.Content[0], true)
}
err := writeString(writer, le.docPrefix)
if err != nil {
return err
}
err = le.encodeAny(writer, node.Content[0])
if err != nil {
return err
}
return writeString(writer, le.docSuffix)
default: default:
return fmt.Errorf("Lua encoder NYI -- %s", node.ShortTag()) return fmt.Errorf("Lua encoder NYI -- %s", node.ShortTag())
} }
} }
func (le *luaEncoder) Encode(writer io.Writer, node *yaml.Node) error { func (le *luaEncoder) encodeTopLevel(writer io.Writer, node *yaml.Node) error {
return le.encodeAny(writer, node) err := writeString(writer, le.docPrefix)
if err != nil {
return err
}
err = le.encodeAny(writer, node)
if err != nil {
return err
}
return writeString(writer, le.docSuffix)
}
func (le *luaEncoder) Encode(writer io.Writer, node *yaml.Node) error {
if node.Kind == yaml.DocumentNode {
return le.Encode(writer, node.Content[0])
}
if le.globals {
if node.Kind != yaml.MappingNode {
return fmt.Errorf("--lua-global requires a top level MappingNode")
}
return le.encodeMap(writer, node, true)
}
return le.encodeTopLevel(writer, node)
} }

View File

@ -135,6 +135,8 @@ numbers:
- octal: 0o30 - octal: 0o30
- float: 123.45 - float: 123.45
- infinity: .inf - infinity: .inf
plus_infinity: +.inf
minus_infinity: -.inf
- not: .nan - not: .nan
`, `,
expected: `return { expected: `return {
@ -161,6 +163,8 @@ numbers:
}, },
{ {
["infinity"] = (1/0); ["infinity"] = (1/0);
["plus_infinity"] = (1/0);
["minus_infinity"] = (-1/0);
}, },
{ {
["not"] = (0/0); ["not"] = (0/0);