Skip to content

Commit

Permalink
fix parsing of escaped new-line-character or white-space in double qu…
Browse files Browse the repository at this point in the history
…oted text
  • Loading branch information
goccy committed Nov 11, 2024
1 parent 7e833a2 commit 9e58f7e
Show file tree
Hide file tree
Showing 2 changed files with 55 additions and 2 deletions.
37 changes: 36 additions & 1 deletion lexer/lexer_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -550,6 +550,41 @@ func TestTokenize(t *testing.T) {
},
},
},
{
YAML: `
a:
"bbb \
ccc
ddd eee\n\
\ \ fff ggg\nhhh iii\n
jjj kkk
"
`,
Tokens: token.Tokens{
{
Type: token.StringType,
CharacterType: token.CharacterTypeMiscellaneous,
Indicator: token.NotIndicator,
Value: "a",
Origin: "\na",
},
{
Type: token.MappingValueType,
CharacterType: token.CharacterTypeIndicator,
Indicator: token.BlockStructureIndicator,
Value: ":",
Origin: ":",
},
{
Type: token.DoubleQuoteType,
CharacterType: token.CharacterTypeIndicator,
Indicator: token.QuotedScalarIndicator,
Value: "bbb ccc\nddd eee\n fff ggg\nhhh iii\n jjj kkk ",
Origin: "\n \"bbb \\\n ccc\n\n ddd eee\\n\\\n \\ \\ fff ggg\\nhhh iii\\n\n jjj kkk\n \"",
},
},
},
{
YAML: `v: null
`,
Expand Down Expand Up @@ -2948,7 +2983,7 @@ foo2: 'bar2'`,
{
line: 1,
column: 6,
value: "test bar",
value: "test\n\n\n\nbar",
},
{
line: 7,
Expand Down
20 changes: 19 additions & 1 deletion scanner/scanner.go
Original file line number Diff line number Diff line change
Expand Up @@ -294,7 +294,15 @@ func (s *Scanner) scanDoubleQuote(ctx *Context) (*token.Token, error) {
c := src[idx]
ctx.addOriginBuf(c)
if s.isNewLineChar(c) {
value = append(value, ' ')
if isFirstLineChar {
if value[len(value)-1] == ' ' {
value[len(value)-1] = '\n'
} else {
value = append(value, '\n')
}
} else {
value = append(value, ' ')
}
isFirstLineChar = true
isNewLine = true
s.progressLine(ctx)
Expand Down Expand Up @@ -388,6 +396,16 @@ func (s *Scanner) scanDoubleQuote(ctx *Context) (*token.Token, error) {
progress = 1
ctx.addOriginBuf(nextChar)
value = append(value, c)
case '\n':
isFirstLineChar = true
isNewLine = true
ctx.addOriginBuf(nextChar)
s.progressColumn(ctx, 1)
s.progressLine(ctx)
idx++
continue
case ' ':
// skip escape character.
default:
value = append(value, c)
}
Expand Down

0 comments on commit 9e58f7e

Please sign in to comment.