// Code generated by protoc-gen-gogo. DO NOT EDIT. // source: oneofembed.proto /* Package proto is a generated protocol buffer package. It is generated from these files: oneofembed.proto It has these top-level messages: Foo Bar */ package proto import proto1 "github.com/gogo/protobuf/proto" import fmt "fmt" import math "math" import _ "github.com/gogo/protobuf/gogoproto" // Reference imports to suppress errors if they are not otherwise used. var _ = proto1.Marshal var _ = fmt.Errorf var _ = math.Inf // This is a compile-time assertion to ensure that this generated file // is compatible with the proto package it is being compiled against. // A compilation error at this line likely means your copy of the // proto package needs to be updated. const _ = proto1.GoGoProtoPackageIsVersion2 // please upgrade the proto package type Foo struct { *Bar `protobuf:"bytes,1,opt,name=bar,embedded=bar" json:"bar,omitempty"` } func (m *Foo) Reset() { *m = Foo{} } func (m *Foo) String() string { return proto1.CompactTextString(m) } func (*Foo) ProtoMessage() {} func (*Foo) Descriptor() ([]byte, []int) { return fileDescriptorOneofembed, []int{0} } type Bar struct { // Types that are valid to be assigned to Pick: // *Bar_A // *Bar_B Pick isBar_Pick `protobuf_oneof:"pick"` } func (m *Bar) Reset() { *m = Bar{} } func (m *Bar) String() string { return proto1.CompactTextString(m) } func (*Bar) ProtoMessage() {} func (*Bar) Descriptor() ([]byte, []int) { return fileDescriptorOneofembed, []int{1} } type isBar_Pick interface { isBar_Pick() Equal(interface{}) bool } type Bar_A struct { A bool `protobuf:"varint,11,opt,name=a,proto3,oneof"` } type Bar_B struct { B bool `protobuf:"varint,12,opt,name=b,proto3,oneof"` } func (*Bar_A) isBar_Pick() {} func (*Bar_B) isBar_Pick() {} func (m *Bar) GetPick() isBar_Pick { if m != nil { return m.Pick } return nil } func (m *Bar) GetA() bool { if x, ok := m.GetPick().(*Bar_A); ok { return x.A } return false } func (m *Bar) GetB() bool { if x, ok := m.GetPick().(*Bar_B); ok { return x.B } return false } // XXX_OneofFuncs is for the internal use of the proto package. func (*Bar) XXX_OneofFuncs() (func(msg proto1.Message, b *proto1.Buffer) error, func(msg proto1.Message, tag, wire int, b *proto1.Buffer) (bool, error), func(msg proto1.Message) (n int), []interface{}) { return _Bar_OneofMarshaler, _Bar_OneofUnmarshaler, _Bar_OneofSizer, []interface{}{ (*Bar_A)(nil), (*Bar_B)(nil), } } func _Bar_OneofMarshaler(msg proto1.Message, b *proto1.Buffer) error { m := msg.(*Bar) // pick switch x := m.Pick.(type) { case *Bar_A: t := uint64(0) if x.A { t = 1 } _ = b.EncodeVarint(11<<3 | proto1.WireVarint) _ = b.EncodeVarint(t) case *Bar_B: t := uint64(0) if x.B { t = 1 } _ = b.EncodeVarint(12<<3 | proto1.WireVarint) _ = b.EncodeVarint(t) case nil: default: return fmt.Errorf("Bar.Pick has unexpected type %T", x) } return nil } func _Bar_OneofUnmarshaler(msg proto1.Message, tag, wire int, b *proto1.Buffer) (bool, error) { m := msg.(*Bar) switch tag { case 11: // pick.a if wire != proto1.WireVarint { return true, proto1.ErrInternalBadWireType } x, err := b.DecodeVarint() m.Pick = &Bar_A{x != 0} return true, err case 12: // pick.b if wire != proto1.WireVarint { return true, proto1.ErrInternalBadWireType } x, err := b.DecodeVarint() m.Pick = &Bar_B{x != 0} return true, err default: return false, nil } } func _Bar_OneofSizer(msg proto1.Message) (n int) { m := msg.(*Bar) // pick switch x := m.Pick.(type) { case *Bar_A: n += proto1.SizeVarint(11<<3 | proto1.WireVarint) n += 1 case *Bar_B: n += proto1.SizeVarint(12<<3 | proto1.WireVarint) n += 1 case nil: default: panic(fmt.Sprintf("proto: unexpected type %T in oneof", x)) } return n } func init() { proto1.RegisterType((*Foo)(nil), "proto.Foo") proto1.RegisterType((*Bar)(nil), "proto.Bar") } func (this *Foo) Equal(that interface{}) bool { if that == nil { return this == nil } that1, ok := that.(*Foo) if !ok { that2, ok := that.(Foo) if ok { that1 = &that2 } else { return false } } if that1 == nil { return this == nil } else if this == nil { return false } if !this.Bar.Equal(that1.Bar) { return false } return true } func (this *Bar) Equal(that interface{}) bool { if that == nil { return this == nil } that1, ok := that.(*Bar) if !ok { that2, ok := that.(Bar) if ok { that1 = &that2 } else { return false } } if that1 == nil { return this == nil } else if this == nil { return false } if that1.Pick == nil { if this.Pick != nil { return false } } else if this.Pick == nil { return false } else if !this.Pick.Equal(that1.Pick) { return false } return true } func (this *Bar_A) Equal(that interface{}) bool { if that == nil { return this == nil } that1, ok := that.(*Bar_A) if !ok { that2, ok := that.(Bar_A) if ok { that1 = &that2 } else { return false } } if that1 == nil { return this == nil } else if this == nil { return false } if this.A != that1.A { return false } return true } func (this *Bar_B) Equal(that interface{}) bool { if that == nil { return this == nil } that1, ok := that.(*Bar_B) if !ok { that2, ok := that.(Bar_B) if ok { that1 = &that2 } else { return false } } if that1 == nil { return this == nil } else if this == nil { return false } if this.B != that1.B { return false } return true } func NewPopulatedFoo(r randyOneofembed, easy bool) *Foo { this := &Foo{} if r.Intn(10) != 0 { this.Bar = NewPopulatedBar(r, easy) } if !easy && r.Intn(10) != 0 { } return this } func NewPopulatedBar(r randyOneofembed, easy bool) *Bar { this := &Bar{} oneofNumber_Pick := []int32{11, 12}[r.Intn(2)] switch oneofNumber_Pick { case 11: this.Pick = NewPopulatedBar_A(r, easy) case 12: this.Pick = NewPopulatedBar_B(r, easy) } if !easy && r.Intn(10) != 0 { } return this } func NewPopulatedBar_A(r randyOneofembed, easy bool) *Bar_A { this := &Bar_A{} this.A = bool(bool(r.Intn(2) == 0)) return this } func NewPopulatedBar_B(r randyOneofembed, easy bool) *Bar_B { this := &Bar_B{} this.B = bool(bool(r.Intn(2) == 0)) return this } type randyOneofembed interface { Float32() float32 Float64() float64 Int63() int64 Int31() int32 Uint32() uint32 Intn(n int) int } func randUTF8RuneOneofembed(r randyOneofembed) rune { ru := r.Intn(62) if ru < 10 { return rune(ru + 48) } else if ru < 36 { return rune(ru + 55) } return rune(ru + 61) } func randStringOneofembed(r randyOneofembed) string { v1 := r.Intn(100) tmps := make([]rune, v1) for i := 0; i < v1; i++ { tmps[i] = randUTF8RuneOneofembed(r) } return string(tmps) } func randUnrecognizedOneofembed(r randyOneofembed, maxFieldNumber int) (dAtA []byte) { l := r.Intn(5) for i := 0; i < l; i++ { wire := r.Intn(4) if wire == 3 { wire = 5 } fieldNumber := maxFieldNumber + r.Intn(100) dAtA = randFieldOneofembed(dAtA, r, fieldNumber, wire) } return dAtA } func randFieldOneofembed(dAtA []byte, r randyOneofembed, fieldNumber int, wire int) []byte { key := uint32(fieldNumber)<<3 | uint32(wire) switch wire { case 0: dAtA = encodeVarintPopulateOneofembed(dAtA, uint64(key)) v2 := r.Int63() if r.Intn(2) == 0 { v2 *= -1 } dAtA = encodeVarintPopulateOneofembed(dAtA, uint64(v2)) case 1: dAtA = encodeVarintPopulateOneofembed(dAtA, uint64(key)) dAtA = append(dAtA, byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256))) case 2: dAtA = encodeVarintPopulateOneofembed(dAtA, uint64(key)) ll := r.Intn(100) dAtA = encodeVarintPopulateOneofembed(dAtA, uint64(ll)) for j := 0; j < ll; j++ { dAtA = append(dAtA, byte(r.Intn(256))) } default: dAtA = encodeVarintPopulateOneofembed(dAtA, uint64(key)) dAtA = append(dAtA, byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256)), byte(r.Intn(256))) } return dAtA } func encodeVarintPopulateOneofembed(dAtA []byte, v uint64) []byte { for v >= 1<<7 { dAtA = append(dAtA, uint8(uint64(v)&0x7f|0x80)) v >>= 7 } dAtA = append(dAtA, uint8(v)) return dAtA } func init() { proto1.RegisterFile("oneofembed.proto", fileDescriptorOneofembed) } var fileDescriptorOneofembed = []byte{ // 171 bytes of a gzipped FileDescriptorProto 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x12, 0xc8, 0xcf, 0x4b, 0xcd, 0x4f, 0x4b, 0xcd, 0x4d, 0x4a, 0x4d, 0xd1, 0x2b, 0x28, 0xca, 0x2f, 0xc9, 0x17, 0x62, 0x05, 0x53, 0x52, 0xba, 0xe9, 0x99, 0x25, 0x19, 0xa5, 0x49, 0x7a, 0xc9, 0xf9, 0xb9, 0xfa, 0xe9, 0xf9, 0xe9, 0xf9, 0xfa, 0x60, 0xe1, 0xa4, 0xd2, 0x34, 0x30, 0x0f, 0xcc, 0x01, 0xb3, 0x20, 0xba, 0x94, 0x34, 0xb9, 0x98, 0xdd, 0xf2, 0xf3, 0x85, 0x94, 0xb8, 0x98, 0x93, 0x12, 0x8b, 0x24, 0x18, 0x15, 0x18, 0x35, 0xb8, 0x8d, 0xb8, 0x20, 0x72, 0x7a, 0x4e, 0x89, 0x45, 0x4e, 0x2c, 0x17, 0xee, 0xc9, 0x33, 0x06, 0x81, 0x24, 0x95, 0x74, 0xb9, 0x98, 0x9d, 0x12, 0x8b, 0x84, 0xf8, 0xb8, 0x18, 0x13, 0x25, 0xb8, 0x15, 0x18, 0x35, 0x38, 0x3c, 0x18, 0x82, 0x18, 0x13, 0x41, 0xfc, 0x24, 0x09, 0x1e, 0x18, 0x3f, 0xc9, 0x89, 0x8d, 0x8b, 0xa5, 0x20, 0x33, 0x39, 0xdb, 0x89, 0xe7, 0xc7, 0x43, 0x39, 0xc6, 0x15, 0x8f, 0xe4, 0x18, 0x77, 0x3c, 0x92, 0x63, 0x4c, 0x62, 0x03, 0x1b, 0x69, 0x0c, 0x08, 0x00, 0x00, 0xff, 0xff, 0x56, 0x58, 0x05, 0x27, 0xb8, 0x00, 0x00, 0x00, }