mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-28 09:25:36 +00:00
wip
This commit is contained in:
parent
eaeeffe417
commit
e16167ff26
@ -72,12 +72,13 @@ 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, FootComment: dec.processComment(n.FootComment)}
|
yamlNode := &yaml.Node{Kind: yaml.MappingNode}
|
||||||
|
|
||||||
if len(n.Data) > 0 {
|
if len(n.Data) > 0 {
|
||||||
label := dec.contentPrefix
|
label := dec.contentPrefix
|
||||||
labelNode := createScalarNode(label, label)
|
labelNode := createScalarNode(label, label)
|
||||||
labelNode.HeadComment = dec.processComment(n.HeadComment)
|
labelNode.HeadComment = dec.processComment(n.HeadComment)
|
||||||
|
labelNode.FootComment = dec.processComment(n.FootComment)
|
||||||
yamlNode.Content = append(yamlNode.Content, labelNode, createScalarNode(n.Data, n.Data))
|
yamlNode.Content = append(yamlNode.Content, labelNode, createScalarNode(n.Data, n.Data))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,6 +91,7 @@ func (dec *xmlDecoder) createMap(n *xmlNode) (*yaml.Node, error) {
|
|||||||
|
|
||||||
if i == 0 {
|
if i == 0 {
|
||||||
labelNode.HeadComment = dec.processComment(n.HeadComment)
|
labelNode.HeadComment = dec.processComment(n.HeadComment)
|
||||||
|
labelNode.FootComment = dec.processComment(n.FootComment)
|
||||||
}
|
}
|
||||||
|
|
||||||
log.Debug("len of children in %v is %v", label, len(children))
|
log.Debug("len of children in %v is %v", label, len(children))
|
||||||
@ -250,7 +252,7 @@ func (dec *xmlDecoder) decodeXml(root *xmlNode) error {
|
|||||||
commentStr := string(xml.CharData(se))
|
commentStr := string(xml.CharData(se))
|
||||||
if elem.state == "started" {
|
if elem.state == "started" {
|
||||||
log.Debug("got a foot comment for %v: [%v]", elem.label, commentStr)
|
log.Debug("got a foot comment for %v: [%v]", elem.label, commentStr)
|
||||||
dec.placeFootCommentOnLastChild(elem.n, commentStr)
|
elem.n.FootComment = joinFilter([]string{elem.n.FootComment, commentStr})
|
||||||
} else if elem.state == "chardata" {
|
} else if elem.state == "chardata" {
|
||||||
log.Debug("got a line comment for (%v) %v: [%v]", elem.state, elem.label, commentStr)
|
log.Debug("got a line comment for (%v) %v: [%v]", elem.state, elem.label, commentStr)
|
||||||
elem.n.LineComment = joinFilter([]string{elem.n.LineComment, commentStr})
|
elem.n.LineComment = joinFilter([]string{elem.n.LineComment, commentStr})
|
||||||
@ -265,21 +267,6 @@ func (dec *xmlDecoder) decodeXml(root *xmlNode) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (dec *xmlDecoder) placeFootCommentOnLastChild(n *xmlNode, commentStr string) {
|
|
||||||
if len(n.Children) > 0 {
|
|
||||||
child := n.Children[len(n.Children)-1]
|
|
||||||
log.Debug("putting it here: %v", child.K)
|
|
||||||
dec.placeFootCommentOnLastChild(child.V[len(child.V)-1], commentStr)
|
|
||||||
} else {
|
|
||||||
log.Debug("putting it on the element")
|
|
||||||
if n.FootComment != "" {
|
|
||||||
n.FootComment = n.FootComment + "\n" + strings.TrimSpace(commentStr)
|
|
||||||
} else {
|
|
||||||
n.FootComment = commentStr
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func joinFilter(rawStrings []string) string {
|
func joinFilter(rawStrings []string) string {
|
||||||
stringsToJoin := make([]string, 0)
|
stringsToJoin := make([]string, 0)
|
||||||
for _, str := range rawStrings {
|
for _, str := range rawStrings {
|
||||||
|
Loading…
Reference in New Issue
Block a user