//go:build (amd64 && go1.17 && !go1.24) || (arm64 && go1.20 && !go1.24) // +build amd64,go1.17,!go1.24 arm64,go1.20,!go1.24 /* * Copyright 2023 ByteDance Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package decoder import ( `github.com/bytedance/sonic/internal/decoder/api` ) // Decoder is the decoder context object type Decoder = api.Decoder // SyntaxError represents json syntax error type SyntaxError = api.SyntaxError // MismatchTypeError represents dismatching between json and object type MismatchTypeError = api.MismatchTypeError // Options for decode. type Options = api.Options const ( OptionUseInt64 Options = api.OptionUseInt64 OptionUseNumber Options = api.OptionUseNumber OptionUseUnicodeErrors Options = api.OptionUseUnicodeErrors OptionDisableUnknown Options = api.OptionDisableUnknown OptionCopyString Options = api.OptionCopyString OptionValidateString Options = api.OptionValidateString OptionNoValidateJSON Options = api.OptionNoValidateJSON ) // StreamDecoder is the decoder context object for streaming input. type StreamDecoder = api.StreamDecoder var ( // NewDecoder creates a new decoder instance. NewDecoder = api.NewDecoder // NewStreamDecoder adapts to encoding/json.NewDecoder API. // // NewStreamDecoder returns a new decoder that reads from r. NewStreamDecoder = api.NewStreamDecoder // Pretouch compiles vt ahead-of-time to avoid JIT compilation on-the-fly, in // order to reduce the first-hit latency. // // Opts are the compile options, for example, "option.WithCompileRecursiveDepth" is // a compile option to set the depth of recursive compile for the nested struct type. Pretouch = api.Pretouch // Skip skips only one json value, and returns first non-blank character position and its ending position if it is valid. // Otherwise, returns negative error code using start and invalid character position using end Skip = api.Skip )