mirror of https://github.com/tidwall/gjson.git
fix path issue
This commit is contained in:
parent
1b1f52024e
commit
260ef19a2e
86
gjson.go
86
gjson.go
|
@ -137,51 +137,49 @@ func Get(json string, path string) Result {
|
||||||
// underscore characters.
|
// underscore characters.
|
||||||
if path[i] >= '_' {
|
if path[i] >= '_' {
|
||||||
continue
|
continue
|
||||||
} else if path[i] <= '\\' {
|
} else if path[i] == '.' {
|
||||||
if path[i] == '\\' {
|
// append a new part
|
||||||
// go into escape mode. this is a slower path that
|
parts = append(parts, part{wild: wild, key: path[s:i]})
|
||||||
// strips off the escape character from the part.
|
if wild {
|
||||||
epart := []byte(path[s:i])
|
wild = false // reset the wild flag
|
||||||
i++
|
|
||||||
if i < len(path) {
|
|
||||||
epart = append(epart, path[i])
|
|
||||||
i++
|
|
||||||
for ; i < len(path); i++ {
|
|
||||||
if path[i] == '\\' {
|
|
||||||
i++
|
|
||||||
if i < len(path) {
|
|
||||||
epart = append(epart, path[i])
|
|
||||||
}
|
|
||||||
continue
|
|
||||||
} else if path[i] == '.' {
|
|
||||||
parts = append(parts, part{wild: wild, key: string(epart)})
|
|
||||||
if wild {
|
|
||||||
wild = false
|
|
||||||
}
|
|
||||||
s = i + 1
|
|
||||||
i++
|
|
||||||
goto next_part
|
|
||||||
} else if path[i] == '*' || path[i] == '?' {
|
|
||||||
wild = true
|
|
||||||
}
|
|
||||||
epart = append(epart, path[i])
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// append the last part
|
|
||||||
parts = append(parts, part{wild: wild, key: string(epart)})
|
|
||||||
goto end_parts
|
|
||||||
} else if path[i] == '.' {
|
|
||||||
// append a new part
|
|
||||||
parts = append(parts, part{wild: wild, key: path[s:i]})
|
|
||||||
if wild {
|
|
||||||
wild = false // reset the wild flag
|
|
||||||
}
|
|
||||||
// set the starting index to one past the dot.
|
|
||||||
s = i + 1
|
|
||||||
} else if path[i] == '*' || path[i] == '?' {
|
|
||||||
// set the wild flag to indicate that the part is a wildcard.
|
|
||||||
wild = true
|
|
||||||
}
|
}
|
||||||
|
// set the starting index to one past the dot.
|
||||||
|
s = i + 1
|
||||||
|
} else if path[i] == '*' || path[i] == '?' {
|
||||||
|
// set the wild flag to indicate that the part is a wildcard.
|
||||||
|
wild = true
|
||||||
|
} else if path[i] == '\\' {
|
||||||
|
// go into escape mode. this is a slower path that
|
||||||
|
// strips off the escape character from the part.
|
||||||
|
epart := []byte(path[s:i])
|
||||||
|
i++
|
||||||
|
if i < len(path) {
|
||||||
|
epart = append(epart, path[i])
|
||||||
|
i++
|
||||||
|
for ; i < len(path); i++ {
|
||||||
|
if path[i] == '\\' {
|
||||||
|
i++
|
||||||
|
if i < len(path) {
|
||||||
|
epart = append(epart, path[i])
|
||||||
|
}
|
||||||
|
continue
|
||||||
|
} else if path[i] == '.' {
|
||||||
|
parts = append(parts, part{wild: wild, key: string(epart)})
|
||||||
|
if wild {
|
||||||
|
wild = false
|
||||||
|
}
|
||||||
|
s = i + 1
|
||||||
|
i++
|
||||||
|
goto next_part
|
||||||
|
} else if path[i] == '*' || path[i] == '?' {
|
||||||
|
wild = true
|
||||||
|
}
|
||||||
|
epart = append(epart, path[i])
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// append the last part
|
||||||
|
parts = append(parts, part{wild: wild, key: string(epart)})
|
||||||
|
goto end_parts
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// append the last part
|
// append the last part
|
||||||
|
|
Loading…
Reference in New Issue