Skip to content

Commit

Permalink
Encode: fix multiline comment (#775)
Browse files Browse the repository at this point in the history
Fixes #768
  • Loading branch information
pelletier authored May 10, 2022
1 parent ba95863 commit b2e0231
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 2 deletions.
13 changes: 11 additions & 2 deletions marshaler.go
Original file line number Diff line number Diff line change
Expand Up @@ -652,10 +652,19 @@ func (enc *Encoder) encodeStruct(b []byte, ctx encoderCtx, v reflect.Value) ([]b
}

func (enc *Encoder) encodeComment(indent int, comment string, b []byte) []byte {
if comment != "" {
for len(comment) > 0 {
var line string
idx := strings.IndexByte(comment, '\n')
if idx >= 0 {
line = comment[:idx]
comment = comment[idx+1:]
} else {
line = comment
comment = ""
}
b = enc.indent(indent, b)
b = append(b, "# "...)
b = append(b, comment...)
b = append(b, line...)
b = append(b, '\n')
}
return b
Expand Down
16 changes: 16 additions & 0 deletions marshaler_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -1004,6 +1004,22 @@ func TestIssue752(t *testing.T) {
require.Equal(t, "", string(out))
}

func TestIssue768(t *testing.T) {
type cfg struct {
Name string `comment:"This is a multiline comment.\nThis is line 2."`
}

out, err := toml.Marshal(&cfg{})
require.NoError(t, err)

expected := `# This is a multiline comment.
# This is line 2.
Name = ''
`

require.Equal(t, expected, string(out))
}

func TestMarshalNestedAnonymousStructs(t *testing.T) {
type Embedded struct {
Value string `toml:"value" json:"value"`
Expand Down

0 comments on commit b2e0231

Please sign in to comment.