Fix parsing integer 0

This commit is contained in:
Thomas Pelletier
2021-03-23 09:02:48 -04:00
parent b8da9d1854
commit e78ccff9a4
3 changed files with 13 additions and 9 deletions
@@ -439,7 +439,7 @@ func TestEmptytomlUnmarshal(t *testing.T) {
String: "", String: "",
StringList: []string{}, StringList: []string{},
Ptr: nil, Ptr: nil,
Map: map[string]string{}, Map: nil,
} }
result := emptyMarshalTestStruct{} result := emptyMarshalTestStruct{}
+7 -3
View File
@@ -977,18 +977,22 @@ func (p *parser) scanIntOrFloat(node *ast.Node, b []byte) ([]byte, error) {
case 'b': case 'b':
isValidRune = isValidBinaryRune isValidRune = isValidBinaryRune
default: default:
return b, fmt.Errorf("unknown number base: %c. possible options are x (hex) o (octal) b (binary)", b[1]) i++
} }
if isValidRune != nil {
i += 2 i += 2
for ; i < len(b); i++ { for ; i < len(b); i++ {
if !isValidRune(b[i]) { if !isValidRune(b[i]) {
break
}
}
}
node.Kind = ast.Integer node.Kind = ast.Integer
node.Data = b[:i] node.Data = b[:i]
return b[i:], nil return b[i:], nil
} }
}
}
isFloat := false isFloat := false