blob: c5322941e3ced1339a6b4170b43712f8a771701e [file] [log] [blame]
// Copyright 2015 The Vanadium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
// This file was auto-generated by the vanadium vdl tool.
// Package: blobtestsvdl
package blobtestsvdl
import (
"fmt"
"reflect"
"v.io/v23/services/syncbase"
"v.io/v23/vdl"
"v.io/v23/vom"
)
var _ = __VDLInit() // Must be first; see __VDLInit comments for details.
//////////////////////////////////////////////////
// Type definitions
type BlobInfo struct {
Info string
Br syncbase.BlobRef
}
func (BlobInfo) __VDLReflect(struct {
Name string `vdl:"v.io/x/ref/services/syncbase/vsync/testdata.BlobInfo"`
}) {
}
func (m *BlobInfo) FillVDLTarget(t vdl.Target, tt *vdl.Type) error {
fieldsTarget1, err := t.StartFields(tt)
if err != nil {
return err
}
var4 := (m.Info == "")
if var4 {
if err := fieldsTarget1.ZeroField("Info"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget2, fieldTarget3, err := fieldsTarget1.StartField("Info")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
if err := fieldTarget3.FromString(string(m.Info), tt.NonOptional().Field(0).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget2, fieldTarget3); err != nil {
return err
}
}
}
var7 := (m.Br == syncbase.BlobRef(""))
if var7 {
if err := fieldsTarget1.ZeroField("Br"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget5, fieldTarget6, err := fieldsTarget1.StartField("Br")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
if err := m.Br.FillVDLTarget(fieldTarget6, tt.NonOptional().Field(1).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget5, fieldTarget6); err != nil {
return err
}
}
}
if err := t.FinishFields(fieldsTarget1); err != nil {
return err
}
return nil
}
func (m *BlobInfo) MakeVDLTarget() vdl.Target {
return &BlobInfoTarget{Value: m}
}
type BlobInfoTarget struct {
Value *BlobInfo
infoTarget vdl.StringTarget
brTarget syncbase.BlobRefTarget
vdl.TargetBase
vdl.FieldsTargetBase
}
func (t *BlobInfoTarget) StartFields(tt *vdl.Type) (vdl.FieldsTarget, error) {
if ttWant := vdl.TypeOf((*BlobInfo)(nil)).Elem(); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
return t, nil
}
func (t *BlobInfoTarget) StartField(name string) (key, field vdl.Target, _ error) {
switch name {
case "Info":
t.infoTarget.Value = &t.Value.Info
target, err := &t.infoTarget, error(nil)
return nil, target, err
case "Br":
t.brTarget.Value = &t.Value.Br
target, err := &t.brTarget, error(nil)
return nil, target, err
default:
return nil, nil, fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobInfo", name)
}
}
func (t *BlobInfoTarget) FinishField(_, _ vdl.Target) error {
return nil
}
func (t *BlobInfoTarget) ZeroField(name string) error {
switch name {
case "Info":
t.Value.Info = ""
return nil
case "Br":
t.Value.Br = syncbase.BlobRef("")
return nil
default:
return fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobInfo", name)
}
}
func (t *BlobInfoTarget) FinishFields(_ vdl.FieldsTarget) error {
return nil
}
func (x *BlobInfo) VDLRead(dec vdl.Decoder) error {
*x = BlobInfo{}
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible struct %T, from %v", *x, dec.Type())
}
match := 0
for {
f, err := dec.NextField()
if err != nil {
return err
}
switch f {
case "":
if match == 0 && dec.Type().NumField() > 0 {
return fmt.Errorf("no matching fields in struct %T, from %v", *x, dec.Type())
}
return dec.FinishValue()
case "Info":
match++
if err = dec.StartValue(); err != nil {
return err
}
if x.Info, err = dec.DecodeString(); err != nil {
return err
}
if err = dec.FinishValue(); err != nil {
return err
}
case "Br":
match++
if err = x.Br.VDLRead(dec); err != nil {
return err
}
default:
if err = dec.SkipValue(); err != nil {
return err
}
}
}
}
type (
// BlobUnion represents any single field of the BlobUnion union type.
BlobUnion interface {
// Index returns the field index.
Index() int
// Interface returns the field value as an interface.
Interface() interface{}
// Name returns the field name.
Name() string
// __VDLReflect describes the BlobUnion union type.
__VDLReflect(__BlobUnionReflect)
FillVDLTarget(vdl.Target, *vdl.Type) error
}
// BlobUnionNum represents field Num of the BlobUnion union type.
BlobUnionNum struct{ Value int32 }
// BlobUnionBi represents field Bi of the BlobUnion union type.
BlobUnionBi struct{ Value BlobInfo }
// __BlobUnionReflect describes the BlobUnion union type.
__BlobUnionReflect struct {
Name string `vdl:"v.io/x/ref/services/syncbase/vsync/testdata.BlobUnion"`
Type BlobUnion
UnionTargetFactory blobUnionTargetFactory
Union struct {
Num BlobUnionNum
Bi BlobUnionBi
}
}
)
func (x BlobUnionNum) Index() int { return 0 }
func (x BlobUnionNum) Interface() interface{} { return x.Value }
func (x BlobUnionNum) Name() string { return "Num" }
func (x BlobUnionNum) __VDLReflect(__BlobUnionReflect) {}
func (m BlobUnionNum) FillVDLTarget(t vdl.Target, tt *vdl.Type) error {
fieldsTarget1, err := t.StartFields(tt)
if err != nil {
return err
}
keyTarget2, fieldTarget3, err := fieldsTarget1.StartField("Num")
if err != nil {
return err
}
if err := fieldTarget3.FromInt(int64(m.Value), tt.NonOptional().Field(0).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget2, fieldTarget3); err != nil {
return err
}
if err := t.FinishFields(fieldsTarget1); err != nil {
return err
}
return nil
}
func (m BlobUnionNum) MakeVDLTarget() vdl.Target {
return nil
}
func (x BlobUnionBi) Index() int { return 1 }
func (x BlobUnionBi) Interface() interface{} { return x.Value }
func (x BlobUnionBi) Name() string { return "Bi" }
func (x BlobUnionBi) __VDLReflect(__BlobUnionReflect) {}
func (m BlobUnionBi) FillVDLTarget(t vdl.Target, tt *vdl.Type) error {
fieldsTarget1, err := t.StartFields(tt)
if err != nil {
return err
}
keyTarget2, fieldTarget3, err := fieldsTarget1.StartField("Bi")
if err != nil {
return err
}
if err := m.Value.FillVDLTarget(fieldTarget3, tt.NonOptional().Field(1).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget2, fieldTarget3); err != nil {
return err
}
if err := t.FinishFields(fieldsTarget1); err != nil {
return err
}
return nil
}
func (m BlobUnionBi) MakeVDLTarget() vdl.Target {
return nil
}
type BlobUnionTarget struct {
Value *BlobUnion
fieldName string
vdl.TargetBase
vdl.FieldsTargetBase
}
func (t *BlobUnionTarget) StartFields(tt *vdl.Type) (vdl.FieldsTarget, error) {
if ttWant := vdl.TypeOf((*BlobUnion)(nil)); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
return t, nil
}
func (t *BlobUnionTarget) StartField(name string) (key, field vdl.Target, _ error) {
t.fieldName = name
switch name {
case "Num":
val := int32(0)
return nil, &vdl.Int32Target{Value: &val}, nil
case "Bi":
val := BlobInfo{}
return nil, &BlobInfoTarget{Value: &val}, nil
default:
return nil, nil, fmt.Errorf("field %s not in union v.io/x/ref/services/syncbase/vsync/testdata.BlobUnion", name)
}
}
func (t *BlobUnionTarget) FinishField(_, fieldTarget vdl.Target) error {
switch t.fieldName {
case "Num":
*t.Value = BlobUnionNum{*(fieldTarget.(*vdl.Int32Target)).Value}
case "Bi":
*t.Value = BlobUnionBi{*(fieldTarget.(*BlobInfoTarget)).Value}
}
return nil
}
func (t *BlobUnionTarget) FinishFields(_ vdl.FieldsTarget) error {
return nil
}
type blobUnionTargetFactory struct{}
func (t blobUnionTargetFactory) VDLMakeUnionTarget(union interface{}) (vdl.Target, error) {
if typedUnion, ok := union.(*BlobUnion); ok {
return &BlobUnionTarget{Value: typedUnion}, nil
}
return nil, fmt.Errorf("got %T, want *BlobUnion", union)
}
func VDLReadBlobUnion(dec vdl.Decoder, x *BlobUnion) error {
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(x), dec.Type()) {
return fmt.Errorf("incompatible union %T, from %v", x, dec.Type())
}
f, err := dec.NextField()
if err != nil {
return err
}
switch f {
case "Num":
var field BlobUnionNum
if err = dec.StartValue(); err != nil {
return err
}
tmp, err := dec.DecodeInt(32)
if err != nil {
return err
}
field.Value = int32(tmp)
if err = dec.FinishValue(); err != nil {
return err
}
*x = field
case "Bi":
var field BlobUnionBi
if err = field.Value.VDLRead(dec); err != nil {
return err
}
*x = field
case "":
return fmt.Errorf("missing field in union %T, from %v", x, dec.Type())
default:
return fmt.Errorf("field %q not in union %T, from %v", f, x, dec.Type())
}
switch f, err := dec.NextField(); {
case err != nil:
return err
case f != "":
return fmt.Errorf("extra field %q in union %T, from %v", f, x, dec.Type())
}
return dec.FinishValue()
}
type BlobSet struct {
Info string
Bs map[syncbase.BlobRef]struct{}
}
func (BlobSet) __VDLReflect(struct {
Name string `vdl:"v.io/x/ref/services/syncbase/vsync/testdata.BlobSet"`
}) {
}
func (m *BlobSet) FillVDLTarget(t vdl.Target, tt *vdl.Type) error {
fieldsTarget1, err := t.StartFields(tt)
if err != nil {
return err
}
var4 := (m.Info == "")
if var4 {
if err := fieldsTarget1.ZeroField("Info"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget2, fieldTarget3, err := fieldsTarget1.StartField("Info")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
if err := fieldTarget3.FromString(string(m.Info), tt.NonOptional().Field(0).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget2, fieldTarget3); err != nil {
return err
}
}
}
var var7 bool
if len(m.Bs) == 0 {
var7 = true
}
if var7 {
if err := fieldsTarget1.ZeroField("Bs"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget5, fieldTarget6, err := fieldsTarget1.StartField("Bs")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
setTarget8, err := fieldTarget6.StartSet(tt.NonOptional().Field(1).Type, len(m.Bs))
if err != nil {
return err
}
for key10 := range m.Bs {
keyTarget9, err := setTarget8.StartKey()
if err != nil {
return err
}
if err := key10.FillVDLTarget(keyTarget9, tt.NonOptional().Field(1).Type.Key()); err != nil {
return err
}
if err := setTarget8.FinishKey(keyTarget9); err != nil {
return err
}
}
if err := fieldTarget6.FinishSet(setTarget8); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget5, fieldTarget6); err != nil {
return err
}
}
}
if err := t.FinishFields(fieldsTarget1); err != nil {
return err
}
return nil
}
func (m *BlobSet) MakeVDLTarget() vdl.Target {
return &BlobSetTarget{Value: m}
}
type BlobSetTarget struct {
Value *BlobSet
infoTarget vdl.StringTarget
bsTarget __VDLTarget1_set
vdl.TargetBase
vdl.FieldsTargetBase
}
func (t *BlobSetTarget) StartFields(tt *vdl.Type) (vdl.FieldsTarget, error) {
if ttWant := vdl.TypeOf((*BlobSet)(nil)).Elem(); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
return t, nil
}
func (t *BlobSetTarget) StartField(name string) (key, field vdl.Target, _ error) {
switch name {
case "Info":
t.infoTarget.Value = &t.Value.Info
target, err := &t.infoTarget, error(nil)
return nil, target, err
case "Bs":
t.bsTarget.Value = &t.Value.Bs
target, err := &t.bsTarget, error(nil)
return nil, target, err
default:
return nil, nil, fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobSet", name)
}
}
func (t *BlobSetTarget) FinishField(_, _ vdl.Target) error {
return nil
}
func (t *BlobSetTarget) ZeroField(name string) error {
switch name {
case "Info":
t.Value.Info = ""
return nil
case "Bs":
t.Value.Bs = map[syncbase.BlobRef]struct{}(nil)
return nil
default:
return fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobSet", name)
}
}
func (t *BlobSetTarget) FinishFields(_ vdl.FieldsTarget) error {
return nil
}
// map[syncbase.BlobRef]struct{}
type __VDLTarget1_set struct {
Value *map[syncbase.BlobRef]struct{}
currKey syncbase.BlobRef
keyTarget syncbase.BlobRefTarget
vdl.TargetBase
vdl.SetTargetBase
}
func (t *__VDLTarget1_set) StartSet(tt *vdl.Type, len int) (vdl.SetTarget, error) {
if ttWant := vdl.TypeOf((*map[syncbase.BlobRef]struct{})(nil)); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
*t.Value = make(map[syncbase.BlobRef]struct{})
return t, nil
}
func (t *__VDLTarget1_set) StartKey() (key vdl.Target, _ error) {
t.currKey = syncbase.BlobRef("")
t.keyTarget.Value = &t.currKey
target, err := &t.keyTarget, error(nil)
return target, err
}
func (t *__VDLTarget1_set) FinishKey(key vdl.Target) error {
(*t.Value)[t.currKey] = struct{}{}
return nil
}
func (t *__VDLTarget1_set) FinishSet(list vdl.SetTarget) error {
if len(*t.Value) == 0 {
*t.Value = nil
}
return nil
}
func (x *BlobSet) VDLRead(dec vdl.Decoder) error {
*x = BlobSet{}
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible struct %T, from %v", *x, dec.Type())
}
match := 0
for {
f, err := dec.NextField()
if err != nil {
return err
}
switch f {
case "":
if match == 0 && dec.Type().NumField() > 0 {
return fmt.Errorf("no matching fields in struct %T, from %v", *x, dec.Type())
}
return dec.FinishValue()
case "Info":
match++
if err = dec.StartValue(); err != nil {
return err
}
if x.Info, err = dec.DecodeString(); err != nil {
return err
}
if err = dec.FinishValue(); err != nil {
return err
}
case "Bs":
match++
if err = __VDLRead1_set(dec, &x.Bs); err != nil {
return err
}
default:
if err = dec.SkipValue(); err != nil {
return err
}
}
}
}
func __VDLRead1_set(dec vdl.Decoder, x *map[syncbase.BlobRef]struct{}) error {
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible set %T, from %v", *x, dec.Type())
}
switch len := dec.LenHint(); {
case len == 0:
*x = nil
return dec.FinishValue()
case len > 0:
*x = make(map[syncbase.BlobRef]struct{}, len)
default:
*x = make(map[syncbase.BlobRef]struct{})
}
for {
switch done, err := dec.NextEntry(); {
case err != nil:
return err
case done:
return dec.FinishValue()
}
var key syncbase.BlobRef
{
if err = key.VDLRead(dec); err != nil {
return err
}
}
(*x)[key] = struct{}{}
}
}
type BlobAny struct {
Info string
Baa []*vom.RawBytes
}
func (BlobAny) __VDLReflect(struct {
Name string `vdl:"v.io/x/ref/services/syncbase/vsync/testdata.BlobAny"`
}) {
}
func (m *BlobAny) FillVDLTarget(t vdl.Target, tt *vdl.Type) error {
fieldsTarget1, err := t.StartFields(tt)
if err != nil {
return err
}
var4 := (m.Info == "")
if var4 {
if err := fieldsTarget1.ZeroField("Info"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget2, fieldTarget3, err := fieldsTarget1.StartField("Info")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
if err := fieldTarget3.FromString(string(m.Info), tt.NonOptional().Field(0).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget2, fieldTarget3); err != nil {
return err
}
}
}
var var7 bool
if len(m.Baa) == 0 {
var7 = true
}
if var7 {
if err := fieldsTarget1.ZeroField("Baa"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget5, fieldTarget6, err := fieldsTarget1.StartField("Baa")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
listTarget8, err := fieldTarget6.StartList(tt.NonOptional().Field(1).Type, len(m.Baa))
if err != nil {
return err
}
for i, elem10 := range m.Baa {
elemTarget9, err := listTarget8.StartElem(i)
if err != nil {
return err
}
if err := elem10.FillVDLTarget(elemTarget9, tt.NonOptional().Field(1).Type.Elem()); err != nil {
return err
}
if err := listTarget8.FinishElem(elemTarget9); err != nil {
return err
}
}
if err := fieldTarget6.FinishList(listTarget8); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget5, fieldTarget6); err != nil {
return err
}
}
}
if err := t.FinishFields(fieldsTarget1); err != nil {
return err
}
return nil
}
func (m *BlobAny) MakeVDLTarget() vdl.Target {
return &BlobAnyTarget{Value: m}
}
type BlobAnyTarget struct {
Value *BlobAny
infoTarget vdl.StringTarget
baaTarget __VDLTarget2_list
vdl.TargetBase
vdl.FieldsTargetBase
}
func (t *BlobAnyTarget) StartFields(tt *vdl.Type) (vdl.FieldsTarget, error) {
if ttWant := vdl.TypeOf((*BlobAny)(nil)).Elem(); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
return t, nil
}
func (t *BlobAnyTarget) StartField(name string) (key, field vdl.Target, _ error) {
switch name {
case "Info":
t.infoTarget.Value = &t.Value.Info
target, err := &t.infoTarget, error(nil)
return nil, target, err
case "Baa":
t.baaTarget.Value = &t.Value.Baa
target, err := &t.baaTarget, error(nil)
return nil, target, err
default:
return nil, nil, fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobAny", name)
}
}
func (t *BlobAnyTarget) FinishField(_, _ vdl.Target) error {
return nil
}
func (t *BlobAnyTarget) ZeroField(name string) error {
switch name {
case "Info":
t.Value.Info = ""
return nil
case "Baa":
t.Value.Baa = []*vom.RawBytes(nil)
return nil
default:
return fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobAny", name)
}
}
func (t *BlobAnyTarget) FinishFields(_ vdl.FieldsTarget) error {
return nil
}
// []*vom.RawBytes
type __VDLTarget2_list struct {
Value *[]*vom.RawBytes
vdl.TargetBase
vdl.ListTargetBase
}
func (t *__VDLTarget2_list) StartList(tt *vdl.Type, len int) (vdl.ListTarget, error) {
if ttWant := vdl.TypeOf((*[]*vom.RawBytes)(nil)); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
if cap(*t.Value) < len {
*t.Value = make([]*vom.RawBytes, len)
} else {
*t.Value = (*t.Value)[:len]
}
return t, nil
}
func (t *__VDLTarget2_list) StartElem(index int) (elem vdl.Target, _ error) {
target, err := vdl.ReflectTarget(reflect.ValueOf(&(*t.Value)[index]))
return target, err
}
func (t *__VDLTarget2_list) FinishElem(elem vdl.Target) error {
return nil
}
func (t *__VDLTarget2_list) FinishList(elem vdl.ListTarget) error {
return nil
}
func (x *BlobAny) VDLRead(dec vdl.Decoder) error {
*x = BlobAny{}
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible struct %T, from %v", *x, dec.Type())
}
match := 0
for {
f, err := dec.NextField()
if err != nil {
return err
}
switch f {
case "":
if match == 0 && dec.Type().NumField() > 0 {
return fmt.Errorf("no matching fields in struct %T, from %v", *x, dec.Type())
}
return dec.FinishValue()
case "Info":
match++
if err = dec.StartValue(); err != nil {
return err
}
if x.Info, err = dec.DecodeString(); err != nil {
return err
}
if err = dec.FinishValue(); err != nil {
return err
}
case "Baa":
match++
if err = __VDLRead2_list(dec, &x.Baa); err != nil {
return err
}
default:
if err = dec.SkipValue(); err != nil {
return err
}
}
}
}
func __VDLRead2_list(dec vdl.Decoder, x *[]*vom.RawBytes) error {
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible list %T, from %v", *x, dec.Type())
}
switch len := dec.LenHint(); {
case len == 0:
*x = nil
case len > 0:
*x = make([]*vom.RawBytes, 0, len)
}
for {
switch done, err := dec.NextEntry(); {
case err != nil:
return err
case done:
return dec.FinishValue()
}
var elem *vom.RawBytes
// TODO(toddw): implement any
*x = append(*x, elem)
}
}
type NonBlobSet struct {
Info string
S map[string]struct{}
}
func (NonBlobSet) __VDLReflect(struct {
Name string `vdl:"v.io/x/ref/services/syncbase/vsync/testdata.NonBlobSet"`
}) {
}
func (m *NonBlobSet) FillVDLTarget(t vdl.Target, tt *vdl.Type) error {
fieldsTarget1, err := t.StartFields(tt)
if err != nil {
return err
}
var4 := (m.Info == "")
if var4 {
if err := fieldsTarget1.ZeroField("Info"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget2, fieldTarget3, err := fieldsTarget1.StartField("Info")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
if err := fieldTarget3.FromString(string(m.Info), tt.NonOptional().Field(0).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget2, fieldTarget3); err != nil {
return err
}
}
}
var var7 bool
if len(m.S) == 0 {
var7 = true
}
if var7 {
if err := fieldsTarget1.ZeroField("S"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget5, fieldTarget6, err := fieldsTarget1.StartField("S")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
setTarget8, err := fieldTarget6.StartSet(tt.NonOptional().Field(1).Type, len(m.S))
if err != nil {
return err
}
for key10 := range m.S {
keyTarget9, err := setTarget8.StartKey()
if err != nil {
return err
}
if err := keyTarget9.FromString(string(key10), tt.NonOptional().Field(1).Type.Key()); err != nil {
return err
}
if err := setTarget8.FinishKey(keyTarget9); err != nil {
return err
}
}
if err := fieldTarget6.FinishSet(setTarget8); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget5, fieldTarget6); err != nil {
return err
}
}
}
if err := t.FinishFields(fieldsTarget1); err != nil {
return err
}
return nil
}
func (m *NonBlobSet) MakeVDLTarget() vdl.Target {
return &NonBlobSetTarget{Value: m}
}
type NonBlobSetTarget struct {
Value *NonBlobSet
infoTarget vdl.StringTarget
sTarget __VDLTarget3_set
vdl.TargetBase
vdl.FieldsTargetBase
}
func (t *NonBlobSetTarget) StartFields(tt *vdl.Type) (vdl.FieldsTarget, error) {
if ttWant := vdl.TypeOf((*NonBlobSet)(nil)).Elem(); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
return t, nil
}
func (t *NonBlobSetTarget) StartField(name string) (key, field vdl.Target, _ error) {
switch name {
case "Info":
t.infoTarget.Value = &t.Value.Info
target, err := &t.infoTarget, error(nil)
return nil, target, err
case "S":
t.sTarget.Value = &t.Value.S
target, err := &t.sTarget, error(nil)
return nil, target, err
default:
return nil, nil, fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.NonBlobSet", name)
}
}
func (t *NonBlobSetTarget) FinishField(_, _ vdl.Target) error {
return nil
}
func (t *NonBlobSetTarget) ZeroField(name string) error {
switch name {
case "Info":
t.Value.Info = ""
return nil
case "S":
t.Value.S = map[string]struct{}(nil)
return nil
default:
return fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.NonBlobSet", name)
}
}
func (t *NonBlobSetTarget) FinishFields(_ vdl.FieldsTarget) error {
return nil
}
// map[string]struct{}
type __VDLTarget3_set struct {
Value *map[string]struct{}
currKey string
keyTarget vdl.StringTarget
vdl.TargetBase
vdl.SetTargetBase
}
func (t *__VDLTarget3_set) StartSet(tt *vdl.Type, len int) (vdl.SetTarget, error) {
if ttWant := vdl.TypeOf((*map[string]struct{})(nil)); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
*t.Value = make(map[string]struct{})
return t, nil
}
func (t *__VDLTarget3_set) StartKey() (key vdl.Target, _ error) {
t.currKey = ""
t.keyTarget.Value = &t.currKey
target, err := &t.keyTarget, error(nil)
return target, err
}
func (t *__VDLTarget3_set) FinishKey(key vdl.Target) error {
(*t.Value)[t.currKey] = struct{}{}
return nil
}
func (t *__VDLTarget3_set) FinishSet(list vdl.SetTarget) error {
if len(*t.Value) == 0 {
*t.Value = nil
}
return nil
}
func (x *NonBlobSet) VDLRead(dec vdl.Decoder) error {
*x = NonBlobSet{}
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible struct %T, from %v", *x, dec.Type())
}
match := 0
for {
f, err := dec.NextField()
if err != nil {
return err
}
switch f {
case "":
if match == 0 && dec.Type().NumField() > 0 {
return fmt.Errorf("no matching fields in struct %T, from %v", *x, dec.Type())
}
return dec.FinishValue()
case "Info":
match++
if err = dec.StartValue(); err != nil {
return err
}
if x.Info, err = dec.DecodeString(); err != nil {
return err
}
if err = dec.FinishValue(); err != nil {
return err
}
case "S":
match++
if err = __VDLRead3_set(dec, &x.S); err != nil {
return err
}
default:
if err = dec.SkipValue(); err != nil {
return err
}
}
}
}
func __VDLRead3_set(dec vdl.Decoder, x *map[string]struct{}) error {
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible set %T, from %v", *x, dec.Type())
}
switch len := dec.LenHint(); {
case len == 0:
*x = nil
return dec.FinishValue()
case len > 0:
*x = make(map[string]struct{}, len)
default:
*x = make(map[string]struct{})
}
for {
switch done, err := dec.NextEntry(); {
case err != nil:
return err
case done:
return dec.FinishValue()
}
var key string
{
if err = dec.StartValue(); err != nil {
return err
}
if key, err = dec.DecodeString(); err != nil {
return err
}
if err = dec.FinishValue(); err != nil {
return err
}
}
(*x)[key] = struct{}{}
}
}
type BlobOpt struct {
Info string
Bo *BlobInfo
}
func (BlobOpt) __VDLReflect(struct {
Name string `vdl:"v.io/x/ref/services/syncbase/vsync/testdata.BlobOpt"`
}) {
}
func (m *BlobOpt) FillVDLTarget(t vdl.Target, tt *vdl.Type) error {
fieldsTarget1, err := t.StartFields(tt)
if err != nil {
return err
}
var4 := (m.Info == "")
if var4 {
if err := fieldsTarget1.ZeroField("Info"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget2, fieldTarget3, err := fieldsTarget1.StartField("Info")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
if err := fieldTarget3.FromString(string(m.Info), tt.NonOptional().Field(0).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget2, fieldTarget3); err != nil {
return err
}
}
}
var7 := (m.Bo == (*BlobInfo)(nil))
if var7 {
if err := fieldsTarget1.ZeroField("Bo"); err != nil && err != vdl.ErrFieldNoExist {
return err
}
} else {
keyTarget5, fieldTarget6, err := fieldsTarget1.StartField("Bo")
if err != vdl.ErrFieldNoExist {
if err != nil {
return err
}
if err := m.Bo.FillVDLTarget(fieldTarget6, tt.NonOptional().Field(1).Type); err != nil {
return err
}
if err := fieldsTarget1.FinishField(keyTarget5, fieldTarget6); err != nil {
return err
}
}
}
if err := t.FinishFields(fieldsTarget1); err != nil {
return err
}
return nil
}
func (m *BlobOpt) MakeVDLTarget() vdl.Target {
return &BlobOptTarget{Value: m}
}
type BlobOptTarget struct {
Value *BlobOpt
infoTarget vdl.StringTarget
boTarget __VDLTarget4_optional
vdl.TargetBase
vdl.FieldsTargetBase
}
func (t *BlobOptTarget) StartFields(tt *vdl.Type) (vdl.FieldsTarget, error) {
if ttWant := vdl.TypeOf((*BlobOpt)(nil)).Elem(); !vdl.Compatible(tt, ttWant) {
return nil, fmt.Errorf("type %v incompatible with %v", tt, ttWant)
}
return t, nil
}
func (t *BlobOptTarget) StartField(name string) (key, field vdl.Target, _ error) {
switch name {
case "Info":
t.infoTarget.Value = &t.Value.Info
target, err := &t.infoTarget, error(nil)
return nil, target, err
case "Bo":
t.boTarget.Value = &t.Value.Bo
target, err := &t.boTarget, error(nil)
return nil, target, err
default:
return nil, nil, fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobOpt", name)
}
}
func (t *BlobOptTarget) FinishField(_, _ vdl.Target) error {
return nil
}
func (t *BlobOptTarget) ZeroField(name string) error {
switch name {
case "Info":
t.Value.Info = ""
return nil
case "Bo":
t.Value.Bo = (*BlobInfo)(nil)
return nil
default:
return fmt.Errorf("field %s not in struct v.io/x/ref/services/syncbase/vsync/testdata.BlobOpt", name)
}
}
func (t *BlobOptTarget) FinishFields(_ vdl.FieldsTarget) error {
return nil
}
// Optional BlobInfo
type __VDLTarget4_optional struct {
Value **BlobInfo
elemTarget BlobInfoTarget
vdl.TargetBase
vdl.FieldsTargetBase
}
func (t *__VDLTarget4_optional) StartFields(tt *vdl.Type) (vdl.FieldsTarget, error) {
if *t.Value == nil {
*t.Value = &BlobInfo{}
}
t.elemTarget.Value = *t.Value
target, err := &t.elemTarget, error(nil)
if err != nil {
return nil, err
}
return target.StartFields(tt)
}
func (t *__VDLTarget4_optional) FinishFields(_ vdl.FieldsTarget) error {
return nil
}
func (t *__VDLTarget4_optional) FromNil(tt *vdl.Type) error {
*t.Value = (*BlobInfo)(nil)
return nil
}
func (x *BlobOpt) VDLRead(dec vdl.Decoder) error {
*x = BlobOpt{}
var err error
if err = dec.StartValue(); err != nil {
return err
}
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(*x), dec.Type()) {
return fmt.Errorf("incompatible struct %T, from %v", *x, dec.Type())
}
match := 0
for {
f, err := dec.NextField()
if err != nil {
return err
}
switch f {
case "":
if match == 0 && dec.Type().NumField() > 0 {
return fmt.Errorf("no matching fields in struct %T, from %v", *x, dec.Type())
}
return dec.FinishValue()
case "Info":
match++
if err = dec.StartValue(); err != nil {
return err
}
if x.Info, err = dec.DecodeString(); err != nil {
return err
}
if err = dec.FinishValue(); err != nil {
return err
}
case "Bo":
match++
if err = dec.StartValue(); err != nil {
return err
}
if dec.IsNil() {
if (dec.StackDepth() == 1 || dec.IsAny()) && !vdl.Compatible(vdl.TypeOf(x.Bo), dec.Type()) {
return fmt.Errorf("incompatible optional %T, from %v", x.Bo, dec.Type())
}
x.Bo = nil
if err = dec.FinishValue(); err != nil {
return err
}
} else {
x.Bo = new(BlobInfo)
dec.IgnoreNextStartValue()
if err = x.Bo.VDLRead(dec); err != nil {
return err
}
}
default:
if err = dec.SkipValue(); err != nil {
return err
}
}
}
}
var __VDLInitCalled bool
// __VDLInit performs vdl initialization. It is safe to call multiple times.
// If you have an init ordering issue, just insert the following line verbatim
// into your source files in this package, right after the "package foo" clause:
//
// var _ = __VDLInit()
//
// The purpose of this function is to ensure that vdl initialization occurs in
// the right order, and very early in the init sequence. In particular, vdl
// registration and package variable initialization needs to occur before
// functions like vdl.TypeOf will work properly.
//
// This function returns a dummy value, so that it can be used to initialize the
// first var in the file, to take advantage of Go's defined init order.
func __VDLInit() struct{} {
if __VDLInitCalled {
return struct{}{}
}
__VDLInitCalled = true
// Register types.
vdl.Register((*BlobInfo)(nil))
vdl.Register((*BlobUnion)(nil))
vdl.Register((*BlobSet)(nil))
vdl.Register((*BlobAny)(nil))
vdl.Register((*NonBlobSet)(nil))
vdl.Register((*BlobOpt)(nil))
return struct{}{}
}