// Code generated by protoc-gen-gogo. DO NOT EDIT.
// source: rpc.proto

package pubsub_pb

import (
	fmt 
	io 
	math 
	math_bits 

	proto 
)

// Reference imports to suppress errors if they are not otherwise used.
var _ = proto.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 _ = proto.GoGoProtoPackageIsVersion3 // please upgrade the proto package

type RPC struct {
	Subscriptions        []*RPC_SubOpts  `protobuf:"bytes,1,rep,name=subscriptions" json:"subscriptions,omitempty"`
	Publish              []*Message      `protobuf:"bytes,2,rep,name=publish" json:"publish,omitempty"`
	Control              *ControlMessage `protobuf:"bytes,3,opt,name=control" json:"control,omitempty"`
	XXX_NoUnkeyedLiteral struct{}        `json:"-"`
	XXX_unrecognized     []byte          `json:"-"`
	XXX_sizecache        int32           `json:"-"`
}

func ( *RPC) ()         { * = RPC{} }
func ( *RPC) () string { return proto.CompactTextString() }
func (*RPC) ()    {}
func (*RPC) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{0}
}
func ( *RPC) ( []byte) error {
	return .Unmarshal()
}
func ( *RPC) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_RPC.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *RPC) ( proto.Message) {
	xxx_messageInfo_RPC.Merge(, )
}
func ( *RPC) () int {
	return .Size()
}
func ( *RPC) () {
	xxx_messageInfo_RPC.DiscardUnknown()
}

var xxx_messageInfo_RPC proto.InternalMessageInfo

func ( *RPC) () []*RPC_SubOpts {
	if  != nil {
		return .Subscriptions
	}
	return nil
}

func ( *RPC) () []*Message {
	if  != nil {
		return .Publish
	}
	return nil
}

func ( *RPC) () *ControlMessage {
	if  != nil {
		return .Control
	}
	return nil
}

type RPC_SubOpts struct {
	Subscribe            *bool    `protobuf:"varint,1,opt,name=subscribe" json:"subscribe,omitempty"`
	Topicid              *string  `protobuf:"bytes,2,opt,name=topicid" json:"topicid,omitempty"`
	XXX_NoUnkeyedLiteral struct{} `json:"-"`
	XXX_unrecognized     []byte   `json:"-"`
	XXX_sizecache        int32    `json:"-"`
}

func ( *RPC_SubOpts) ()         { * = RPC_SubOpts{} }
func ( *RPC_SubOpts) () string { return proto.CompactTextString() }
func (*RPC_SubOpts) ()    {}
func (*RPC_SubOpts) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{0, 0}
}
func ( *RPC_SubOpts) ( []byte) error {
	return .Unmarshal()
}
func ( *RPC_SubOpts) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_RPC_SubOpts.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *RPC_SubOpts) ( proto.Message) {
	xxx_messageInfo_RPC_SubOpts.Merge(, )
}
func ( *RPC_SubOpts) () int {
	return .Size()
}
func ( *RPC_SubOpts) () {
	xxx_messageInfo_RPC_SubOpts.DiscardUnknown()
}

var xxx_messageInfo_RPC_SubOpts proto.InternalMessageInfo

func ( *RPC_SubOpts) () bool {
	if  != nil && .Subscribe != nil {
		return *.Subscribe
	}
	return false
}

func ( *RPC_SubOpts) () string {
	if  != nil && .Topicid != nil {
		return *.Topicid
	}
	return ""
}

type Message struct {
	From                 []byte   `protobuf:"bytes,1,opt,name=from" json:"from,omitempty"`
	Data                 []byte   `protobuf:"bytes,2,opt,name=data" json:"data,omitempty"`
	Seqno                []byte   `protobuf:"bytes,3,opt,name=seqno" json:"seqno,omitempty"`
	Topic                *string  `protobuf:"bytes,4,opt,name=topic" json:"topic,omitempty"`
	Signature            []byte   `protobuf:"bytes,5,opt,name=signature" json:"signature,omitempty"`
	Key                  []byte   `protobuf:"bytes,6,opt,name=key" json:"key,omitempty"`
	XXX_NoUnkeyedLiteral struct{} `json:"-"`
	XXX_unrecognized     []byte   `json:"-"`
	XXX_sizecache        int32    `json:"-"`
}

func ( *Message) ()         { * = Message{} }
func ( *Message) () string { return proto.CompactTextString() }
func (*Message) ()    {}
func (*Message) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{1}
}
func ( *Message) ( []byte) error {
	return .Unmarshal()
}
func ( *Message) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_Message.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *Message) ( proto.Message) {
	xxx_messageInfo_Message.Merge(, )
}
func ( *Message) () int {
	return .Size()
}
func ( *Message) () {
	xxx_messageInfo_Message.DiscardUnknown()
}

var xxx_messageInfo_Message proto.InternalMessageInfo

func ( *Message) () []byte {
	if  != nil {
		return .From
	}
	return nil
}

func ( *Message) () []byte {
	if  != nil {
		return .Data
	}
	return nil
}

func ( *Message) () []byte {
	if  != nil {
		return .Seqno
	}
	return nil
}

func ( *Message) () string {
	if  != nil && .Topic != nil {
		return *.Topic
	}
	return ""
}

func ( *Message) () []byte {
	if  != nil {
		return .Signature
	}
	return nil
}

func ( *Message) () []byte {
	if  != nil {
		return .Key
	}
	return nil
}

type ControlMessage struct {
	Ihave                []*ControlIHave     `protobuf:"bytes,1,rep,name=ihave" json:"ihave,omitempty"`
	Iwant                []*ControlIWant     `protobuf:"bytes,2,rep,name=iwant" json:"iwant,omitempty"`
	Graft                []*ControlGraft     `protobuf:"bytes,3,rep,name=graft" json:"graft,omitempty"`
	Prune                []*ControlPrune     `protobuf:"bytes,4,rep,name=prune" json:"prune,omitempty"`
	Idontwant            []*ControlIDontWant `protobuf:"bytes,5,rep,name=idontwant" json:"idontwant,omitempty"`
	XXX_NoUnkeyedLiteral struct{}            `json:"-"`
	XXX_unrecognized     []byte              `json:"-"`
	XXX_sizecache        int32               `json:"-"`
}

func ( *ControlMessage) ()         { * = ControlMessage{} }
func ( *ControlMessage) () string { return proto.CompactTextString() }
func (*ControlMessage) ()    {}
func (*ControlMessage) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{2}
}
func ( *ControlMessage) ( []byte) error {
	return .Unmarshal()
}
func ( *ControlMessage) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_ControlMessage.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *ControlMessage) ( proto.Message) {
	xxx_messageInfo_ControlMessage.Merge(, )
}
func ( *ControlMessage) () int {
	return .Size()
}
func ( *ControlMessage) () {
	xxx_messageInfo_ControlMessage.DiscardUnknown()
}

var xxx_messageInfo_ControlMessage proto.InternalMessageInfo

func ( *ControlMessage) () []*ControlIHave {
	if  != nil {
		return .Ihave
	}
	return nil
}

func ( *ControlMessage) () []*ControlIWant {
	if  != nil {
		return .Iwant
	}
	return nil
}

func ( *ControlMessage) () []*ControlGraft {
	if  != nil {
		return .Graft
	}
	return nil
}

func ( *ControlMessage) () []*ControlPrune {
	if  != nil {
		return .Prune
	}
	return nil
}

func ( *ControlMessage) () []*ControlIDontWant {
	if  != nil {
		return .Idontwant
	}
	return nil
}

type ControlIHave struct {
	TopicID *string `protobuf:"bytes,1,opt,name=topicID" json:"topicID,omitempty"`
	// implementors from other languages should use bytes here - go protobuf emits invalid utf8 strings
	MessageIDs           []string `protobuf:"bytes,2,rep,name=messageIDs" json:"messageIDs,omitempty"`
	XXX_NoUnkeyedLiteral struct{} `json:"-"`
	XXX_unrecognized     []byte   `json:"-"`
	XXX_sizecache        int32    `json:"-"`
}

func ( *ControlIHave) ()         { * = ControlIHave{} }
func ( *ControlIHave) () string { return proto.CompactTextString() }
func (*ControlIHave) ()    {}
func (*ControlIHave) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{3}
}
func ( *ControlIHave) ( []byte) error {
	return .Unmarshal()
}
func ( *ControlIHave) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_ControlIHave.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *ControlIHave) ( proto.Message) {
	xxx_messageInfo_ControlIHave.Merge(, )
}
func ( *ControlIHave) () int {
	return .Size()
}
func ( *ControlIHave) () {
	xxx_messageInfo_ControlIHave.DiscardUnknown()
}

var xxx_messageInfo_ControlIHave proto.InternalMessageInfo

func ( *ControlIHave) () string {
	if  != nil && .TopicID != nil {
		return *.TopicID
	}
	return ""
}

func ( *ControlIHave) () []string {
	if  != nil {
		return .MessageIDs
	}
	return nil
}

type ControlIWant struct {
	// implementors from other languages should use bytes here - go protobuf emits invalid utf8 strings
	MessageIDs           []string `protobuf:"bytes,1,rep,name=messageIDs" json:"messageIDs,omitempty"`
	XXX_NoUnkeyedLiteral struct{} `json:"-"`
	XXX_unrecognized     []byte   `json:"-"`
	XXX_sizecache        int32    `json:"-"`
}

func ( *ControlIWant) ()         { * = ControlIWant{} }
func ( *ControlIWant) () string { return proto.CompactTextString() }
func (*ControlIWant) ()    {}
func (*ControlIWant) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{4}
}
func ( *ControlIWant) ( []byte) error {
	return .Unmarshal()
}
func ( *ControlIWant) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_ControlIWant.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *ControlIWant) ( proto.Message) {
	xxx_messageInfo_ControlIWant.Merge(, )
}
func ( *ControlIWant) () int {
	return .Size()
}
func ( *ControlIWant) () {
	xxx_messageInfo_ControlIWant.DiscardUnknown()
}

var xxx_messageInfo_ControlIWant proto.InternalMessageInfo

func ( *ControlIWant) () []string {
	if  != nil {
		return .MessageIDs
	}
	return nil
}

type ControlGraft struct {
	TopicID              *string  `protobuf:"bytes,1,opt,name=topicID" json:"topicID,omitempty"`
	XXX_NoUnkeyedLiteral struct{} `json:"-"`
	XXX_unrecognized     []byte   `json:"-"`
	XXX_sizecache        int32    `json:"-"`
}

func ( *ControlGraft) ()         { * = ControlGraft{} }
func ( *ControlGraft) () string { return proto.CompactTextString() }
func (*ControlGraft) ()    {}
func (*ControlGraft) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{5}
}
func ( *ControlGraft) ( []byte) error {
	return .Unmarshal()
}
func ( *ControlGraft) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_ControlGraft.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *ControlGraft) ( proto.Message) {
	xxx_messageInfo_ControlGraft.Merge(, )
}
func ( *ControlGraft) () int {
	return .Size()
}
func ( *ControlGraft) () {
	xxx_messageInfo_ControlGraft.DiscardUnknown()
}

var xxx_messageInfo_ControlGraft proto.InternalMessageInfo

func ( *ControlGraft) () string {
	if  != nil && .TopicID != nil {
		return *.TopicID
	}
	return ""
}

type ControlPrune struct {
	TopicID              *string     `protobuf:"bytes,1,opt,name=topicID" json:"topicID,omitempty"`
	Peers                []*PeerInfo `protobuf:"bytes,2,rep,name=peers" json:"peers,omitempty"`
	Backoff              *uint64     `protobuf:"varint,3,opt,name=backoff" json:"backoff,omitempty"`
	XXX_NoUnkeyedLiteral struct{}    `json:"-"`
	XXX_unrecognized     []byte      `json:"-"`
	XXX_sizecache        int32       `json:"-"`
}

func ( *ControlPrune) ()         { * = ControlPrune{} }
func ( *ControlPrune) () string { return proto.CompactTextString() }
func (*ControlPrune) ()    {}
func (*ControlPrune) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{6}
}
func ( *ControlPrune) ( []byte) error {
	return .Unmarshal()
}
func ( *ControlPrune) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_ControlPrune.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *ControlPrune) ( proto.Message) {
	xxx_messageInfo_ControlPrune.Merge(, )
}
func ( *ControlPrune) () int {
	return .Size()
}
func ( *ControlPrune) () {
	xxx_messageInfo_ControlPrune.DiscardUnknown()
}

var xxx_messageInfo_ControlPrune proto.InternalMessageInfo

func ( *ControlPrune) () string {
	if  != nil && .TopicID != nil {
		return *.TopicID
	}
	return ""
}

func ( *ControlPrune) () []*PeerInfo {
	if  != nil {
		return .Peers
	}
	return nil
}

func ( *ControlPrune) () uint64 {
	if  != nil && .Backoff != nil {
		return *.Backoff
	}
	return 0
}

type ControlIDontWant struct {
	// implementors from other languages should use bytes here - go protobuf emits invalid utf8 strings
	MessageIDs           []string `protobuf:"bytes,1,rep,name=messageIDs" json:"messageIDs,omitempty"`
	XXX_NoUnkeyedLiteral struct{} `json:"-"`
	XXX_unrecognized     []byte   `json:"-"`
	XXX_sizecache        int32    `json:"-"`
}

func ( *ControlIDontWant) ()         { * = ControlIDontWant{} }
func ( *ControlIDontWant) () string { return proto.CompactTextString() }
func (*ControlIDontWant) ()    {}
func (*ControlIDontWant) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{7}
}
func ( *ControlIDontWant) ( []byte) error {
	return .Unmarshal()
}
func ( *ControlIDontWant) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_ControlIDontWant.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *ControlIDontWant) ( proto.Message) {
	xxx_messageInfo_ControlIDontWant.Merge(, )
}
func ( *ControlIDontWant) () int {
	return .Size()
}
func ( *ControlIDontWant) () {
	xxx_messageInfo_ControlIDontWant.DiscardUnknown()
}

var xxx_messageInfo_ControlIDontWant proto.InternalMessageInfo

func ( *ControlIDontWant) () []string {
	if  != nil {
		return .MessageIDs
	}
	return nil
}

type PeerInfo struct {
	PeerID               []byte   `protobuf:"bytes,1,opt,name=peerID" json:"peerID,omitempty"`
	SignedPeerRecord     []byte   `protobuf:"bytes,2,opt,name=signedPeerRecord" json:"signedPeerRecord,omitempty"`
	XXX_NoUnkeyedLiteral struct{} `json:"-"`
	XXX_unrecognized     []byte   `json:"-"`
	XXX_sizecache        int32    `json:"-"`
}

func ( *PeerInfo) ()         { * = PeerInfo{} }
func ( *PeerInfo) () string { return proto.CompactTextString() }
func (*PeerInfo) ()    {}
func (*PeerInfo) () ([]byte, []int) {
	return fileDescriptor_77a6da22d6a3feb1, []int{8}
}
func ( *PeerInfo) ( []byte) error {
	return .Unmarshal()
}
func ( *PeerInfo) ( []byte,  bool) ([]byte, error) {
	if  {
		return xxx_messageInfo_PeerInfo.Marshal(, , )
	} else {
		 = [:cap()]
		,  := .MarshalToSizedBuffer()
		if  != nil {
			return nil, 
		}
		return [:], nil
	}
}
func ( *PeerInfo) ( proto.Message) {
	xxx_messageInfo_PeerInfo.Merge(, )
}
func ( *PeerInfo) () int {
	return .Size()
}
func ( *PeerInfo) () {
	xxx_messageInfo_PeerInfo.DiscardUnknown()
}

var xxx_messageInfo_PeerInfo proto.InternalMessageInfo

func ( *PeerInfo) () []byte {
	if  != nil {
		return .PeerID
	}
	return nil
}

func ( *PeerInfo) () []byte {
	if  != nil {
		return .SignedPeerRecord
	}
	return nil
}

func init() {
	proto.RegisterType((*RPC)(nil), "pubsub.pb.RPC")
	proto.RegisterType((*RPC_SubOpts)(nil), "pubsub.pb.RPC.SubOpts")
	proto.RegisterType((*Message)(nil), "pubsub.pb.Message")
	proto.RegisterType((*ControlMessage)(nil), "pubsub.pb.ControlMessage")
	proto.RegisterType((*ControlIHave)(nil), "pubsub.pb.ControlIHave")
	proto.RegisterType((*ControlIWant)(nil), "pubsub.pb.ControlIWant")
	proto.RegisterType((*ControlGraft)(nil), "pubsub.pb.ControlGraft")
	proto.RegisterType((*ControlPrune)(nil), "pubsub.pb.ControlPrune")
	proto.RegisterType((*ControlIDontWant)(nil), "pubsub.pb.ControlIDontWant")
	proto.RegisterType((*PeerInfo)(nil), "pubsub.pb.PeerInfo")
}

func init() { proto.RegisterFile("rpc.proto", fileDescriptor_77a6da22d6a3feb1) }

var fileDescriptor_77a6da22d6a3feb1 = []byte{
	// 511 bytes of a gzipped FileDescriptorProto
	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x84, 0x92, 0xcd, 0x6e, 0x13, 0x31,
	0x10, 0xc7, 0xe5, 0x7c, 0x34, 0xdd, 0xe9, 0x82, 0x22, 0x83, 0x8a, 0xf9, 0x50, 0x14, 0xed, 0x29,
	0x20, 0xd8, 0x43, 0x38, 0x21, 0x71, 0x81, 0x44, 0xa2, 0x39, 0x00, 0x91, 0x39, 0x70, 0xde, 0xdd,
	0x38, 0xe9, 0xaa, 0x8d, 0x6d, 0x6c, 0x6f, 0x11, 0x4f, 0xc0, 0x89, 0xf7, 0xe2, 0xc8, 0x23, 0xa0,
	0xdc, 0x78, 0x0b, 0xe4, 0x59, 0xe7, 0xa3, 0x4d, 0x03, 0x37, 0xcf, 0xf8, 0x37, 0xfe, 0xff, 0x67,
	0xc6, 0x10, 0x19, 0x5d, 0xa4, 0xda, 0x28, 0xa7, 0x68, 0xa4, 0xab, 0xdc, 0x56, 0x79, 0xaa, 0xf3,
	0xe4, 0x0f, 0x81, 0x26, 0x9f, 0x8e, 0xe8, 0x6b, 0xb8, 0x63, 0xab, 0xdc, 0x16, 0xa6, 0xd4, 0xae,
	0x54, 0xd2, 0x32, 0xd2, 0x6f, 0x0e, 0x4e, 0x86, 0xa7, 0xe9, 0x06, 0x4d, 0xf9, 0x74, 0x94, 0x7e,
	0xaa, 0xf2, 0x8f, 0xda, 0x59, 0x7e, 0x1d, 0xa6, 0xcf, 0xa1, 0xa3, 0xab, 0xfc, 0xb2, 0xb4, 0xe7,
	0xac, 0x81, 0x75, 0x74, 0xa7, 0xee, 0xbd, 0xb0, 0x36, 0x5b, 0x08, 0xbe, 0x46, 0xe8, 0x4b, 0xe8,
	0x14, 0x4a, 0x3a, 0xa3, 0x2e, 0x59, 0xb3, 0x4f, 0x06, 0x27, 0xc3, 0x87, 0x3b, 0xf4, 0xa8, 0xbe,
	0xd9, 0x14, 0x05, 0xf2, 0xd1, 0x1b, 0xe8, 0x04, 0x71, 0xfa, 0x04, 0xa2, 0x20, 0x9f, 0x0b, 0x46,
	0xfa, 0x64, 0x70, 0xcc, 0xb7, 0x09, 0xca, 0xa0, 0xe3, 0x94, 0x2e, 0x8b, 0x72, 0xc6, 0x1a, 0x7d,
	0x32, 0x88, 0xf8, 0x3a, 0x4c, 0x7e, 0x10, 0xe8, 0x84, 0x77, 0x29, 0x85, 0xd6, 0xdc, 0xa8, 0x25,
	0x96, 0xc7, 0x1c, 0xcf, 0x3e, 0x37, 0xcb, 0x5c, 0x86, 0x65, 0x31, 0xc7, 0x33, 0xbd, 0x0f, 0x6d,
	0x2b, 0xbe, 0x48, 0x85, 0x4e, 0x63, 0x5e, 0x07, 0x3e, 0x8b, 0x8f, 0xb2, 0x16, 0x2a, 0xd4, 0x01,
	0xfa, 0x2a, 0x17, 0x32, 0x73, 0x95, 0x11, 0xac, 0x8d, 0xfc, 0x36, 0x41, 0xbb, 0xd0, 0xbc, 0x10,
	0xdf, 0xd8, 0x11, 0xe6, 0xfd, 0x31, 0xf9, 0xde, 0x80, 0xbb, 0xd7, 0xdb, 0xa5, 0x2f, 0xa0, 0x5d,
	0x9e, 0x67, 0x57, 0x22, 0x8c, 0xff, 0xc1, 0xfe, 0x60, 0x26, 0x67, 0xd9, 0x95, 0xe0, 0x35, 0x85,
	0xf8, 0xd7, 0x4c, 0xba, 0x30, 0xf5, 0xdb, 0xf0, 0xcf, 0x99, 0x74, 0xbc, 0xa6, 0x3c, 0xbe, 0x30,
	0xd9, 0xdc, 0xb1, 0xe6, 0x21, 0xfc, 0x9d, 0xbf, 0xe6, 0x35, 0xe5, 0x71, 0x6d, 0x2a, 0x29, 0x58,
	0xeb, 0x10, 0x3e, 0xf5, 0xd7, 0xbc, 0xa6, 0xe8, 0x2b, 0x88, 0xca, 0x99, 0x92, 0x0e, 0x0d, 0xb5,
	0xb1, 0xe4, 0xf1, 0x2d, 0x86, 0xc6, 0x4a, 0x3a, 0x34, 0xb5, 0xa5, 0x93, 0x33, 0x88, 0x77, 0xdb,
	0xdb, 0xec, 0x70, 0x32, 0xc6, 0x05, 0xad, 0x77, 0x38, 0x19, 0xd3, 0x1e, 0xc0, 0xb2, 0x9e, 0xd5,
	0x64, 0x6c, 0xb1, 0xed, 0x88, 0xef, 0x64, 0x92, 0x74, 0xfb, 0x92, 0x17, 0xb9, 0xc1, 0x93, 0x3d,
	0x7e, 0xb0, 0xe1, 0xb1, 0xf5, 0xc3, 0xca, 0xc9, 0x72, 0x43, 0x62, 0xd7, 0xff, 0xf0, 0xf8, 0x14,
	0xda, 0x5a, 0x08, 0x63, 0xc3, 0x56, 0xee, 0xed, 0x0c, 0x61, 0x2a, 0x84, 0x99, 0xc8, 0xb9, 0xe2,
	0x35, 0xe1, 0x1f, 0xc9, 0xb3, 0xe2, 0x42, 0xcd, 0xe7, 0xf8, 0xc1, 0x5a, 0x7c, 0x1d, 0x26, 0x43,
	0xe8, 0xde, 0x9c, 0xd8, 0x7f, 0x9b, 0xf9, 0x00, 0xc7, 0x6b, 0x01, 0x7a, 0x0a, 0x47, 0x5e, 0x22,
	0xb8, 0x8b, 0x79, 0x88, 0xe8, 0x33, 0xe8, 0xfa, 0x3f, 0x29, 0x66, 0x9e, 0xe4, 0xa2, 0x50, 0x66,
	0x16, 0x3e, 0xfc, 0x5e, 0xfe, 0x6d, 0xfc, 0x73, 0xd5, 0x23, 0xbf, 0x56, 0x3d, 0xf2, 0x7b, 0xd5,
	0x23, 0x7f, 0x03, 0x00, 0x00, 0xff, 0xff, 0xba, 0x73, 0x8e, 0xbf, 0x41, 0x04, 0x00, 0x00,
}

func ( *RPC) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *RPC) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *RPC) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if .Control != nil {
		{
			,  := .Control.MarshalToSizedBuffer([:])
			if  != nil {
				return 0, 
			}
			 -= 
			 = encodeVarintRpc(, , uint64())
		}
		--
		[] = 0x1a
	}
	if len(.Publish) > 0 {
		for  := len(.Publish) - 1;  >= 0; -- {
			{
				,  := .Publish[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0x12
		}
	}
	if len(.Subscriptions) > 0 {
		for  := len(.Subscriptions) - 1;  >= 0; -- {
			{
				,  := .Subscriptions[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0xa
		}
	}
	return len() - , nil
}

func ( *RPC_SubOpts) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *RPC_SubOpts) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *RPC_SubOpts) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if .Topicid != nil {
		 -= len(*.Topicid)
		copy([:], *.Topicid)
		 = encodeVarintRpc(, , uint64(len(*.Topicid)))
		--
		[] = 0x12
	}
	if .Subscribe != nil {
		--
		if *.Subscribe {
			[] = 1
		} else {
			[] = 0
		}
		--
		[] = 0x8
	}
	return len() - , nil
}

func ( *Message) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *Message) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *Message) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if .Key != nil {
		 -= len(.Key)
		copy([:], .Key)
		 = encodeVarintRpc(, , uint64(len(.Key)))
		--
		[] = 0x32
	}
	if .Signature != nil {
		 -= len(.Signature)
		copy([:], .Signature)
		 = encodeVarintRpc(, , uint64(len(.Signature)))
		--
		[] = 0x2a
	}
	if .Topic != nil {
		 -= len(*.Topic)
		copy([:], *.Topic)
		 = encodeVarintRpc(, , uint64(len(*.Topic)))
		--
		[] = 0x22
	}
	if .Seqno != nil {
		 -= len(.Seqno)
		copy([:], .Seqno)
		 = encodeVarintRpc(, , uint64(len(.Seqno)))
		--
		[] = 0x1a
	}
	if .Data != nil {
		 -= len(.Data)
		copy([:], .Data)
		 = encodeVarintRpc(, , uint64(len(.Data)))
		--
		[] = 0x12
	}
	if .From != nil {
		 -= len(.From)
		copy([:], .From)
		 = encodeVarintRpc(, , uint64(len(.From)))
		--
		[] = 0xa
	}
	return len() - , nil
}

func ( *ControlMessage) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *ControlMessage) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *ControlMessage) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if len(.Idontwant) > 0 {
		for  := len(.Idontwant) - 1;  >= 0; -- {
			{
				,  := .Idontwant[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0x2a
		}
	}
	if len(.Prune) > 0 {
		for  := len(.Prune) - 1;  >= 0; -- {
			{
				,  := .Prune[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0x22
		}
	}
	if len(.Graft) > 0 {
		for  := len(.Graft) - 1;  >= 0; -- {
			{
				,  := .Graft[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0x1a
		}
	}
	if len(.Iwant) > 0 {
		for  := len(.Iwant) - 1;  >= 0; -- {
			{
				,  := .Iwant[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0x12
		}
	}
	if len(.Ihave) > 0 {
		for  := len(.Ihave) - 1;  >= 0; -- {
			{
				,  := .Ihave[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0xa
		}
	}
	return len() - , nil
}

func ( *ControlIHave) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *ControlIHave) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *ControlIHave) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if len(.MessageIDs) > 0 {
		for  := len(.MessageIDs) - 1;  >= 0; -- {
			 -= len(.MessageIDs[])
			copy([:], .MessageIDs[])
			 = encodeVarintRpc(, , uint64(len(.MessageIDs[])))
			--
			[] = 0x12
		}
	}
	if .TopicID != nil {
		 -= len(*.TopicID)
		copy([:], *.TopicID)
		 = encodeVarintRpc(, , uint64(len(*.TopicID)))
		--
		[] = 0xa
	}
	return len() - , nil
}

func ( *ControlIWant) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *ControlIWant) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *ControlIWant) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if len(.MessageIDs) > 0 {
		for  := len(.MessageIDs) - 1;  >= 0; -- {
			 -= len(.MessageIDs[])
			copy([:], .MessageIDs[])
			 = encodeVarintRpc(, , uint64(len(.MessageIDs[])))
			--
			[] = 0xa
		}
	}
	return len() - , nil
}

func ( *ControlGraft) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *ControlGraft) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *ControlGraft) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if .TopicID != nil {
		 -= len(*.TopicID)
		copy([:], *.TopicID)
		 = encodeVarintRpc(, , uint64(len(*.TopicID)))
		--
		[] = 0xa
	}
	return len() - , nil
}

func ( *ControlPrune) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *ControlPrune) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *ControlPrune) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if .Backoff != nil {
		 = encodeVarintRpc(, , uint64(*.Backoff))
		--
		[] = 0x18
	}
	if len(.Peers) > 0 {
		for  := len(.Peers) - 1;  >= 0; -- {
			{
				,  := .Peers[].MarshalToSizedBuffer([:])
				if  != nil {
					return 0, 
				}
				 -= 
				 = encodeVarintRpc(, , uint64())
			}
			--
			[] = 0x12
		}
	}
	if .TopicID != nil {
		 -= len(*.TopicID)
		copy([:], *.TopicID)
		 = encodeVarintRpc(, , uint64(len(*.TopicID)))
		--
		[] = 0xa
	}
	return len() - , nil
}

func ( *ControlIDontWant) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *ControlIDontWant) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *ControlIDontWant) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if len(.MessageIDs) > 0 {
		for  := len(.MessageIDs) - 1;  >= 0; -- {
			 -= len(.MessageIDs[])
			copy([:], .MessageIDs[])
			 = encodeVarintRpc(, , uint64(len(.MessageIDs[])))
			--
			[] = 0xa
		}
	}
	return len() - , nil
}

func ( *PeerInfo) () ( []byte,  error) {
	 := .Size()
	 = make([]byte, )
	,  := .MarshalToSizedBuffer([:])
	if  != nil {
		return nil, 
	}
	return [:], nil
}

func ( *PeerInfo) ( []byte) (int, error) {
	 := .Size()
	return .MarshalToSizedBuffer([:])
}

func ( *PeerInfo) ( []byte) (int, error) {
	 := len()
	_ = 
	var  int
	_ = 
	if .XXX_unrecognized != nil {
		 -= len(.XXX_unrecognized)
		copy([:], .XXX_unrecognized)
	}
	if .SignedPeerRecord != nil {
		 -= len(.SignedPeerRecord)
		copy([:], .SignedPeerRecord)
		 = encodeVarintRpc(, , uint64(len(.SignedPeerRecord)))
		--
		[] = 0x12
	}
	if .PeerID != nil {
		 -= len(.PeerID)
		copy([:], .PeerID)
		 = encodeVarintRpc(, , uint64(len(.PeerID)))
		--
		[] = 0xa
	}
	return len() - , nil
}

func encodeVarintRpc( []byte,  int,  uint64) int {
	 -= sovRpc()
	 := 
	for  >= 1<<7 {
		[] = uint8(&0x7f | 0x80)
		 >>= 7
		++
	}
	[] = uint8()
	return 
}
func ( *RPC) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if len(.Subscriptions) > 0 {
		for ,  := range .Subscriptions {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if len(.Publish) > 0 {
		for ,  := range .Publish {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if .Control != nil {
		 = .Control.Size()
		 += 1 +  + sovRpc(uint64())
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *RPC_SubOpts) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if .Subscribe != nil {
		 += 2
	}
	if .Topicid != nil {
		 = len(*.Topicid)
		 += 1 +  + sovRpc(uint64())
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *Message) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if .From != nil {
		 = len(.From)
		 += 1 +  + sovRpc(uint64())
	}
	if .Data != nil {
		 = len(.Data)
		 += 1 +  + sovRpc(uint64())
	}
	if .Seqno != nil {
		 = len(.Seqno)
		 += 1 +  + sovRpc(uint64())
	}
	if .Topic != nil {
		 = len(*.Topic)
		 += 1 +  + sovRpc(uint64())
	}
	if .Signature != nil {
		 = len(.Signature)
		 += 1 +  + sovRpc(uint64())
	}
	if .Key != nil {
		 = len(.Key)
		 += 1 +  + sovRpc(uint64())
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *ControlMessage) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if len(.Ihave) > 0 {
		for ,  := range .Ihave {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if len(.Iwant) > 0 {
		for ,  := range .Iwant {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if len(.Graft) > 0 {
		for ,  := range .Graft {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if len(.Prune) > 0 {
		for ,  := range .Prune {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if len(.Idontwant) > 0 {
		for ,  := range .Idontwant {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *ControlIHave) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if .TopicID != nil {
		 = len(*.TopicID)
		 += 1 +  + sovRpc(uint64())
	}
	if len(.MessageIDs) > 0 {
		for ,  := range .MessageIDs {
			 = len()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *ControlIWant) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if len(.MessageIDs) > 0 {
		for ,  := range .MessageIDs {
			 = len()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *ControlGraft) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if .TopicID != nil {
		 = len(*.TopicID)
		 += 1 +  + sovRpc(uint64())
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *ControlPrune) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if .TopicID != nil {
		 = len(*.TopicID)
		 += 1 +  + sovRpc(uint64())
	}
	if len(.Peers) > 0 {
		for ,  := range .Peers {
			 = .Size()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if .Backoff != nil {
		 += 1 + sovRpc(uint64(*.Backoff))
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *ControlIDontWant) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if len(.MessageIDs) > 0 {
		for ,  := range .MessageIDs {
			 = len()
			 += 1 +  + sovRpc(uint64())
		}
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func ( *PeerInfo) () ( int) {
	if  == nil {
		return 0
	}
	var  int
	_ = 
	if .PeerID != nil {
		 = len(.PeerID)
		 += 1 +  + sovRpc(uint64())
	}
	if .SignedPeerRecord != nil {
		 = len(.SignedPeerRecord)
		 += 1 +  + sovRpc(uint64())
	}
	if .XXX_unrecognized != nil {
		 += len(.XXX_unrecognized)
	}
	return 
}

func sovRpc( uint64) ( int) {
	return (math_bits.Len64(|1) + 6) / 7
}
func sozRpc( uint64) ( int) {
	return sovRpc(uint64(( << 1) ^ uint64((int64() >> 63))))
}
func ( *RPC) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: RPC: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: RPC: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Subscriptions", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Subscriptions = append(.Subscriptions, &RPC_SubOpts{})
			if  := .Subscriptions[len(.Subscriptions)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		case 2:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Publish", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Publish = append(.Publish, &Message{})
			if  := .Publish[len(.Publish)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		case 3:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Control", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			if .Control == nil {
				.Control = &ControlMessage{}
			}
			if  := .Control.Unmarshal([:]);  != nil {
				return 
			}
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *RPC_SubOpts) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: SubOpts: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: SubOpts: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 0 {
				return fmt.Errorf("proto: wrong wireType = %d for field Subscribe", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := bool( != 0)
			.Subscribe = &
		case 2:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Topicid", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			 := string([:])
			.Topicid = &
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *Message) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: Message: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: Message: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field From", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.From = append(.From[:0], [:]...)
			if .From == nil {
				.From = []byte{}
			}
			 = 
		case 2:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Data", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Data = append(.Data[:0], [:]...)
			if .Data == nil {
				.Data = []byte{}
			}
			 = 
		case 3:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Seqno", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Seqno = append(.Seqno[:0], [:]...)
			if .Seqno == nil {
				.Seqno = []byte{}
			}
			 = 
		case 4:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Topic", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			 := string([:])
			.Topic = &
			 = 
		case 5:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Signature", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Signature = append(.Signature[:0], [:]...)
			if .Signature == nil {
				.Signature = []byte{}
			}
			 = 
		case 6:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Key", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Key = append(.Key[:0], [:]...)
			if .Key == nil {
				.Key = []byte{}
			}
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *ControlMessage) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: ControlMessage: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: ControlMessage: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Ihave", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Ihave = append(.Ihave, &ControlIHave{})
			if  := .Ihave[len(.Ihave)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		case 2:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Iwant", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Iwant = append(.Iwant, &ControlIWant{})
			if  := .Iwant[len(.Iwant)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		case 3:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Graft", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Graft = append(.Graft, &ControlGraft{})
			if  := .Graft[len(.Graft)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		case 4:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Prune", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Prune = append(.Prune, &ControlPrune{})
			if  := .Prune[len(.Prune)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		case 5:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Idontwant", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Idontwant = append(.Idontwant, &ControlIDontWant{})
			if  := .Idontwant[len(.Idontwant)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *ControlIHave) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: ControlIHave: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: ControlIHave: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field TopicID", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			 := string([:])
			.TopicID = &
			 = 
		case 2:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field MessageIDs", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.MessageIDs = append(.MessageIDs, string([:]))
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *ControlIWant) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: ControlIWant: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: ControlIWant: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field MessageIDs", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.MessageIDs = append(.MessageIDs, string([:]))
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *ControlGraft) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: ControlGraft: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: ControlGraft: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field TopicID", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			 := string([:])
			.TopicID = &
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *ControlPrune) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: ControlPrune: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: ControlPrune: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field TopicID", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			 := string([:])
			.TopicID = &
			 = 
		case 2:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field Peers", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.Peers = append(.Peers, &PeerInfo{})
			if  := .Peers[len(.Peers)-1].Unmarshal([:]);  != nil {
				return 
			}
			 = 
		case 3:
			if  != 0 {
				return fmt.Errorf("proto: wrong wireType = %d for field Backoff", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			.Backoff = &
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *ControlIDontWant) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: ControlIDontWant: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: ControlIDontWant: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field MessageIDs", )
			}
			var  uint64
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= uint64(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			 := int()
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.MessageIDs = append(.MessageIDs, string([:]))
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func ( *PeerInfo) ( []byte) error {
	 := len()
	 := 0
	for  <  {
		 := 
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return ErrIntOverflowRpc
			}
			if  >=  {
				return io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= uint64(&0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int32( >> 3)
		 := int( & 0x7)
		if  == 4 {
			return fmt.Errorf("proto: PeerInfo: wiretype end group for non-group")
		}
		if  <= 0 {
			return fmt.Errorf("proto: PeerInfo: illegal tag %d (wire type %d)", , )
		}
		switch  {
		case 1:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field PeerID", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.PeerID = append(.PeerID[:0], [:]...)
			if .PeerID == nil {
				.PeerID = []byte{}
			}
			 = 
		case 2:
			if  != 2 {
				return fmt.Errorf("proto: wrong wireType = %d for field SignedPeerRecord", )
			}
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return ErrIntOverflowRpc
				}
				if  >=  {
					return io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= int(&0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			 :=  + 
			if  < 0 {
				return ErrInvalidLengthRpc
			}
			if  >  {
				return io.ErrUnexpectedEOF
			}
			.SignedPeerRecord = append(.SignedPeerRecord[:0], [:]...)
			if .SignedPeerRecord == nil {
				.SignedPeerRecord = []byte{}
			}
			 = 
		default:
			 = 
			,  := skipRpc([:])
			if  != nil {
				return 
			}
			if ( < 0) || (+) < 0 {
				return ErrInvalidLengthRpc
			}
			if ( + ) >  {
				return io.ErrUnexpectedEOF
			}
			.XXX_unrecognized = append(.XXX_unrecognized, [:+]...)
			 += 
		}
	}

	if  >  {
		return io.ErrUnexpectedEOF
	}
	return nil
}
func skipRpc( []byte) ( int,  error) {
	 := len()
	 := 0
	 := 0
	for  <  {
		var  uint64
		for  := uint(0); ;  += 7 {
			if  >= 64 {
				return 0, ErrIntOverflowRpc
			}
			if  >=  {
				return 0, io.ErrUnexpectedEOF
			}
			 := []
			++
			 |= (uint64() & 0x7F) << 
			if  < 0x80 {
				break
			}
		}
		 := int( & 0x7)
		switch  {
		case 0:
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return 0, ErrIntOverflowRpc
				}
				if  >=  {
					return 0, io.ErrUnexpectedEOF
				}
				++
				if [-1] < 0x80 {
					break
				}
			}
		case 1:
			 += 8
		case 2:
			var  int
			for  := uint(0); ;  += 7 {
				if  >= 64 {
					return 0, ErrIntOverflowRpc
				}
				if  >=  {
					return 0, io.ErrUnexpectedEOF
				}
				 := []
				++
				 |= (int() & 0x7F) << 
				if  < 0x80 {
					break
				}
			}
			if  < 0 {
				return 0, ErrInvalidLengthRpc
			}
			 += 
		case 3:
			++
		case 4:
			if  == 0 {
				return 0, ErrUnexpectedEndOfGroupRpc
			}
			--
		case 5:
			 += 4
		default:
			return 0, fmt.Errorf("proto: illegal wireType %d", )
		}
		if  < 0 {
			return 0, ErrInvalidLengthRpc
		}
		if  == 0 {
			return , nil
		}
	}
	return 0, io.ErrUnexpectedEOF
}

var (
	ErrInvalidLengthRpc        = fmt.Errorf("proto: negative length found during unmarshaling")
	ErrIntOverflowRpc          = fmt.Errorf("proto: integer overflow")
	ErrUnexpectedEndOfGroupRpc = fmt.Errorf("proto: unexpected end of group")
)