mirror of
https://github.com/DNSCrypt/dnscrypt-proxy.git
synced 2025-04-05 22:27:37 +03:00
Bump github.com/BurntSushi/toml from 1.4.0 to 1.5.0
Bumps [github.com/BurntSushi/toml](https://github.com/BurntSushi/toml) from 1.4.0 to 1.5.0. - [Release notes](https://github.com/BurntSushi/toml/releases) - [Commits](https://github.com/BurntSushi/toml/compare/v1.4.0...v1.5.0) --- updated-dependencies: - dependency-name: github.com/BurntSushi/toml dependency-type: direct:production update-type: version-update:semver-minor ... Signed-off-by: dependabot[bot] <support@github.com>
This commit is contained in:
parent
5a46f0db9a
commit
0a759bf362
10 changed files with 107 additions and 104 deletions
2
go.mod
2
go.mod
|
@ -3,7 +3,7 @@ module github.com/dnscrypt/dnscrypt-proxy
|
||||||
go 1.24.1
|
go 1.24.1
|
||||||
|
|
||||||
require (
|
require (
|
||||||
github.com/BurntSushi/toml v1.4.0
|
github.com/BurntSushi/toml v1.5.0
|
||||||
github.com/VividCortex/ewma v1.2.0
|
github.com/VividCortex/ewma v1.2.0
|
||||||
github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf
|
github.com/coreos/go-systemd v0.0.0-20191104093116-d3cd4ed1dbcf
|
||||||
github.com/dchest/safefile v0.0.0-20151022103144-855e8d98f185
|
github.com/dchest/safefile v0.0.0-20151022103144-855e8d98f185
|
||||||
|
|
4
go.sum
4
go.sum
|
@ -1,5 +1,5 @@
|
||||||
github.com/BurntSushi/toml v1.4.0 h1:kuoIxZQy2WRRk1pttg9asf+WVv6tWQuBNVmK8+nqPr0=
|
github.com/BurntSushi/toml v1.5.0 h1:W5quZX/G/csjUnuI8SUYlsHs9M38FC7znL0lIO+DvMg=
|
||||||
github.com/BurntSushi/toml v1.4.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho=
|
github.com/BurntSushi/toml v1.5.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho=
|
||||||
github.com/VividCortex/ewma v1.2.0 h1:f58SaIzcDXrSy3kWaHNvuJgJ3Nmz59Zji6XoJR/q1ow=
|
github.com/VividCortex/ewma v1.2.0 h1:f58SaIzcDXrSy3kWaHNvuJgJ3Nmz59Zji6XoJR/q1ow=
|
||||||
github.com/VividCortex/ewma v1.2.0/go.mod h1:nz4BbCtbLyFDeC9SUHbtcT5644juEuWfUAUnGx7j5l4=
|
github.com/VividCortex/ewma v1.2.0/go.mod h1:nz4BbCtbLyFDeC9SUHbtcT5644juEuWfUAUnGx7j5l4=
|
||||||
github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI=
|
github.com/chzyer/logex v1.1.10/go.mod h1:+Ywpsq7O8HXn0nuIou7OrIPyXbp3wmkHB+jjWRnGsAI=
|
||||||
|
|
2
vendor/github.com/BurntSushi/toml/README.md
generated
vendored
2
vendor/github.com/BurntSushi/toml/README.md
generated
vendored
|
@ -3,7 +3,7 @@ reflection interface similar to Go's standard library `json` and `xml` packages.
|
||||||
|
|
||||||
Compatible with TOML version [v1.0.0](https://toml.io/en/v1.0.0).
|
Compatible with TOML version [v1.0.0](https://toml.io/en/v1.0.0).
|
||||||
|
|
||||||
Documentation: https://godocs.io/github.com/BurntSushi/toml
|
Documentation: https://pkg.go.dev/github.com/BurntSushi/toml
|
||||||
|
|
||||||
See the [releases page](https://github.com/BurntSushi/toml/releases) for a
|
See the [releases page](https://github.com/BurntSushi/toml/releases) for a
|
||||||
changelog; this information is also in the git tag annotations (e.g. `git show
|
changelog; this information is also in the git tag annotations (e.g. `git show
|
||||||
|
|
33
vendor/github.com/BurntSushi/toml/decode.go
generated
vendored
33
vendor/github.com/BurntSushi/toml/decode.go
generated
vendored
|
@ -196,6 +196,19 @@ func (md *MetaData) PrimitiveDecode(primValue Primitive, v any) error {
|
||||||
return md.unify(primValue.undecoded, rvalue(v))
|
return md.unify(primValue.undecoded, rvalue(v))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// markDecodedRecursive is a helper to mark any key under the given tmap as
|
||||||
|
// decoded, recursing as needed
|
||||||
|
func markDecodedRecursive(md *MetaData, tmap map[string]any) {
|
||||||
|
for key := range tmap {
|
||||||
|
md.decoded[md.context.add(key).String()] = struct{}{}
|
||||||
|
if tmap, ok := tmap[key].(map[string]any); ok {
|
||||||
|
md.context = append(md.context, key)
|
||||||
|
markDecodedRecursive(md, tmap)
|
||||||
|
md.context = md.context[0 : len(md.context)-1]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// unify performs a sort of type unification based on the structure of `rv`,
|
// unify performs a sort of type unification based on the structure of `rv`,
|
||||||
// which is the client representation.
|
// which is the client representation.
|
||||||
//
|
//
|
||||||
|
@ -222,6 +235,16 @@ func (md *MetaData) unify(data any, rv reflect.Value) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return md.parseErr(err)
|
return md.parseErr(err)
|
||||||
}
|
}
|
||||||
|
// Assume the Unmarshaler decoded everything, so mark all keys under
|
||||||
|
// this table as decoded.
|
||||||
|
if tmap, ok := data.(map[string]any); ok {
|
||||||
|
markDecodedRecursive(md, tmap)
|
||||||
|
}
|
||||||
|
if aot, ok := data.([]map[string]any); ok {
|
||||||
|
for _, tmap := range aot {
|
||||||
|
markDecodedRecursive(md, tmap)
|
||||||
|
}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
if v, ok := rvi.(encoding.TextUnmarshaler); ok {
|
if v, ok := rvi.(encoding.TextUnmarshaler); ok {
|
||||||
|
@ -540,12 +563,14 @@ func (md *MetaData) badtype(dst string, data any) error {
|
||||||
|
|
||||||
func (md *MetaData) parseErr(err error) error {
|
func (md *MetaData) parseErr(err error) error {
|
||||||
k := md.context.String()
|
k := md.context.String()
|
||||||
|
d := string(md.data)
|
||||||
return ParseError{
|
return ParseError{
|
||||||
LastKey: k,
|
Message: err.Error(),
|
||||||
Position: md.keyInfo[k].pos,
|
|
||||||
Line: md.keyInfo[k].pos.Line,
|
|
||||||
err: err,
|
err: err,
|
||||||
input: string(md.data),
|
LastKey: k,
|
||||||
|
Position: md.keyInfo[k].pos.withCol(d),
|
||||||
|
Line: md.keyInfo[k].pos.Line,
|
||||||
|
input: d,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
40
vendor/github.com/BurntSushi/toml/encode.go
generated
vendored
40
vendor/github.com/BurntSushi/toml/encode.go
generated
vendored
|
@ -402,31 +402,30 @@ func (enc *Encoder) eMap(key Key, rv reflect.Value, inline bool) {
|
||||||
|
|
||||||
// Sort keys so that we have deterministic output. And write keys directly
|
// Sort keys so that we have deterministic output. And write keys directly
|
||||||
// underneath this key first, before writing sub-structs or sub-maps.
|
// underneath this key first, before writing sub-structs or sub-maps.
|
||||||
var mapKeysDirect, mapKeysSub []string
|
var mapKeysDirect, mapKeysSub []reflect.Value
|
||||||
for _, mapKey := range rv.MapKeys() {
|
for _, mapKey := range rv.MapKeys() {
|
||||||
k := mapKey.String()
|
|
||||||
if typeIsTable(tomlTypeOfGo(eindirect(rv.MapIndex(mapKey)))) {
|
if typeIsTable(tomlTypeOfGo(eindirect(rv.MapIndex(mapKey)))) {
|
||||||
mapKeysSub = append(mapKeysSub, k)
|
mapKeysSub = append(mapKeysSub, mapKey)
|
||||||
} else {
|
} else {
|
||||||
mapKeysDirect = append(mapKeysDirect, k)
|
mapKeysDirect = append(mapKeysDirect, mapKey)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var writeMapKeys = func(mapKeys []string, trailC bool) {
|
writeMapKeys := func(mapKeys []reflect.Value, trailC bool) {
|
||||||
sort.Strings(mapKeys)
|
sort.Slice(mapKeys, func(i, j int) bool { return mapKeys[i].String() < mapKeys[j].String() })
|
||||||
for i, mapKey := range mapKeys {
|
for i, mapKey := range mapKeys {
|
||||||
val := eindirect(rv.MapIndex(reflect.ValueOf(mapKey)))
|
val := eindirect(rv.MapIndex(mapKey))
|
||||||
if isNil(val) {
|
if isNil(val) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if inline {
|
if inline {
|
||||||
enc.writeKeyValue(Key{mapKey}, val, true)
|
enc.writeKeyValue(Key{mapKey.String()}, val, true)
|
||||||
if trailC || i != len(mapKeys)-1 {
|
if trailC || i != len(mapKeys)-1 {
|
||||||
enc.wf(", ")
|
enc.wf(", ")
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
enc.encode(key.add(mapKey), val)
|
enc.encode(key.add(mapKey.String()), val)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -441,8 +440,6 @@ func (enc *Encoder) eMap(key Key, rv reflect.Value, inline bool) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const is32Bit = (32 << (^uint(0) >> 63)) == 32
|
|
||||||
|
|
||||||
func pointerTo(t reflect.Type) reflect.Type {
|
func pointerTo(t reflect.Type) reflect.Type {
|
||||||
if t.Kind() == reflect.Ptr {
|
if t.Kind() == reflect.Ptr {
|
||||||
return pointerTo(t.Elem())
|
return pointerTo(t.Elem())
|
||||||
|
@ -477,15 +474,14 @@ func (enc *Encoder) eStruct(key Key, rv reflect.Value, inline bool) {
|
||||||
|
|
||||||
frv := eindirect(rv.Field(i))
|
frv := eindirect(rv.Field(i))
|
||||||
|
|
||||||
if is32Bit {
|
// Need to make a copy because ... ehm, I don't know why... I guess
|
||||||
// Copy so it works correct on 32bit archs; not clear why this
|
// allocating a new array can cause it to fail(?)
|
||||||
// is needed. See #314, and https://www.reddit.com/r/golang/comments/pnx8v4
|
//
|
||||||
// This also works fine on 64bit, but 32bit archs are somewhat
|
// Done for: https://github.com/BurntSushi/toml/issues/430
|
||||||
// rare and this is a wee bit faster.
|
// Previously only on 32bit for: https://github.com/BurntSushi/toml/issues/314
|
||||||
copyStart := make([]int, len(start))
|
copyStart := make([]int, len(start))
|
||||||
copy(copyStart, start)
|
copy(copyStart, start)
|
||||||
start = copyStart
|
start = copyStart
|
||||||
}
|
|
||||||
|
|
||||||
// Treat anonymous struct fields with tag names as though they are
|
// Treat anonymous struct fields with tag names as though they are
|
||||||
// not anonymous, like encoding/json does.
|
// not anonymous, like encoding/json does.
|
||||||
|
@ -507,7 +503,7 @@ func (enc *Encoder) eStruct(key Key, rv reflect.Value, inline bool) {
|
||||||
}
|
}
|
||||||
addFields(rt, rv, nil)
|
addFields(rt, rv, nil)
|
||||||
|
|
||||||
writeFields := func(fields [][]int) {
|
writeFields := func(fields [][]int, totalFields int) {
|
||||||
for _, fieldIndex := range fields {
|
for _, fieldIndex := range fields {
|
||||||
fieldType := rt.FieldByIndex(fieldIndex)
|
fieldType := rt.FieldByIndex(fieldIndex)
|
||||||
fieldVal := rv.FieldByIndex(fieldIndex)
|
fieldVal := rv.FieldByIndex(fieldIndex)
|
||||||
|
@ -537,7 +533,7 @@ func (enc *Encoder) eStruct(key Key, rv reflect.Value, inline bool) {
|
||||||
|
|
||||||
if inline {
|
if inline {
|
||||||
enc.writeKeyValue(Key{keyName}, fieldVal, true)
|
enc.writeKeyValue(Key{keyName}, fieldVal, true)
|
||||||
if fieldIndex[0] != len(fields)-1 {
|
if fieldIndex[0] != totalFields-1 {
|
||||||
enc.wf(", ")
|
enc.wf(", ")
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
@ -549,8 +545,10 @@ func (enc *Encoder) eStruct(key Key, rv reflect.Value, inline bool) {
|
||||||
if inline {
|
if inline {
|
||||||
enc.wf("{")
|
enc.wf("{")
|
||||||
}
|
}
|
||||||
writeFields(fieldsDirect)
|
|
||||||
writeFields(fieldsSub)
|
l := len(fieldsDirect) + len(fieldsSub)
|
||||||
|
writeFields(fieldsDirect, l)
|
||||||
|
writeFields(fieldsSub, l)
|
||||||
if inline {
|
if inline {
|
||||||
enc.wf("}")
|
enc.wf("}")
|
||||||
}
|
}
|
||||||
|
|
69
vendor/github.com/BurntSushi/toml/error.go
generated
vendored
69
vendor/github.com/BurntSushi/toml/error.go
generated
vendored
|
@ -67,21 +67,36 @@ type ParseError struct {
|
||||||
// Position of an error.
|
// Position of an error.
|
||||||
type Position struct {
|
type Position struct {
|
||||||
Line int // Line number, starting at 1.
|
Line int // Line number, starting at 1.
|
||||||
|
Col int // Error column, starting at 1.
|
||||||
Start int // Start of error, as byte offset starting at 0.
|
Start int // Start of error, as byte offset starting at 0.
|
||||||
Len int // Lenght in bytes.
|
Len int // Length of the error in bytes.
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p Position) withCol(tomlFile string) Position {
|
||||||
|
var (
|
||||||
|
pos int
|
||||||
|
lines = strings.Split(tomlFile, "\n")
|
||||||
|
)
|
||||||
|
for i := range lines {
|
||||||
|
ll := len(lines[i]) + 1 // +1 for the removed newline
|
||||||
|
if pos+ll >= p.Start {
|
||||||
|
p.Col = p.Start - pos + 1
|
||||||
|
if p.Col < 1 { // Should never happen, but just in case.
|
||||||
|
p.Col = 1
|
||||||
|
}
|
||||||
|
break
|
||||||
|
}
|
||||||
|
pos += ll
|
||||||
|
}
|
||||||
|
return p
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pe ParseError) Error() string {
|
func (pe ParseError) Error() string {
|
||||||
msg := pe.Message
|
|
||||||
if msg == "" { // Error from errorf()
|
|
||||||
msg = pe.err.Error()
|
|
||||||
}
|
|
||||||
|
|
||||||
if pe.LastKey == "" {
|
if pe.LastKey == "" {
|
||||||
return fmt.Sprintf("toml: line %d: %s", pe.Position.Line, msg)
|
return fmt.Sprintf("toml: line %d: %s", pe.Position.Line, pe.Message)
|
||||||
}
|
}
|
||||||
return fmt.Sprintf("toml: line %d (last key %q): %s",
|
return fmt.Sprintf("toml: line %d (last key %q): %s",
|
||||||
pe.Position.Line, pe.LastKey, msg)
|
pe.Position.Line, pe.LastKey, pe.Message)
|
||||||
}
|
}
|
||||||
|
|
||||||
// ErrorWithPosition returns the error with detailed location context.
|
// ErrorWithPosition returns the error with detailed location context.
|
||||||
|
@ -92,26 +107,19 @@ func (pe ParseError) ErrorWithPosition() string {
|
||||||
return pe.Error()
|
return pe.Error()
|
||||||
}
|
}
|
||||||
|
|
||||||
var (
|
|
||||||
lines = strings.Split(pe.input, "\n")
|
|
||||||
col = pe.column(lines)
|
|
||||||
b = new(strings.Builder)
|
|
||||||
)
|
|
||||||
|
|
||||||
msg := pe.Message
|
|
||||||
if msg == "" {
|
|
||||||
msg = pe.err.Error()
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: don't show control characters as literals? This may not show up
|
// TODO: don't show control characters as literals? This may not show up
|
||||||
// well everywhere.
|
// well everywhere.
|
||||||
|
|
||||||
|
var (
|
||||||
|
lines = strings.Split(pe.input, "\n")
|
||||||
|
b = new(strings.Builder)
|
||||||
|
)
|
||||||
if pe.Position.Len == 1 {
|
if pe.Position.Len == 1 {
|
||||||
fmt.Fprintf(b, "toml: error: %s\n\nAt line %d, column %d:\n\n",
|
fmt.Fprintf(b, "toml: error: %s\n\nAt line %d, column %d:\n\n",
|
||||||
msg, pe.Position.Line, col+1)
|
pe.Message, pe.Position.Line, pe.Position.Col)
|
||||||
} else {
|
} else {
|
||||||
fmt.Fprintf(b, "toml: error: %s\n\nAt line %d, column %d-%d:\n\n",
|
fmt.Fprintf(b, "toml: error: %s\n\nAt line %d, column %d-%d:\n\n",
|
||||||
msg, pe.Position.Line, col, col+pe.Position.Len)
|
pe.Message, pe.Position.Line, pe.Position.Col, pe.Position.Col+pe.Position.Len-1)
|
||||||
}
|
}
|
||||||
if pe.Position.Line > 2 {
|
if pe.Position.Line > 2 {
|
||||||
fmt.Fprintf(b, "% 7d | %s\n", pe.Position.Line-2, expandTab(lines[pe.Position.Line-3]))
|
fmt.Fprintf(b, "% 7d | %s\n", pe.Position.Line-2, expandTab(lines[pe.Position.Line-3]))
|
||||||
|
@ -129,7 +137,7 @@ func (pe ParseError) ErrorWithPosition() string {
|
||||||
diff := len(expanded) - len(lines[pe.Position.Line-1])
|
diff := len(expanded) - len(lines[pe.Position.Line-1])
|
||||||
|
|
||||||
fmt.Fprintf(b, "% 7d | %s\n", pe.Position.Line, expanded)
|
fmt.Fprintf(b, "% 7d | %s\n", pe.Position.Line, expanded)
|
||||||
fmt.Fprintf(b, "% 10s%s%s\n", "", strings.Repeat(" ", col+diff), strings.Repeat("^", pe.Position.Len))
|
fmt.Fprintf(b, "% 10s%s%s\n", "", strings.Repeat(" ", pe.Position.Col-1+diff), strings.Repeat("^", pe.Position.Len))
|
||||||
return b.String()
|
return b.String()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -151,23 +159,6 @@ func (pe ParseError) ErrorWithUsage() string {
|
||||||
return m
|
return m
|
||||||
}
|
}
|
||||||
|
|
||||||
func (pe ParseError) column(lines []string) int {
|
|
||||||
var pos, col int
|
|
||||||
for i := range lines {
|
|
||||||
ll := len(lines[i]) + 1 // +1 for the removed newline
|
|
||||||
if pos+ll >= pe.Position.Start {
|
|
||||||
col = pe.Position.Start - pos
|
|
||||||
if col < 0 { // Should never happen, but just in case.
|
|
||||||
col = 0
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
|
||||||
pos += ll
|
|
||||||
}
|
|
||||||
|
|
||||||
return col
|
|
||||||
}
|
|
||||||
|
|
||||||
func expandTab(s string) string {
|
func expandTab(s string) string {
|
||||||
var (
|
var (
|
||||||
b strings.Builder
|
b strings.Builder
|
||||||
|
|
31
vendor/github.com/BurntSushi/toml/lex.go
generated
vendored
31
vendor/github.com/BurntSushi/toml/lex.go
generated
vendored
|
@ -275,7 +275,9 @@ func (lx *lexer) errorPos(start, length int, err error) stateFn {
|
||||||
func (lx *lexer) errorf(format string, values ...any) stateFn {
|
func (lx *lexer) errorf(format string, values ...any) stateFn {
|
||||||
if lx.atEOF {
|
if lx.atEOF {
|
||||||
pos := lx.getPos()
|
pos := lx.getPos()
|
||||||
|
if lx.pos >= 1 && lx.input[lx.pos-1] == '\n' {
|
||||||
pos.Line--
|
pos.Line--
|
||||||
|
}
|
||||||
pos.Len = 1
|
pos.Len = 1
|
||||||
pos.Start = lx.pos - 1
|
pos.Start = lx.pos - 1
|
||||||
lx.items <- item{typ: itemError, pos: pos, err: fmt.Errorf(format, values...)}
|
lx.items <- item{typ: itemError, pos: pos, err: fmt.Errorf(format, values...)}
|
||||||
|
@ -492,6 +494,9 @@ func lexKeyEnd(lx *lexer) stateFn {
|
||||||
lx.emit(itemKeyEnd)
|
lx.emit(itemKeyEnd)
|
||||||
return lexSkip(lx, lexValue)
|
return lexSkip(lx, lexValue)
|
||||||
default:
|
default:
|
||||||
|
if r == '\n' {
|
||||||
|
return lx.errorPrevLine(fmt.Errorf("expected '.' or '=', but got %q instead", r))
|
||||||
|
}
|
||||||
return lx.errorf("expected '.' or '=', but got %q instead", r)
|
return lx.errorf("expected '.' or '=', but got %q instead", r)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -560,6 +565,9 @@ func lexValue(lx *lexer) stateFn {
|
||||||
if r == eof {
|
if r == eof {
|
||||||
return lx.errorf("unexpected EOF; expected value")
|
return lx.errorf("unexpected EOF; expected value")
|
||||||
}
|
}
|
||||||
|
if r == '\n' {
|
||||||
|
return lx.errorPrevLine(fmt.Errorf("expected value but found %q instead", r))
|
||||||
|
}
|
||||||
return lx.errorf("expected value but found %q instead", r)
|
return lx.errorf("expected value but found %q instead", r)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1111,7 +1119,7 @@ func lexBaseNumberOrDate(lx *lexer) stateFn {
|
||||||
case 'x':
|
case 'x':
|
||||||
r = lx.peek()
|
r = lx.peek()
|
||||||
if !isHex(r) {
|
if !isHex(r) {
|
||||||
lx.errorf("not a hexidecimal number: '%s%c'", lx.current(), r)
|
lx.errorf("not a hexadecimal number: '%s%c'", lx.current(), r)
|
||||||
}
|
}
|
||||||
return lexHexInteger
|
return lexHexInteger
|
||||||
}
|
}
|
||||||
|
@ -1259,23 +1267,6 @@ func isBinary(r rune) bool { return r == '0' || r == '1' }
|
||||||
func isOctal(r rune) bool { return r >= '0' && r <= '7' }
|
func isOctal(r rune) bool { return r >= '0' && r <= '7' }
|
||||||
func isHex(r rune) bool { return (r >= '0' && r <= '9') || (r|0x20 >= 'a' && r|0x20 <= 'f') }
|
func isHex(r rune) bool { return (r >= '0' && r <= '9') || (r|0x20 >= 'a' && r|0x20 <= 'f') }
|
||||||
func isBareKeyChar(r rune, tomlNext bool) bool {
|
func isBareKeyChar(r rune, tomlNext bool) bool {
|
||||||
if tomlNext {
|
return (r >= 'A' && r <= 'Z') || (r >= 'a' && r <= 'z') ||
|
||||||
return (r >= 'A' && r <= 'Z') ||
|
(r >= '0' && r <= '9') || r == '_' || r == '-'
|
||||||
(r >= 'a' && r <= 'z') ||
|
|
||||||
(r >= '0' && r <= '9') ||
|
|
||||||
r == '_' || r == '-' ||
|
|
||||||
r == 0xb2 || r == 0xb3 || r == 0xb9 || (r >= 0xbc && r <= 0xbe) ||
|
|
||||||
(r >= 0xc0 && r <= 0xd6) || (r >= 0xd8 && r <= 0xf6) || (r >= 0xf8 && r <= 0x037d) ||
|
|
||||||
(r >= 0x037f && r <= 0x1fff) ||
|
|
||||||
(r >= 0x200c && r <= 0x200d) || (r >= 0x203f && r <= 0x2040) ||
|
|
||||||
(r >= 0x2070 && r <= 0x218f) || (r >= 0x2460 && r <= 0x24ff) ||
|
|
||||||
(r >= 0x2c00 && r <= 0x2fef) || (r >= 0x3001 && r <= 0xd7ff) ||
|
|
||||||
(r >= 0xf900 && r <= 0xfdcf) || (r >= 0xfdf0 && r <= 0xfffd) ||
|
|
||||||
(r >= 0x10000 && r <= 0xeffff)
|
|
||||||
}
|
|
||||||
|
|
||||||
return (r >= 'A' && r <= 'Z') ||
|
|
||||||
(r >= 'a' && r <= 'z') ||
|
|
||||||
(r >= '0' && r <= '9') ||
|
|
||||||
r == '_' || r == '-'
|
|
||||||
}
|
}
|
||||||
|
|
3
vendor/github.com/BurntSushi/toml/meta.go
generated
vendored
3
vendor/github.com/BurntSushi/toml/meta.go
generated
vendored
|
@ -135,9 +135,6 @@ func (k Key) maybeQuoted(i int) string {
|
||||||
|
|
||||||
// Like append(), but only increase the cap by 1.
|
// Like append(), but only increase the cap by 1.
|
||||||
func (k Key) add(piece string) Key {
|
func (k Key) add(piece string) Key {
|
||||||
if cap(k) > len(k) {
|
|
||||||
return append(k, piece)
|
|
||||||
}
|
|
||||||
newKey := make(Key, len(k)+1)
|
newKey := make(Key, len(k)+1)
|
||||||
copy(newKey, k)
|
copy(newKey, k)
|
||||||
newKey[len(k)] = piece
|
newKey[len(k)] = piece
|
||||||
|
|
17
vendor/github.com/BurntSushi/toml/parse.go
generated
vendored
17
vendor/github.com/BurntSushi/toml/parse.go
generated
vendored
|
@ -50,7 +50,6 @@ func parse(data string) (p *parser, err error) {
|
||||||
// it anyway.
|
// it anyway.
|
||||||
if strings.HasPrefix(data, "\xff\xfe") || strings.HasPrefix(data, "\xfe\xff") { // UTF-16
|
if strings.HasPrefix(data, "\xff\xfe") || strings.HasPrefix(data, "\xfe\xff") { // UTF-16
|
||||||
data = data[2:]
|
data = data[2:]
|
||||||
//lint:ignore S1017 https://github.com/dominikh/go-tools/issues/1447
|
|
||||||
} else if strings.HasPrefix(data, "\xef\xbb\xbf") { // UTF-8
|
} else if strings.HasPrefix(data, "\xef\xbb\xbf") { // UTF-8
|
||||||
data = data[3:]
|
data = data[3:]
|
||||||
}
|
}
|
||||||
|
@ -65,7 +64,7 @@ func parse(data string) (p *parser, err error) {
|
||||||
if i := strings.IndexRune(data[:ex], 0); i > -1 {
|
if i := strings.IndexRune(data[:ex], 0); i > -1 {
|
||||||
return nil, ParseError{
|
return nil, ParseError{
|
||||||
Message: "files cannot contain NULL bytes; probably using UTF-16; TOML files must be UTF-8",
|
Message: "files cannot contain NULL bytes; probably using UTF-16; TOML files must be UTF-8",
|
||||||
Position: Position{Line: 1, Start: i, Len: 1},
|
Position: Position{Line: 1, Col: 1, Start: i, Len: 1},
|
||||||
Line: 1,
|
Line: 1,
|
||||||
input: data,
|
input: data,
|
||||||
}
|
}
|
||||||
|
@ -92,8 +91,9 @@ func parse(data string) (p *parser, err error) {
|
||||||
|
|
||||||
func (p *parser) panicErr(it item, err error) {
|
func (p *parser) panicErr(it item, err error) {
|
||||||
panic(ParseError{
|
panic(ParseError{
|
||||||
|
Message: err.Error(),
|
||||||
err: err,
|
err: err,
|
||||||
Position: it.pos,
|
Position: it.pos.withCol(p.lx.input),
|
||||||
Line: it.pos.Len,
|
Line: it.pos.Len,
|
||||||
LastKey: p.current(),
|
LastKey: p.current(),
|
||||||
})
|
})
|
||||||
|
@ -102,7 +102,7 @@ func (p *parser) panicErr(it item, err error) {
|
||||||
func (p *parser) panicItemf(it item, format string, v ...any) {
|
func (p *parser) panicItemf(it item, format string, v ...any) {
|
||||||
panic(ParseError{
|
panic(ParseError{
|
||||||
Message: fmt.Sprintf(format, v...),
|
Message: fmt.Sprintf(format, v...),
|
||||||
Position: it.pos,
|
Position: it.pos.withCol(p.lx.input),
|
||||||
Line: it.pos.Len,
|
Line: it.pos.Len,
|
||||||
LastKey: p.current(),
|
LastKey: p.current(),
|
||||||
})
|
})
|
||||||
|
@ -111,7 +111,7 @@ func (p *parser) panicItemf(it item, format string, v ...any) {
|
||||||
func (p *parser) panicf(format string, v ...any) {
|
func (p *parser) panicf(format string, v ...any) {
|
||||||
panic(ParseError{
|
panic(ParseError{
|
||||||
Message: fmt.Sprintf(format, v...),
|
Message: fmt.Sprintf(format, v...),
|
||||||
Position: p.pos,
|
Position: p.pos.withCol(p.lx.input),
|
||||||
Line: p.pos.Line,
|
Line: p.pos.Line,
|
||||||
LastKey: p.current(),
|
LastKey: p.current(),
|
||||||
})
|
})
|
||||||
|
@ -123,10 +123,11 @@ func (p *parser) next() item {
|
||||||
if it.typ == itemError {
|
if it.typ == itemError {
|
||||||
if it.err != nil {
|
if it.err != nil {
|
||||||
panic(ParseError{
|
panic(ParseError{
|
||||||
Position: it.pos,
|
Message: it.err.Error(),
|
||||||
|
err: it.err,
|
||||||
|
Position: it.pos.withCol(p.lx.input),
|
||||||
Line: it.pos.Line,
|
Line: it.pos.Line,
|
||||||
LastKey: p.current(),
|
LastKey: p.current(),
|
||||||
err: it.err,
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -527,7 +528,7 @@ func numUnderscoresOK(s string) bool {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// isHexis a superset of all the permissable characters surrounding an
|
// isHex is a superset of all the permissible characters surrounding an
|
||||||
// underscore.
|
// underscore.
|
||||||
accept = isHex(r)
|
accept = isHex(r)
|
||||||
}
|
}
|
||||||
|
|
2
vendor/modules.txt
vendored
2
vendor/modules.txt
vendored
|
@ -1,4 +1,4 @@
|
||||||
# github.com/BurntSushi/toml v1.4.0
|
# github.com/BurntSushi/toml v1.5.0
|
||||||
## explicit; go 1.18
|
## explicit; go 1.18
|
||||||
github.com/BurntSushi/toml
|
github.com/BurntSushi/toml
|
||||||
github.com/BurntSushi/toml/internal
|
github.com/BurntSushi/toml/internal
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue