...

Source file src/github.com/goccy/go-json/internal/encoder/vm_color/vm.go

Documentation: github.com/goccy/go-json/internal/encoder/vm_color

     1  // Code generated by internal/cmd/generator. DO NOT EDIT!
     2  package vm_color
     3  
     4  import (
     5  	"math"
     6  	"reflect"
     7  	"sort"
     8  	"unsafe"
     9  
    10  	"github.com/goccy/go-json/internal/encoder"
    11  	"github.com/goccy/go-json/internal/runtime"
    12  )
    13  
    14  func Run(ctx *encoder.RuntimeContext, b []byte, codeSet *encoder.OpcodeSet) ([]byte, error) {
    15  	recursiveLevel := 0
    16  	ptrOffset := uintptr(0)
    17  	ctxptr := ctx.Ptr()
    18  	var code *encoder.Opcode
    19  	if (ctx.Option.Flag & encoder.HTMLEscapeOption) != 0 {
    20  		code = codeSet.EscapeKeyCode
    21  	} else {
    22  		code = codeSet.NoescapeKeyCode
    23  	}
    24  
    25  	for {
    26  		switch code.Op {
    27  		default:
    28  			return nil, errUnimplementedOp(code.Op)
    29  		case encoder.OpPtr:
    30  			p := load(ctxptr, code.Idx)
    31  			code = code.Next
    32  			store(ctxptr, code.Idx, ptrToPtr(p))
    33  		case encoder.OpIntPtr:
    34  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
    35  			if p == 0 {
    36  				b = appendNullComma(ctx, b)
    37  				code = code.Next
    38  				break
    39  			}
    40  			store(ctxptr, code.Idx, p)
    41  			fallthrough
    42  		case encoder.OpInt:
    43  			b = appendInt(ctx, b, load(ctxptr, code.Idx), code)
    44  			b = appendComma(ctx, b)
    45  			code = code.Next
    46  		case encoder.OpUintPtr:
    47  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
    48  			if p == 0 {
    49  				b = appendNullComma(ctx, b)
    50  				code = code.Next
    51  				break
    52  			}
    53  			store(ctxptr, code.Idx, p)
    54  			fallthrough
    55  		case encoder.OpUint:
    56  			b = appendUint(ctx, b, load(ctxptr, code.Idx), code)
    57  			b = appendComma(ctx, b)
    58  			code = code.Next
    59  		case encoder.OpIntString:
    60  			b = append(b, '"')
    61  			b = appendInt(ctx, b, load(ctxptr, code.Idx), code)
    62  			b = append(b, '"')
    63  			b = appendComma(ctx, b)
    64  			code = code.Next
    65  		case encoder.OpUintString:
    66  			b = append(b, '"')
    67  			b = appendUint(ctx, b, load(ctxptr, code.Idx), code)
    68  			b = append(b, '"')
    69  			b = appendComma(ctx, b)
    70  			code = code.Next
    71  		case encoder.OpFloat32Ptr:
    72  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
    73  			if p == 0 {
    74  				b = appendNull(ctx, b)
    75  				b = appendComma(ctx, b)
    76  				code = code.Next
    77  				break
    78  			}
    79  			store(ctxptr, code.Idx, p)
    80  			fallthrough
    81  		case encoder.OpFloat32:
    82  			b = appendFloat32(ctx, b, ptrToFloat32(load(ctxptr, code.Idx)))
    83  			b = appendComma(ctx, b)
    84  			code = code.Next
    85  		case encoder.OpFloat64Ptr:
    86  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
    87  			if p == 0 {
    88  				b = appendNullComma(ctx, b)
    89  				code = code.Next
    90  				break
    91  			}
    92  			store(ctxptr, code.Idx, p)
    93  			fallthrough
    94  		case encoder.OpFloat64:
    95  			v := ptrToFloat64(load(ctxptr, code.Idx))
    96  			if math.IsInf(v, 0) || math.IsNaN(v) {
    97  				return nil, errUnsupportedFloat(v)
    98  			}
    99  			b = appendFloat64(ctx, b, v)
   100  			b = appendComma(ctx, b)
   101  			code = code.Next
   102  		case encoder.OpStringPtr:
   103  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   104  			if p == 0 {
   105  				b = appendNullComma(ctx, b)
   106  				code = code.Next
   107  				break
   108  			}
   109  			store(ctxptr, code.Idx, p)
   110  			fallthrough
   111  		case encoder.OpString:
   112  			b = appendString(ctx, b, ptrToString(load(ctxptr, code.Idx)))
   113  			b = appendComma(ctx, b)
   114  			code = code.Next
   115  		case encoder.OpBoolPtr:
   116  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   117  			if p == 0 {
   118  				b = appendNullComma(ctx, b)
   119  				code = code.Next
   120  				break
   121  			}
   122  			store(ctxptr, code.Idx, p)
   123  			fallthrough
   124  		case encoder.OpBool:
   125  			b = appendBool(ctx, b, ptrToBool(load(ctxptr, code.Idx)))
   126  			b = appendComma(ctx, b)
   127  			code = code.Next
   128  		case encoder.OpBytesPtr:
   129  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   130  			if p == 0 {
   131  				b = appendNullComma(ctx, b)
   132  				code = code.Next
   133  				break
   134  			}
   135  			store(ctxptr, code.Idx, p)
   136  			fallthrough
   137  		case encoder.OpBytes:
   138  			b = appendByteSlice(ctx, b, ptrToBytes(load(ctxptr, code.Idx)))
   139  			b = appendComma(ctx, b)
   140  			code = code.Next
   141  		case encoder.OpNumberPtr:
   142  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   143  			if p == 0 {
   144  				b = appendNullComma(ctx, b)
   145  				code = code.Next
   146  				break
   147  			}
   148  			store(ctxptr, code.Idx, p)
   149  			fallthrough
   150  		case encoder.OpNumber:
   151  			bb, err := appendNumber(ctx, b, ptrToNumber(load(ctxptr, code.Idx)))
   152  			if err != nil {
   153  				return nil, err
   154  			}
   155  			b = appendComma(ctx, bb)
   156  			code = code.Next
   157  		case encoder.OpInterfacePtr:
   158  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   159  			if p == 0 {
   160  				b = appendNullComma(ctx, b)
   161  				code = code.Next
   162  				break
   163  			}
   164  			store(ctxptr, code.Idx, p)
   165  			fallthrough
   166  		case encoder.OpInterface:
   167  			p := load(ctxptr, code.Idx)
   168  			if p == 0 {
   169  				b = appendNullComma(ctx, b)
   170  				code = code.Next
   171  				break
   172  			}
   173  			if recursiveLevel > encoder.StartDetectingCyclesAfter {
   174  				for _, seen := range ctx.SeenPtr {
   175  					if p == seen {
   176  						return nil, errUnsupportedValue(code, p)
   177  					}
   178  				}
   179  			}
   180  			ctx.SeenPtr = append(ctx.SeenPtr, p)
   181  			var (
   182  				typ      *runtime.Type
   183  				ifacePtr unsafe.Pointer
   184  			)
   185  			up := ptrToUnsafePtr(p)
   186  			if code.Flags&encoder.NonEmptyInterfaceFlags != 0 {
   187  				iface := (*nonEmptyInterface)(up)
   188  				ifacePtr = iface.ptr
   189  				if iface.itab != nil {
   190  					typ = iface.itab.typ
   191  				}
   192  			} else {
   193  				iface := (*emptyInterface)(up)
   194  				ifacePtr = iface.ptr
   195  				typ = iface.typ
   196  			}
   197  			if ifacePtr == nil {
   198  				isDirectedNil := typ != nil && typ.Kind() == reflect.Struct && !runtime.IfaceIndir(typ)
   199  				if !isDirectedNil {
   200  					b = appendNullComma(ctx, b)
   201  					code = code.Next
   202  					break
   203  				}
   204  			}
   205  			ctx.KeepRefs = append(ctx.KeepRefs, up)
   206  			ifaceCodeSet, err := encoder.CompileToGetCodeSet(ctx, uintptr(unsafe.Pointer(typ)))
   207  			if err != nil {
   208  				return nil, err
   209  			}
   210  
   211  			totalLength := uintptr(code.Length) + 3
   212  			nextTotalLength := uintptr(ifaceCodeSet.CodeLength) + 3
   213  
   214  			var c *encoder.Opcode
   215  			if (ctx.Option.Flag & encoder.HTMLEscapeOption) != 0 {
   216  				c = ifaceCodeSet.InterfaceEscapeKeyCode
   217  			} else {
   218  				c = ifaceCodeSet.InterfaceNoescapeKeyCode
   219  			}
   220  			curlen := uintptr(len(ctx.Ptrs))
   221  			offsetNum := ptrOffset / uintptrSize
   222  			oldOffset := ptrOffset
   223  			ptrOffset += totalLength * uintptrSize
   224  			oldBaseIndent := ctx.BaseIndent
   225  			ctx.BaseIndent += code.Indent
   226  
   227  			newLen := offsetNum + totalLength + nextTotalLength
   228  			if curlen < newLen {
   229  				ctx.Ptrs = append(ctx.Ptrs, make([]uintptr, newLen-curlen)...)
   230  			}
   231  			ctxptr = ctx.Ptr() + ptrOffset // assign new ctxptr
   232  
   233  			end := ifaceCodeSet.EndCode
   234  			store(ctxptr, c.Idx, uintptr(ifacePtr))
   235  			store(ctxptr, end.Idx, oldOffset)
   236  			store(ctxptr, end.ElemIdx, uintptr(unsafe.Pointer(code.Next)))
   237  			storeIndent(ctxptr, end, uintptr(oldBaseIndent))
   238  			code = c
   239  			recursiveLevel++
   240  		case encoder.OpInterfaceEnd:
   241  			recursiveLevel--
   242  
   243  			// restore ctxptr
   244  			offset := load(ctxptr, code.Idx)
   245  			restoreIndent(ctx, code, ctxptr)
   246  			ctx.SeenPtr = ctx.SeenPtr[:len(ctx.SeenPtr)-1]
   247  
   248  			codePtr := load(ctxptr, code.ElemIdx)
   249  			code = (*encoder.Opcode)(ptrToUnsafePtr(codePtr))
   250  			ctxptr = ctx.Ptr() + offset
   251  			ptrOffset = offset
   252  		case encoder.OpMarshalJSONPtr:
   253  			p := load(ctxptr, code.Idx)
   254  			if p == 0 {
   255  				b = appendNullComma(ctx, b)
   256  				code = code.Next
   257  				break
   258  			}
   259  			store(ctxptr, code.Idx, ptrToPtr(p))
   260  			fallthrough
   261  		case encoder.OpMarshalJSON:
   262  			p := load(ctxptr, code.Idx)
   263  			if p == 0 {
   264  				b = appendNullComma(ctx, b)
   265  				code = code.Next
   266  				break
   267  			}
   268  			if (code.Flags&encoder.IsNilableTypeFlags) != 0 && (code.Flags&encoder.IndirectFlags) != 0 {
   269  				p = ptrToPtr(p)
   270  			}
   271  			bb, err := appendMarshalJSON(ctx, code, b, ptrToInterface(code, p))
   272  			if err != nil {
   273  				return nil, err
   274  			}
   275  			b = appendComma(ctx, bb)
   276  			code = code.Next
   277  		case encoder.OpMarshalTextPtr:
   278  			p := load(ctxptr, code.Idx)
   279  			if p == 0 {
   280  				b = appendNullComma(ctx, b)
   281  				code = code.Next
   282  				break
   283  			}
   284  			store(ctxptr, code.Idx, ptrToPtr(p))
   285  			fallthrough
   286  		case encoder.OpMarshalText:
   287  			p := load(ctxptr, code.Idx)
   288  			if p == 0 {
   289  				b = append(b, `""`...)
   290  				b = appendComma(ctx, b)
   291  				code = code.Next
   292  				break
   293  			}
   294  			if (code.Flags&encoder.IsNilableTypeFlags) != 0 && (code.Flags&encoder.IndirectFlags) != 0 {
   295  				p = ptrToPtr(p)
   296  			}
   297  			bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
   298  			if err != nil {
   299  				return nil, err
   300  			}
   301  			b = appendComma(ctx, bb)
   302  			code = code.Next
   303  		case encoder.OpSlicePtr:
   304  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   305  			if p == 0 {
   306  				b = appendNullComma(ctx, b)
   307  				code = code.End.Next
   308  				break
   309  			}
   310  			store(ctxptr, code.Idx, p)
   311  			fallthrough
   312  		case encoder.OpSlice:
   313  			p := load(ctxptr, code.Idx)
   314  			slice := ptrToSlice(p)
   315  			if p == 0 || slice.Data == nil {
   316  				b = appendNullComma(ctx, b)
   317  				code = code.End.Next
   318  				break
   319  			}
   320  			store(ctxptr, code.ElemIdx, 0)
   321  			store(ctxptr, code.Length, uintptr(slice.Len))
   322  			store(ctxptr, code.Idx, uintptr(slice.Data))
   323  			if slice.Len > 0 {
   324  				b = appendArrayHead(ctx, code, b)
   325  				code = code.Next
   326  				store(ctxptr, code.Idx, uintptr(slice.Data))
   327  			} else {
   328  				b = appendEmptyArray(ctx, b)
   329  				code = code.End.Next
   330  			}
   331  		case encoder.OpSliceElem:
   332  			idx := load(ctxptr, code.ElemIdx)
   333  			length := load(ctxptr, code.Length)
   334  			idx++
   335  			if idx < length {
   336  				b = appendArrayElemIndent(ctx, code, b)
   337  				store(ctxptr, code.ElemIdx, idx)
   338  				data := load(ctxptr, code.Idx)
   339  				size := uintptr(code.Size)
   340  				code = code.Next
   341  				store(ctxptr, code.Idx, data+idx*size)
   342  			} else {
   343  				b = appendArrayEnd(ctx, code, b)
   344  				code = code.End.Next
   345  			}
   346  		case encoder.OpArrayPtr:
   347  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   348  			if p == 0 {
   349  				b = appendNullComma(ctx, b)
   350  				code = code.End.Next
   351  				break
   352  			}
   353  			store(ctxptr, code.Idx, p)
   354  			fallthrough
   355  		case encoder.OpArray:
   356  			p := load(ctxptr, code.Idx)
   357  			if p == 0 {
   358  				b = appendNullComma(ctx, b)
   359  				code = code.End.Next
   360  				break
   361  			}
   362  			if code.Length > 0 {
   363  				b = appendArrayHead(ctx, code, b)
   364  				store(ctxptr, code.ElemIdx, 0)
   365  				code = code.Next
   366  				store(ctxptr, code.Idx, p)
   367  			} else {
   368  				b = appendEmptyArray(ctx, b)
   369  				code = code.End.Next
   370  			}
   371  		case encoder.OpArrayElem:
   372  			idx := load(ctxptr, code.ElemIdx)
   373  			idx++
   374  			if idx < uintptr(code.Length) {
   375  				b = appendArrayElemIndent(ctx, code, b)
   376  				store(ctxptr, code.ElemIdx, idx)
   377  				p := load(ctxptr, code.Idx)
   378  				size := uintptr(code.Size)
   379  				code = code.Next
   380  				store(ctxptr, code.Idx, p+idx*size)
   381  			} else {
   382  				b = appendArrayEnd(ctx, code, b)
   383  				code = code.End.Next
   384  			}
   385  		case encoder.OpMapPtr:
   386  			p := loadNPtr(ctxptr, code.Idx, code.PtrNum)
   387  			if p == 0 {
   388  				b = appendNullComma(ctx, b)
   389  				code = code.End.Next
   390  				break
   391  			}
   392  			store(ctxptr, code.Idx, p)
   393  			fallthrough
   394  		case encoder.OpMap:
   395  			p := load(ctxptr, code.Idx)
   396  			if p == 0 {
   397  				b = appendNullComma(ctx, b)
   398  				code = code.End.Next
   399  				break
   400  			}
   401  			uptr := ptrToUnsafePtr(p)
   402  			mlen := maplen(uptr)
   403  			if mlen <= 0 {
   404  				b = appendEmptyObject(ctx, b)
   405  				code = code.End.Next
   406  				break
   407  			}
   408  			b = appendStructHead(ctx, b)
   409  			unorderedMap := (ctx.Option.Flag & encoder.UnorderedMapOption) != 0
   410  			mapCtx := encoder.NewMapContext(mlen, unorderedMap)
   411  			mapiterinit(code.Type, uptr, &mapCtx.Iter)
   412  			store(ctxptr, code.Idx, uintptr(unsafe.Pointer(mapCtx)))
   413  			ctx.KeepRefs = append(ctx.KeepRefs, unsafe.Pointer(mapCtx))
   414  			if unorderedMap {
   415  				b = appendMapKeyIndent(ctx, code.Next, b)
   416  			} else {
   417  				mapCtx.Start = len(b)
   418  				mapCtx.First = len(b)
   419  			}
   420  			key := mapiterkey(&mapCtx.Iter)
   421  			store(ctxptr, code.Next.Idx, uintptr(key))
   422  			code = code.Next
   423  		case encoder.OpMapKey:
   424  			mapCtx := (*encoder.MapContext)(ptrToUnsafePtr(load(ctxptr, code.Idx)))
   425  			idx := mapCtx.Idx
   426  			idx++
   427  			if (ctx.Option.Flag & encoder.UnorderedMapOption) != 0 {
   428  				if idx < mapCtx.Len {
   429  					b = appendMapKeyIndent(ctx, code, b)
   430  					mapCtx.Idx = int(idx)
   431  					key := mapiterkey(&mapCtx.Iter)
   432  					store(ctxptr, code.Next.Idx, uintptr(key))
   433  					code = code.Next
   434  				} else {
   435  					b = appendObjectEnd(ctx, code, b)
   436  					encoder.ReleaseMapContext(mapCtx)
   437  					code = code.End.Next
   438  				}
   439  			} else {
   440  				mapCtx.Slice.Items[mapCtx.Idx].Value = b[mapCtx.Start:len(b)]
   441  				if idx < mapCtx.Len {
   442  					mapCtx.Idx = int(idx)
   443  					mapCtx.Start = len(b)
   444  					key := mapiterkey(&mapCtx.Iter)
   445  					store(ctxptr, code.Next.Idx, uintptr(key))
   446  					code = code.Next
   447  				} else {
   448  					code = code.End
   449  				}
   450  			}
   451  		case encoder.OpMapValue:
   452  			mapCtx := (*encoder.MapContext)(ptrToUnsafePtr(load(ctxptr, code.Idx)))
   453  			if (ctx.Option.Flag & encoder.UnorderedMapOption) != 0 {
   454  				b = appendColon(ctx, b)
   455  			} else {
   456  				mapCtx.Slice.Items[mapCtx.Idx].Key = b[mapCtx.Start:len(b)]
   457  				mapCtx.Start = len(b)
   458  			}
   459  			value := mapitervalue(&mapCtx.Iter)
   460  			store(ctxptr, code.Next.Idx, uintptr(value))
   461  			mapiternext(&mapCtx.Iter)
   462  			code = code.Next
   463  		case encoder.OpMapEnd:
   464  			// this operation only used by sorted map.
   465  			mapCtx := (*encoder.MapContext)(ptrToUnsafePtr(load(ctxptr, code.Idx)))
   466  			sort.Sort(mapCtx.Slice)
   467  			buf := mapCtx.Buf
   468  			for _, item := range mapCtx.Slice.Items {
   469  				buf = appendMapKeyValue(ctx, code, buf, item.Key, item.Value)
   470  			}
   471  			buf = appendMapEnd(ctx, code, buf)
   472  			b = b[:mapCtx.First]
   473  			b = append(b, buf...)
   474  			mapCtx.Buf = buf
   475  			encoder.ReleaseMapContext(mapCtx)
   476  			code = code.Next
   477  		case encoder.OpRecursivePtr:
   478  			p := load(ctxptr, code.Idx)
   479  			if p == 0 {
   480  				code = code.Next
   481  				break
   482  			}
   483  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   484  			fallthrough
   485  		case encoder.OpRecursive:
   486  			ptr := load(ctxptr, code.Idx)
   487  			if ptr != 0 {
   488  				if recursiveLevel > encoder.StartDetectingCyclesAfter {
   489  					for _, seen := range ctx.SeenPtr {
   490  						if ptr == seen {
   491  							return nil, errUnsupportedValue(code, ptr)
   492  						}
   493  					}
   494  				}
   495  			}
   496  			ctx.SeenPtr = append(ctx.SeenPtr, ptr)
   497  			c := code.Jmp.Code
   498  			curlen := uintptr(len(ctx.Ptrs))
   499  			offsetNum := ptrOffset / uintptrSize
   500  			oldOffset := ptrOffset
   501  			ptrOffset += code.Jmp.CurLen * uintptrSize
   502  			oldBaseIndent := ctx.BaseIndent
   503  			indentDiffFromTop := c.Indent - 1
   504  			ctx.BaseIndent += code.Indent - indentDiffFromTop
   505  
   506  			newLen := offsetNum + code.Jmp.CurLen + code.Jmp.NextLen
   507  			if curlen < newLen {
   508  				ctx.Ptrs = append(ctx.Ptrs, make([]uintptr, newLen-curlen)...)
   509  			}
   510  			ctxptr = ctx.Ptr() + ptrOffset // assign new ctxptr
   511  
   512  			store(ctxptr, c.Idx, ptr)
   513  			store(ctxptr, c.End.Next.Idx, oldOffset)
   514  			store(ctxptr, c.End.Next.ElemIdx, uintptr(unsafe.Pointer(code.Next)))
   515  			storeIndent(ctxptr, c.End.Next, uintptr(oldBaseIndent))
   516  			code = c
   517  			recursiveLevel++
   518  		case encoder.OpRecursiveEnd:
   519  			recursiveLevel--
   520  
   521  			// restore ctxptr
   522  			restoreIndent(ctx, code, ctxptr)
   523  			offset := load(ctxptr, code.Idx)
   524  			ctx.SeenPtr = ctx.SeenPtr[:len(ctx.SeenPtr)-1]
   525  
   526  			codePtr := load(ctxptr, code.ElemIdx)
   527  			code = (*encoder.Opcode)(ptrToUnsafePtr(codePtr))
   528  			ctxptr = ctx.Ptr() + offset
   529  			ptrOffset = offset
   530  		case encoder.OpStructPtrHead:
   531  			p := load(ctxptr, code.Idx)
   532  			if p == 0 {
   533  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   534  					b = appendNullComma(ctx, b)
   535  				}
   536  				code = code.End.Next
   537  				break
   538  			}
   539  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   540  			fallthrough
   541  		case encoder.OpStructHead:
   542  			p := load(ctxptr, code.Idx)
   543  			if p == 0 && ((code.Flags&encoder.IndirectFlags) != 0 || code.Next.Op == encoder.OpStructEnd) {
   544  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   545  					b = appendNullComma(ctx, b)
   546  				}
   547  				code = code.End.Next
   548  				break
   549  			}
   550  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   551  				b = appendStructHead(ctx, b)
   552  			}
   553  			if len(code.Key) > 0 {
   554  				if (code.Flags&encoder.IsTaggedKeyFlags) != 0 || code.Flags&encoder.AnonymousKeyFlags == 0 {
   555  					b = appendStructKey(ctx, code, b)
   556  				}
   557  			}
   558  			p += uintptr(code.Offset)
   559  			code = code.Next
   560  			store(ctxptr, code.Idx, p)
   561  		case encoder.OpStructPtrHeadOmitEmpty:
   562  			p := load(ctxptr, code.Idx)
   563  			if p == 0 {
   564  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   565  					b = appendNullComma(ctx, b)
   566  				}
   567  				code = code.End.Next
   568  				break
   569  			}
   570  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   571  			fallthrough
   572  		case encoder.OpStructHeadOmitEmpty:
   573  			p := load(ctxptr, code.Idx)
   574  			if p == 0 && ((code.Flags&encoder.IndirectFlags) != 0 || code.Next.Op == encoder.OpStructEnd) {
   575  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   576  					b = appendNullComma(ctx, b)
   577  				}
   578  				code = code.End.Next
   579  				break
   580  			}
   581  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   582  				b = appendStructHead(ctx, b)
   583  			}
   584  			p += uintptr(code.Offset)
   585  			if p == 0 || (ptrToPtr(p) == 0 && (code.Flags&encoder.IsNextOpPtrTypeFlags) != 0) {
   586  				code = code.NextField
   587  			} else {
   588  				b = appendStructKey(ctx, code, b)
   589  				code = code.Next
   590  				store(ctxptr, code.Idx, p)
   591  			}
   592  		case encoder.OpStructPtrHeadInt:
   593  			if (code.Flags & encoder.IndirectFlags) != 0 {
   594  				p := load(ctxptr, code.Idx)
   595  				if p == 0 {
   596  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   597  						b = appendNullComma(ctx, b)
   598  					}
   599  					code = code.End.Next
   600  					break
   601  				}
   602  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   603  			}
   604  			fallthrough
   605  		case encoder.OpStructHeadInt:
   606  			p := load(ctxptr, code.Idx)
   607  			if p == 0 {
   608  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   609  					b = appendNullComma(ctx, b)
   610  				}
   611  				code = code.End.Next
   612  				break
   613  			}
   614  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   615  				b = appendStructHead(ctx, b)
   616  			}
   617  			b = appendStructKey(ctx, code, b)
   618  			b = appendInt(ctx, b, p+uintptr(code.Offset), code)
   619  			b = appendComma(ctx, b)
   620  			code = code.Next
   621  		case encoder.OpStructPtrHeadOmitEmptyInt:
   622  			if (code.Flags & encoder.IndirectFlags) != 0 {
   623  				p := load(ctxptr, code.Idx)
   624  				if p == 0 {
   625  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   626  						b = appendNullComma(ctx, b)
   627  					}
   628  					code = code.End.Next
   629  					break
   630  				}
   631  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   632  			}
   633  			fallthrough
   634  		case encoder.OpStructHeadOmitEmptyInt:
   635  			p := load(ctxptr, code.Idx)
   636  			if p == 0 {
   637  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   638  					b = appendNullComma(ctx, b)
   639  				}
   640  				code = code.End.Next
   641  				break
   642  			}
   643  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   644  				b = appendStructHead(ctx, b)
   645  			}
   646  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
   647  			v := u64 & ((1 << code.NumBitSize) - 1)
   648  			if v == 0 {
   649  				code = code.NextField
   650  			} else {
   651  				b = appendStructKey(ctx, code, b)
   652  				b = appendInt(ctx, b, p+uintptr(code.Offset), code)
   653  				b = appendComma(ctx, b)
   654  				code = code.Next
   655  			}
   656  		case encoder.OpStructPtrHeadIntString:
   657  			if (code.Flags & encoder.IndirectFlags) != 0 {
   658  				p := load(ctxptr, code.Idx)
   659  				if p == 0 {
   660  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   661  						b = appendNullComma(ctx, b)
   662  					}
   663  					code = code.End.Next
   664  					break
   665  				}
   666  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   667  			}
   668  			fallthrough
   669  		case encoder.OpStructHeadIntString:
   670  			p := load(ctxptr, code.Idx)
   671  			if p == 0 {
   672  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   673  					b = appendNullComma(ctx, b)
   674  				}
   675  				code = code.End.Next
   676  				break
   677  			}
   678  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   679  				b = appendStructHead(ctx, b)
   680  			}
   681  			b = appendStructKey(ctx, code, b)
   682  			b = append(b, '"')
   683  			b = appendInt(ctx, b, p+uintptr(code.Offset), code)
   684  			b = append(b, '"')
   685  			b = appendComma(ctx, b)
   686  			code = code.Next
   687  		case encoder.OpStructPtrHeadOmitEmptyIntString:
   688  			if (code.Flags & encoder.IndirectFlags) != 0 {
   689  				p := load(ctxptr, code.Idx)
   690  				if p == 0 {
   691  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   692  						b = appendNullComma(ctx, b)
   693  					}
   694  					code = code.End.Next
   695  					break
   696  				}
   697  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   698  			}
   699  			fallthrough
   700  		case encoder.OpStructHeadOmitEmptyIntString:
   701  			p := load(ctxptr, code.Idx)
   702  			if p == 0 {
   703  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   704  					b = appendNullComma(ctx, b)
   705  				}
   706  				code = code.End.Next
   707  				break
   708  			}
   709  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   710  				b = appendStructHead(ctx, b)
   711  			}
   712  			p += uintptr(code.Offset)
   713  			u64 := ptrToUint64(p, code.NumBitSize)
   714  			v := u64 & ((1 << code.NumBitSize) - 1)
   715  			if v == 0 {
   716  				code = code.NextField
   717  			} else {
   718  				b = appendStructKey(ctx, code, b)
   719  				b = append(b, '"')
   720  				b = appendInt(ctx, b, p, code)
   721  				b = append(b, '"')
   722  				b = appendComma(ctx, b)
   723  				code = code.Next
   724  			}
   725  		case encoder.OpStructPtrHeadIntPtr:
   726  			p := load(ctxptr, code.Idx)
   727  			if p == 0 {
   728  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   729  					b = appendNullComma(ctx, b)
   730  				}
   731  				code = code.End.Next
   732  				break
   733  			}
   734  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   735  			fallthrough
   736  		case encoder.OpStructHeadIntPtr:
   737  			p := load(ctxptr, code.Idx)
   738  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
   739  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   740  					b = appendNullComma(ctx, b)
   741  				}
   742  				code = code.End.Next
   743  				break
   744  			}
   745  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   746  				b = appendStructHead(ctx, b)
   747  			}
   748  			b = appendStructKey(ctx, code, b)
   749  			if (code.Flags & encoder.IndirectFlags) != 0 {
   750  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
   751  			}
   752  			if p == 0 {
   753  				b = appendNull(ctx, b)
   754  			} else {
   755  				b = appendInt(ctx, b, p, code)
   756  			}
   757  			b = appendComma(ctx, b)
   758  			code = code.Next
   759  		case encoder.OpStructPtrHeadOmitEmptyIntPtr:
   760  			p := load(ctxptr, code.Idx)
   761  			if p == 0 {
   762  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   763  					b = appendNullComma(ctx, b)
   764  				}
   765  				code = code.End.Next
   766  				break
   767  			}
   768  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   769  			fallthrough
   770  		case encoder.OpStructHeadOmitEmptyIntPtr:
   771  			p := load(ctxptr, code.Idx)
   772  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
   773  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   774  					b = appendNullComma(ctx, b)
   775  				}
   776  				code = code.End.Next
   777  				break
   778  			}
   779  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   780  				b = appendStructHead(ctx, b)
   781  			}
   782  			if (code.Flags & encoder.IndirectFlags) != 0 {
   783  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
   784  			}
   785  			if p != 0 {
   786  				b = appendStructKey(ctx, code, b)
   787  				b = appendInt(ctx, b, p, code)
   788  				b = appendComma(ctx, b)
   789  			}
   790  			code = code.Next
   791  		case encoder.OpStructPtrHeadIntPtrString:
   792  			p := load(ctxptr, code.Idx)
   793  			if p == 0 {
   794  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   795  					b = appendNullComma(ctx, b)
   796  				}
   797  				code = code.End.Next
   798  				break
   799  			}
   800  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   801  			fallthrough
   802  		case encoder.OpStructHeadIntPtrString:
   803  			p := load(ctxptr, code.Idx)
   804  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
   805  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   806  					b = appendNullComma(ctx, b)
   807  				}
   808  				code = code.End.Next
   809  				break
   810  			}
   811  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   812  				b = appendStructHead(ctx, b)
   813  			}
   814  			b = appendStructKey(ctx, code, b)
   815  			if (code.Flags & encoder.IndirectFlags) != 0 {
   816  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
   817  			}
   818  			if p == 0 {
   819  				b = appendNull(ctx, b)
   820  			} else {
   821  				b = append(b, '"')
   822  				b = appendInt(ctx, b, p, code)
   823  				b = append(b, '"')
   824  			}
   825  			b = appendComma(ctx, b)
   826  			code = code.Next
   827  		case encoder.OpStructPtrHeadOmitEmptyIntPtrString:
   828  			p := load(ctxptr, code.Idx)
   829  			if p == 0 {
   830  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   831  					b = appendNullComma(ctx, b)
   832  				}
   833  				code = code.End.Next
   834  				break
   835  			}
   836  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   837  			fallthrough
   838  		case encoder.OpStructHeadOmitEmptyIntPtrString:
   839  			p := load(ctxptr, code.Idx)
   840  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
   841  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   842  					b = appendNullComma(ctx, b)
   843  				}
   844  				code = code.End.Next
   845  				break
   846  			}
   847  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   848  				b = appendStructHead(ctx, b)
   849  			}
   850  			if (code.Flags & encoder.IndirectFlags) != 0 {
   851  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
   852  			}
   853  			if p != 0 {
   854  				b = appendStructKey(ctx, code, b)
   855  				b = append(b, '"')
   856  				b = appendInt(ctx, b, p, code)
   857  				b = append(b, '"')
   858  				b = appendComma(ctx, b)
   859  			}
   860  			code = code.Next
   861  		case encoder.OpStructPtrHeadUint:
   862  			if (code.Flags & encoder.IndirectFlags) != 0 {
   863  				p := load(ctxptr, code.Idx)
   864  				if p == 0 {
   865  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   866  						b = appendNullComma(ctx, b)
   867  					}
   868  					code = code.End.Next
   869  					break
   870  				}
   871  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   872  			}
   873  			fallthrough
   874  		case encoder.OpStructHeadUint:
   875  			p := load(ctxptr, code.Idx)
   876  			if p == 0 {
   877  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   878  					b = appendNullComma(ctx, b)
   879  				}
   880  				code = code.End.Next
   881  				break
   882  			}
   883  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   884  				b = appendStructHead(ctx, b)
   885  			}
   886  			b = appendStructKey(ctx, code, b)
   887  			b = appendUint(ctx, b, p+uintptr(code.Offset), code)
   888  			b = appendComma(ctx, b)
   889  			code = code.Next
   890  		case encoder.OpStructPtrHeadOmitEmptyUint:
   891  			if (code.Flags & encoder.IndirectFlags) != 0 {
   892  				p := load(ctxptr, code.Idx)
   893  				if p == 0 {
   894  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   895  						b = appendNullComma(ctx, b)
   896  					}
   897  					code = code.End.Next
   898  					break
   899  				}
   900  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   901  			}
   902  			fallthrough
   903  		case encoder.OpStructHeadOmitEmptyUint:
   904  			p := load(ctxptr, code.Idx)
   905  			if p == 0 {
   906  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   907  					b = appendNullComma(ctx, b)
   908  				}
   909  				code = code.End.Next
   910  				break
   911  			}
   912  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   913  				b = appendStructHead(ctx, b)
   914  			}
   915  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
   916  			v := u64 & ((1 << code.NumBitSize) - 1)
   917  			if v == 0 {
   918  				code = code.NextField
   919  			} else {
   920  				b = appendStructKey(ctx, code, b)
   921  				b = appendUint(ctx, b, p+uintptr(code.Offset), code)
   922  				b = appendComma(ctx, b)
   923  				code = code.Next
   924  			}
   925  		case encoder.OpStructPtrHeadUintString:
   926  			if (code.Flags & encoder.IndirectFlags) != 0 {
   927  				p := load(ctxptr, code.Idx)
   928  				if p == 0 {
   929  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   930  						b = appendNullComma(ctx, b)
   931  					}
   932  					code = code.End.Next
   933  					break
   934  				}
   935  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   936  			}
   937  			fallthrough
   938  		case encoder.OpStructHeadUintString:
   939  			p := load(ctxptr, code.Idx)
   940  			if p == 0 {
   941  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   942  					b = appendNullComma(ctx, b)
   943  				}
   944  				code = code.End.Next
   945  				break
   946  			}
   947  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   948  				b = appendStructHead(ctx, b)
   949  			}
   950  			b = appendStructKey(ctx, code, b)
   951  			b = append(b, '"')
   952  			b = appendUint(ctx, b, p+uintptr(code.Offset), code)
   953  			b = append(b, '"')
   954  			b = appendComma(ctx, b)
   955  			code = code.Next
   956  		case encoder.OpStructPtrHeadOmitEmptyUintString:
   957  			if (code.Flags & encoder.IndirectFlags) != 0 {
   958  				p := load(ctxptr, code.Idx)
   959  				if p == 0 {
   960  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
   961  						b = appendNullComma(ctx, b)
   962  					}
   963  					code = code.End.Next
   964  					break
   965  				}
   966  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
   967  			}
   968  			fallthrough
   969  		case encoder.OpStructHeadOmitEmptyUintString:
   970  			p := load(ctxptr, code.Idx)
   971  			if p == 0 {
   972  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   973  					b = appendNullComma(ctx, b)
   974  				}
   975  				code = code.End.Next
   976  				break
   977  			}
   978  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
   979  				b = appendStructHead(ctx, b)
   980  			}
   981  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
   982  			v := u64 & ((1 << code.NumBitSize) - 1)
   983  			if v == 0 {
   984  				code = code.NextField
   985  			} else {
   986  				b = appendStructKey(ctx, code, b)
   987  				b = append(b, '"')
   988  				b = appendUint(ctx, b, p+uintptr(code.Offset), code)
   989  				b = append(b, '"')
   990  				b = appendComma(ctx, b)
   991  				code = code.Next
   992  			}
   993  		case encoder.OpStructPtrHeadUintPtr:
   994  			p := load(ctxptr, code.Idx)
   995  			if p == 0 {
   996  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
   997  					b = appendNullComma(ctx, b)
   998  				}
   999  				code = code.End.Next
  1000  				break
  1001  			}
  1002  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1003  			fallthrough
  1004  		case encoder.OpStructHeadUintPtr:
  1005  			p := load(ctxptr, code.Idx)
  1006  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1007  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1008  					b = appendNullComma(ctx, b)
  1009  				}
  1010  				code = code.End.Next
  1011  				break
  1012  			}
  1013  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1014  				b = appendStructHead(ctx, b)
  1015  			}
  1016  			b = appendStructKey(ctx, code, b)
  1017  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1018  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1019  			}
  1020  			if p == 0 {
  1021  				b = appendNull(ctx, b)
  1022  			} else {
  1023  				b = appendUint(ctx, b, p, code)
  1024  			}
  1025  			b = appendComma(ctx, b)
  1026  			code = code.Next
  1027  		case encoder.OpStructPtrHeadOmitEmptyUintPtr:
  1028  			p := load(ctxptr, code.Idx)
  1029  			if p == 0 {
  1030  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1031  					b = appendNullComma(ctx, b)
  1032  				}
  1033  				code = code.End.Next
  1034  				break
  1035  			}
  1036  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1037  			fallthrough
  1038  		case encoder.OpStructHeadOmitEmptyUintPtr:
  1039  			p := load(ctxptr, code.Idx)
  1040  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1041  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1042  					b = appendNullComma(ctx, b)
  1043  				}
  1044  				code = code.End.Next
  1045  				break
  1046  			}
  1047  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1048  				b = appendStructHead(ctx, b)
  1049  			}
  1050  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1051  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1052  			}
  1053  			if p != 0 {
  1054  				b = appendStructKey(ctx, code, b)
  1055  				b = appendUint(ctx, b, p, code)
  1056  				b = appendComma(ctx, b)
  1057  			}
  1058  			code = code.Next
  1059  		case encoder.OpStructPtrHeadUintPtrString:
  1060  			p := load(ctxptr, code.Idx)
  1061  			if p == 0 {
  1062  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1063  					b = appendNullComma(ctx, b)
  1064  				}
  1065  				code = code.End.Next
  1066  				break
  1067  			}
  1068  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1069  			fallthrough
  1070  		case encoder.OpStructHeadUintPtrString:
  1071  			p := load(ctxptr, code.Idx)
  1072  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1073  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1074  					b = appendNullComma(ctx, b)
  1075  				}
  1076  				code = code.End.Next
  1077  				break
  1078  			}
  1079  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1080  				b = appendStructHead(ctx, b)
  1081  			}
  1082  			b = appendStructKey(ctx, code, b)
  1083  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1084  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1085  			}
  1086  			if p == 0 {
  1087  				b = appendNull(ctx, b)
  1088  			} else {
  1089  				b = append(b, '"')
  1090  				b = appendUint(ctx, b, p, code)
  1091  				b = append(b, '"')
  1092  			}
  1093  			b = appendComma(ctx, b)
  1094  			code = code.Next
  1095  		case encoder.OpStructPtrHeadOmitEmptyUintPtrString:
  1096  			p := load(ctxptr, code.Idx)
  1097  			if p == 0 {
  1098  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1099  					b = appendNullComma(ctx, b)
  1100  				}
  1101  				code = code.End.Next
  1102  				break
  1103  			}
  1104  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1105  			fallthrough
  1106  		case encoder.OpStructHeadOmitEmptyUintPtrString:
  1107  			p := load(ctxptr, code.Idx)
  1108  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1109  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1110  					b = appendNullComma(ctx, b)
  1111  				}
  1112  				code = code.End.Next
  1113  				break
  1114  			}
  1115  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1116  				b = appendStructHead(ctx, b)
  1117  			}
  1118  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1119  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1120  			}
  1121  			if p != 0 {
  1122  				b = appendStructKey(ctx, code, b)
  1123  				b = append(b, '"')
  1124  				b = appendUint(ctx, b, p, code)
  1125  				b = append(b, '"')
  1126  				b = appendComma(ctx, b)
  1127  			}
  1128  			code = code.Next
  1129  		case encoder.OpStructPtrHeadFloat32:
  1130  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1131  				p := load(ctxptr, code.Idx)
  1132  				if p == 0 {
  1133  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1134  						b = appendNullComma(ctx, b)
  1135  					}
  1136  					code = code.End.Next
  1137  					break
  1138  				}
  1139  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1140  			}
  1141  			fallthrough
  1142  		case encoder.OpStructHeadFloat32:
  1143  			p := load(ctxptr, code.Idx)
  1144  			if p == 0 {
  1145  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1146  					b = appendNullComma(ctx, b)
  1147  				}
  1148  				code = code.End.Next
  1149  				break
  1150  			}
  1151  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1152  				b = appendStructHead(ctx, b)
  1153  			}
  1154  			b = appendStructKey(ctx, code, b)
  1155  			b = appendFloat32(ctx, b, ptrToFloat32(p+uintptr(code.Offset)))
  1156  			b = appendComma(ctx, b)
  1157  			code = code.Next
  1158  		case encoder.OpStructPtrHeadOmitEmptyFloat32:
  1159  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1160  				p := load(ctxptr, code.Idx)
  1161  				if p == 0 {
  1162  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1163  						b = appendNullComma(ctx, b)
  1164  					}
  1165  					code = code.End.Next
  1166  					break
  1167  				}
  1168  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1169  			}
  1170  			fallthrough
  1171  		case encoder.OpStructHeadOmitEmptyFloat32:
  1172  			p := load(ctxptr, code.Idx)
  1173  			if p == 0 {
  1174  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1175  					b = appendNullComma(ctx, b)
  1176  				}
  1177  				code = code.End.Next
  1178  				break
  1179  			}
  1180  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1181  				b = appendStructHead(ctx, b)
  1182  			}
  1183  			v := ptrToFloat32(p + uintptr(code.Offset))
  1184  			if v == 0 {
  1185  				code = code.NextField
  1186  			} else {
  1187  				b = appendStructKey(ctx, code, b)
  1188  				b = appendFloat32(ctx, b, v)
  1189  				b = appendComma(ctx, b)
  1190  				code = code.Next
  1191  			}
  1192  		case encoder.OpStructPtrHeadFloat32String:
  1193  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1194  				p := load(ctxptr, code.Idx)
  1195  				if p == 0 {
  1196  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1197  						b = appendNullComma(ctx, b)
  1198  					}
  1199  					code = code.End.Next
  1200  					break
  1201  				}
  1202  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1203  			}
  1204  			fallthrough
  1205  		case encoder.OpStructHeadFloat32String:
  1206  			p := load(ctxptr, code.Idx)
  1207  			if p == 0 {
  1208  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1209  					b = appendNullComma(ctx, b)
  1210  				}
  1211  				code = code.End.Next
  1212  				break
  1213  			}
  1214  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1215  				b = appendStructHead(ctx, b)
  1216  			}
  1217  			b = appendStructKey(ctx, code, b)
  1218  			b = append(b, '"')
  1219  			b = appendFloat32(ctx, b, ptrToFloat32(p+uintptr(code.Offset)))
  1220  			b = append(b, '"')
  1221  			b = appendComma(ctx, b)
  1222  			code = code.Next
  1223  		case encoder.OpStructPtrHeadOmitEmptyFloat32String:
  1224  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1225  				p := load(ctxptr, code.Idx)
  1226  				if p == 0 {
  1227  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1228  						b = appendNullComma(ctx, b)
  1229  					}
  1230  					code = code.End.Next
  1231  					break
  1232  				}
  1233  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1234  			}
  1235  			fallthrough
  1236  		case encoder.OpStructHeadOmitEmptyFloat32String:
  1237  			p := load(ctxptr, code.Idx)
  1238  			if p == 0 {
  1239  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1240  					b = appendNullComma(ctx, b)
  1241  				}
  1242  				code = code.End.Next
  1243  				break
  1244  			}
  1245  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1246  				b = appendStructHead(ctx, b)
  1247  			}
  1248  			v := ptrToFloat32(p + uintptr(code.Offset))
  1249  			if v == 0 {
  1250  				code = code.NextField
  1251  			} else {
  1252  				b = appendStructKey(ctx, code, b)
  1253  				b = append(b, '"')
  1254  				b = appendFloat32(ctx, b, v)
  1255  				b = append(b, '"')
  1256  				b = appendComma(ctx, b)
  1257  				code = code.Next
  1258  			}
  1259  		case encoder.OpStructPtrHeadFloat32Ptr:
  1260  			p := load(ctxptr, code.Idx)
  1261  			if p == 0 {
  1262  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1263  					b = appendNullComma(ctx, b)
  1264  				}
  1265  				code = code.End.Next
  1266  				break
  1267  			}
  1268  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1269  			fallthrough
  1270  		case encoder.OpStructHeadFloat32Ptr:
  1271  			p := load(ctxptr, code.Idx)
  1272  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1273  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1274  					b = appendNullComma(ctx, b)
  1275  				}
  1276  				code = code.End.Next
  1277  				break
  1278  			}
  1279  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1280  				b = appendStructHead(ctx, b)
  1281  			}
  1282  			b = appendStructKey(ctx, code, b)
  1283  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1284  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1285  			}
  1286  			if p == 0 {
  1287  				b = appendNull(ctx, b)
  1288  			} else {
  1289  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  1290  			}
  1291  			b = appendComma(ctx, b)
  1292  			code = code.Next
  1293  		case encoder.OpStructPtrHeadOmitEmptyFloat32Ptr:
  1294  			p := load(ctxptr, code.Idx)
  1295  			if p == 0 {
  1296  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1297  					b = appendNullComma(ctx, b)
  1298  				}
  1299  				code = code.End.Next
  1300  				break
  1301  			}
  1302  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1303  			fallthrough
  1304  		case encoder.OpStructHeadOmitEmptyFloat32Ptr:
  1305  			p := load(ctxptr, code.Idx)
  1306  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1307  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1308  					b = appendNullComma(ctx, b)
  1309  				}
  1310  				code = code.End.Next
  1311  				break
  1312  			}
  1313  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1314  				b = appendStructHead(ctx, b)
  1315  			}
  1316  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1317  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1318  			}
  1319  			if p != 0 {
  1320  				b = appendStructKey(ctx, code, b)
  1321  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  1322  				b = appendComma(ctx, b)
  1323  			}
  1324  			code = code.Next
  1325  		case encoder.OpStructPtrHeadFloat32PtrString:
  1326  			p := load(ctxptr, code.Idx)
  1327  			if p == 0 {
  1328  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1329  					b = appendNullComma(ctx, b)
  1330  				}
  1331  				code = code.End.Next
  1332  				break
  1333  			}
  1334  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1335  			fallthrough
  1336  		case encoder.OpStructHeadFloat32PtrString:
  1337  			p := load(ctxptr, code.Idx)
  1338  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1339  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1340  					b = appendNullComma(ctx, b)
  1341  				}
  1342  				code = code.End.Next
  1343  				break
  1344  			}
  1345  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1346  				b = appendStructHead(ctx, b)
  1347  			}
  1348  			b = appendStructKey(ctx, code, b)
  1349  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1350  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1351  			}
  1352  			if p == 0 {
  1353  				b = appendNull(ctx, b)
  1354  			} else {
  1355  				b = append(b, '"')
  1356  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  1357  				b = append(b, '"')
  1358  			}
  1359  			b = appendComma(ctx, b)
  1360  			code = code.Next
  1361  		case encoder.OpStructPtrHeadOmitEmptyFloat32PtrString:
  1362  			p := load(ctxptr, code.Idx)
  1363  			if p == 0 {
  1364  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1365  					b = appendNullComma(ctx, b)
  1366  				}
  1367  				code = code.End.Next
  1368  				break
  1369  			}
  1370  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1371  			fallthrough
  1372  		case encoder.OpStructHeadOmitEmptyFloat32PtrString:
  1373  			p := load(ctxptr, code.Idx)
  1374  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1375  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1376  					b = appendNullComma(ctx, b)
  1377  				}
  1378  				code = code.End.Next
  1379  				break
  1380  			}
  1381  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1382  				b = appendStructHead(ctx, b)
  1383  			}
  1384  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1385  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1386  			}
  1387  			if p != 0 {
  1388  				b = appendStructKey(ctx, code, b)
  1389  				b = append(b, '"')
  1390  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  1391  				b = append(b, '"')
  1392  				b = appendComma(ctx, b)
  1393  			}
  1394  			code = code.Next
  1395  		case encoder.OpStructPtrHeadFloat64:
  1396  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1397  				p := load(ctxptr, code.Idx)
  1398  				if p == 0 {
  1399  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1400  						b = appendNullComma(ctx, b)
  1401  					}
  1402  					code = code.End.Next
  1403  					break
  1404  				}
  1405  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1406  			}
  1407  			fallthrough
  1408  		case encoder.OpStructHeadFloat64:
  1409  			p := load(ctxptr, code.Idx)
  1410  			if p == 0 {
  1411  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1412  					b = appendNullComma(ctx, b)
  1413  				}
  1414  				code = code.End.Next
  1415  				break
  1416  			}
  1417  			v := ptrToFloat64(p + uintptr(code.Offset))
  1418  			if math.IsInf(v, 0) || math.IsNaN(v) {
  1419  				return nil, errUnsupportedFloat(v)
  1420  			}
  1421  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1422  				b = appendStructHead(ctx, b)
  1423  			}
  1424  			b = appendStructKey(ctx, code, b)
  1425  			b = appendFloat64(ctx, b, v)
  1426  			b = appendComma(ctx, b)
  1427  			code = code.Next
  1428  		case encoder.OpStructPtrHeadOmitEmptyFloat64:
  1429  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1430  				p := load(ctxptr, code.Idx)
  1431  				if p == 0 {
  1432  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1433  						b = appendNullComma(ctx, b)
  1434  					}
  1435  					code = code.End.Next
  1436  					break
  1437  				}
  1438  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1439  			}
  1440  			fallthrough
  1441  		case encoder.OpStructHeadOmitEmptyFloat64:
  1442  			p := load(ctxptr, code.Idx)
  1443  			if p == 0 {
  1444  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1445  					b = appendNullComma(ctx, b)
  1446  				}
  1447  				code = code.End.Next
  1448  				break
  1449  			}
  1450  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1451  				b = appendStructHead(ctx, b)
  1452  			}
  1453  			v := ptrToFloat64(p + uintptr(code.Offset))
  1454  			if v == 0 {
  1455  				code = code.NextField
  1456  			} else {
  1457  				if math.IsInf(v, 0) || math.IsNaN(v) {
  1458  					return nil, errUnsupportedFloat(v)
  1459  				}
  1460  				b = appendStructKey(ctx, code, b)
  1461  				b = appendFloat64(ctx, b, v)
  1462  				b = appendComma(ctx, b)
  1463  				code = code.Next
  1464  			}
  1465  		case encoder.OpStructPtrHeadFloat64String:
  1466  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1467  				p := load(ctxptr, code.Idx)
  1468  				if p == 0 {
  1469  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1470  						b = appendNullComma(ctx, b)
  1471  					}
  1472  					code = code.End.Next
  1473  					break
  1474  				}
  1475  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1476  			}
  1477  			fallthrough
  1478  		case encoder.OpStructHeadFloat64String:
  1479  			p := load(ctxptr, code.Idx)
  1480  			if p == 0 {
  1481  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1482  					b = appendNullComma(ctx, b)
  1483  				}
  1484  				code = code.End.Next
  1485  				break
  1486  			}
  1487  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1488  				b = appendStructHead(ctx, b)
  1489  			}
  1490  			v := ptrToFloat64(p + uintptr(code.Offset))
  1491  			if math.IsInf(v, 0) || math.IsNaN(v) {
  1492  				return nil, errUnsupportedFloat(v)
  1493  			}
  1494  			b = appendStructKey(ctx, code, b)
  1495  			b = append(b, '"')
  1496  			b = appendFloat64(ctx, b, v)
  1497  			b = append(b, '"')
  1498  			b = appendComma(ctx, b)
  1499  			code = code.Next
  1500  		case encoder.OpStructPtrHeadOmitEmptyFloat64String:
  1501  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1502  				p := load(ctxptr, code.Idx)
  1503  				if p == 0 {
  1504  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1505  						b = appendNullComma(ctx, b)
  1506  					}
  1507  					code = code.End.Next
  1508  					break
  1509  				}
  1510  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1511  			}
  1512  			fallthrough
  1513  		case encoder.OpStructHeadOmitEmptyFloat64String:
  1514  			p := load(ctxptr, code.Idx)
  1515  			if p == 0 {
  1516  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1517  					b = appendNullComma(ctx, b)
  1518  				}
  1519  				code = code.End.Next
  1520  				break
  1521  			}
  1522  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1523  				b = appendStructHead(ctx, b)
  1524  			}
  1525  			v := ptrToFloat64(p + uintptr(code.Offset))
  1526  			if v == 0 {
  1527  				code = code.NextField
  1528  			} else {
  1529  				if math.IsInf(v, 0) || math.IsNaN(v) {
  1530  					return nil, errUnsupportedFloat(v)
  1531  				}
  1532  				b = appendStructKey(ctx, code, b)
  1533  				b = append(b, '"')
  1534  				b = appendFloat64(ctx, b, v)
  1535  				b = append(b, '"')
  1536  				b = appendComma(ctx, b)
  1537  				code = code.Next
  1538  			}
  1539  		case encoder.OpStructPtrHeadFloat64Ptr:
  1540  			p := load(ctxptr, code.Idx)
  1541  			if p == 0 {
  1542  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1543  					b = appendNullComma(ctx, b)
  1544  				}
  1545  				code = code.End.Next
  1546  				break
  1547  			}
  1548  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1549  			fallthrough
  1550  		case encoder.OpStructHeadFloat64Ptr:
  1551  			p := load(ctxptr, code.Idx)
  1552  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1553  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1554  					b = appendNullComma(ctx, b)
  1555  				}
  1556  				code = code.End.Next
  1557  				break
  1558  			}
  1559  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1560  				b = appendStructHead(ctx, b)
  1561  			}
  1562  			b = appendStructKey(ctx, code, b)
  1563  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1564  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1565  			}
  1566  			if p == 0 {
  1567  				b = appendNull(ctx, b)
  1568  			} else {
  1569  				v := ptrToFloat64(p)
  1570  				if math.IsInf(v, 0) || math.IsNaN(v) {
  1571  					return nil, errUnsupportedFloat(v)
  1572  				}
  1573  				b = appendFloat64(ctx, b, v)
  1574  			}
  1575  			b = appendComma(ctx, b)
  1576  			code = code.Next
  1577  		case encoder.OpStructPtrHeadOmitEmptyFloat64Ptr:
  1578  			p := load(ctxptr, code.Idx)
  1579  			if p == 0 {
  1580  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1581  					b = appendNullComma(ctx, b)
  1582  				}
  1583  				code = code.End.Next
  1584  				break
  1585  			}
  1586  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1587  			fallthrough
  1588  		case encoder.OpStructHeadOmitEmptyFloat64Ptr:
  1589  			p := load(ctxptr, code.Idx)
  1590  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1591  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1592  					b = appendNullComma(ctx, b)
  1593  				}
  1594  				code = code.End.Next
  1595  				break
  1596  			}
  1597  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1598  				b = appendStructHead(ctx, b)
  1599  			}
  1600  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1601  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1602  			}
  1603  			if p != 0 {
  1604  				b = appendStructKey(ctx, code, b)
  1605  				v := ptrToFloat64(p)
  1606  				if math.IsInf(v, 0) || math.IsNaN(v) {
  1607  					return nil, errUnsupportedFloat(v)
  1608  				}
  1609  				b = appendFloat64(ctx, b, v)
  1610  				b = appendComma(ctx, b)
  1611  			}
  1612  			code = code.Next
  1613  		case encoder.OpStructPtrHeadFloat64PtrString:
  1614  			p := load(ctxptr, code.Idx)
  1615  			if p == 0 {
  1616  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1617  					b = appendNullComma(ctx, b)
  1618  				}
  1619  				code = code.End.Next
  1620  				break
  1621  			}
  1622  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1623  			fallthrough
  1624  		case encoder.OpStructHeadFloat64PtrString:
  1625  			p := load(ctxptr, code.Idx)
  1626  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1627  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1628  					b = appendNullComma(ctx, b)
  1629  				}
  1630  				code = code.End.Next
  1631  				break
  1632  			}
  1633  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1634  				b = appendStructHead(ctx, b)
  1635  			}
  1636  			b = appendStructKey(ctx, code, b)
  1637  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1638  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1639  			}
  1640  			if p == 0 {
  1641  				b = appendNull(ctx, b)
  1642  			} else {
  1643  				b = append(b, '"')
  1644  				v := ptrToFloat64(p)
  1645  				if math.IsInf(v, 0) || math.IsNaN(v) {
  1646  					return nil, errUnsupportedFloat(v)
  1647  				}
  1648  				b = appendFloat64(ctx, b, v)
  1649  				b = append(b, '"')
  1650  			}
  1651  			b = appendComma(ctx, b)
  1652  			code = code.Next
  1653  		case encoder.OpStructPtrHeadOmitEmptyFloat64PtrString:
  1654  			p := load(ctxptr, code.Idx)
  1655  			if p == 0 {
  1656  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1657  					b = appendNullComma(ctx, b)
  1658  				}
  1659  				code = code.End.Next
  1660  				break
  1661  			}
  1662  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1663  			fallthrough
  1664  		case encoder.OpStructHeadOmitEmptyFloat64PtrString:
  1665  			p := load(ctxptr, code.Idx)
  1666  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1667  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1668  					b = appendNullComma(ctx, b)
  1669  				}
  1670  				code = code.End.Next
  1671  				break
  1672  			}
  1673  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1674  				b = appendStructHead(ctx, b)
  1675  			}
  1676  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1677  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1678  			}
  1679  			if p != 0 {
  1680  				b = appendStructKey(ctx, code, b)
  1681  				b = append(b, '"')
  1682  				v := ptrToFloat64(p)
  1683  				if math.IsInf(v, 0) || math.IsNaN(v) {
  1684  					return nil, errUnsupportedFloat(v)
  1685  				}
  1686  				b = appendFloat64(ctx, b, v)
  1687  				b = append(b, '"')
  1688  				b = appendComma(ctx, b)
  1689  			}
  1690  			code = code.Next
  1691  		case encoder.OpStructPtrHeadString:
  1692  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1693  				p := load(ctxptr, code.Idx)
  1694  				if p == 0 {
  1695  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1696  						b = appendNullComma(ctx, b)
  1697  					}
  1698  					code = code.End.Next
  1699  					break
  1700  				}
  1701  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1702  			}
  1703  			fallthrough
  1704  		case encoder.OpStructHeadString:
  1705  			p := load(ctxptr, code.Idx)
  1706  			if p == 0 {
  1707  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1708  					b = appendNull(ctx, b)
  1709  					b = appendComma(ctx, b)
  1710  				}
  1711  				code = code.End.Next
  1712  				break
  1713  			}
  1714  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1715  				b = appendStructHead(ctx, b)
  1716  			}
  1717  			b = appendStructKey(ctx, code, b)
  1718  			b = appendString(ctx, b, ptrToString(p+uintptr(code.Offset)))
  1719  			b = appendComma(ctx, b)
  1720  			code = code.Next
  1721  		case encoder.OpStructPtrHeadOmitEmptyString:
  1722  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1723  				p := load(ctxptr, code.Idx)
  1724  				if p == 0 {
  1725  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1726  						b = appendNullComma(ctx, b)
  1727  					}
  1728  					code = code.End.Next
  1729  					break
  1730  				}
  1731  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1732  			}
  1733  			fallthrough
  1734  		case encoder.OpStructHeadOmitEmptyString:
  1735  			p := load(ctxptr, code.Idx)
  1736  			if p == 0 {
  1737  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1738  					b = appendNullComma(ctx, b)
  1739  				}
  1740  				code = code.End.Next
  1741  				break
  1742  			}
  1743  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1744  				b = appendStructHead(ctx, b)
  1745  			}
  1746  			v := ptrToString(p + uintptr(code.Offset))
  1747  			if v == "" {
  1748  				code = code.NextField
  1749  			} else {
  1750  				b = appendStructKey(ctx, code, b)
  1751  				b = appendString(ctx, b, v)
  1752  				b = appendComma(ctx, b)
  1753  				code = code.Next
  1754  			}
  1755  		case encoder.OpStructPtrHeadStringString:
  1756  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1757  				p := load(ctxptr, code.Idx)
  1758  				if p == 0 {
  1759  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1760  						b = appendNullComma(ctx, b)
  1761  					}
  1762  					code = code.End.Next
  1763  					break
  1764  				}
  1765  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1766  			}
  1767  			fallthrough
  1768  		case encoder.OpStructHeadStringString:
  1769  			p := load(ctxptr, code.Idx)
  1770  			if p == 0 {
  1771  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1772  					b = appendNullComma(ctx, b)
  1773  				}
  1774  				code = code.End.Next
  1775  				break
  1776  			}
  1777  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1778  				b = appendStructHead(ctx, b)
  1779  			}
  1780  			b = appendStructKey(ctx, code, b)
  1781  			b = appendString(ctx, b, string(appendString(ctx, []byte{}, ptrToString(p+uintptr(code.Offset)))))
  1782  			b = appendComma(ctx, b)
  1783  			code = code.Next
  1784  		case encoder.OpStructPtrHeadOmitEmptyStringString:
  1785  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1786  				p := load(ctxptr, code.Idx)
  1787  				if p == 0 {
  1788  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1789  						b = appendNullComma(ctx, b)
  1790  					}
  1791  					code = code.End.Next
  1792  					break
  1793  				}
  1794  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1795  			}
  1796  			fallthrough
  1797  		case encoder.OpStructHeadOmitEmptyStringString:
  1798  			p := load(ctxptr, code.Idx)
  1799  			if p == 0 {
  1800  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1801  					b = appendNullComma(ctx, b)
  1802  				}
  1803  				code = code.End.Next
  1804  				break
  1805  			}
  1806  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1807  				b = appendStructHead(ctx, b)
  1808  			}
  1809  			v := ptrToString(p + uintptr(code.Offset))
  1810  			if v == "" {
  1811  				code = code.NextField
  1812  			} else {
  1813  				b = appendStructKey(ctx, code, b)
  1814  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, v)))
  1815  				b = appendComma(ctx, b)
  1816  				code = code.Next
  1817  			}
  1818  		case encoder.OpStructPtrHeadStringPtr:
  1819  			p := load(ctxptr, code.Idx)
  1820  			if p == 0 {
  1821  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1822  					b = appendNullComma(ctx, b)
  1823  				}
  1824  				code = code.End.Next
  1825  				break
  1826  			}
  1827  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1828  			fallthrough
  1829  		case encoder.OpStructHeadStringPtr:
  1830  			p := load(ctxptr, code.Idx)
  1831  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1832  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1833  					b = appendNullComma(ctx, b)
  1834  				}
  1835  				code = code.End.Next
  1836  				break
  1837  			}
  1838  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1839  				b = appendStructHead(ctx, b)
  1840  			}
  1841  			b = appendStructKey(ctx, code, b)
  1842  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1843  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1844  			}
  1845  			if p == 0 {
  1846  				b = appendNull(ctx, b)
  1847  			} else {
  1848  				b = appendString(ctx, b, ptrToString(p))
  1849  			}
  1850  			b = appendComma(ctx, b)
  1851  			code = code.Next
  1852  		case encoder.OpStructPtrHeadOmitEmptyStringPtr:
  1853  			p := load(ctxptr, code.Idx)
  1854  			if p == 0 {
  1855  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1856  					b = appendNullComma(ctx, b)
  1857  				}
  1858  				code = code.End.Next
  1859  				break
  1860  			}
  1861  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1862  			fallthrough
  1863  		case encoder.OpStructHeadOmitEmptyStringPtr:
  1864  			p := load(ctxptr, code.Idx)
  1865  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1866  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1867  					b = appendNullComma(ctx, b)
  1868  				}
  1869  				code = code.End.Next
  1870  				break
  1871  			}
  1872  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1873  				b = appendStructHead(ctx, b)
  1874  			}
  1875  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1876  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1877  			}
  1878  			if p != 0 {
  1879  				b = appendStructKey(ctx, code, b)
  1880  				b = appendString(ctx, b, ptrToString(p))
  1881  				b = appendComma(ctx, b)
  1882  			}
  1883  			code = code.Next
  1884  		case encoder.OpStructPtrHeadStringPtrString:
  1885  			p := load(ctxptr, code.Idx)
  1886  			if p == 0 {
  1887  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1888  					b = appendNullComma(ctx, b)
  1889  				}
  1890  				code = code.End.Next
  1891  				break
  1892  			}
  1893  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1894  			fallthrough
  1895  		case encoder.OpStructHeadStringPtrString:
  1896  			p := load(ctxptr, code.Idx)
  1897  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1898  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1899  					b = appendNullComma(ctx, b)
  1900  				}
  1901  				code = code.End.Next
  1902  				break
  1903  			}
  1904  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1905  				b = appendStructHead(ctx, b)
  1906  			}
  1907  			b = appendStructKey(ctx, code, b)
  1908  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1909  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1910  			}
  1911  			if p == 0 {
  1912  				b = appendNull(ctx, b)
  1913  			} else {
  1914  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, ptrToString(p))))
  1915  			}
  1916  			b = appendComma(ctx, b)
  1917  			code = code.Next
  1918  		case encoder.OpStructPtrHeadOmitEmptyStringPtrString:
  1919  			p := load(ctxptr, code.Idx)
  1920  			if p == 0 {
  1921  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1922  					b = appendNullComma(ctx, b)
  1923  				}
  1924  				code = code.End.Next
  1925  				break
  1926  			}
  1927  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1928  			fallthrough
  1929  		case encoder.OpStructHeadOmitEmptyStringPtrString:
  1930  			p := load(ctxptr, code.Idx)
  1931  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  1932  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1933  					b = appendNullComma(ctx, b)
  1934  				}
  1935  				code = code.End.Next
  1936  				break
  1937  			}
  1938  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1939  				b = appendStructHead(ctx, b)
  1940  			}
  1941  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1942  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  1943  			}
  1944  			if p != 0 {
  1945  				b = appendStructKey(ctx, code, b)
  1946  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, ptrToString(p))))
  1947  				b = appendComma(ctx, b)
  1948  			}
  1949  			code = code.Next
  1950  		case encoder.OpStructPtrHeadBool:
  1951  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1952  				p := load(ctxptr, code.Idx)
  1953  				if p == 0 {
  1954  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1955  						b = appendNullComma(ctx, b)
  1956  					}
  1957  					code = code.End.Next
  1958  					break
  1959  				}
  1960  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1961  			}
  1962  			fallthrough
  1963  		case encoder.OpStructHeadBool:
  1964  			p := load(ctxptr, code.Idx)
  1965  			if p == 0 {
  1966  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1967  					b = appendNullComma(ctx, b)
  1968  				}
  1969  				code = code.End.Next
  1970  				break
  1971  			}
  1972  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1973  				b = appendStructHead(ctx, b)
  1974  			}
  1975  			b = appendStructKey(ctx, code, b)
  1976  			b = appendBool(ctx, b, ptrToBool(p+uintptr(code.Offset)))
  1977  			b = appendComma(ctx, b)
  1978  			code = code.Next
  1979  		case encoder.OpStructPtrHeadOmitEmptyBool:
  1980  			if (code.Flags & encoder.IndirectFlags) != 0 {
  1981  				p := load(ctxptr, code.Idx)
  1982  				if p == 0 {
  1983  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1984  						b = appendNullComma(ctx, b)
  1985  					}
  1986  					code = code.End.Next
  1987  					break
  1988  				}
  1989  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  1990  			}
  1991  			fallthrough
  1992  		case encoder.OpStructHeadOmitEmptyBool:
  1993  			p := load(ctxptr, code.Idx)
  1994  			if p == 0 {
  1995  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  1996  					b = appendNullComma(ctx, b)
  1997  				}
  1998  				code = code.End.Next
  1999  				break
  2000  			}
  2001  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2002  				b = appendStructHead(ctx, b)
  2003  			}
  2004  			v := ptrToBool(p + uintptr(code.Offset))
  2005  			if v {
  2006  				b = appendStructKey(ctx, code, b)
  2007  				b = appendBool(ctx, b, v)
  2008  				b = appendComma(ctx, b)
  2009  				code = code.Next
  2010  			} else {
  2011  				code = code.NextField
  2012  			}
  2013  		case encoder.OpStructPtrHeadBoolString:
  2014  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2015  				p := load(ctxptr, code.Idx)
  2016  				if p == 0 {
  2017  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2018  						b = appendNullComma(ctx, b)
  2019  					}
  2020  					code = code.End.Next
  2021  					break
  2022  				}
  2023  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2024  			}
  2025  			fallthrough
  2026  		case encoder.OpStructHeadBoolString:
  2027  			p := load(ctxptr, code.Idx)
  2028  			if p == 0 {
  2029  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2030  					b = appendNullComma(ctx, b)
  2031  				}
  2032  				code = code.End.Next
  2033  				break
  2034  			}
  2035  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2036  				b = appendStructHead(ctx, b)
  2037  			}
  2038  			b = appendStructKey(ctx, code, b)
  2039  			b = append(b, '"')
  2040  			b = appendBool(ctx, b, ptrToBool(p+uintptr(code.Offset)))
  2041  			b = append(b, '"')
  2042  			b = appendComma(ctx, b)
  2043  			code = code.Next
  2044  		case encoder.OpStructPtrHeadOmitEmptyBoolString:
  2045  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2046  				p := load(ctxptr, code.Idx)
  2047  				if p == 0 {
  2048  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2049  						b = appendNullComma(ctx, b)
  2050  					}
  2051  					code = code.End.Next
  2052  					break
  2053  				}
  2054  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2055  			}
  2056  			fallthrough
  2057  		case encoder.OpStructHeadOmitEmptyBoolString:
  2058  			p := load(ctxptr, code.Idx)
  2059  			if p == 0 {
  2060  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2061  					b = appendNullComma(ctx, b)
  2062  				}
  2063  				code = code.End.Next
  2064  				break
  2065  			}
  2066  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2067  				b = appendStructHead(ctx, b)
  2068  			}
  2069  			v := ptrToBool(p + uintptr(code.Offset))
  2070  			if v {
  2071  				b = appendStructKey(ctx, code, b)
  2072  				b = append(b, '"')
  2073  				b = appendBool(ctx, b, v)
  2074  				b = append(b, '"')
  2075  				b = appendComma(ctx, b)
  2076  				code = code.Next
  2077  			} else {
  2078  				code = code.NextField
  2079  			}
  2080  		case encoder.OpStructPtrHeadBoolPtr:
  2081  			p := load(ctxptr, code.Idx)
  2082  			if p == 0 {
  2083  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2084  					b = appendNullComma(ctx, b)
  2085  				}
  2086  				code = code.End.Next
  2087  				break
  2088  			}
  2089  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2090  			fallthrough
  2091  		case encoder.OpStructHeadBoolPtr:
  2092  			p := load(ctxptr, code.Idx)
  2093  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2094  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2095  					b = appendNullComma(ctx, b)
  2096  				}
  2097  				code = code.End.Next
  2098  				break
  2099  			}
  2100  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2101  				b = appendStructHead(ctx, b)
  2102  			}
  2103  			b = appendStructKey(ctx, code, b)
  2104  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2105  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2106  			}
  2107  			if p == 0 {
  2108  				b = appendNull(ctx, b)
  2109  			} else {
  2110  				b = appendBool(ctx, b, ptrToBool(p))
  2111  			}
  2112  			b = appendComma(ctx, b)
  2113  			code = code.Next
  2114  		case encoder.OpStructPtrHeadOmitEmptyBoolPtr:
  2115  			p := load(ctxptr, code.Idx)
  2116  			if p == 0 {
  2117  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2118  					b = appendNullComma(ctx, b)
  2119  				}
  2120  				code = code.End.Next
  2121  				break
  2122  			}
  2123  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2124  			fallthrough
  2125  		case encoder.OpStructHeadOmitEmptyBoolPtr:
  2126  			p := load(ctxptr, code.Idx)
  2127  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2128  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2129  					b = appendNullComma(ctx, b)
  2130  				}
  2131  				code = code.End.Next
  2132  				break
  2133  			}
  2134  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2135  				b = appendStructHead(ctx, b)
  2136  			}
  2137  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2138  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2139  			}
  2140  			if p != 0 {
  2141  				b = appendStructKey(ctx, code, b)
  2142  				b = appendBool(ctx, b, ptrToBool(p))
  2143  				b = appendComma(ctx, b)
  2144  			}
  2145  			code = code.Next
  2146  		case encoder.OpStructPtrHeadBoolPtrString:
  2147  			p := load(ctxptr, code.Idx)
  2148  			if p == 0 {
  2149  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2150  					b = appendNullComma(ctx, b)
  2151  				}
  2152  				code = code.End.Next
  2153  				break
  2154  			}
  2155  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2156  			fallthrough
  2157  		case encoder.OpStructHeadBoolPtrString:
  2158  			p := load(ctxptr, code.Idx)
  2159  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2160  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2161  					b = appendNullComma(ctx, b)
  2162  				}
  2163  				code = code.End.Next
  2164  				break
  2165  			}
  2166  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2167  				b = appendStructHead(ctx, b)
  2168  			}
  2169  			b = appendStructKey(ctx, code, b)
  2170  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2171  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2172  			}
  2173  			if p == 0 {
  2174  				b = appendNull(ctx, b)
  2175  			} else {
  2176  				b = append(b, '"')
  2177  				b = appendBool(ctx, b, ptrToBool(p))
  2178  				b = append(b, '"')
  2179  			}
  2180  			b = appendComma(ctx, b)
  2181  			code = code.Next
  2182  		case encoder.OpStructPtrHeadOmitEmptyBoolPtrString:
  2183  			p := load(ctxptr, code.Idx)
  2184  			if p == 0 {
  2185  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2186  					b = appendNullComma(ctx, b)
  2187  				}
  2188  				code = code.End.Next
  2189  				break
  2190  			}
  2191  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2192  			fallthrough
  2193  		case encoder.OpStructHeadOmitEmptyBoolPtrString:
  2194  			p := load(ctxptr, code.Idx)
  2195  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2196  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2197  					b = appendNullComma(ctx, b)
  2198  				}
  2199  				code = code.End.Next
  2200  				break
  2201  			}
  2202  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2203  				b = appendStructHead(ctx, b)
  2204  			}
  2205  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2206  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2207  			}
  2208  			if p != 0 {
  2209  				b = appendStructKey(ctx, code, b)
  2210  				b = append(b, '"')
  2211  				b = appendBool(ctx, b, ptrToBool(p))
  2212  				b = append(b, '"')
  2213  				b = appendComma(ctx, b)
  2214  			}
  2215  			code = code.Next
  2216  		case encoder.OpStructPtrHeadBytes:
  2217  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2218  				p := load(ctxptr, code.Idx)
  2219  				if p == 0 {
  2220  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2221  						b = appendNullComma(ctx, b)
  2222  					}
  2223  					code = code.End.Next
  2224  					break
  2225  				}
  2226  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2227  			}
  2228  			fallthrough
  2229  		case encoder.OpStructHeadBytes:
  2230  			p := load(ctxptr, code.Idx)
  2231  			if p == 0 {
  2232  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2233  					b = appendNullComma(ctx, b)
  2234  				}
  2235  				code = code.End.Next
  2236  				break
  2237  			}
  2238  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2239  				b = appendStructHead(ctx, b)
  2240  			}
  2241  			b = appendStructKey(ctx, code, b)
  2242  			b = appendByteSlice(ctx, b, ptrToBytes(p+uintptr(code.Offset)))
  2243  			b = appendComma(ctx, b)
  2244  			code = code.Next
  2245  		case encoder.OpStructPtrHeadOmitEmptyBytes:
  2246  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2247  				p := load(ctxptr, code.Idx)
  2248  				if p == 0 {
  2249  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2250  						b = appendNullComma(ctx, b)
  2251  					}
  2252  					code = code.End.Next
  2253  					break
  2254  				}
  2255  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2256  			}
  2257  			fallthrough
  2258  		case encoder.OpStructHeadOmitEmptyBytes:
  2259  			p := load(ctxptr, code.Idx)
  2260  			if p == 0 {
  2261  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2262  					b = appendNullComma(ctx, b)
  2263  				}
  2264  				code = code.End.Next
  2265  				break
  2266  			}
  2267  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2268  				b = appendStructHead(ctx, b)
  2269  			}
  2270  			v := ptrToBytes(p + uintptr(code.Offset))
  2271  			if len(v) == 0 {
  2272  				code = code.NextField
  2273  			} else {
  2274  				b = appendStructKey(ctx, code, b)
  2275  				b = appendByteSlice(ctx, b, v)
  2276  				b = appendComma(ctx, b)
  2277  				code = code.Next
  2278  			}
  2279  		case encoder.OpStructPtrHeadBytesPtr:
  2280  			p := load(ctxptr, code.Idx)
  2281  			if p == 0 {
  2282  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2283  					b = appendNullComma(ctx, b)
  2284  				}
  2285  				code = code.End.Next
  2286  				break
  2287  			}
  2288  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2289  			fallthrough
  2290  		case encoder.OpStructHeadBytesPtr:
  2291  			p := load(ctxptr, code.Idx)
  2292  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2293  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2294  					b = appendNullComma(ctx, b)
  2295  				}
  2296  				code = code.End.Next
  2297  				break
  2298  			}
  2299  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2300  				b = appendStructHead(ctx, b)
  2301  			}
  2302  			b = appendStructKey(ctx, code, b)
  2303  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2304  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2305  			}
  2306  			if p == 0 {
  2307  				b = appendNull(ctx, b)
  2308  			} else {
  2309  				b = appendByteSlice(ctx, b, ptrToBytes(p))
  2310  			}
  2311  			b = appendComma(ctx, b)
  2312  			code = code.Next
  2313  		case encoder.OpStructPtrHeadOmitEmptyBytesPtr:
  2314  			p := load(ctxptr, code.Idx)
  2315  			if p == 0 {
  2316  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2317  					b = appendNullComma(ctx, b)
  2318  				}
  2319  				code = code.End.Next
  2320  				break
  2321  			}
  2322  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2323  			fallthrough
  2324  		case encoder.OpStructHeadOmitEmptyBytesPtr:
  2325  			p := load(ctxptr, code.Idx)
  2326  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2327  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2328  					b = appendNullComma(ctx, b)
  2329  				}
  2330  				code = code.End.Next
  2331  				break
  2332  			}
  2333  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2334  				b = appendStructHead(ctx, b)
  2335  			}
  2336  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2337  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2338  			}
  2339  			if p != 0 {
  2340  				b = appendStructKey(ctx, code, b)
  2341  				b = appendByteSlice(ctx, b, ptrToBytes(p))
  2342  				b = appendComma(ctx, b)
  2343  			}
  2344  			code = code.Next
  2345  		case encoder.OpStructPtrHeadNumber:
  2346  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2347  				p := load(ctxptr, code.Idx)
  2348  				if p == 0 {
  2349  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2350  						b = appendNullComma(ctx, b)
  2351  					}
  2352  					code = code.End.Next
  2353  					break
  2354  				}
  2355  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2356  			}
  2357  			fallthrough
  2358  		case encoder.OpStructHeadNumber:
  2359  			p := load(ctxptr, code.Idx)
  2360  			if p == 0 {
  2361  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2362  					b = appendNullComma(ctx, b)
  2363  				}
  2364  				code = code.End.Next
  2365  				break
  2366  			}
  2367  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2368  				b = appendStructHead(ctx, b)
  2369  			}
  2370  			b = appendStructKey(ctx, code, b)
  2371  			bb, err := appendNumber(ctx, b, ptrToNumber(p+uintptr(code.Offset)))
  2372  			if err != nil {
  2373  				return nil, err
  2374  			}
  2375  			b = appendComma(ctx, bb)
  2376  			code = code.Next
  2377  		case encoder.OpStructPtrHeadOmitEmptyNumber:
  2378  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2379  				p := load(ctxptr, code.Idx)
  2380  				if p == 0 {
  2381  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2382  						b = appendNullComma(ctx, b)
  2383  					}
  2384  					code = code.End.Next
  2385  					break
  2386  				}
  2387  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2388  			}
  2389  			fallthrough
  2390  		case encoder.OpStructHeadOmitEmptyNumber:
  2391  			p := load(ctxptr, code.Idx)
  2392  			if p == 0 {
  2393  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2394  					b = appendNullComma(ctx, b)
  2395  				}
  2396  				code = code.End.Next
  2397  				break
  2398  			}
  2399  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2400  				b = appendStructHead(ctx, b)
  2401  			}
  2402  			v := ptrToNumber(p + uintptr(code.Offset))
  2403  			if v == "" {
  2404  				code = code.NextField
  2405  			} else {
  2406  				b = appendStructKey(ctx, code, b)
  2407  				bb, err := appendNumber(ctx, b, v)
  2408  				if err != nil {
  2409  					return nil, err
  2410  				}
  2411  				b = appendComma(ctx, bb)
  2412  				code = code.Next
  2413  			}
  2414  		case encoder.OpStructPtrHeadNumberString:
  2415  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2416  				p := load(ctxptr, code.Idx)
  2417  				if p == 0 {
  2418  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2419  						b = appendNullComma(ctx, b)
  2420  					}
  2421  					code = code.End.Next
  2422  					break
  2423  				}
  2424  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2425  			}
  2426  			fallthrough
  2427  		case encoder.OpStructHeadNumberString:
  2428  			p := load(ctxptr, code.Idx)
  2429  			if p == 0 {
  2430  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2431  					b = appendNullComma(ctx, b)
  2432  				}
  2433  				code = code.End.Next
  2434  				break
  2435  			}
  2436  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2437  				b = appendStructHead(ctx, b)
  2438  			}
  2439  			b = appendStructKey(ctx, code, b)
  2440  			b = append(b, '"')
  2441  			bb, err := appendNumber(ctx, b, ptrToNumber(p+uintptr(code.Offset)))
  2442  			if err != nil {
  2443  				return nil, err
  2444  			}
  2445  			b = append(bb, '"')
  2446  			b = appendComma(ctx, b)
  2447  			code = code.Next
  2448  		case encoder.OpStructPtrHeadOmitEmptyNumberString:
  2449  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2450  				p := load(ctxptr, code.Idx)
  2451  				if p == 0 {
  2452  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2453  						b = appendNullComma(ctx, b)
  2454  					}
  2455  					code = code.End.Next
  2456  					break
  2457  				}
  2458  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2459  			}
  2460  			fallthrough
  2461  		case encoder.OpStructHeadOmitEmptyNumberString:
  2462  			p := load(ctxptr, code.Idx)
  2463  			if p == 0 {
  2464  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2465  					b = appendNullComma(ctx, b)
  2466  				}
  2467  				code = code.End.Next
  2468  				break
  2469  			}
  2470  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2471  				b = appendStructHead(ctx, b)
  2472  			}
  2473  			v := ptrToNumber(p + uintptr(code.Offset))
  2474  			if v == "" {
  2475  				code = code.NextField
  2476  			} else {
  2477  				b = appendStructKey(ctx, code, b)
  2478  				b = append(b, '"')
  2479  				bb, err := appendNumber(ctx, b, v)
  2480  				if err != nil {
  2481  					return nil, err
  2482  				}
  2483  				b = append(bb, '"')
  2484  				b = appendComma(ctx, b)
  2485  				code = code.Next
  2486  			}
  2487  		case encoder.OpStructPtrHeadNumberPtr:
  2488  			p := load(ctxptr, code.Idx)
  2489  			if p == 0 {
  2490  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2491  					b = appendNullComma(ctx, b)
  2492  				}
  2493  				code = code.End.Next
  2494  				break
  2495  			}
  2496  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2497  			fallthrough
  2498  		case encoder.OpStructHeadNumberPtr:
  2499  			p := load(ctxptr, code.Idx)
  2500  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2501  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2502  					b = appendNullComma(ctx, b)
  2503  				}
  2504  				code = code.End.Next
  2505  				break
  2506  			}
  2507  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2508  				b = appendStructHead(ctx, b)
  2509  			}
  2510  			b = appendStructKey(ctx, code, b)
  2511  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2512  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2513  			}
  2514  			if p == 0 {
  2515  				b = appendNull(ctx, b)
  2516  			} else {
  2517  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  2518  				if err != nil {
  2519  					return nil, err
  2520  				}
  2521  				b = bb
  2522  			}
  2523  			b = appendComma(ctx, b)
  2524  			code = code.Next
  2525  		case encoder.OpStructPtrHeadOmitEmptyNumberPtr:
  2526  			p := load(ctxptr, code.Idx)
  2527  			if p == 0 {
  2528  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2529  					b = appendNullComma(ctx, b)
  2530  				}
  2531  				code = code.End.Next
  2532  				break
  2533  			}
  2534  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2535  			fallthrough
  2536  		case encoder.OpStructHeadOmitEmptyNumberPtr:
  2537  			p := load(ctxptr, code.Idx)
  2538  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2539  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2540  					b = appendNullComma(ctx, b)
  2541  				}
  2542  				code = code.End.Next
  2543  				break
  2544  			}
  2545  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2546  				b = appendStructHead(ctx, b)
  2547  			}
  2548  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2549  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2550  			}
  2551  			if p != 0 {
  2552  				b = appendStructKey(ctx, code, b)
  2553  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  2554  				if err != nil {
  2555  					return nil, err
  2556  				}
  2557  				b = appendComma(ctx, bb)
  2558  			}
  2559  			code = code.Next
  2560  		case encoder.OpStructPtrHeadNumberPtrString:
  2561  			p := load(ctxptr, code.Idx)
  2562  			if p == 0 {
  2563  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2564  					b = appendNullComma(ctx, b)
  2565  				}
  2566  				code = code.End.Next
  2567  				break
  2568  			}
  2569  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2570  			fallthrough
  2571  		case encoder.OpStructHeadNumberPtrString:
  2572  			p := load(ctxptr, code.Idx)
  2573  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2574  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2575  					b = appendNullComma(ctx, b)
  2576  				}
  2577  				code = code.End.Next
  2578  				break
  2579  			}
  2580  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2581  				b = appendStructHead(ctx, b)
  2582  			}
  2583  			b = appendStructKey(ctx, code, b)
  2584  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2585  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2586  			}
  2587  			if p == 0 {
  2588  				b = appendNull(ctx, b)
  2589  			} else {
  2590  				b = append(b, '"')
  2591  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  2592  				if err != nil {
  2593  					return nil, err
  2594  				}
  2595  				b = append(bb, '"')
  2596  			}
  2597  			b = appendComma(ctx, b)
  2598  			code = code.Next
  2599  		case encoder.OpStructPtrHeadOmitEmptyNumberPtrString:
  2600  			p := load(ctxptr, code.Idx)
  2601  			if p == 0 {
  2602  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2603  					b = appendNullComma(ctx, b)
  2604  				}
  2605  				code = code.End.Next
  2606  				break
  2607  			}
  2608  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2609  			fallthrough
  2610  		case encoder.OpStructHeadOmitEmptyNumberPtrString:
  2611  			p := load(ctxptr, code.Idx)
  2612  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2613  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2614  					b = appendNullComma(ctx, b)
  2615  				}
  2616  				code = code.End.Next
  2617  				break
  2618  			}
  2619  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2620  				b = appendStructHead(ctx, b)
  2621  			}
  2622  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2623  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2624  			}
  2625  			if p != 0 {
  2626  				b = appendStructKey(ctx, code, b)
  2627  				b = append(b, '"')
  2628  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  2629  				if err != nil {
  2630  					return nil, err
  2631  				}
  2632  				b = append(bb, '"')
  2633  				b = appendComma(ctx, b)
  2634  			}
  2635  			code = code.Next
  2636  		case encoder.OpStructPtrHeadArray, encoder.OpStructPtrHeadSlice:
  2637  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2638  				p := load(ctxptr, code.Idx)
  2639  				if p == 0 {
  2640  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2641  						b = appendNullComma(ctx, b)
  2642  					}
  2643  					code = code.End.Next
  2644  					break
  2645  				}
  2646  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2647  			}
  2648  			fallthrough
  2649  		case encoder.OpStructHeadArray, encoder.OpStructHeadSlice:
  2650  			p := load(ctxptr, code.Idx)
  2651  			if p == 0 {
  2652  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2653  					b = appendNullComma(ctx, b)
  2654  				}
  2655  				code = code.End.Next
  2656  				break
  2657  			}
  2658  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2659  				b = appendStructHead(ctx, b)
  2660  			}
  2661  			b = appendStructKey(ctx, code, b)
  2662  			p += uintptr(code.Offset)
  2663  			code = code.Next
  2664  			store(ctxptr, code.Idx, p)
  2665  		case encoder.OpStructPtrHeadOmitEmptyArray:
  2666  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2667  				p := load(ctxptr, code.Idx)
  2668  				if p == 0 {
  2669  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2670  						b = appendNullComma(ctx, b)
  2671  					}
  2672  					code = code.End.Next
  2673  					break
  2674  				}
  2675  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2676  			}
  2677  			fallthrough
  2678  		case encoder.OpStructHeadOmitEmptyArray:
  2679  			p := load(ctxptr, code.Idx)
  2680  			if p == 0 {
  2681  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2682  					b = appendNullComma(ctx, b)
  2683  				}
  2684  				code = code.End.Next
  2685  				break
  2686  			}
  2687  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2688  				b = appendStructHead(ctx, b)
  2689  			}
  2690  			p += uintptr(code.Offset)
  2691  			b = appendStructKey(ctx, code, b)
  2692  			code = code.Next
  2693  			store(ctxptr, code.Idx, p)
  2694  		case encoder.OpStructPtrHeadOmitEmptySlice:
  2695  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2696  				p := load(ctxptr, code.Idx)
  2697  				if p == 0 {
  2698  					if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2699  						b = appendNullComma(ctx, b)
  2700  					}
  2701  					code = code.End.Next
  2702  					break
  2703  				}
  2704  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2705  			}
  2706  			fallthrough
  2707  		case encoder.OpStructHeadOmitEmptySlice:
  2708  			p := load(ctxptr, code.Idx)
  2709  			if p == 0 {
  2710  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2711  					b = appendNullComma(ctx, b)
  2712  				}
  2713  				code = code.End.Next
  2714  				break
  2715  			}
  2716  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2717  				b = appendStructHead(ctx, b)
  2718  			}
  2719  			p += uintptr(code.Offset)
  2720  			slice := ptrToSlice(p)
  2721  			if slice.Len == 0 {
  2722  				code = code.NextField
  2723  			} else {
  2724  				b = appendStructKey(ctx, code, b)
  2725  				code = code.Next
  2726  				store(ctxptr, code.Idx, p)
  2727  			}
  2728  		case encoder.OpStructPtrHeadArrayPtr, encoder.OpStructPtrHeadSlicePtr:
  2729  			p := load(ctxptr, code.Idx)
  2730  			if p == 0 {
  2731  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2732  					b = appendNullComma(ctx, b)
  2733  				}
  2734  				code = code.End.Next
  2735  				break
  2736  			}
  2737  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2738  			fallthrough
  2739  		case encoder.OpStructHeadArrayPtr, encoder.OpStructHeadSlicePtr:
  2740  			p := load(ctxptr, code.Idx)
  2741  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2742  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2743  					b = appendNullComma(ctx, b)
  2744  				}
  2745  				code = code.End.Next
  2746  				break
  2747  			}
  2748  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2749  				b = appendStructHead(ctx, b)
  2750  			}
  2751  			b = appendStructKey(ctx, code, b)
  2752  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2753  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2754  			}
  2755  			if p == 0 {
  2756  				b = appendNullComma(ctx, b)
  2757  				code = code.NextField
  2758  			} else {
  2759  				code = code.Next
  2760  				store(ctxptr, code.Idx, p)
  2761  			}
  2762  		case encoder.OpStructPtrHeadOmitEmptyArrayPtr, encoder.OpStructPtrHeadOmitEmptySlicePtr:
  2763  			p := load(ctxptr, code.Idx)
  2764  			if p == 0 {
  2765  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2766  					b = appendNullComma(ctx, b)
  2767  				}
  2768  				code = code.End.Next
  2769  				break
  2770  			}
  2771  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2772  			fallthrough
  2773  		case encoder.OpStructHeadOmitEmptyArrayPtr, encoder.OpStructHeadOmitEmptySlicePtr:
  2774  			p := load(ctxptr, code.Idx)
  2775  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2776  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2777  					b = appendNullComma(ctx, b)
  2778  				}
  2779  				code = code.End.Next
  2780  				break
  2781  			}
  2782  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2783  				b = appendStructHead(ctx, b)
  2784  			}
  2785  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2786  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  2787  			}
  2788  			if p == 0 {
  2789  				code = code.NextField
  2790  			} else {
  2791  				b = appendStructKey(ctx, code, b)
  2792  				code = code.Next
  2793  				store(ctxptr, code.Idx, p)
  2794  			}
  2795  		case encoder.OpStructPtrHeadMap:
  2796  			p := load(ctxptr, code.Idx)
  2797  			if p == 0 {
  2798  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2799  					b = appendNullComma(ctx, b)
  2800  				}
  2801  				code = code.End.Next
  2802  				break
  2803  			}
  2804  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2805  			fallthrough
  2806  		case encoder.OpStructHeadMap:
  2807  			p := load(ctxptr, code.Idx)
  2808  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2809  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2810  					b = appendNullComma(ctx, b)
  2811  				}
  2812  				code = code.End.Next
  2813  				break
  2814  			}
  2815  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2816  				b = appendStructHead(ctx, b)
  2817  			}
  2818  			b = appendStructKey(ctx, code, b)
  2819  			if p != 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2820  				p = ptrToPtr(p + uintptr(code.Offset))
  2821  			}
  2822  			code = code.Next
  2823  			store(ctxptr, code.Idx, p)
  2824  		case encoder.OpStructPtrHeadOmitEmptyMap:
  2825  			p := load(ctxptr, code.Idx)
  2826  			if p == 0 {
  2827  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2828  					b = appendNullComma(ctx, b)
  2829  				}
  2830  				code = code.End.Next
  2831  				break
  2832  			}
  2833  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2834  			fallthrough
  2835  		case encoder.OpStructHeadOmitEmptyMap:
  2836  			p := load(ctxptr, code.Idx)
  2837  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2838  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2839  					b = appendNullComma(ctx, b)
  2840  				}
  2841  				code = code.End.Next
  2842  				break
  2843  			}
  2844  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2845  				b = appendStructHead(ctx, b)
  2846  			}
  2847  			if p != 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2848  				p = ptrToPtr(p + uintptr(code.Offset))
  2849  			}
  2850  			if maplen(ptrToUnsafePtr(p)) == 0 {
  2851  				code = code.NextField
  2852  			} else {
  2853  				b = appendStructKey(ctx, code, b)
  2854  				code = code.Next
  2855  				store(ctxptr, code.Idx, p)
  2856  			}
  2857  		case encoder.OpStructPtrHeadMapPtr:
  2858  			p := load(ctxptr, code.Idx)
  2859  			if p == 0 {
  2860  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2861  					b = appendNullComma(ctx, b)
  2862  				}
  2863  				code = code.End.Next
  2864  				break
  2865  			}
  2866  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2867  			fallthrough
  2868  		case encoder.OpStructHeadMapPtr:
  2869  			p := load(ctxptr, code.Idx)
  2870  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2871  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2872  					b = appendNullComma(ctx, b)
  2873  				}
  2874  				code = code.End.Next
  2875  				break
  2876  			}
  2877  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2878  				b = appendStructHead(ctx, b)
  2879  			}
  2880  			b = appendStructKey(ctx, code, b)
  2881  			if p == 0 {
  2882  				b = appendNullComma(ctx, b)
  2883  				code = code.NextField
  2884  				break
  2885  			}
  2886  			p = ptrToPtr(p + uintptr(code.Offset))
  2887  			if p == 0 {
  2888  				b = appendNullComma(ctx, b)
  2889  				code = code.NextField
  2890  			} else {
  2891  				if (code.Flags & encoder.IndirectFlags) != 0 {
  2892  					p = ptrToNPtr(p, code.PtrNum)
  2893  				}
  2894  				code = code.Next
  2895  				store(ctxptr, code.Idx, p)
  2896  			}
  2897  		case encoder.OpStructPtrHeadOmitEmptyMapPtr:
  2898  			p := load(ctxptr, code.Idx)
  2899  			if p == 0 {
  2900  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2901  					b = appendNullComma(ctx, b)
  2902  				}
  2903  				code = code.End.Next
  2904  				break
  2905  			}
  2906  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2907  			fallthrough
  2908  		case encoder.OpStructHeadOmitEmptyMapPtr:
  2909  			p := load(ctxptr, code.Idx)
  2910  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2911  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2912  					b = appendNullComma(ctx, b)
  2913  				}
  2914  				code = code.End.Next
  2915  				break
  2916  			}
  2917  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2918  				b = appendStructHead(ctx, b)
  2919  			}
  2920  			if p == 0 {
  2921  				code = code.NextField
  2922  				break
  2923  			}
  2924  			p = ptrToPtr(p + uintptr(code.Offset))
  2925  			if p == 0 {
  2926  				code = code.NextField
  2927  			} else {
  2928  				if (code.Flags & encoder.IndirectFlags) != 0 {
  2929  					p = ptrToNPtr(p, code.PtrNum)
  2930  				}
  2931  				b = appendStructKey(ctx, code, b)
  2932  				code = code.Next
  2933  				store(ctxptr, code.Idx, p)
  2934  			}
  2935  		case encoder.OpStructPtrHeadMarshalJSON:
  2936  			p := load(ctxptr, code.Idx)
  2937  			if p == 0 {
  2938  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2939  					b = appendNullComma(ctx, b)
  2940  				}
  2941  				code = code.End.Next
  2942  				break
  2943  			}
  2944  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2945  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2946  			}
  2947  			fallthrough
  2948  		case encoder.OpStructHeadMarshalJSON:
  2949  			p := load(ctxptr, code.Idx)
  2950  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2951  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2952  					b = appendNullComma(ctx, b)
  2953  				}
  2954  				code = code.End.Next
  2955  				break
  2956  			}
  2957  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2958  				b = appendStructHead(ctx, b)
  2959  			}
  2960  			b = appendStructKey(ctx, code, b)
  2961  			p += uintptr(code.Offset)
  2962  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  2963  				if (code.Flags&encoder.IndirectFlags) != 0 || code.Op == encoder.OpStructPtrHeadMarshalJSON {
  2964  					p = ptrToPtr(p)
  2965  				}
  2966  			}
  2967  			if p == 0 && (code.Flags&encoder.NilCheckFlags) != 0 {
  2968  				b = appendNull(ctx, b)
  2969  			} else {
  2970  				bb, err := appendMarshalJSON(ctx, code, b, ptrToInterface(code, p))
  2971  				if err != nil {
  2972  					return nil, err
  2973  				}
  2974  				b = bb
  2975  			}
  2976  			b = appendComma(ctx, b)
  2977  			code = code.Next
  2978  		case encoder.OpStructPtrHeadOmitEmptyMarshalJSON:
  2979  			p := load(ctxptr, code.Idx)
  2980  			if p == 0 {
  2981  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2982  					b = appendNullComma(ctx, b)
  2983  				}
  2984  				code = code.End.Next
  2985  				break
  2986  			}
  2987  			if (code.Flags & encoder.IndirectFlags) != 0 {
  2988  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  2989  			}
  2990  			fallthrough
  2991  		case encoder.OpStructHeadOmitEmptyMarshalJSON:
  2992  			p := load(ctxptr, code.Idx)
  2993  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  2994  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  2995  					b = appendNullComma(ctx, b)
  2996  				}
  2997  				code = code.End.Next
  2998  				break
  2999  			}
  3000  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3001  				b = appendStructHead(ctx, b)
  3002  			}
  3003  			p += uintptr(code.Offset)
  3004  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  3005  				if (code.Flags&encoder.IndirectFlags) != 0 || code.Op == encoder.OpStructPtrHeadOmitEmptyMarshalJSON {
  3006  					p = ptrToPtr(p)
  3007  				}
  3008  			}
  3009  			iface := ptrToInterface(code, p)
  3010  			if (code.Flags&encoder.NilCheckFlags) != 0 && encoder.IsNilForMarshaler(iface) {
  3011  				code = code.NextField
  3012  			} else {
  3013  				b = appendStructKey(ctx, code, b)
  3014  				bb, err := appendMarshalJSON(ctx, code, b, iface)
  3015  				if err != nil {
  3016  					return nil, err
  3017  				}
  3018  				b = bb
  3019  				b = appendComma(ctx, b)
  3020  				code = code.Next
  3021  			}
  3022  		case encoder.OpStructPtrHeadMarshalJSONPtr:
  3023  			p := load(ctxptr, code.Idx)
  3024  			if p == 0 {
  3025  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3026  					b = appendNullComma(ctx, b)
  3027  				}
  3028  				code = code.End.Next
  3029  				break
  3030  			}
  3031  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  3032  			fallthrough
  3033  		case encoder.OpStructHeadMarshalJSONPtr:
  3034  			p := load(ctxptr, code.Idx)
  3035  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  3036  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3037  					b = appendNullComma(ctx, b)
  3038  				}
  3039  				code = code.End.Next
  3040  				break
  3041  			}
  3042  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3043  				b = appendStructHead(ctx, b)
  3044  			}
  3045  			b = appendStructKey(ctx, code, b)
  3046  			if (code.Flags & encoder.IndirectFlags) != 0 {
  3047  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3048  			}
  3049  			if p == 0 {
  3050  				b = appendNull(ctx, b)
  3051  			} else {
  3052  				bb, err := appendMarshalJSON(ctx, code, b, ptrToInterface(code, p))
  3053  				if err != nil {
  3054  					return nil, err
  3055  				}
  3056  				b = bb
  3057  			}
  3058  			b = appendComma(ctx, b)
  3059  			code = code.Next
  3060  		case encoder.OpStructPtrHeadOmitEmptyMarshalJSONPtr:
  3061  			p := load(ctxptr, code.Idx)
  3062  			if p == 0 {
  3063  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3064  					b = appendNullComma(ctx, b)
  3065  				}
  3066  				code = code.End.Next
  3067  				break
  3068  			}
  3069  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  3070  			fallthrough
  3071  		case encoder.OpStructHeadOmitEmptyMarshalJSONPtr:
  3072  			p := load(ctxptr, code.Idx)
  3073  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  3074  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3075  					b = appendNullComma(ctx, b)
  3076  				}
  3077  				code = code.End.Next
  3078  				break
  3079  			}
  3080  			if (code.Flags & encoder.IndirectFlags) != 0 {
  3081  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3082  			}
  3083  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3084  				b = appendStructHead(ctx, b)
  3085  			}
  3086  			if p == 0 {
  3087  				code = code.NextField
  3088  			} else {
  3089  				b = appendStructKey(ctx, code, b)
  3090  				bb, err := appendMarshalJSON(ctx, code, b, ptrToInterface(code, p))
  3091  				if err != nil {
  3092  					return nil, err
  3093  				}
  3094  				b = bb
  3095  				b = appendComma(ctx, b)
  3096  				code = code.Next
  3097  			}
  3098  		case encoder.OpStructPtrHeadMarshalText:
  3099  			p := load(ctxptr, code.Idx)
  3100  			if p == 0 {
  3101  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3102  					b = appendNullComma(ctx, b)
  3103  				}
  3104  				code = code.End.Next
  3105  				break
  3106  			}
  3107  			if (code.Flags & encoder.IndirectFlags) != 0 {
  3108  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  3109  			}
  3110  			fallthrough
  3111  		case encoder.OpStructHeadMarshalText:
  3112  			p := load(ctxptr, code.Idx)
  3113  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  3114  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3115  					b = appendNullComma(ctx, b)
  3116  				}
  3117  				code = code.End.Next
  3118  				break
  3119  			}
  3120  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3121  				b = appendStructHead(ctx, b)
  3122  			}
  3123  			b = appendStructKey(ctx, code, b)
  3124  			p += uintptr(code.Offset)
  3125  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  3126  				if (code.Flags&encoder.IndirectFlags) != 0 || code.Op == encoder.OpStructPtrHeadMarshalText {
  3127  					p = ptrToPtr(p)
  3128  				}
  3129  			}
  3130  			if p == 0 && (code.Flags&encoder.NilCheckFlags) != 0 {
  3131  				b = appendNull(ctx, b)
  3132  			} else {
  3133  				bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  3134  				if err != nil {
  3135  					return nil, err
  3136  				}
  3137  				b = bb
  3138  			}
  3139  			b = appendComma(ctx, b)
  3140  			code = code.Next
  3141  		case encoder.OpStructPtrHeadOmitEmptyMarshalText:
  3142  			p := load(ctxptr, code.Idx)
  3143  			if p == 0 {
  3144  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3145  					b = appendNullComma(ctx, b)
  3146  				}
  3147  				code = code.End.Next
  3148  				break
  3149  			}
  3150  			if (code.Flags & encoder.IndirectFlags) != 0 {
  3151  				store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  3152  			}
  3153  			fallthrough
  3154  		case encoder.OpStructHeadOmitEmptyMarshalText:
  3155  			p := load(ctxptr, code.Idx)
  3156  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  3157  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3158  					b = appendNullComma(ctx, b)
  3159  				}
  3160  				code = code.End.Next
  3161  				break
  3162  			}
  3163  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3164  				b = appendStructHead(ctx, b)
  3165  			}
  3166  			p += uintptr(code.Offset)
  3167  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  3168  				if (code.Flags&encoder.IndirectFlags) != 0 || code.Op == encoder.OpStructPtrHeadOmitEmptyMarshalText {
  3169  					p = ptrToPtr(p)
  3170  				}
  3171  			}
  3172  			if p == 0 && (code.Flags&encoder.NilCheckFlags) != 0 {
  3173  				code = code.NextField
  3174  			} else {
  3175  				b = appendStructKey(ctx, code, b)
  3176  				bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  3177  				if err != nil {
  3178  					return nil, err
  3179  				}
  3180  				b = bb
  3181  				b = appendComma(ctx, b)
  3182  				code = code.Next
  3183  			}
  3184  		case encoder.OpStructPtrHeadMarshalTextPtr:
  3185  			p := load(ctxptr, code.Idx)
  3186  			if p == 0 {
  3187  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3188  					b = appendNullComma(ctx, b)
  3189  				}
  3190  				code = code.End.Next
  3191  				break
  3192  			}
  3193  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  3194  			fallthrough
  3195  		case encoder.OpStructHeadMarshalTextPtr:
  3196  			p := load(ctxptr, code.Idx)
  3197  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  3198  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3199  					b = appendNullComma(ctx, b)
  3200  				}
  3201  				code = code.End.Next
  3202  				break
  3203  			}
  3204  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3205  				b = appendStructHead(ctx, b)
  3206  			}
  3207  			b = appendStructKey(ctx, code, b)
  3208  			if (code.Flags & encoder.IndirectFlags) != 0 {
  3209  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3210  			}
  3211  			if p == 0 {
  3212  				b = appendNull(ctx, b)
  3213  			} else {
  3214  				bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  3215  				if err != nil {
  3216  					return nil, err
  3217  				}
  3218  				b = bb
  3219  			}
  3220  			b = appendComma(ctx, b)
  3221  			code = code.Next
  3222  		case encoder.OpStructPtrHeadOmitEmptyMarshalTextPtr:
  3223  			p := load(ctxptr, code.Idx)
  3224  			if p == 0 {
  3225  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3226  					b = appendNullComma(ctx, b)
  3227  				}
  3228  				code = code.End.Next
  3229  				break
  3230  			}
  3231  			store(ctxptr, code.Idx, ptrToNPtr(p, code.PtrNum))
  3232  			fallthrough
  3233  		case encoder.OpStructHeadOmitEmptyMarshalTextPtr:
  3234  			p := load(ctxptr, code.Idx)
  3235  			if p == 0 && (code.Flags&encoder.IndirectFlags) != 0 {
  3236  				if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3237  					b = appendNullComma(ctx, b)
  3238  				}
  3239  				code = code.End.Next
  3240  				break
  3241  			}
  3242  			if (code.Flags & encoder.IndirectFlags) != 0 {
  3243  				p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3244  			}
  3245  			if code.Flags&encoder.AnonymousHeadFlags == 0 {
  3246  				b = appendStructHead(ctx, b)
  3247  			}
  3248  			if p == 0 {
  3249  				code = code.NextField
  3250  			} else {
  3251  				b = appendStructKey(ctx, code, b)
  3252  				bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  3253  				if err != nil {
  3254  					return nil, err
  3255  				}
  3256  				b = bb
  3257  				b = appendComma(ctx, b)
  3258  				code = code.Next
  3259  			}
  3260  		case encoder.OpStructField:
  3261  			if code.Flags&encoder.IsTaggedKeyFlags != 0 || code.Flags&encoder.AnonymousKeyFlags == 0 {
  3262  				b = appendStructKey(ctx, code, b)
  3263  			}
  3264  			p := load(ctxptr, code.Idx) + uintptr(code.Offset)
  3265  			code = code.Next
  3266  			store(ctxptr, code.Idx, p)
  3267  		case encoder.OpStructFieldOmitEmpty:
  3268  			p := load(ctxptr, code.Idx)
  3269  			p += uintptr(code.Offset)
  3270  			if ptrToPtr(p) == 0 && (code.Flags&encoder.IsNextOpPtrTypeFlags) != 0 {
  3271  				code = code.NextField
  3272  			} else {
  3273  				b = appendStructKey(ctx, code, b)
  3274  				code = code.Next
  3275  				store(ctxptr, code.Idx, p)
  3276  			}
  3277  		case encoder.OpStructFieldInt:
  3278  			p := load(ctxptr, code.Idx)
  3279  			b = appendStructKey(ctx, code, b)
  3280  			b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  3281  			b = appendComma(ctx, b)
  3282  			code = code.Next
  3283  		case encoder.OpStructFieldOmitEmptyInt:
  3284  			p := load(ctxptr, code.Idx)
  3285  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  3286  			v := u64 & ((1 << code.NumBitSize) - 1)
  3287  			if v != 0 {
  3288  				b = appendStructKey(ctx, code, b)
  3289  				b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  3290  				b = appendComma(ctx, b)
  3291  			}
  3292  			code = code.Next
  3293  		case encoder.OpStructFieldIntString:
  3294  			p := load(ctxptr, code.Idx)
  3295  			b = appendStructKey(ctx, code, b)
  3296  			b = append(b, '"')
  3297  			b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  3298  			b = append(b, '"')
  3299  			b = appendComma(ctx, b)
  3300  			code = code.Next
  3301  		case encoder.OpStructFieldOmitEmptyIntString:
  3302  			p := load(ctxptr, code.Idx)
  3303  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  3304  			v := u64 & ((1 << code.NumBitSize) - 1)
  3305  			if v != 0 {
  3306  				b = appendStructKey(ctx, code, b)
  3307  				b = append(b, '"')
  3308  				b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  3309  				b = append(b, '"')
  3310  				b = appendComma(ctx, b)
  3311  			}
  3312  			code = code.Next
  3313  		case encoder.OpStructFieldIntPtr:
  3314  			p := load(ctxptr, code.Idx)
  3315  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3316  			b = appendStructKey(ctx, code, b)
  3317  			if p == 0 {
  3318  				b = appendNull(ctx, b)
  3319  			} else {
  3320  				b = appendInt(ctx, b, p, code)
  3321  			}
  3322  			b = appendComma(ctx, b)
  3323  			code = code.Next
  3324  		case encoder.OpStructFieldOmitEmptyIntPtr:
  3325  			p := load(ctxptr, code.Idx)
  3326  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3327  			if p != 0 {
  3328  				b = appendStructKey(ctx, code, b)
  3329  				b = appendInt(ctx, b, p, code)
  3330  				b = appendComma(ctx, b)
  3331  			}
  3332  			code = code.Next
  3333  		case encoder.OpStructFieldIntPtrString:
  3334  			p := load(ctxptr, code.Idx)
  3335  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3336  			b = appendStructKey(ctx, code, b)
  3337  			if p == 0 {
  3338  				b = appendNull(ctx, b)
  3339  			} else {
  3340  				b = append(b, '"')
  3341  				b = appendInt(ctx, b, p, code)
  3342  				b = append(b, '"')
  3343  			}
  3344  			b = appendComma(ctx, b)
  3345  			code = code.Next
  3346  		case encoder.OpStructFieldOmitEmptyIntPtrString:
  3347  			p := load(ctxptr, code.Idx)
  3348  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3349  			if p != 0 {
  3350  				b = appendStructKey(ctx, code, b)
  3351  				b = append(b, '"')
  3352  				b = appendInt(ctx, b, p, code)
  3353  				b = append(b, '"')
  3354  				b = appendComma(ctx, b)
  3355  			}
  3356  			code = code.Next
  3357  		case encoder.OpStructFieldUint:
  3358  			p := load(ctxptr, code.Idx)
  3359  			b = appendStructKey(ctx, code, b)
  3360  			b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  3361  			b = appendComma(ctx, b)
  3362  			code = code.Next
  3363  		case encoder.OpStructFieldOmitEmptyUint:
  3364  			p := load(ctxptr, code.Idx)
  3365  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  3366  			v := u64 & ((1 << code.NumBitSize) - 1)
  3367  			if v != 0 {
  3368  				b = appendStructKey(ctx, code, b)
  3369  				b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  3370  				b = appendComma(ctx, b)
  3371  			}
  3372  			code = code.Next
  3373  		case encoder.OpStructFieldUintString:
  3374  			p := load(ctxptr, code.Idx)
  3375  			b = appendStructKey(ctx, code, b)
  3376  			b = append(b, '"')
  3377  			b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  3378  			b = append(b, '"')
  3379  			b = appendComma(ctx, b)
  3380  			code = code.Next
  3381  		case encoder.OpStructFieldOmitEmptyUintString:
  3382  			p := load(ctxptr, code.Idx)
  3383  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  3384  			v := u64 & ((1 << code.NumBitSize) - 1)
  3385  			if v != 0 {
  3386  				b = appendStructKey(ctx, code, b)
  3387  				b = append(b, '"')
  3388  				b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  3389  				b = append(b, '"')
  3390  				b = appendComma(ctx, b)
  3391  			}
  3392  			code = code.Next
  3393  		case encoder.OpStructFieldUintPtr:
  3394  			p := load(ctxptr, code.Idx)
  3395  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3396  			b = appendStructKey(ctx, code, b)
  3397  			if p == 0 {
  3398  				b = appendNull(ctx, b)
  3399  			} else {
  3400  				b = appendUint(ctx, b, p, code)
  3401  			}
  3402  			b = appendComma(ctx, b)
  3403  			code = code.Next
  3404  		case encoder.OpStructFieldOmitEmptyUintPtr:
  3405  			p := load(ctxptr, code.Idx)
  3406  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3407  			if p != 0 {
  3408  				b = appendStructKey(ctx, code, b)
  3409  				b = appendUint(ctx, b, p, code)
  3410  				b = appendComma(ctx, b)
  3411  			}
  3412  			code = code.Next
  3413  		case encoder.OpStructFieldUintPtrString:
  3414  			p := load(ctxptr, code.Idx)
  3415  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3416  			b = appendStructKey(ctx, code, b)
  3417  			if p == 0 {
  3418  				b = appendNull(ctx, b)
  3419  			} else {
  3420  				b = append(b, '"')
  3421  				b = appendUint(ctx, b, p, code)
  3422  				b = append(b, '"')
  3423  			}
  3424  			b = appendComma(ctx, b)
  3425  			code = code.Next
  3426  		case encoder.OpStructFieldOmitEmptyUintPtrString:
  3427  			p := load(ctxptr, code.Idx)
  3428  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3429  			if p != 0 {
  3430  				b = appendStructKey(ctx, code, b)
  3431  				b = append(b, '"')
  3432  				b = appendUint(ctx, b, p, code)
  3433  				b = append(b, '"')
  3434  				b = appendComma(ctx, b)
  3435  			}
  3436  			code = code.Next
  3437  		case encoder.OpStructFieldFloat32:
  3438  			p := load(ctxptr, code.Idx)
  3439  			b = appendStructKey(ctx, code, b)
  3440  			b = appendFloat32(ctx, b, ptrToFloat32(p+uintptr(code.Offset)))
  3441  			b = appendComma(ctx, b)
  3442  			code = code.Next
  3443  		case encoder.OpStructFieldOmitEmptyFloat32:
  3444  			p := load(ctxptr, code.Idx)
  3445  			v := ptrToFloat32(p + uintptr(code.Offset))
  3446  			if v != 0 {
  3447  				b = appendStructKey(ctx, code, b)
  3448  				b = appendFloat32(ctx, b, v)
  3449  				b = appendComma(ctx, b)
  3450  			}
  3451  			code = code.Next
  3452  		case encoder.OpStructFieldFloat32String:
  3453  			p := load(ctxptr, code.Idx)
  3454  			b = appendStructKey(ctx, code, b)
  3455  			b = append(b, '"')
  3456  			b = appendFloat32(ctx, b, ptrToFloat32(p+uintptr(code.Offset)))
  3457  			b = append(b, '"')
  3458  			b = appendComma(ctx, b)
  3459  			code = code.Next
  3460  		case encoder.OpStructFieldOmitEmptyFloat32String:
  3461  			p := load(ctxptr, code.Idx)
  3462  			v := ptrToFloat32(p + uintptr(code.Offset))
  3463  			if v != 0 {
  3464  				b = appendStructKey(ctx, code, b)
  3465  				b = append(b, '"')
  3466  				b = appendFloat32(ctx, b, v)
  3467  				b = append(b, '"')
  3468  				b = appendComma(ctx, b)
  3469  			}
  3470  			code = code.Next
  3471  		case encoder.OpStructFieldFloat32Ptr:
  3472  			p := load(ctxptr, code.Idx)
  3473  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3474  			b = appendStructKey(ctx, code, b)
  3475  			if p == 0 {
  3476  				b = appendNull(ctx, b)
  3477  			} else {
  3478  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  3479  			}
  3480  			b = appendComma(ctx, b)
  3481  			code = code.Next
  3482  		case encoder.OpStructFieldOmitEmptyFloat32Ptr:
  3483  			p := load(ctxptr, code.Idx)
  3484  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3485  			if p != 0 {
  3486  				b = appendStructKey(ctx, code, b)
  3487  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  3488  				b = appendComma(ctx, b)
  3489  			}
  3490  			code = code.Next
  3491  		case encoder.OpStructFieldFloat32PtrString:
  3492  			p := load(ctxptr, code.Idx)
  3493  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3494  			b = appendStructKey(ctx, code, b)
  3495  			if p == 0 {
  3496  				b = appendNull(ctx, b)
  3497  			} else {
  3498  				b = append(b, '"')
  3499  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  3500  				b = append(b, '"')
  3501  			}
  3502  			b = appendComma(ctx, b)
  3503  			code = code.Next
  3504  		case encoder.OpStructFieldOmitEmptyFloat32PtrString:
  3505  			p := load(ctxptr, code.Idx)
  3506  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3507  			if p != 0 {
  3508  				b = appendStructKey(ctx, code, b)
  3509  				b = append(b, '"')
  3510  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  3511  				b = append(b, '"')
  3512  				b = appendComma(ctx, b)
  3513  			}
  3514  			code = code.Next
  3515  		case encoder.OpStructFieldFloat64:
  3516  			p := load(ctxptr, code.Idx)
  3517  			b = appendStructKey(ctx, code, b)
  3518  			v := ptrToFloat64(p + uintptr(code.Offset))
  3519  			if math.IsInf(v, 0) || math.IsNaN(v) {
  3520  				return nil, errUnsupportedFloat(v)
  3521  			}
  3522  			b = appendFloat64(ctx, b, v)
  3523  			b = appendComma(ctx, b)
  3524  			code = code.Next
  3525  		case encoder.OpStructFieldOmitEmptyFloat64:
  3526  			p := load(ctxptr, code.Idx)
  3527  			v := ptrToFloat64(p + uintptr(code.Offset))
  3528  			if v != 0 {
  3529  				if math.IsInf(v, 0) || math.IsNaN(v) {
  3530  					return nil, errUnsupportedFloat(v)
  3531  				}
  3532  				b = appendStructKey(ctx, code, b)
  3533  				b = appendFloat64(ctx, b, v)
  3534  				b = appendComma(ctx, b)
  3535  			}
  3536  			code = code.Next
  3537  		case encoder.OpStructFieldFloat64String:
  3538  			p := load(ctxptr, code.Idx)
  3539  			v := ptrToFloat64(p + uintptr(code.Offset))
  3540  			if math.IsInf(v, 0) || math.IsNaN(v) {
  3541  				return nil, errUnsupportedFloat(v)
  3542  			}
  3543  			b = appendStructKey(ctx, code, b)
  3544  			b = append(b, '"')
  3545  			b = appendFloat64(ctx, b, v)
  3546  			b = append(b, '"')
  3547  			b = appendComma(ctx, b)
  3548  			code = code.Next
  3549  		case encoder.OpStructFieldOmitEmptyFloat64String:
  3550  			p := load(ctxptr, code.Idx)
  3551  			v := ptrToFloat64(p + uintptr(code.Offset))
  3552  			if v != 0 {
  3553  				if math.IsInf(v, 0) || math.IsNaN(v) {
  3554  					return nil, errUnsupportedFloat(v)
  3555  				}
  3556  				b = appendStructKey(ctx, code, b)
  3557  				b = append(b, '"')
  3558  				b = appendFloat64(ctx, b, v)
  3559  				b = append(b, '"')
  3560  				b = appendComma(ctx, b)
  3561  			}
  3562  			code = code.Next
  3563  		case encoder.OpStructFieldFloat64Ptr:
  3564  			p := load(ctxptr, code.Idx)
  3565  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3566  			b = appendStructKey(ctx, code, b)
  3567  			if p == 0 {
  3568  				b = appendNullComma(ctx, b)
  3569  				code = code.Next
  3570  				break
  3571  			}
  3572  			v := ptrToFloat64(p)
  3573  			if math.IsInf(v, 0) || math.IsNaN(v) {
  3574  				return nil, errUnsupportedFloat(v)
  3575  			}
  3576  			b = appendFloat64(ctx, b, v)
  3577  			b = appendComma(ctx, b)
  3578  			code = code.Next
  3579  		case encoder.OpStructFieldOmitEmptyFloat64Ptr:
  3580  			p := load(ctxptr, code.Idx)
  3581  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3582  			if p != 0 {
  3583  				b = appendStructKey(ctx, code, b)
  3584  				v := ptrToFloat64(p)
  3585  				if math.IsInf(v, 0) || math.IsNaN(v) {
  3586  					return nil, errUnsupportedFloat(v)
  3587  				}
  3588  				b = appendFloat64(ctx, b, v)
  3589  				b = appendComma(ctx, b)
  3590  			}
  3591  			code = code.Next
  3592  		case encoder.OpStructFieldFloat64PtrString:
  3593  			p := load(ctxptr, code.Idx)
  3594  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3595  			b = appendStructKey(ctx, code, b)
  3596  			if p == 0 {
  3597  				b = appendNull(ctx, b)
  3598  			} else {
  3599  				v := ptrToFloat64(p)
  3600  				if math.IsInf(v, 0) || math.IsNaN(v) {
  3601  					return nil, errUnsupportedFloat(v)
  3602  				}
  3603  				b = append(b, '"')
  3604  				b = appendFloat64(ctx, b, v)
  3605  				b = append(b, '"')
  3606  			}
  3607  			b = appendComma(ctx, b)
  3608  			code = code.Next
  3609  		case encoder.OpStructFieldOmitEmptyFloat64PtrString:
  3610  			p := load(ctxptr, code.Idx)
  3611  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3612  			if p != 0 {
  3613  				b = appendStructKey(ctx, code, b)
  3614  				b = append(b, '"')
  3615  				v := ptrToFloat64(p)
  3616  				if math.IsInf(v, 0) || math.IsNaN(v) {
  3617  					return nil, errUnsupportedFloat(v)
  3618  				}
  3619  				b = appendFloat64(ctx, b, v)
  3620  				b = append(b, '"')
  3621  				b = appendComma(ctx, b)
  3622  			}
  3623  			code = code.Next
  3624  		case encoder.OpStructFieldString:
  3625  			p := load(ctxptr, code.Idx)
  3626  			b = appendStructKey(ctx, code, b)
  3627  			b = appendString(ctx, b, ptrToString(p+uintptr(code.Offset)))
  3628  			b = appendComma(ctx, b)
  3629  			code = code.Next
  3630  		case encoder.OpStructFieldOmitEmptyString:
  3631  			p := load(ctxptr, code.Idx)
  3632  			v := ptrToString(p + uintptr(code.Offset))
  3633  			if v != "" {
  3634  				b = appendStructKey(ctx, code, b)
  3635  				b = appendString(ctx, b, v)
  3636  				b = appendComma(ctx, b)
  3637  			}
  3638  			code = code.Next
  3639  		case encoder.OpStructFieldStringString:
  3640  			p := load(ctxptr, code.Idx)
  3641  			s := ptrToString(p + uintptr(code.Offset))
  3642  			b = appendStructKey(ctx, code, b)
  3643  			b = appendString(ctx, b, string(appendString(ctx, []byte{}, s)))
  3644  			b = appendComma(ctx, b)
  3645  			code = code.Next
  3646  		case encoder.OpStructFieldOmitEmptyStringString:
  3647  			p := load(ctxptr, code.Idx)
  3648  			v := ptrToString(p + uintptr(code.Offset))
  3649  			if v != "" {
  3650  				b = appendStructKey(ctx, code, b)
  3651  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, v)))
  3652  				b = appendComma(ctx, b)
  3653  			}
  3654  			code = code.Next
  3655  		case encoder.OpStructFieldStringPtr:
  3656  			p := load(ctxptr, code.Idx)
  3657  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3658  			b = appendStructKey(ctx, code, b)
  3659  			if p == 0 {
  3660  				b = appendNull(ctx, b)
  3661  			} else {
  3662  				b = appendString(ctx, b, ptrToString(p))
  3663  			}
  3664  			b = appendComma(ctx, b)
  3665  			code = code.Next
  3666  		case encoder.OpStructFieldOmitEmptyStringPtr:
  3667  			p := load(ctxptr, code.Idx)
  3668  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3669  			if p != 0 {
  3670  				b = appendStructKey(ctx, code, b)
  3671  				b = appendString(ctx, b, ptrToString(p))
  3672  				b = appendComma(ctx, b)
  3673  			}
  3674  			code = code.Next
  3675  		case encoder.OpStructFieldStringPtrString:
  3676  			p := load(ctxptr, code.Idx)
  3677  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3678  			b = appendStructKey(ctx, code, b)
  3679  			if p == 0 {
  3680  				b = appendNull(ctx, b)
  3681  			} else {
  3682  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, ptrToString(p))))
  3683  			}
  3684  			b = appendComma(ctx, b)
  3685  			code = code.Next
  3686  		case encoder.OpStructFieldOmitEmptyStringPtrString:
  3687  			p := load(ctxptr, code.Idx)
  3688  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3689  			if p != 0 {
  3690  				b = appendStructKey(ctx, code, b)
  3691  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, ptrToString(p))))
  3692  				b = appendComma(ctx, b)
  3693  			}
  3694  			code = code.Next
  3695  		case encoder.OpStructFieldBool:
  3696  			p := load(ctxptr, code.Idx)
  3697  			b = appendStructKey(ctx, code, b)
  3698  			b = appendBool(ctx, b, ptrToBool(p+uintptr(code.Offset)))
  3699  			b = appendComma(ctx, b)
  3700  			code = code.Next
  3701  		case encoder.OpStructFieldOmitEmptyBool:
  3702  			p := load(ctxptr, code.Idx)
  3703  			v := ptrToBool(p + uintptr(code.Offset))
  3704  			if v {
  3705  				b = appendStructKey(ctx, code, b)
  3706  				b = appendBool(ctx, b, v)
  3707  				b = appendComma(ctx, b)
  3708  			}
  3709  			code = code.Next
  3710  		case encoder.OpStructFieldBoolString:
  3711  			p := load(ctxptr, code.Idx)
  3712  			b = appendStructKey(ctx, code, b)
  3713  			b = append(b, '"')
  3714  			b = appendBool(ctx, b, ptrToBool(p+uintptr(code.Offset)))
  3715  			b = append(b, '"')
  3716  			b = appendComma(ctx, b)
  3717  			code = code.Next
  3718  		case encoder.OpStructFieldOmitEmptyBoolString:
  3719  			p := load(ctxptr, code.Idx)
  3720  			v := ptrToBool(p + uintptr(code.Offset))
  3721  			if v {
  3722  				b = appendStructKey(ctx, code, b)
  3723  				b = append(b, '"')
  3724  				b = appendBool(ctx, b, v)
  3725  				b = append(b, '"')
  3726  				b = appendComma(ctx, b)
  3727  			}
  3728  			code = code.Next
  3729  		case encoder.OpStructFieldBoolPtr:
  3730  			p := load(ctxptr, code.Idx)
  3731  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3732  			b = appendStructKey(ctx, code, b)
  3733  			if p == 0 {
  3734  				b = appendNull(ctx, b)
  3735  			} else {
  3736  				b = appendBool(ctx, b, ptrToBool(p))
  3737  			}
  3738  			b = appendComma(ctx, b)
  3739  			code = code.Next
  3740  		case encoder.OpStructFieldOmitEmptyBoolPtr:
  3741  			p := load(ctxptr, code.Idx)
  3742  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3743  			if p != 0 {
  3744  				b = appendStructKey(ctx, code, b)
  3745  				b = appendBool(ctx, b, ptrToBool(p))
  3746  				b = appendComma(ctx, b)
  3747  			}
  3748  			code = code.Next
  3749  		case encoder.OpStructFieldBoolPtrString:
  3750  			p := load(ctxptr, code.Idx)
  3751  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3752  			b = appendStructKey(ctx, code, b)
  3753  			if p == 0 {
  3754  				b = appendNull(ctx, b)
  3755  			} else {
  3756  				b = append(b, '"')
  3757  				b = appendBool(ctx, b, ptrToBool(p))
  3758  				b = append(b, '"')
  3759  			}
  3760  			b = appendComma(ctx, b)
  3761  			code = code.Next
  3762  		case encoder.OpStructFieldOmitEmptyBoolPtrString:
  3763  			p := load(ctxptr, code.Idx)
  3764  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3765  			if p != 0 {
  3766  				b = appendStructKey(ctx, code, b)
  3767  				b = append(b, '"')
  3768  				b = appendBool(ctx, b, ptrToBool(p))
  3769  				b = append(b, '"')
  3770  				b = appendComma(ctx, b)
  3771  			}
  3772  			code = code.Next
  3773  		case encoder.OpStructFieldBytes:
  3774  			p := load(ctxptr, code.Idx)
  3775  			b = appendStructKey(ctx, code, b)
  3776  			b = appendByteSlice(ctx, b, ptrToBytes(p+uintptr(code.Offset)))
  3777  			b = appendComma(ctx, b)
  3778  			code = code.Next
  3779  		case encoder.OpStructFieldOmitEmptyBytes:
  3780  			p := load(ctxptr, code.Idx)
  3781  			v := ptrToBytes(p + uintptr(code.Offset))
  3782  			if len(v) > 0 {
  3783  				b = appendStructKey(ctx, code, b)
  3784  				b = appendByteSlice(ctx, b, v)
  3785  				b = appendComma(ctx, b)
  3786  			}
  3787  			code = code.Next
  3788  		case encoder.OpStructFieldBytesPtr:
  3789  			p := load(ctxptr, code.Idx)
  3790  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3791  			b = appendStructKey(ctx, code, b)
  3792  			if p == 0 {
  3793  				b = appendNull(ctx, b)
  3794  			} else {
  3795  				b = appendByteSlice(ctx, b, ptrToBytes(p))
  3796  			}
  3797  			b = appendComma(ctx, b)
  3798  			code = code.Next
  3799  		case encoder.OpStructFieldOmitEmptyBytesPtr:
  3800  			p := load(ctxptr, code.Idx)
  3801  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3802  			if p != 0 {
  3803  				b = appendStructKey(ctx, code, b)
  3804  				b = appendByteSlice(ctx, b, ptrToBytes(p))
  3805  				b = appendComma(ctx, b)
  3806  			}
  3807  			code = code.Next
  3808  		case encoder.OpStructFieldNumber:
  3809  			p := load(ctxptr, code.Idx)
  3810  			b = appendStructKey(ctx, code, b)
  3811  			bb, err := appendNumber(ctx, b, ptrToNumber(p+uintptr(code.Offset)))
  3812  			if err != nil {
  3813  				return nil, err
  3814  			}
  3815  			b = appendComma(ctx, bb)
  3816  			code = code.Next
  3817  		case encoder.OpStructFieldOmitEmptyNumber:
  3818  			p := load(ctxptr, code.Idx)
  3819  			v := ptrToNumber(p + uintptr(code.Offset))
  3820  			if v != "" {
  3821  				b = appendStructKey(ctx, code, b)
  3822  				bb, err := appendNumber(ctx, b, v)
  3823  				if err != nil {
  3824  					return nil, err
  3825  				}
  3826  				b = appendComma(ctx, bb)
  3827  			}
  3828  			code = code.Next
  3829  		case encoder.OpStructFieldNumberString:
  3830  			p := load(ctxptr, code.Idx)
  3831  			b = appendStructKey(ctx, code, b)
  3832  			b = append(b, '"')
  3833  			bb, err := appendNumber(ctx, b, ptrToNumber(p+uintptr(code.Offset)))
  3834  			if err != nil {
  3835  				return nil, err
  3836  			}
  3837  			b = append(bb, '"')
  3838  			b = appendComma(ctx, b)
  3839  			code = code.Next
  3840  		case encoder.OpStructFieldOmitEmptyNumberString:
  3841  			p := load(ctxptr, code.Idx)
  3842  			v := ptrToNumber(p + uintptr(code.Offset))
  3843  			if v != "" {
  3844  				b = appendStructKey(ctx, code, b)
  3845  				b = append(b, '"')
  3846  				bb, err := appendNumber(ctx, b, v)
  3847  				if err != nil {
  3848  					return nil, err
  3849  				}
  3850  				b = append(bb, '"')
  3851  				b = appendComma(ctx, b)
  3852  			}
  3853  			code = code.Next
  3854  		case encoder.OpStructFieldNumberPtr:
  3855  			p := load(ctxptr, code.Idx)
  3856  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3857  			b = appendStructKey(ctx, code, b)
  3858  			if p == 0 {
  3859  				b = appendNull(ctx, b)
  3860  			} else {
  3861  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  3862  				if err != nil {
  3863  					return nil, err
  3864  				}
  3865  				b = bb
  3866  			}
  3867  			b = appendComma(ctx, b)
  3868  			code = code.Next
  3869  		case encoder.OpStructFieldOmitEmptyNumberPtr:
  3870  			p := load(ctxptr, code.Idx)
  3871  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3872  			if p != 0 {
  3873  				b = appendStructKey(ctx, code, b)
  3874  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  3875  				if err != nil {
  3876  					return nil, err
  3877  				}
  3878  				b = appendComma(ctx, bb)
  3879  			}
  3880  			code = code.Next
  3881  		case encoder.OpStructFieldNumberPtrString:
  3882  			p := load(ctxptr, code.Idx)
  3883  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3884  			b = appendStructKey(ctx, code, b)
  3885  			if p == 0 {
  3886  				b = appendNull(ctx, b)
  3887  			} else {
  3888  				b = append(b, '"')
  3889  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  3890  				if err != nil {
  3891  					return nil, err
  3892  				}
  3893  				b = append(bb, '"')
  3894  			}
  3895  			b = appendComma(ctx, b)
  3896  			code = code.Next
  3897  		case encoder.OpStructFieldOmitEmptyNumberPtrString:
  3898  			p := load(ctxptr, code.Idx)
  3899  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3900  			if p != 0 {
  3901  				b = appendStructKey(ctx, code, b)
  3902  				b = append(b, '"')
  3903  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  3904  				if err != nil {
  3905  					return nil, err
  3906  				}
  3907  				b = append(bb, '"')
  3908  				b = appendComma(ctx, b)
  3909  			}
  3910  			code = code.Next
  3911  		case encoder.OpStructFieldMarshalJSON:
  3912  			p := load(ctxptr, code.Idx)
  3913  			b = appendStructKey(ctx, code, b)
  3914  			p += uintptr(code.Offset)
  3915  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  3916  				p = ptrToPtr(p)
  3917  			}
  3918  			if p == 0 && (code.Flags&encoder.NilCheckFlags) != 0 {
  3919  				b = appendNull(ctx, b)
  3920  			} else {
  3921  				bb, err := appendMarshalJSON(ctx, code, b, ptrToInterface(code, p))
  3922  				if err != nil {
  3923  					return nil, err
  3924  				}
  3925  				b = bb
  3926  			}
  3927  			b = appendComma(ctx, b)
  3928  			code = code.Next
  3929  		case encoder.OpStructFieldOmitEmptyMarshalJSON:
  3930  			p := load(ctxptr, code.Idx)
  3931  			p += uintptr(code.Offset)
  3932  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  3933  				p = ptrToPtr(p)
  3934  			}
  3935  			if p == 0 && (code.Flags&encoder.NilCheckFlags) != 0 {
  3936  				code = code.NextField
  3937  				break
  3938  			}
  3939  			iface := ptrToInterface(code, p)
  3940  			if (code.Flags&encoder.NilCheckFlags) != 0 && encoder.IsNilForMarshaler(iface) {
  3941  				code = code.NextField
  3942  				break
  3943  			}
  3944  			b = appendStructKey(ctx, code, b)
  3945  			bb, err := appendMarshalJSON(ctx, code, b, iface)
  3946  			if err != nil {
  3947  				return nil, err
  3948  			}
  3949  			b = appendComma(ctx, bb)
  3950  			code = code.Next
  3951  		case encoder.OpStructFieldMarshalJSONPtr:
  3952  			p := load(ctxptr, code.Idx)
  3953  			b = appendStructKey(ctx, code, b)
  3954  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3955  			if p == 0 {
  3956  				b = appendNull(ctx, b)
  3957  			} else {
  3958  				bb, err := appendMarshalJSON(ctx, code, b, ptrToInterface(code, p))
  3959  				if err != nil {
  3960  					return nil, err
  3961  				}
  3962  				b = bb
  3963  			}
  3964  			b = appendComma(ctx, b)
  3965  			code = code.Next
  3966  		case encoder.OpStructFieldOmitEmptyMarshalJSONPtr:
  3967  			p := load(ctxptr, code.Idx)
  3968  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  3969  			if p != 0 {
  3970  				b = appendStructKey(ctx, code, b)
  3971  				bb, err := appendMarshalJSON(ctx, code, b, ptrToInterface(code, p))
  3972  				if err != nil {
  3973  					return nil, err
  3974  				}
  3975  				b = appendComma(ctx, bb)
  3976  			}
  3977  			code = code.Next
  3978  		case encoder.OpStructFieldMarshalText:
  3979  			p := load(ctxptr, code.Idx)
  3980  			b = appendStructKey(ctx, code, b)
  3981  			p += uintptr(code.Offset)
  3982  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  3983  				p = ptrToPtr(p)
  3984  			}
  3985  			if p == 0 && (code.Flags&encoder.NilCheckFlags) != 0 {
  3986  				b = appendNull(ctx, b)
  3987  			} else {
  3988  				bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  3989  				if err != nil {
  3990  					return nil, err
  3991  				}
  3992  				b = bb
  3993  			}
  3994  			b = appendComma(ctx, b)
  3995  			code = code.Next
  3996  		case encoder.OpStructFieldOmitEmptyMarshalText:
  3997  			p := load(ctxptr, code.Idx)
  3998  			p += uintptr(code.Offset)
  3999  			if (code.Flags & encoder.IsNilableTypeFlags) != 0 {
  4000  				p = ptrToPtr(p)
  4001  			}
  4002  			if p == 0 && (code.Flags&encoder.NilCheckFlags) != 0 {
  4003  				code = code.NextField
  4004  				break
  4005  			}
  4006  			b = appendStructKey(ctx, code, b)
  4007  			bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  4008  			if err != nil {
  4009  				return nil, err
  4010  			}
  4011  			b = appendComma(ctx, bb)
  4012  			code = code.Next
  4013  		case encoder.OpStructFieldMarshalTextPtr:
  4014  			p := load(ctxptr, code.Idx)
  4015  			b = appendStructKey(ctx, code, b)
  4016  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4017  			if p == 0 {
  4018  				b = appendNull(ctx, b)
  4019  			} else {
  4020  				bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  4021  				if err != nil {
  4022  					return nil, err
  4023  				}
  4024  				b = bb
  4025  			}
  4026  			b = appendComma(ctx, b)
  4027  			code = code.Next
  4028  		case encoder.OpStructFieldOmitEmptyMarshalTextPtr:
  4029  			p := load(ctxptr, code.Idx)
  4030  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4031  			if p != 0 {
  4032  				b = appendStructKey(ctx, code, b)
  4033  				bb, err := appendMarshalText(ctx, code, b, ptrToInterface(code, p))
  4034  				if err != nil {
  4035  					return nil, err
  4036  				}
  4037  				b = appendComma(ctx, bb)
  4038  			}
  4039  			code = code.Next
  4040  		case encoder.OpStructFieldArray:
  4041  			b = appendStructKey(ctx, code, b)
  4042  			p := load(ctxptr, code.Idx)
  4043  			p += uintptr(code.Offset)
  4044  			code = code.Next
  4045  			store(ctxptr, code.Idx, p)
  4046  		case encoder.OpStructFieldOmitEmptyArray:
  4047  			b = appendStructKey(ctx, code, b)
  4048  			p := load(ctxptr, code.Idx)
  4049  			p += uintptr(code.Offset)
  4050  			code = code.Next
  4051  			store(ctxptr, code.Idx, p)
  4052  		case encoder.OpStructFieldArrayPtr:
  4053  			b = appendStructKey(ctx, code, b)
  4054  			p := load(ctxptr, code.Idx)
  4055  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4056  			code = code.Next
  4057  			store(ctxptr, code.Idx, p)
  4058  		case encoder.OpStructFieldOmitEmptyArrayPtr:
  4059  			p := load(ctxptr, code.Idx)
  4060  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4061  			if p != 0 {
  4062  				b = appendStructKey(ctx, code, b)
  4063  				code = code.Next
  4064  				store(ctxptr, code.Idx, p)
  4065  			} else {
  4066  				code = code.NextField
  4067  			}
  4068  		case encoder.OpStructFieldSlice:
  4069  			b = appendStructKey(ctx, code, b)
  4070  			p := load(ctxptr, code.Idx)
  4071  			p += uintptr(code.Offset)
  4072  			code = code.Next
  4073  			store(ctxptr, code.Idx, p)
  4074  		case encoder.OpStructFieldOmitEmptySlice:
  4075  			p := load(ctxptr, code.Idx)
  4076  			p += uintptr(code.Offset)
  4077  			slice := ptrToSlice(p)
  4078  			if slice.Len == 0 {
  4079  				code = code.NextField
  4080  			} else {
  4081  				b = appendStructKey(ctx, code, b)
  4082  				code = code.Next
  4083  				store(ctxptr, code.Idx, p)
  4084  			}
  4085  		case encoder.OpStructFieldSlicePtr:
  4086  			b = appendStructKey(ctx, code, b)
  4087  			p := load(ctxptr, code.Idx)
  4088  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4089  			code = code.Next
  4090  			store(ctxptr, code.Idx, p)
  4091  		case encoder.OpStructFieldOmitEmptySlicePtr:
  4092  			p := load(ctxptr, code.Idx)
  4093  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4094  			if p != 0 {
  4095  				b = appendStructKey(ctx, code, b)
  4096  				code = code.Next
  4097  				store(ctxptr, code.Idx, p)
  4098  			} else {
  4099  				code = code.NextField
  4100  			}
  4101  		case encoder.OpStructFieldMap:
  4102  			b = appendStructKey(ctx, code, b)
  4103  			p := load(ctxptr, code.Idx)
  4104  			p = ptrToPtr(p + uintptr(code.Offset))
  4105  			code = code.Next
  4106  			store(ctxptr, code.Idx, p)
  4107  		case encoder.OpStructFieldOmitEmptyMap:
  4108  			p := load(ctxptr, code.Idx)
  4109  			p = ptrToPtr(p + uintptr(code.Offset))
  4110  			if p == 0 || maplen(ptrToUnsafePtr(p)) == 0 {
  4111  				code = code.NextField
  4112  			} else {
  4113  				b = appendStructKey(ctx, code, b)
  4114  				code = code.Next
  4115  				store(ctxptr, code.Idx, p)
  4116  			}
  4117  		case encoder.OpStructFieldMapPtr:
  4118  			b = appendStructKey(ctx, code, b)
  4119  			p := load(ctxptr, code.Idx)
  4120  			p = ptrToPtr(p + uintptr(code.Offset))
  4121  			if p != 0 {
  4122  				p = ptrToNPtr(p, code.PtrNum)
  4123  			}
  4124  			code = code.Next
  4125  			store(ctxptr, code.Idx, p)
  4126  		case encoder.OpStructFieldOmitEmptyMapPtr:
  4127  			p := load(ctxptr, code.Idx)
  4128  			p = ptrToPtr(p + uintptr(code.Offset))
  4129  			if p != 0 {
  4130  				p = ptrToNPtr(p, code.PtrNum)
  4131  			}
  4132  			if p != 0 {
  4133  				b = appendStructKey(ctx, code, b)
  4134  				code = code.Next
  4135  				store(ctxptr, code.Idx, p)
  4136  			} else {
  4137  				code = code.NextField
  4138  			}
  4139  		case encoder.OpStructFieldStruct:
  4140  			b = appendStructKey(ctx, code, b)
  4141  			p := load(ctxptr, code.Idx)
  4142  			p += uintptr(code.Offset)
  4143  			code = code.Next
  4144  			store(ctxptr, code.Idx, p)
  4145  		case encoder.OpStructFieldOmitEmptyStruct:
  4146  			p := load(ctxptr, code.Idx)
  4147  			p += uintptr(code.Offset)
  4148  			if ptrToPtr(p) == 0 && (code.Flags&encoder.IsNextOpPtrTypeFlags) != 0 {
  4149  				code = code.NextField
  4150  			} else {
  4151  				b = appendStructKey(ctx, code, b)
  4152  				code = code.Next
  4153  				store(ctxptr, code.Idx, p)
  4154  			}
  4155  		case encoder.OpStructEnd:
  4156  			b = appendStructEndSkipLast(ctx, code, b)
  4157  			code = code.Next
  4158  		case encoder.OpStructEndInt:
  4159  			p := load(ctxptr, code.Idx)
  4160  			b = appendStructKey(ctx, code, b)
  4161  			b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  4162  			b = appendStructEnd(ctx, code, b)
  4163  			code = code.Next
  4164  		case encoder.OpStructEndOmitEmptyInt:
  4165  			p := load(ctxptr, code.Idx)
  4166  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  4167  			v := u64 & ((1 << code.NumBitSize) - 1)
  4168  			if v != 0 {
  4169  				b = appendStructKey(ctx, code, b)
  4170  				b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  4171  				b = appendStructEnd(ctx, code, b)
  4172  			} else {
  4173  				b = appendStructEndSkipLast(ctx, code, b)
  4174  			}
  4175  			code = code.Next
  4176  		case encoder.OpStructEndIntString:
  4177  			p := load(ctxptr, code.Idx)
  4178  			b = appendStructKey(ctx, code, b)
  4179  			b = append(b, '"')
  4180  			b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  4181  			b = append(b, '"')
  4182  			b = appendStructEnd(ctx, code, b)
  4183  			code = code.Next
  4184  		case encoder.OpStructEndOmitEmptyIntString:
  4185  			p := load(ctxptr, code.Idx)
  4186  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  4187  			v := u64 & ((1 << code.NumBitSize) - 1)
  4188  			if v != 0 {
  4189  				b = appendStructKey(ctx, code, b)
  4190  				b = append(b, '"')
  4191  				b = appendInt(ctx, b, p+uintptr(code.Offset), code)
  4192  				b = append(b, '"')
  4193  				b = appendStructEnd(ctx, code, b)
  4194  			} else {
  4195  				b = appendStructEndSkipLast(ctx, code, b)
  4196  			}
  4197  			code = code.Next
  4198  		case encoder.OpStructEndIntPtr:
  4199  			b = appendStructKey(ctx, code, b)
  4200  			p := load(ctxptr, code.Idx)
  4201  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4202  			if p == 0 {
  4203  				b = appendNull(ctx, b)
  4204  			} else {
  4205  				b = appendInt(ctx, b, p, code)
  4206  			}
  4207  			b = appendStructEnd(ctx, code, b)
  4208  			code = code.Next
  4209  		case encoder.OpStructEndOmitEmptyIntPtr:
  4210  			p := load(ctxptr, code.Idx)
  4211  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4212  			if p != 0 {
  4213  				b = appendStructKey(ctx, code, b)
  4214  				b = appendInt(ctx, b, p, code)
  4215  				b = appendStructEnd(ctx, code, b)
  4216  			} else {
  4217  				b = appendStructEndSkipLast(ctx, code, b)
  4218  			}
  4219  			code = code.Next
  4220  		case encoder.OpStructEndIntPtrString:
  4221  			b = appendStructKey(ctx, code, b)
  4222  			p := load(ctxptr, code.Idx)
  4223  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4224  			if p == 0 {
  4225  				b = appendNull(ctx, b)
  4226  			} else {
  4227  				b = append(b, '"')
  4228  				b = appendInt(ctx, b, p, code)
  4229  				b = append(b, '"')
  4230  			}
  4231  			b = appendStructEnd(ctx, code, b)
  4232  			code = code.Next
  4233  		case encoder.OpStructEndOmitEmptyIntPtrString:
  4234  			p := load(ctxptr, code.Idx)
  4235  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4236  			if p != 0 {
  4237  				b = appendStructKey(ctx, code, b)
  4238  				b = append(b, '"')
  4239  				b = appendInt(ctx, b, p, code)
  4240  				b = append(b, '"')
  4241  				b = appendStructEnd(ctx, code, b)
  4242  			} else {
  4243  				b = appendStructEndSkipLast(ctx, code, b)
  4244  			}
  4245  			code = code.Next
  4246  		case encoder.OpStructEndUint:
  4247  			p := load(ctxptr, code.Idx)
  4248  			b = appendStructKey(ctx, code, b)
  4249  			b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  4250  			b = appendStructEnd(ctx, code, b)
  4251  			code = code.Next
  4252  		case encoder.OpStructEndOmitEmptyUint:
  4253  			p := load(ctxptr, code.Idx)
  4254  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  4255  			v := u64 & ((1 << code.NumBitSize) - 1)
  4256  			if v != 0 {
  4257  				b = appendStructKey(ctx, code, b)
  4258  				b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  4259  				b = appendStructEnd(ctx, code, b)
  4260  			} else {
  4261  				b = appendStructEndSkipLast(ctx, code, b)
  4262  			}
  4263  			code = code.Next
  4264  		case encoder.OpStructEndUintString:
  4265  			p := load(ctxptr, code.Idx)
  4266  			b = appendStructKey(ctx, code, b)
  4267  			b = append(b, '"')
  4268  			b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  4269  			b = append(b, '"')
  4270  			b = appendStructEnd(ctx, code, b)
  4271  			code = code.Next
  4272  		case encoder.OpStructEndOmitEmptyUintString:
  4273  			p := load(ctxptr, code.Idx)
  4274  			u64 := ptrToUint64(p+uintptr(code.Offset), code.NumBitSize)
  4275  			v := u64 & ((1 << code.NumBitSize) - 1)
  4276  			if v != 0 {
  4277  				b = appendStructKey(ctx, code, b)
  4278  				b = append(b, '"')
  4279  				b = appendUint(ctx, b, p+uintptr(code.Offset), code)
  4280  				b = append(b, '"')
  4281  				b = appendStructEnd(ctx, code, b)
  4282  			} else {
  4283  				b = appendStructEndSkipLast(ctx, code, b)
  4284  			}
  4285  			code = code.Next
  4286  		case encoder.OpStructEndUintPtr:
  4287  			b = appendStructKey(ctx, code, b)
  4288  			p := load(ctxptr, code.Idx)
  4289  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4290  			if p == 0 {
  4291  				b = appendNull(ctx, b)
  4292  			} else {
  4293  				b = appendUint(ctx, b, p, code)
  4294  			}
  4295  			b = appendStructEnd(ctx, code, b)
  4296  			code = code.Next
  4297  		case encoder.OpStructEndOmitEmptyUintPtr:
  4298  			p := load(ctxptr, code.Idx)
  4299  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4300  			if p != 0 {
  4301  				b = appendStructKey(ctx, code, b)
  4302  				b = appendUint(ctx, b, p, code)
  4303  				b = appendStructEnd(ctx, code, b)
  4304  			} else {
  4305  				b = appendStructEndSkipLast(ctx, code, b)
  4306  			}
  4307  			code = code.Next
  4308  		case encoder.OpStructEndUintPtrString:
  4309  			b = appendStructKey(ctx, code, b)
  4310  			p := load(ctxptr, code.Idx)
  4311  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4312  			if p == 0 {
  4313  				b = appendNull(ctx, b)
  4314  			} else {
  4315  				b = append(b, '"')
  4316  				b = appendUint(ctx, b, p, code)
  4317  				b = append(b, '"')
  4318  			}
  4319  			b = appendStructEnd(ctx, code, b)
  4320  			code = code.Next
  4321  		case encoder.OpStructEndOmitEmptyUintPtrString:
  4322  			p := load(ctxptr, code.Idx)
  4323  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4324  			if p != 0 {
  4325  				b = appendStructKey(ctx, code, b)
  4326  				b = append(b, '"')
  4327  				b = appendUint(ctx, b, p, code)
  4328  				b = append(b, '"')
  4329  				b = appendStructEnd(ctx, code, b)
  4330  			} else {
  4331  				b = appendStructEndSkipLast(ctx, code, b)
  4332  			}
  4333  			code = code.Next
  4334  		case encoder.OpStructEndFloat32:
  4335  			p := load(ctxptr, code.Idx)
  4336  			b = appendStructKey(ctx, code, b)
  4337  			b = appendFloat32(ctx, b, ptrToFloat32(p+uintptr(code.Offset)))
  4338  			b = appendStructEnd(ctx, code, b)
  4339  			code = code.Next
  4340  		case encoder.OpStructEndOmitEmptyFloat32:
  4341  			p := load(ctxptr, code.Idx)
  4342  			v := ptrToFloat32(p + uintptr(code.Offset))
  4343  			if v != 0 {
  4344  				b = appendStructKey(ctx, code, b)
  4345  				b = appendFloat32(ctx, b, v)
  4346  				b = appendStructEnd(ctx, code, b)
  4347  			} else {
  4348  				b = appendStructEndSkipLast(ctx, code, b)
  4349  			}
  4350  			code = code.Next
  4351  		case encoder.OpStructEndFloat32String:
  4352  			p := load(ctxptr, code.Idx)
  4353  			b = appendStructKey(ctx, code, b)
  4354  			b = append(b, '"')
  4355  			b = appendFloat32(ctx, b, ptrToFloat32(p+uintptr(code.Offset)))
  4356  			b = append(b, '"')
  4357  			b = appendStructEnd(ctx, code, b)
  4358  			code = code.Next
  4359  		case encoder.OpStructEndOmitEmptyFloat32String:
  4360  			p := load(ctxptr, code.Idx)
  4361  			v := ptrToFloat32(p + uintptr(code.Offset))
  4362  			if v != 0 {
  4363  				b = appendStructKey(ctx, code, b)
  4364  				b = append(b, '"')
  4365  				b = appendFloat32(ctx, b, v)
  4366  				b = append(b, '"')
  4367  				b = appendStructEnd(ctx, code, b)
  4368  			} else {
  4369  				b = appendStructEndSkipLast(ctx, code, b)
  4370  			}
  4371  			code = code.Next
  4372  		case encoder.OpStructEndFloat32Ptr:
  4373  			b = appendStructKey(ctx, code, b)
  4374  			p := load(ctxptr, code.Idx)
  4375  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4376  			if p == 0 {
  4377  				b = appendNull(ctx, b)
  4378  			} else {
  4379  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  4380  			}
  4381  			b = appendStructEnd(ctx, code, b)
  4382  			code = code.Next
  4383  		case encoder.OpStructEndOmitEmptyFloat32Ptr:
  4384  			p := load(ctxptr, code.Idx)
  4385  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4386  			if p != 0 {
  4387  				b = appendStructKey(ctx, code, b)
  4388  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  4389  				b = appendStructEnd(ctx, code, b)
  4390  			} else {
  4391  				b = appendStructEndSkipLast(ctx, code, b)
  4392  			}
  4393  			code = code.Next
  4394  		case encoder.OpStructEndFloat32PtrString:
  4395  			b = appendStructKey(ctx, code, b)
  4396  			p := load(ctxptr, code.Idx)
  4397  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4398  			if p == 0 {
  4399  				b = appendNull(ctx, b)
  4400  			} else {
  4401  				b = append(b, '"')
  4402  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  4403  				b = append(b, '"')
  4404  			}
  4405  			b = appendStructEnd(ctx, code, b)
  4406  			code = code.Next
  4407  		case encoder.OpStructEndOmitEmptyFloat32PtrString:
  4408  			p := load(ctxptr, code.Idx)
  4409  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4410  			if p != 0 {
  4411  				b = appendStructKey(ctx, code, b)
  4412  				b = append(b, '"')
  4413  				b = appendFloat32(ctx, b, ptrToFloat32(p))
  4414  				b = append(b, '"')
  4415  				b = appendStructEnd(ctx, code, b)
  4416  			} else {
  4417  				b = appendStructEndSkipLast(ctx, code, b)
  4418  			}
  4419  			code = code.Next
  4420  		case encoder.OpStructEndFloat64:
  4421  			p := load(ctxptr, code.Idx)
  4422  			v := ptrToFloat64(p + uintptr(code.Offset))
  4423  			if math.IsInf(v, 0) || math.IsNaN(v) {
  4424  				return nil, errUnsupportedFloat(v)
  4425  			}
  4426  			b = appendStructKey(ctx, code, b)
  4427  			b = appendFloat64(ctx, b, v)
  4428  			b = appendStructEnd(ctx, code, b)
  4429  			code = code.Next
  4430  		case encoder.OpStructEndOmitEmptyFloat64:
  4431  			p := load(ctxptr, code.Idx)
  4432  			v := ptrToFloat64(p + uintptr(code.Offset))
  4433  			if v != 0 {
  4434  				if math.IsInf(v, 0) || math.IsNaN(v) {
  4435  					return nil, errUnsupportedFloat(v)
  4436  				}
  4437  				b = appendStructKey(ctx, code, b)
  4438  				b = appendFloat64(ctx, b, v)
  4439  				b = appendStructEnd(ctx, code, b)
  4440  			} else {
  4441  				b = appendStructEndSkipLast(ctx, code, b)
  4442  			}
  4443  			code = code.Next
  4444  		case encoder.OpStructEndFloat64String:
  4445  			p := load(ctxptr, code.Idx)
  4446  			v := ptrToFloat64(p + uintptr(code.Offset))
  4447  			if math.IsInf(v, 0) || math.IsNaN(v) {
  4448  				return nil, errUnsupportedFloat(v)
  4449  			}
  4450  			b = appendStructKey(ctx, code, b)
  4451  			b = append(b, '"')
  4452  			b = appendFloat64(ctx, b, v)
  4453  			b = append(b, '"')
  4454  			b = appendStructEnd(ctx, code, b)
  4455  			code = code.Next
  4456  		case encoder.OpStructEndOmitEmptyFloat64String:
  4457  			p := load(ctxptr, code.Idx)
  4458  			v := ptrToFloat64(p + uintptr(code.Offset))
  4459  			if v != 0 {
  4460  				if math.IsInf(v, 0) || math.IsNaN(v) {
  4461  					return nil, errUnsupportedFloat(v)
  4462  				}
  4463  				b = appendStructKey(ctx, code, b)
  4464  				b = append(b, '"')
  4465  				b = appendFloat64(ctx, b, v)
  4466  				b = append(b, '"')
  4467  				b = appendStructEnd(ctx, code, b)
  4468  			} else {
  4469  				b = appendStructEndSkipLast(ctx, code, b)
  4470  			}
  4471  			code = code.Next
  4472  		case encoder.OpStructEndFloat64Ptr:
  4473  			b = appendStructKey(ctx, code, b)
  4474  			p := load(ctxptr, code.Idx)
  4475  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4476  			if p == 0 {
  4477  				b = appendNull(ctx, b)
  4478  				b = appendStructEnd(ctx, code, b)
  4479  				code = code.Next
  4480  				break
  4481  			}
  4482  			v := ptrToFloat64(p)
  4483  			if math.IsInf(v, 0) || math.IsNaN(v) {
  4484  				return nil, errUnsupportedFloat(v)
  4485  			}
  4486  			b = appendFloat64(ctx, b, v)
  4487  			b = appendStructEnd(ctx, code, b)
  4488  			code = code.Next
  4489  		case encoder.OpStructEndOmitEmptyFloat64Ptr:
  4490  			p := load(ctxptr, code.Idx)
  4491  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4492  			if p != 0 {
  4493  				b = appendStructKey(ctx, code, b)
  4494  				v := ptrToFloat64(p)
  4495  				if math.IsInf(v, 0) || math.IsNaN(v) {
  4496  					return nil, errUnsupportedFloat(v)
  4497  				}
  4498  				b = appendFloat64(ctx, b, v)
  4499  				b = appendStructEnd(ctx, code, b)
  4500  			} else {
  4501  				b = appendStructEndSkipLast(ctx, code, b)
  4502  			}
  4503  			code = code.Next
  4504  		case encoder.OpStructEndFloat64PtrString:
  4505  			b = appendStructKey(ctx, code, b)
  4506  			p := load(ctxptr, code.Idx)
  4507  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4508  			if p == 0 {
  4509  				b = appendNull(ctx, b)
  4510  			} else {
  4511  				b = append(b, '"')
  4512  				v := ptrToFloat64(p)
  4513  				if math.IsInf(v, 0) || math.IsNaN(v) {
  4514  					return nil, errUnsupportedFloat(v)
  4515  				}
  4516  				b = appendFloat64(ctx, b, v)
  4517  				b = append(b, '"')
  4518  			}
  4519  			b = appendStructEnd(ctx, code, b)
  4520  			code = code.Next
  4521  		case encoder.OpStructEndOmitEmptyFloat64PtrString:
  4522  			p := load(ctxptr, code.Idx)
  4523  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4524  			if p != 0 {
  4525  				b = appendStructKey(ctx, code, b)
  4526  				v := ptrToFloat64(p)
  4527  				if math.IsInf(v, 0) || math.IsNaN(v) {
  4528  					return nil, errUnsupportedFloat(v)
  4529  				}
  4530  				b = append(b, '"')
  4531  				b = appendFloat64(ctx, b, v)
  4532  				b = append(b, '"')
  4533  				b = appendStructEnd(ctx, code, b)
  4534  			} else {
  4535  				b = appendStructEndSkipLast(ctx, code, b)
  4536  			}
  4537  			code = code.Next
  4538  		case encoder.OpStructEndString:
  4539  			p := load(ctxptr, code.Idx)
  4540  			b = appendStructKey(ctx, code, b)
  4541  			b = appendString(ctx, b, ptrToString(p+uintptr(code.Offset)))
  4542  			b = appendStructEnd(ctx, code, b)
  4543  			code = code.Next
  4544  		case encoder.OpStructEndOmitEmptyString:
  4545  			p := load(ctxptr, code.Idx)
  4546  			v := ptrToString(p + uintptr(code.Offset))
  4547  			if v != "" {
  4548  				b = appendStructKey(ctx, code, b)
  4549  				b = appendString(ctx, b, v)
  4550  				b = appendStructEnd(ctx, code, b)
  4551  			} else {
  4552  				b = appendStructEndSkipLast(ctx, code, b)
  4553  			}
  4554  			code = code.Next
  4555  		case encoder.OpStructEndStringString:
  4556  			p := load(ctxptr, code.Idx)
  4557  			b = appendStructKey(ctx, code, b)
  4558  			s := ptrToString(p + uintptr(code.Offset))
  4559  			b = appendString(ctx, b, string(appendString(ctx, []byte{}, s)))
  4560  			b = appendStructEnd(ctx, code, b)
  4561  			code = code.Next
  4562  		case encoder.OpStructEndOmitEmptyStringString:
  4563  			p := load(ctxptr, code.Idx)
  4564  			v := ptrToString(p + uintptr(code.Offset))
  4565  			if v != "" {
  4566  				b = appendStructKey(ctx, code, b)
  4567  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, v)))
  4568  				b = appendStructEnd(ctx, code, b)
  4569  			} else {
  4570  				b = appendStructEndSkipLast(ctx, code, b)
  4571  			}
  4572  			code = code.Next
  4573  		case encoder.OpStructEndStringPtr:
  4574  			b = appendStructKey(ctx, code, b)
  4575  			p := load(ctxptr, code.Idx)
  4576  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4577  			if p == 0 {
  4578  				b = appendNull(ctx, b)
  4579  			} else {
  4580  				b = appendString(ctx, b, ptrToString(p))
  4581  			}
  4582  			b = appendStructEnd(ctx, code, b)
  4583  			code = code.Next
  4584  		case encoder.OpStructEndOmitEmptyStringPtr:
  4585  			p := load(ctxptr, code.Idx)
  4586  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4587  			if p != 0 {
  4588  				b = appendStructKey(ctx, code, b)
  4589  				b = appendString(ctx, b, ptrToString(p))
  4590  				b = appendStructEnd(ctx, code, b)
  4591  			} else {
  4592  				b = appendStructEndSkipLast(ctx, code, b)
  4593  			}
  4594  			code = code.Next
  4595  		case encoder.OpStructEndStringPtrString:
  4596  			b = appendStructKey(ctx, code, b)
  4597  			p := load(ctxptr, code.Idx)
  4598  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4599  			if p == 0 {
  4600  				b = appendNull(ctx, b)
  4601  			} else {
  4602  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, ptrToString(p))))
  4603  			}
  4604  			b = appendStructEnd(ctx, code, b)
  4605  			code = code.Next
  4606  		case encoder.OpStructEndOmitEmptyStringPtrString:
  4607  			p := load(ctxptr, code.Idx)
  4608  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4609  			if p != 0 {
  4610  				b = appendStructKey(ctx, code, b)
  4611  				b = appendString(ctx, b, string(appendString(ctx, []byte{}, ptrToString(p))))
  4612  				b = appendStructEnd(ctx, code, b)
  4613  			} else {
  4614  				b = appendStructEndSkipLast(ctx, code, b)
  4615  			}
  4616  			code = code.Next
  4617  		case encoder.OpStructEndBool:
  4618  			p := load(ctxptr, code.Idx)
  4619  			b = appendStructKey(ctx, code, b)
  4620  			b = appendBool(ctx, b, ptrToBool(p+uintptr(code.Offset)))
  4621  			b = appendStructEnd(ctx, code, b)
  4622  			code = code.Next
  4623  		case encoder.OpStructEndOmitEmptyBool:
  4624  			p := load(ctxptr, code.Idx)
  4625  			v := ptrToBool(p + uintptr(code.Offset))
  4626  			if v {
  4627  				b = appendStructKey(ctx, code, b)
  4628  				b = appendBool(ctx, b, v)
  4629  				b = appendStructEnd(ctx, code, b)
  4630  			} else {
  4631  				b = appendStructEndSkipLast(ctx, code, b)
  4632  			}
  4633  			code = code.Next
  4634  		case encoder.OpStructEndBoolString:
  4635  			p := load(ctxptr, code.Idx)
  4636  			b = appendStructKey(ctx, code, b)
  4637  			b = append(b, '"')
  4638  			b = appendBool(ctx, b, ptrToBool(p+uintptr(code.Offset)))
  4639  			b = append(b, '"')
  4640  			b = appendStructEnd(ctx, code, b)
  4641  			code = code.Next
  4642  		case encoder.OpStructEndOmitEmptyBoolString:
  4643  			p := load(ctxptr, code.Idx)
  4644  			v := ptrToBool(p + uintptr(code.Offset))
  4645  			if v {
  4646  				b = appendStructKey(ctx, code, b)
  4647  				b = append(b, '"')
  4648  				b = appendBool(ctx, b, v)
  4649  				b = append(b, '"')
  4650  				b = appendStructEnd(ctx, code, b)
  4651  			} else {
  4652  				b = appendStructEndSkipLast(ctx, code, b)
  4653  			}
  4654  			code = code.Next
  4655  		case encoder.OpStructEndBoolPtr:
  4656  			b = appendStructKey(ctx, code, b)
  4657  			p := load(ctxptr, code.Idx)
  4658  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4659  			if p == 0 {
  4660  				b = appendNull(ctx, b)
  4661  			} else {
  4662  				b = appendBool(ctx, b, ptrToBool(p))
  4663  			}
  4664  			b = appendStructEnd(ctx, code, b)
  4665  			code = code.Next
  4666  		case encoder.OpStructEndOmitEmptyBoolPtr:
  4667  			p := load(ctxptr, code.Idx)
  4668  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4669  			if p != 0 {
  4670  				b = appendStructKey(ctx, code, b)
  4671  				b = appendBool(ctx, b, ptrToBool(p))
  4672  				b = appendStructEnd(ctx, code, b)
  4673  			} else {
  4674  				b = appendStructEndSkipLast(ctx, code, b)
  4675  			}
  4676  			code = code.Next
  4677  		case encoder.OpStructEndBoolPtrString:
  4678  			b = appendStructKey(ctx, code, b)
  4679  			p := load(ctxptr, code.Idx)
  4680  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4681  			if p == 0 {
  4682  				b = appendNull(ctx, b)
  4683  			} else {
  4684  				b = append(b, '"')
  4685  				b = appendBool(ctx, b, ptrToBool(p))
  4686  				b = append(b, '"')
  4687  			}
  4688  			b = appendStructEnd(ctx, code, b)
  4689  			code = code.Next
  4690  		case encoder.OpStructEndOmitEmptyBoolPtrString:
  4691  			p := load(ctxptr, code.Idx)
  4692  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4693  			if p != 0 {
  4694  				b = appendStructKey(ctx, code, b)
  4695  				b = append(b, '"')
  4696  				b = appendBool(ctx, b, ptrToBool(p))
  4697  				b = append(b, '"')
  4698  				b = appendStructEnd(ctx, code, b)
  4699  			} else {
  4700  				b = appendStructEndSkipLast(ctx, code, b)
  4701  			}
  4702  			code = code.Next
  4703  		case encoder.OpStructEndBytes:
  4704  			p := load(ctxptr, code.Idx)
  4705  			b = appendStructKey(ctx, code, b)
  4706  			b = appendByteSlice(ctx, b, ptrToBytes(p+uintptr(code.Offset)))
  4707  			b = appendStructEnd(ctx, code, b)
  4708  			code = code.Next
  4709  		case encoder.OpStructEndOmitEmptyBytes:
  4710  			p := load(ctxptr, code.Idx)
  4711  			v := ptrToBytes(p + uintptr(code.Offset))
  4712  			if len(v) > 0 {
  4713  				b = appendStructKey(ctx, code, b)
  4714  				b = appendByteSlice(ctx, b, v)
  4715  				b = appendStructEnd(ctx, code, b)
  4716  			} else {
  4717  				b = appendStructEndSkipLast(ctx, code, b)
  4718  			}
  4719  			code = code.Next
  4720  		case encoder.OpStructEndBytesPtr:
  4721  			b = appendStructKey(ctx, code, b)
  4722  			p := load(ctxptr, code.Idx)
  4723  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4724  			if p == 0 {
  4725  				b = appendNull(ctx, b)
  4726  			} else {
  4727  				b = appendByteSlice(ctx, b, ptrToBytes(p))
  4728  			}
  4729  			b = appendStructEnd(ctx, code, b)
  4730  			code = code.Next
  4731  		case encoder.OpStructEndOmitEmptyBytesPtr:
  4732  			p := load(ctxptr, code.Idx)
  4733  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4734  			if p != 0 {
  4735  				b = appendStructKey(ctx, code, b)
  4736  				b = appendByteSlice(ctx, b, ptrToBytes(p))
  4737  				b = appendStructEnd(ctx, code, b)
  4738  			} else {
  4739  				b = appendStructEndSkipLast(ctx, code, b)
  4740  			}
  4741  			code = code.Next
  4742  		case encoder.OpStructEndNumber:
  4743  			p := load(ctxptr, code.Idx)
  4744  			b = appendStructKey(ctx, code, b)
  4745  			bb, err := appendNumber(ctx, b, ptrToNumber(p+uintptr(code.Offset)))
  4746  			if err != nil {
  4747  				return nil, err
  4748  			}
  4749  			b = appendStructEnd(ctx, code, bb)
  4750  			code = code.Next
  4751  		case encoder.OpStructEndOmitEmptyNumber:
  4752  			p := load(ctxptr, code.Idx)
  4753  			v := ptrToNumber(p + uintptr(code.Offset))
  4754  			if v != "" {
  4755  				b = appendStructKey(ctx, code, b)
  4756  				bb, err := appendNumber(ctx, b, v)
  4757  				if err != nil {
  4758  					return nil, err
  4759  				}
  4760  				b = appendStructEnd(ctx, code, bb)
  4761  			} else {
  4762  				b = appendStructEndSkipLast(ctx, code, b)
  4763  			}
  4764  			code = code.Next
  4765  		case encoder.OpStructEndNumberString:
  4766  			p := load(ctxptr, code.Idx)
  4767  			b = appendStructKey(ctx, code, b)
  4768  			b = append(b, '"')
  4769  			bb, err := appendNumber(ctx, b, ptrToNumber(p+uintptr(code.Offset)))
  4770  			if err != nil {
  4771  				return nil, err
  4772  			}
  4773  			b = append(bb, '"')
  4774  			b = appendStructEnd(ctx, code, b)
  4775  			code = code.Next
  4776  		case encoder.OpStructEndOmitEmptyNumberString:
  4777  			p := load(ctxptr, code.Idx)
  4778  			v := ptrToNumber(p + uintptr(code.Offset))
  4779  			if v != "" {
  4780  				b = appendStructKey(ctx, code, b)
  4781  				b = append(b, '"')
  4782  				bb, err := appendNumber(ctx, b, v)
  4783  				if err != nil {
  4784  					return nil, err
  4785  				}
  4786  				b = append(bb, '"')
  4787  				b = appendStructEnd(ctx, code, b)
  4788  			} else {
  4789  				b = appendStructEndSkipLast(ctx, code, b)
  4790  			}
  4791  			code = code.Next
  4792  		case encoder.OpStructEndNumberPtr:
  4793  			b = appendStructKey(ctx, code, b)
  4794  			p := load(ctxptr, code.Idx)
  4795  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4796  			if p == 0 {
  4797  				b = appendNull(ctx, b)
  4798  			} else {
  4799  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  4800  				if err != nil {
  4801  					return nil, err
  4802  				}
  4803  				b = bb
  4804  			}
  4805  			b = appendStructEnd(ctx, code, b)
  4806  			code = code.Next
  4807  		case encoder.OpStructEndOmitEmptyNumberPtr:
  4808  			p := load(ctxptr, code.Idx)
  4809  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4810  			if p != 0 {
  4811  				b = appendStructKey(ctx, code, b)
  4812  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  4813  				if err != nil {
  4814  					return nil, err
  4815  				}
  4816  				b = appendStructEnd(ctx, code, bb)
  4817  			} else {
  4818  				b = appendStructEndSkipLast(ctx, code, b)
  4819  			}
  4820  			code = code.Next
  4821  		case encoder.OpStructEndNumberPtrString:
  4822  			b = appendStructKey(ctx, code, b)
  4823  			p := load(ctxptr, code.Idx)
  4824  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4825  			if p == 0 {
  4826  				b = appendNull(ctx, b)
  4827  			} else {
  4828  				b = append(b, '"')
  4829  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  4830  				if err != nil {
  4831  					return nil, err
  4832  				}
  4833  				b = append(bb, '"')
  4834  			}
  4835  			b = appendStructEnd(ctx, code, b)
  4836  			code = code.Next
  4837  		case encoder.OpStructEndOmitEmptyNumberPtrString:
  4838  			p := load(ctxptr, code.Idx)
  4839  			p = ptrToNPtr(p+uintptr(code.Offset), code.PtrNum)
  4840  			if p != 0 {
  4841  				b = appendStructKey(ctx, code, b)
  4842  				b = append(b, '"')
  4843  				bb, err := appendNumber(ctx, b, ptrToNumber(p))
  4844  				if err != nil {
  4845  					return nil, err
  4846  				}
  4847  				b = append(bb, '"')
  4848  				b = appendStructEnd(ctx, code, b)
  4849  			} else {
  4850  				b = appendStructEndSkipLast(ctx, code, b)
  4851  			}
  4852  			code = code.Next
  4853  		case encoder.OpEnd:
  4854  			goto END
  4855  		}
  4856  	}
  4857  END:
  4858  	return b, nil
  4859  }
  4860  

View as plain text