yq/pkg/yqlib/doc/Comment Operators.md
2021-04-29 13:18:57 +10:00

2.1 KiB

Use these comment operators to set or retrieve comments.

Like the = and |= assign operators, the same syntax applies when updating comments:

plain form: =

This will assign the LHS nodes comments to the expression on the RHS. The RHS is run against the matching nodes in the pipeline

relative form: |=

Similar to the plain form, however the RHS evaluates against each matching LHS node! This is useful if you want to set the comments as a relative expression of the node, for instance its value or path.

Set line comment

Given a sample.yml file of:

a: cat

then

yq eval '.a lineComment="single"' sample.yml

will output

a: cat # single

Use update assign to perform relative updates

Given a sample.yml file of:

a: cat
b: dog

then

yq eval '.. lineComment |= .' sample.yml

will output

a: cat # cat
b: dog # dog

Set head comment

Given a sample.yml file of:

a: cat

then

yq eval '. headComment="single"' sample.yml

will output

# single

a: cat

Set foot comment, using an expression

Given a sample.yml file of:

a: cat

then

yq eval '. footComment=.a' sample.yml

will output

a: cat

# cat

Remove comment

Given a sample.yml file of:

a: cat # comment
b: dog # leave this

then

yq eval '.a lineComment=""' sample.yml

will output

a: cat
b: dog # leave this

Remove (strip) all comments

Note the use of ... to ensure key nodes are included.

Given a sample.yml file of:

a: cat # comment
# great
b: # key comment

then

yq eval '... comments=""' sample.yml

will output

a: cat
b:

Get line comment

Given a sample.yml file of:

a: cat # meow

then

yq eval '.a | lineComment' sample.yml

will output

meow

Get head comment

Given a sample.yml file of:

a: cat # meow

then

yq eval '. | headComment' sample.yml

will output


Get foot comment

Given a sample.yml file of:

a: cat # meow

then

yq eval '. | footComment' sample.yml

will output