mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-12 11:05:37 +00:00
Fixes xml decode missing tags #1284
This commit is contained in:
parent
b9a1ef89fe
commit
8c3a8c085e
@ -43,7 +43,7 @@ func (dec *xmlDecoder) Init(reader io.Reader) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (dec *xmlDecoder) createSequence(nodes []*xmlNode) (*yaml.Node, error) {
|
func (dec *xmlDecoder) createSequence(nodes []*xmlNode) (*yaml.Node, error) {
|
||||||
yamlNode := &yaml.Node{Kind: yaml.SequenceNode}
|
yamlNode := &yaml.Node{Kind: yaml.SequenceNode, Tag: "!!seq"}
|
||||||
for _, child := range nodes {
|
for _, child := range nodes {
|
||||||
yamlChild, err := dec.convertToYamlNode(child)
|
yamlChild, err := dec.convertToYamlNode(child)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -64,7 +64,7 @@ func (dec *xmlDecoder) processComment(c string) string {
|
|||||||
|
|
||||||
func (dec *xmlDecoder) createMap(n *xmlNode) (*yaml.Node, error) {
|
func (dec *xmlDecoder) createMap(n *xmlNode) (*yaml.Node, error) {
|
||||||
log.Debug("createMap: headC: %v, footC: %v", n.HeadComment, n.FootComment)
|
log.Debug("createMap: headC: %v, footC: %v", n.HeadComment, n.FootComment)
|
||||||
yamlNode := &yaml.Node{Kind: yaml.MappingNode}
|
yamlNode := &yaml.Node{Kind: yaml.MappingNode, Tag: "!!map"}
|
||||||
|
|
||||||
if len(n.Data) > 0 {
|
if len(n.Data) > 0 {
|
||||||
label := dec.contentName
|
label := dec.contentName
|
||||||
|
@ -67,9 +67,9 @@ func pickOperator(d *dataTreeNavigator, context Context, expressionNode *Express
|
|||||||
node := unwrapDoc(candidate.Node)
|
node := unwrapDoc(candidate.Node)
|
||||||
|
|
||||||
var replacement *yaml.Node
|
var replacement *yaml.Node
|
||||||
if node.Tag == "!!map" {
|
if node.Kind == yaml.MappingNode {
|
||||||
replacement = pickMap(node, indicesToPick)
|
replacement = pickMap(node, indicesToPick)
|
||||||
} else if node.Tag == "!!seq" {
|
} else if node.Kind == yaml.SequenceNode {
|
||||||
replacement, err = pickSequence(node, indicesToPick)
|
replacement, err = pickSequence(node, indicesToPick)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return Context{}, err
|
return Context{}, err
|
||||||
|
@ -14,6 +14,15 @@ var pickOperatorScenarios = []expressionScenario{
|
|||||||
"D0, P[], (doc)::myMap: {hamster: squeek, cat: meow}\n",
|
"D0, P[], (doc)::myMap: {hamster: squeek, cat: meow}\n",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
description: "Pick keys from map",
|
||||||
|
skipDoc: true,
|
||||||
|
document: "!things myMap: {cat: meow, dog: bark, thing: hamster, hamster: squeek}\n",
|
||||||
|
expression: `.myMap |= pick(["hamster", "cat", "goat"])`,
|
||||||
|
expected: []string{
|
||||||
|
"D0, P[], (doc)::!things myMap: {hamster: squeek, cat: meow}\n",
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
description: "Pick keys from map with comments",
|
description: "Pick keys from map with comments",
|
||||||
skipDoc: true,
|
skipDoc: true,
|
||||||
|
@ -292,6 +292,22 @@ var xmlScenarios = []formatScenario{
|
|||||||
expected: "<cat>purrs</cat>\n",
|
expected: "<cat>purrs</cat>\n",
|
||||||
scenarioType: "encode",
|
scenarioType: "encode",
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
description: "includes map tags",
|
||||||
|
skipDoc: true,
|
||||||
|
input: "<cat>purrs</cat>\n",
|
||||||
|
expression: `tag`,
|
||||||
|
expected: "!!map\n",
|
||||||
|
scenarioType: "decode",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
description: "includes array tags",
|
||||||
|
skipDoc: true,
|
||||||
|
input: "<cat>purrs</cat><cat>purrs</cat>\n",
|
||||||
|
expression: `.cat | tag`,
|
||||||
|
expected: "!!seq\n",
|
||||||
|
scenarioType: "decode",
|
||||||
|
},
|
||||||
{
|
{
|
||||||
description: "Encode xml: array",
|
description: "Encode xml: array",
|
||||||
input: "pets:\n cat:\n - purrs\n - meows",
|
input: "pets:\n cat:\n - purrs\n - meows",
|
||||||
|
Loading…
Reference in New Issue
Block a user