...

Text file src/github.com/ugorji/go/codec/gen-helper.go.tmpl

Documentation: github.com/ugorji/go/codec

     1// comment this out // + build ignore
     2
     3// Copyright (c) 2012-2020 Ugorji Nwoke. All rights reserved.
     4// Use of this source code is governed by a MIT license found in the LICENSE file.
     5
     6// Code generated from gen-helper.go.tmpl - DO NOT EDIT.
     7
     8package codec
     9
    10import (
    11	"encoding"
    12	"reflect"
    13)
    14
    15// GenVersion is the current version of codecgen.
    16const GenVersion = {{ .Version }} 
    17
    18// This file is used to generate helper code for codecgen. 
    19// The values here i.e. genHelper(En|De)coder are not to be used directly by 
    20// library users. They WILL change continuously and without notice.
    21
    22{{/*
    23// To help enforce this, we create an unexported type with exported members.
    24// The only way to get the type is via the one exported type that we control (somewhat).
    25//
    26// When static codecs are created for types, they will use this value
    27// to perform encoding or decoding of primitives or known slice or map types.
    28*/ -}}
    29
    30// GenHelperEncoder is exported so that it can be used externally by codecgen.
    31//
    32// Library users: DO NOT USE IT DIRECTLY or INDIRECTLY. IT WILL CHANGE CONTINOUSLY WITHOUT NOTICE.
    33func GenHelper() (g genHelper) { return }
    34
    35type genHelper struct {}
    36
    37func (genHelper) Encoder(e *Encoder) (ge genHelperEncoder, ee genHelperEncDriver) {
    38	ge = genHelperEncoder{e: e}
    39	ee = genHelperEncDriver{encDriver: e.e}
    40	return 
    41}
    42
    43func (genHelper) Decoder(d *Decoder) (gd genHelperDecoder, dd genHelperDecDriver) {
    44	gd = genHelperDecoder{d: d}
    45	dd = genHelperDecDriver{decDriver: d.d}
    46	return
    47}
    48
    49type genHelperEncDriver struct {
    50	encDriver
    51}
    52
    53type genHelperDecDriver struct {
    54	decDriver
    55}
    56
    57// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    58type genHelperEncoder struct {
    59	M mustHdl
    60	F fastpathT 
    61	e *Encoder
    62}
    63
    64// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    65type genHelperDecoder struct {
    66	C checkOverflow
    67	F fastpathT 
    68	d *Decoder
    69}
    70
    71// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    72func (f genHelperEncoder) EncBasicHandle() *BasicHandle {
    73	return f.e.h
    74}
    75// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    76func (f genHelperEncoder) EncWr() *encWr {
    77	return f.e.w()
    78}
    79// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    80func (f genHelperEncoder) EncBinary() bool {
    81	return f.e.be // f.e.hh.isBinaryEncoding()
    82}
    83// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    84func (f genHelperEncoder) IsJSONHandle() bool {
    85	return f.e.js
    86}
    87// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    88func (f genHelperEncoder) EncFallback(iv interface{}) {
    89	// f.e.encodeI(iv, false, false)
    90	f.e.encodeValue(reflect.ValueOf(iv), nil)
    91}
    92// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    93func (f genHelperEncoder) EncTextMarshal(iv encoding.TextMarshaler) {
    94	bs, fnerr := iv.MarshalText()
    95	f.e.marshalUtf8(bs, fnerr)
    96}
    97// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
    98func (f genHelperEncoder) EncJSONMarshal(iv jsonMarshaler) {
    99	bs, fnerr := iv.MarshalJSON()
   100	f.e.marshalAsis(bs, fnerr)
   101}
   102// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   103func (f genHelperEncoder) EncBinaryMarshal(iv encoding.BinaryMarshaler) {
   104	bs, fnerr := iv.MarshalBinary()
   105	f.e.marshalRaw(bs, fnerr)
   106}
   107// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   108func (f genHelperEncoder) EncRaw(iv Raw) { f.e.rawBytes(iv) }
   109
   110// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   111func (f genHelperEncoder) Extension(v interface{}) (xfn *extTypeTagFn) {
   112	return f.e.h.getExtForI(v)
   113}
   114// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   115func (f genHelperEncoder) EncExtension(v interface{}, xfFn *extTypeTagFn) {
   116	f.e.e.EncodeExt(v, xfFn.rt, xfFn.tag, xfFn.ext)
   117}
   118
   119// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   120func (f genHelperEncoder) EncWriteMapStart(length int) { f.e.mapStart(length) }
   121// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   122func (f genHelperEncoder) EncWriteMapEnd() { f.e.mapEnd() }
   123// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   124func (f genHelperEncoder) EncWriteArrayStart(length int) { f.e.arrayStart(length) }
   125// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   126func (f genHelperEncoder) EncWriteArrayEnd() { f.e.arrayEnd() }
   127// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   128func (f genHelperEncoder) EncWriteArrayElem() { f.e.arrayElem() }
   129// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   130func (f genHelperEncoder) EncWriteMapElemKey() { f.e.mapElemKey() }
   131// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   132func (f genHelperEncoder) EncWriteMapElemValue() { f.e.mapElemValue() }
   133// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   134func (f genHelperEncoder) EncEncodeComplex64(v complex64) { f.e.encodeComplex64(v) }
   135// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   136func (f genHelperEncoder) EncEncodeComplex128(v complex128) { f.e.encodeComplex128(v) }
   137// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   138func (f genHelperEncoder) EncEncode(v interface{}) { f.e.encode(v) }
   139// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   140func (f genHelperEncoder) EncFnGivenAddr(v interface{}) *codecFn { return f.e.h.fn(reflect.TypeOf(v).Elem()) }
   141// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   142func (f genHelperEncoder) EncEncodeNumBoolStrKindGivenAddr(v interface{}, encFn *codecFn) {
   143     f.e.encodeValueNonNil(reflect.ValueOf(v).Elem(), encFn)
   144}
   145// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   146func (f genHelperEncoder) EncEncodeMapNonNil(v interface{}) {
   147	if skipFastpathTypeSwitchInDirectCall || !fastpathEncodeTypeSwitch(v, f.e) {
   148		f.e.encodeValueNonNil(reflect.ValueOf(v), nil)
   149	}
   150}
   151
   152// ---------------- DECODER FOLLOWS -----------------
   153
   154// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   155func (f genHelperDecoder) DecBasicHandle() *BasicHandle {
   156	return f.d.h
   157}
   158// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   159func (f genHelperDecoder) DecBinary() bool {
   160     return f.d.be // f.d.hh.isBinaryEncoding()
   161}
   162// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   163func (f genHelperDecoder) DecSwallow() { f.d.swallow() }
   164
   165// // FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   166// func (f genHelperDecoder) DecScratchBuffer() []byte {
   167// 	return f.d.b[:]
   168// }
   169
   170// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   171func (f genHelperDecoder) DecScratchArrayBuffer() *[decScratchByteArrayLen]byte {
   172	return &f.d.b
   173}
   174// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   175func (f genHelperDecoder) DecFallback(iv interface{}, chkPtr bool) {
   176	rv := reflect.ValueOf(iv)
   177	if chkPtr {
   178    	if x, _ := isDecodeable(rv); !x {
   179			f.d.haltAsNotDecodeable(rv)
   180		}
   181	}
   182	f.d.decodeValue(rv, nil)
   183}
   184// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   185func (f genHelperDecoder) DecSliceHelperStart() (decSliceHelper, int) {
   186	return f.d.decSliceHelperStart()
   187}
   188// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   189func (f genHelperDecoder) DecStructFieldNotFound(index int, name string) {
   190	f.d.structFieldNotFound(index, name)
   191}
   192// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   193func (f genHelperDecoder) DecArrayCannotExpand(sliceLen, streamLen int) {
   194	f.d.arrayCannotExpand(sliceLen, streamLen)
   195}
   196// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   197func (f genHelperDecoder) DecTextUnmarshal(tm encoding.TextUnmarshaler) {
   198	halt.onerror(tm.UnmarshalText(f.d.d.DecodeStringAsBytes()))
   199}
   200// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   201func (f genHelperDecoder) DecJSONUnmarshal(tm jsonUnmarshaler) {
   202	f.d.jsonUnmarshalV(tm)
   203}
   204// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   205func (f genHelperDecoder) DecBinaryUnmarshal(bm encoding.BinaryUnmarshaler) {
   206	halt.onerror(bm.UnmarshalBinary(f.d.d.DecodeBytes(nil)))
   207}
   208// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   209func (f genHelperDecoder) DecRaw() []byte {	return f.d.rawBytes() }
   210
   211// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   212func (f genHelperDecoder) IsJSONHandle() bool {
   213	return f.d.js 
   214}
   215// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   216func (f genHelperDecoder) Extension(v interface{}) (xfn *extTypeTagFn) {
   217	return f.d.h.getExtForI(v)
   218}
   219// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   220func (f genHelperDecoder) DecExtension(v interface{}, xfFn *extTypeTagFn) {
   221	f.d.d.DecodeExt(v, xfFn.rt, xfFn.tag, xfFn.ext)
   222}
   223// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   224func (f genHelperDecoder) DecInferLen(clen, maxlen, unit int) (rvlen int) {
   225	return decInferLen(clen, maxlen, unit)
   226}
   227
   228// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   229func (f genHelperDecoder) DecReadMapStart() int { return f.d.mapStart(f.d.d.ReadMapStart()) }
   230// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   231func (f genHelperDecoder) DecReadMapEnd() { f.d.mapEnd() }
   232// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   233func (f genHelperDecoder) DecReadArrayStart() int { return f.d.arrayStart(f.d.d.ReadArrayStart()) }
   234// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   235func (f genHelperDecoder) DecReadArrayEnd() { f.d.arrayEnd() }
   236// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   237func (f genHelperDecoder) DecReadArrayElem() { f.d.arrayElem() }
   238// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   239func (f genHelperDecoder) DecReadMapElemKey() { f.d.mapElemKey() }
   240// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   241func (f genHelperDecoder) DecReadMapElemValue() { f.d.mapElemValue() }
   242
   243// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   244func (f genHelperDecoder) DecDecodeFloat32() float32 { return f.d.decodeFloat32() }
   245// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   246func (f genHelperDecoder) DecStringZC(v []byte) string { return f.d.stringZC(v) }
   247// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   248func (f genHelperDecoder) DecodeBytesInto(v []byte) []byte { return f.d.decodeBytesInto(v) }
   249// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   250func (f genHelperDecoder) DecContainerNext(j, containerLen int, hasLen bool) bool {
   251	// return f.d.containerNext(j, containerLen, hasLen)
   252	// rewriting so it can be inlined
   253	if hasLen {
   254		return j < containerLen
   255	}
   256	return !f.d.checkBreak()
   257}
   258
   259{{/*
   260// MARKER: remove WriteStr, as it cannot be inlined as of 20230201.
   261// Instead, generated code calls (*encWr).WriteStr directly.
   262
   263// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   264// func (f genHelperEncoder) WriteStr(s string) {
   265//     f.e.encWr.writestr(s)
   266// }
   267
   268// FOR USE BY CODECGEN ONLY. IT *WILL* CHANGE WITHOUT NOTICE. *DO NOT USE*
   269func (f genHelperDecoder) I2Rtid(v interface{}) uintptr {
   270	return i2rtid(v)
   271}
   272
   273*/ -}}

View as plain text