From 783b85ce8760f8caf20c2f66842b29dd65b9d2d5 Mon Sep 17 00:00:00 2001 From: Masaaki Goshima Date: Thu, 5 Dec 2024 23:04:31 +0900 Subject: [PATCH] Fix unknown secondary tag behavior (#572) * fix unknown secondary tag behavior * fix test case --- parser/parser.go | 3 --- parser/parser_test.go | 9 +-------- yaml_test_suite_test.go | 1 + 3 files changed, 2 insertions(+), 11 deletions(-) diff --git a/parser/parser.go b/parser/parser.go index dee4e25..46a1c7d 100644 --- a/parser/parser.go +++ b/parser/parser.go @@ -880,9 +880,6 @@ func (p *parser) parseTagValue(ctx *context, tagRawTk *token.Token, tk *Token) ( } return p.parseSequence(ctx) } - if strings.HasPrefix(tagRawTk.Value, "!!") { - return nil, errors.ErrSyntax(fmt.Sprintf("unknown secondary tag name %q specified", tagRawTk.Value), tagRawTk) - } return p.parseToken(ctx, tk) } diff --git a/parser/parser_test.go b/parser/parser_test.go index 8d1db7b..c82adb7 100644 --- a/parser/parser_test.go +++ b/parser/parser_test.go @@ -70,6 +70,7 @@ func TestParser(t *testing.T) { "%YAML 1.2\n---\n", "a: !!binary gIGC\n", "a: !!binary |\n " + strings.Repeat("kJCQ", 17) + "kJ\n CQ\n", + "v: !!foo 1", "v:\n- A\n- |-\n B\n C\n", "v:\n- A\n- >-\n B\n C\n", "v: |-\n 0\n", @@ -1029,14 +1030,6 @@ func TestSyntaxError(t *testing.T) { source string expect string }{ - { - `v: !!int64 2`, - ` -[1:4] unknown secondary tag name "!!int64" specified -> 1 | v: !!int64 2 - ^ -`, - }, { ` a: diff --git a/yaml_test_suite_test.go b/yaml_test_suite_test.go index eae8f16..17ca273 100644 --- a/yaml_test_suite_test.go +++ b/yaml_test_suite_test.go @@ -48,6 +48,7 @@ var failureTestNames = []string{ "implicit-flow-mapping-key-on-one-line", // no json. "invalid-comment-after-comma", "invalid-comment-after-end-of-flow-sequence", + "invalid-comma-in-tag", "invalid-tag", "leading-tabs-in-double-quoted/02", "leading-tabs-in-double-quoted/05",