Source File
json_enc.go
Belonging Package
github.com/nats-io/nats.go/encoders/builtin
// Copyright 2012-2023 The NATS Authors// 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 builtinimport ()// JsonEncoder is a JSON Encoder implementation for EncodedConn.// This encoder will use the builtin encoding/json to Marshal// and Unmarshal most types, including structs.//// Deprecated: Encoded connections are no longer supported.type JsonEncoder struct {// Empty}// Encode//// Deprecated: Encoded connections are no longer supported.func ( *JsonEncoder) ( string, any) ([]byte, error) {, := json.Marshal()if != nil {return nil,}return , nil}// Decode//// Deprecated: Encoded connections are no longer supported.func ( *JsonEncoder) ( string, []byte, any) ( error) {switch arg := .(type) {case *string:// If they want a string and it is a JSON string, strip quotes// This allows someone to send a struct but receive as a plain string// This cast should be efficient for Go 1.3 and beyond.:= string()if strings.HasPrefix(, `"`) && strings.HasSuffix(, `"`) {* = [1 : len()-1]} else {* =}case *[]byte:* =default:= json.Unmarshal(, )}return}
![]() |
The pages are generated with Golds v0.8.2. (GOOS=linux GOARCH=amd64) Golds is a Go 101 project developed by Tapir Liu. PR and bug reports are welcome and can be submitted to the issue list. Please follow @zigo_101 (reachable from the left QR code) to get the latest news of Golds. |