mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-10 15:14:09 +00:00
1c436b2723
This fixes parsing of `inf` and `nan` values in json lines passed to `/api/v1/import`
170 lines
4 KiB
Go
170 lines
4 KiB
Go
package fastjson
|
|
|
|
var handyPool ParserPool
|
|
|
|
// GetString returns string value for the field identified by keys path
|
|
// in JSON data.
|
|
//
|
|
// Array indexes may be represented as decimal numbers in keys.
|
|
//
|
|
// An empty string is returned on error. Use Parser for proper error handling.
|
|
//
|
|
// Parser is faster for obtaining multiple fields from JSON.
|
|
func GetString(data []byte, keys ...string) string {
|
|
p := handyPool.Get()
|
|
v, err := p.ParseBytes(data)
|
|
if err != nil {
|
|
handyPool.Put(p)
|
|
return ""
|
|
}
|
|
sb := v.GetStringBytes(keys...)
|
|
str := string(sb)
|
|
handyPool.Put(p)
|
|
return str
|
|
}
|
|
|
|
// GetBytes returns string value for the field identified by keys path
|
|
// in JSON data.
|
|
//
|
|
// Array indexes may be represented as decimal numbers in keys.
|
|
//
|
|
// nil is returned on error. Use Parser for proper error handling.
|
|
//
|
|
// Parser is faster for obtaining multiple fields from JSON.
|
|
func GetBytes(data []byte, keys ...string) []byte {
|
|
p := handyPool.Get()
|
|
v, err := p.ParseBytes(data)
|
|
if err != nil {
|
|
handyPool.Put(p)
|
|
return nil
|
|
}
|
|
sb := v.GetStringBytes(keys...)
|
|
|
|
// Make a copy of sb, since sb belongs to p.
|
|
var b []byte
|
|
if sb != nil {
|
|
b = append(b, sb...)
|
|
}
|
|
|
|
handyPool.Put(p)
|
|
return b
|
|
}
|
|
|
|
// GetInt returns int value for the field identified by keys path
|
|
// in JSON data.
|
|
//
|
|
// Array indexes may be represented as decimal numbers in keys.
|
|
//
|
|
// 0 is returned on error. Use Parser for proper error handling.
|
|
//
|
|
// Parser is faster for obtaining multiple fields from JSON.
|
|
func GetInt(data []byte, keys ...string) int {
|
|
p := handyPool.Get()
|
|
v, err := p.ParseBytes(data)
|
|
if err != nil {
|
|
handyPool.Put(p)
|
|
return 0
|
|
}
|
|
n := v.GetInt(keys...)
|
|
handyPool.Put(p)
|
|
return n
|
|
}
|
|
|
|
// GetFloat64 returns float64 value for the field identified by keys path
|
|
// in JSON data.
|
|
//
|
|
// Array indexes may be represented as decimal numbers in keys.
|
|
//
|
|
// 0 is returned on error. Use Parser for proper error handling.
|
|
//
|
|
// Parser is faster for obtaining multiple fields from JSON.
|
|
func GetFloat64(data []byte, keys ...string) float64 {
|
|
p := handyPool.Get()
|
|
v, err := p.ParseBytes(data)
|
|
if err != nil {
|
|
handyPool.Put(p)
|
|
return 0
|
|
}
|
|
f := v.GetFloat64(keys...)
|
|
handyPool.Put(p)
|
|
return f
|
|
}
|
|
|
|
// GetBool returns boolean value for the field identified by keys path
|
|
// in JSON data.
|
|
//
|
|
// Array indexes may be represented as decimal numbers in keys.
|
|
//
|
|
// False is returned on error. Use Parser for proper error handling.
|
|
//
|
|
// Parser is faster for obtaining multiple fields from JSON.
|
|
func GetBool(data []byte, keys ...string) bool {
|
|
p := handyPool.Get()
|
|
v, err := p.ParseBytes(data)
|
|
if err != nil {
|
|
handyPool.Put(p)
|
|
return false
|
|
}
|
|
b := v.GetBool(keys...)
|
|
handyPool.Put(p)
|
|
return b
|
|
}
|
|
|
|
// Exists returns true if the field identified by keys path exists in JSON data.
|
|
//
|
|
// Array indexes may be represented as decimal numbers in keys.
|
|
//
|
|
// False is returned on error. Use Parser for proper error handling.
|
|
//
|
|
// Parser is faster when multiple fields must be checked in the JSON.
|
|
func Exists(data []byte, keys ...string) bool {
|
|
p := handyPool.Get()
|
|
v, err := p.ParseBytes(data)
|
|
if err != nil {
|
|
handyPool.Put(p)
|
|
return false
|
|
}
|
|
ok := v.Exists(keys...)
|
|
handyPool.Put(p)
|
|
return ok
|
|
}
|
|
|
|
// Parse parses json string s.
|
|
//
|
|
// The function is slower than the Parser.Parse for re-used Parser.
|
|
func Parse(s string) (*Value, error) {
|
|
var p Parser
|
|
return p.Parse(s)
|
|
}
|
|
|
|
// MustParse parses json string s.
|
|
//
|
|
// The function panics if s cannot be parsed.
|
|
// The function is slower than the Parser.Parse for re-used Parser.
|
|
func MustParse(s string) *Value {
|
|
v, err := Parse(s)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return v
|
|
}
|
|
|
|
// ParseBytes parses b containing json.
|
|
//
|
|
// The function is slower than the Parser.ParseBytes for re-used Parser.
|
|
func ParseBytes(b []byte) (*Value, error) {
|
|
var p Parser
|
|
return p.ParseBytes(b)
|
|
}
|
|
|
|
// MustParseBytes parses b containing json.
|
|
//
|
|
// The function panics if b cannot be parsed.
|
|
// The function is slower than the Parser.ParseBytes for re-used Parser.
|
|
func MustParseBytes(b []byte) *Value {
|
|
v, err := ParseBytes(b)
|
|
if err != nil {
|
|
panic(err)
|
|
}
|
|
return v
|
|
}
|