本文整理汇总了Golang中github.com/golang/protobuf/proto.Buffer.EncodeFixed64方法的典型用法代码示例。如果您正苦于以下问题:Golang Buffer.EncodeFixed64方法的具体用法?Golang Buffer.EncodeFixed64怎么用?Golang Buffer.EncodeFixed64使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/golang/protobuf/proto.Buffer
的用法示例。
在下文中一共展示了Buffer.EncodeFixed64方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: _OptionValue_OneofMarshaler
func _OptionValue_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*OptionValue)
// value
switch x := m.Value.(type) {
case *OptionValue_BoolValue:
t := uint64(0)
if x.BoolValue {
t = 1
}
b.EncodeVarint(2<<3 | proto.WireVarint)
b.EncodeVarint(t)
case *OptionValue_IntValue:
b.EncodeVarint(3<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.IntValue))
case *OptionValue_DoubleValue:
b.EncodeVarint(4<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.DoubleValue))
case *OptionValue_StringValue:
b.EncodeVarint(5<<3 | proto.WireBytes)
b.EncodeStringBytes(x.StringValue)
case *OptionValue_DurationValue:
b.EncodeVarint(6<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.DurationValue))
case nil:
default:
return fmt.Errorf("OptionValue.Value has unexpected type %T", x)
}
return nil
}
示例2: _Metric_OneofMarshaler
func _Metric_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*Metric)
// data
switch x := m.Data.(type) {
case *Metric_StringData:
b.EncodeVarint(9<<3 | proto.WireBytes)
b.EncodeStringBytes(x.StringData)
case *Metric_Float32Data:
b.EncodeVarint(10<<3 | proto.WireFixed32)
b.EncodeFixed32(uint64(math.Float32bits(x.Float32Data)))
case *Metric_Float64Data:
b.EncodeVarint(11<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.Float64Data))
case *Metric_Int32Data:
b.EncodeVarint(12<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.Int32Data))
case *Metric_Int64Data:
b.EncodeVarint(13<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.Int64Data))
case *Metric_BytesData:
b.EncodeVarint(14<<3 | proto.WireBytes)
b.EncodeRawBytes(x.BytesData)
case *Metric_BoolData:
t := uint64(0)
if x.BoolData {
t = 1
}
b.EncodeVarint(15<<3 | proto.WireVarint)
b.EncodeVarint(t)
case nil:
default:
return fmt.Errorf("Metric.Data has unexpected type %T", x)
}
return nil
}
示例3: _Value_OneofMarshaler
func _Value_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*Value)
// value_type
switch x := m.ValueType.(type) {
case *Value_NullValue:
b.EncodeVarint(11<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.NullValue))
case *Value_BooleanValue:
t := uint64(0)
if x.BooleanValue {
t = 1
}
b.EncodeVarint(1<<3 | proto.WireVarint)
b.EncodeVarint(t)
case *Value_IntegerValue:
b.EncodeVarint(2<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.IntegerValue))
case *Value_DoubleValue:
b.EncodeVarint(3<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.DoubleValue))
case *Value_TimestampValue:
b.EncodeVarint(10<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.TimestampValue); err != nil {
return err
}
case *Value_KeyValue:
b.EncodeVarint(5<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.KeyValue); err != nil {
return err
}
case *Value_StringValue:
b.EncodeVarint(17<<3 | proto.WireBytes)
b.EncodeStringBytes(x.StringValue)
case *Value_BlobValue:
b.EncodeVarint(18<<3 | proto.WireBytes)
b.EncodeRawBytes(x.BlobValue)
case *Value_GeoPointValue:
b.EncodeVarint(8<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.GeoPointValue); err != nil {
return err
}
case *Value_EntityValue:
b.EncodeVarint(6<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.EntityValue); err != nil {
return err
}
case *Value_ArrayValue:
b.EncodeVarint(9<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.ArrayValue); err != nil {
return err
}
case nil:
default:
return fmt.Errorf("Value.ValueType has unexpected type %T", x)
}
return nil
}
示例4: _Communique_OneofMarshaler
func _Communique_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*Communique)
// union
switch x := m.Union.(type) {
case *Communique_Number:
b.EncodeVarint(5<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.Number))
case *Communique_Name:
b.EncodeVarint(6<<3 | proto.WireBytes)
b.EncodeStringBytes(x.Name)
case *Communique_Data:
b.EncodeVarint(7<<3 | proto.WireBytes)
b.EncodeRawBytes(x.Data)
case *Communique_TempC:
b.EncodeVarint(8<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.TempC))
case *Communique_Height:
b.EncodeVarint(9<<3 | proto.WireFixed32)
b.EncodeFixed32(uint64(math.Float32bits(x.Height)))
case *Communique_Today:
b.EncodeVarint(10<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.Today))
case *Communique_Maybe:
t := uint64(0)
if x.Maybe {
t = 1
}
b.EncodeVarint(11<<3 | proto.WireVarint)
b.EncodeVarint(t)
case *Communique_Delta_:
b.EncodeVarint(12<<3 | proto.WireVarint)
b.EncodeZigzag32(uint64(x.Delta))
case *Communique_Msg:
b.EncodeVarint(13<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.Msg); err != nil {
return err
}
case *Communique_Somegroup:
b.EncodeVarint(14<<3 | proto.WireStartGroup)
if err := b.Marshal(x.Somegroup); err != nil {
return err
}
b.EncodeVarint(14<<3 | proto.WireEndGroup)
case nil:
default:
return fmt.Errorf("Communique.Union has unexpected type %T", x)
}
return nil
}
示例5: _GaugeResponse_OneofMarshaler
func _GaugeResponse_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*GaugeResponse)
// value
switch x := m.Value.(type) {
case *GaugeResponse_LongValue:
b.EncodeVarint(2<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.LongValue))
case *GaugeResponse_DoubleValue:
b.EncodeVarint(3<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.DoubleValue))
case *GaugeResponse_StringValue:
b.EncodeVarint(4<<3 | proto.WireBytes)
b.EncodeStringBytes(x.StringValue)
case nil:
default:
return fmt.Errorf("GaugeResponse.Value has unexpected type %T", x)
}
return nil
}
示例6: _Field_OneofMarshaler
func _Field_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*Field)
// value
switch x := m.Value.(type) {
case *Field_Number:
b.EncodeVarint(2<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.Number))
case *Field_Str:
b.EncodeVarint(3<<3 | proto.WireBytes)
b.EncodeStringBytes(x.Str)
case *Field_Boolean:
t := uint64(0)
if x.Boolean {
t = 1
}
b.EncodeVarint(4<<3 | proto.WireVarint)
b.EncodeVarint(t)
case *Field_Object:
b.EncodeVarint(5<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.Object); err != nil {
return err
}
case *Field_Array:
b.EncodeVarint(6<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.Array); err != nil {
return err
}
case *Field_Link:
b.EncodeVarint(7<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.Link); err != nil {
return err
}
case nil:
default:
return fmt.Errorf("Field.Value has unexpected type %T", x)
}
return nil
}
示例7: _Argument_OneofMarshaler
func _Argument_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*Argument)
// value
switch x := m.Value.(type) {
case *Argument_Number:
b.EncodeVarint(1<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.Number))
case *Argument_Str:
b.EncodeVarint(2<<3 | proto.WireBytes)
b.EncodeStringBytes(x.Str)
case *Argument_Boolean:
t := uint64(0)
if x.Boolean {
t = 1
}
b.EncodeVarint(3<<3 | proto.WireVarint)
b.EncodeVarint(t)
case nil:
default:
return fmt.Errorf("Argument.Value has unexpected type %T", x)
}
return nil
}
示例8: _Value_OneofMarshaler
func _Value_OneofMarshaler(msg proto.Message, b *proto.Buffer) error {
m := msg.(*Value)
// kind
switch x := m.Kind.(type) {
case *Value_NullValue:
b.EncodeVarint(1<<3 | proto.WireVarint)
b.EncodeVarint(uint64(x.NullValue))
case *Value_NumberValue:
b.EncodeVarint(2<<3 | proto.WireFixed64)
b.EncodeFixed64(math.Float64bits(x.NumberValue))
case *Value_StringValue:
b.EncodeVarint(3<<3 | proto.WireBytes)
b.EncodeStringBytes(x.StringValue)
case *Value_BoolValue:
t := uint64(0)
if x.BoolValue {
t = 1
}
b.EncodeVarint(4<<3 | proto.WireVarint)
b.EncodeVarint(t)
case *Value_StructValue:
b.EncodeVarint(5<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.StructValue); err != nil {
return err
}
case *Value_ListValue:
b.EncodeVarint(6<<3 | proto.WireBytes)
if err := b.EncodeMessage(x.ListValue); err != nil {
return err
}
case nil:
default:
return fmt.Errorf("Value.Kind has unexpected type %T", x)
}
return nil
}