ed091163be
This adds the new `required_plugins` block to be nested under the packer block. Example: ```hcl packer { required_plugins { aws = { version = ">= 2.7.0" source = "azr/aws" } azure = ">= 2.7.0" } } ``` For example on darwin_amd64 Packer will install those under : * "${PACKER_HOME_DIR}/plugin/github.com/azr/amazon/packer-plugin-amazon_2.7.0_x5.0_darwin_amd64" * "${PACKER_HOME_DIR}/plugin/github.com/hashicorp/azure/packer-plugin-azure_2.7.0_x5.0_darwin_amd64_x5" + docs + tests |
||
---|---|---|
.. | ||
.codecov.yml | ||
.gitignore | ||
.travis.yml | ||
Gopkg.lock | ||
Gopkg.toml | ||
LICENSE | ||
README.md | ||
adapter.go | ||
any.go | ||
any_array.go | ||
any_bool.go | ||
any_float.go | ||
any_int32.go | ||
any_int64.go | ||
any_invalid.go | ||
any_nil.go | ||
any_number.go | ||
any_object.go | ||
any_str.go | ||
any_uint32.go | ||
any_uint64.go | ||
build.sh | ||
config.go | ||
fuzzy_mode_convert_table.md | ||
go.mod | ||
go.sum | ||
iter.go | ||
iter_array.go | ||
iter_float.go | ||
iter_int.go | ||
iter_object.go | ||
iter_skip.go | ||
iter_skip_sloppy.go | ||
iter_skip_strict.go | ||
iter_str.go | ||
jsoniter.go | ||
pool.go | ||
reflect.go | ||
reflect_array.go | ||
reflect_dynamic.go | ||
reflect_extension.go | ||
reflect_json_number.go | ||
reflect_json_raw_message.go | ||
reflect_map.go | ||
reflect_marshaler.go | ||
reflect_native.go | ||
reflect_optional.go | ||
reflect_slice.go | ||
reflect_struct_decoder.go | ||
reflect_struct_encoder.go | ||
stream.go | ||
stream_float.go | ||
stream_int.go | ||
stream_str.go | ||
test.sh |
README.md
A high-performance 100% compatible drop-in replacement of "encoding/json"
You can also use thrift like JSON using thrift-iterator
Benchmark
Raw Result (easyjson requires static code generation)
ns/op | allocation bytes | allocation times | |
---|---|---|---|
std decode | 35510 ns/op | 1960 B/op | 99 allocs/op |
easyjson decode | 8499 ns/op | 160 B/op | 4 allocs/op |
jsoniter decode | 5623 ns/op | 160 B/op | 3 allocs/op |
std encode | 2213 ns/op | 712 B/op | 5 allocs/op |
easyjson encode | 883 ns/op | 576 B/op | 3 allocs/op |
jsoniter encode | 837 ns/op | 384 B/op | 4 allocs/op |
Always benchmark with your own workload. The result depends heavily on the data input.
Usage
100% compatibility with standard lib
Replace
import "encoding/json"
json.Marshal(&data)
with
import jsoniter "github.com/json-iterator/go"
var json = jsoniter.ConfigCompatibleWithStandardLibrary
json.Marshal(&data)
Replace
import "encoding/json"
json.Unmarshal(input, &data)
with
import jsoniter "github.com/json-iterator/go"
var json = jsoniter.ConfigCompatibleWithStandardLibrary
json.Unmarshal(input, &data)
How to get
go get github.com/json-iterator/go
Contribution Welcomed !
Contributors
Report issue or pull request, or email taowen@gmail.com, or