Merge branch 'master' into vendor

This commit is contained in:
Javier Provecho Fernandez 2017-07-18 23:02:11 +02:00 committed by GitHub
commit 2c3c37266b
7 changed files with 47 additions and 9 deletions

View File

@ -88,7 +88,6 @@ BenchmarkZeus_GithubAll | 2000 | 944234 | 300688 | 2648
- [x] Battle tested - [x] Battle tested
- [x] API frozen, new releases will not break your code. - [x] API frozen, new releases will not break your code.
## Start using it ## Start using it
1. Download and install it: 1. Download and install it:
@ -141,6 +140,14 @@ $ curl https://raw.githubusercontent.com/gin-gonic/gin/master/examples/basic/mai
$ go run main.go $ go run main.go
``` ```
## Build with [jsoniter](https://github.com/json-iterator/go)
Gin use `encoding/json` as default json package but you can change to [jsoniter](https://github.com/json-iterator/go) by build from other tags.
```sh
$ go build -tags=jsoniter .
```
## API Examples ## API Examples
### Using GET, POST, PUT, PATCH, DELETE and OPTIONS ### Using GET, POST, PUT, PATCH, DELETE and OPTIONS

View File

@ -7,11 +7,10 @@ package binding
import ( import (
"net/http" "net/http"
"github.com/json-iterator/go" "github.com/gin-gonic/gin/json"
) )
var ( var (
json = jsoniter.ConfigCompatibleWithStandardLibrary
EnableDecoderUseNumber = false EnableDecoderUseNumber = false
) )

View File

@ -9,11 +9,9 @@ import (
"fmt" "fmt"
"reflect" "reflect"
"github.com/json-iterator/go" "github.com/gin-gonic/gin/json"
) )
var json = jsoniter.ConfigCompatibleWithStandardLibrary
type ErrorType uint64 type ErrorType uint64
const ( const (

View File

@ -8,6 +8,7 @@ import (
"errors" "errors"
"testing" "testing"
"github.com/gin-gonic/gin/json"
"github.com/stretchr/testify/assert" "github.com/stretchr/testify/assert"
) )

17
json/json.go Normal file
View File

@ -0,0 +1,17 @@
// Copyright 2017 Bo-Yi Wu. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
// +build !jsoniter
package json
import (
"encoding/json"
)
var (
Marshal = json.Marshal
MarshalIndent = json.MarshalIndent
NewDecoder = json.NewDecoder
)

18
json/jsoniter.go Normal file
View File

@ -0,0 +1,18 @@
// Copyright 2017 Bo-Yi Wu. All rights reserved.
// Use of this source code is governed by a MIT style
// license that can be found in the LICENSE file.
// +build jsoniter
package json
import (
"github.com/json-iterator/go"
)
var (
json = jsoniter.ConfigCompatibleWithStandardLibrary
Marshal = json.Marshal
MarshalIndent = json.MarshalIndent
NewDecoder = json.NewDecoder
)

View File

@ -8,11 +8,9 @@ import (
"bytes" "bytes"
"net/http" "net/http"
"github.com/json-iterator/go" "github.com/gin-gonic/gin/json"
) )
var json = jsoniter.ConfigCompatibleWithStandardLibrary
type JSON struct { type JSON struct {
Data interface{} Data interface{}
} }