mirror of https://github.com/docker/cli.git
230 lines
6.3 KiB
Go
230 lines
6.3 KiB
Go
|
// Protocol Buffers for Go with Gadgets
|
||
|
//
|
||
|
// Copyright (c) 2016, The GoGo Authors. All rights reserved.
|
||
|
// http://github.com/gogo/protobuf
|
||
|
//
|
||
|
// Redistribution and use in source and binary forms, with or without
|
||
|
// modification, are permitted provided that the following conditions are
|
||
|
// met:
|
||
|
//
|
||
|
// * Redistributions of source code must retain the above copyright
|
||
|
// notice, this list of conditions and the following disclaimer.
|
||
|
// * Redistributions in binary form must reproduce the above
|
||
|
// copyright notice, this list of conditions and the following disclaimer
|
||
|
// in the documentation and/or other materials provided with the
|
||
|
// distribution.
|
||
|
//
|
||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||
|
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||
|
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||
|
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||
|
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||
|
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||
|
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||
|
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||
|
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||
|
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||
|
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||
|
|
||
|
package proto
|
||
|
|
||
|
import (
|
||
|
"reflect"
|
||
|
"time"
|
||
|
)
|
||
|
|
||
|
var timeType = reflect.TypeOf((*time.Time)(nil)).Elem()
|
||
|
|
||
|
type timestamp struct {
|
||
|
Seconds int64 `protobuf:"varint,1,opt,name=seconds,proto3" json:"seconds,omitempty"`
|
||
|
Nanos int32 `protobuf:"varint,2,opt,name=nanos,proto3" json:"nanos,omitempty"`
|
||
|
}
|
||
|
|
||
|
func (m *timestamp) Reset() { *m = timestamp{} }
|
||
|
func (*timestamp) ProtoMessage() {}
|
||
|
func (*timestamp) String() string { return "timestamp<string>" }
|
||
|
|
||
|
func init() {
|
||
|
RegisterType((*timestamp)(nil), "gogo.protobuf.proto.timestamp")
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) decTimestamp() (time.Time, error) {
|
||
|
b, err := o.DecodeRawBytes(true)
|
||
|
if err != nil {
|
||
|
return time.Time{}, err
|
||
|
}
|
||
|
tproto := ×tamp{}
|
||
|
if err := Unmarshal(b, tproto); err != nil {
|
||
|
return time.Time{}, err
|
||
|
}
|
||
|
return timestampFromProto(tproto)
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) dec_time(p *Properties, base structPointer) error {
|
||
|
t, err := o.decTimestamp()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
setPtrCustomType(base, p.field, &t)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) dec_ref_time(p *Properties, base structPointer) error {
|
||
|
t, err := o.decTimestamp()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
setCustomType(base, p.field, &t)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) dec_slice_time(p *Properties, base structPointer) error {
|
||
|
t, err := o.decTimestamp()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
newBas := appendStructPointer(base, p.field, reflect.SliceOf(reflect.PtrTo(timeType)))
|
||
|
var zero field
|
||
|
setPtrCustomType(newBas, zero, &t)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) dec_slice_ref_time(p *Properties, base structPointer) error {
|
||
|
t, err := o.decTimestamp()
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
newBas := appendStructPointer(base, p.field, reflect.SliceOf(timeType))
|
||
|
var zero field
|
||
|
setCustomType(newBas, zero, &t)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func size_time(p *Properties, base structPointer) (n int) {
|
||
|
structp := structPointer_GetStructPointer(base, p.field)
|
||
|
if structPointer_IsNil(structp) {
|
||
|
return 0
|
||
|
}
|
||
|
tim := structPointer_Interface(structp, timeType).(*time.Time)
|
||
|
t, err := timestampProto(*tim)
|
||
|
if err != nil {
|
||
|
return 0
|
||
|
}
|
||
|
size := Size(t)
|
||
|
return size + sizeVarint(uint64(size)) + len(p.tagcode)
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) enc_time(p *Properties, base structPointer) error {
|
||
|
structp := structPointer_GetStructPointer(base, p.field)
|
||
|
if structPointer_IsNil(structp) {
|
||
|
return ErrNil
|
||
|
}
|
||
|
tim := structPointer_Interface(structp, timeType).(*time.Time)
|
||
|
t, err := timestampProto(*tim)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
data, err := Marshal(t)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
o.buf = append(o.buf, p.tagcode...)
|
||
|
o.EncodeRawBytes(data)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func size_ref_time(p *Properties, base structPointer) (n int) {
|
||
|
tim := structPointer_InterfaceAt(base, p.field, timeType).(*time.Time)
|
||
|
t, err := timestampProto(*tim)
|
||
|
if err != nil {
|
||
|
return 0
|
||
|
}
|
||
|
size := Size(t)
|
||
|
return size + sizeVarint(uint64(size)) + len(p.tagcode)
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) enc_ref_time(p *Properties, base structPointer) error {
|
||
|
tim := structPointer_InterfaceAt(base, p.field, timeType).(*time.Time)
|
||
|
t, err := timestampProto(*tim)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
data, err := Marshal(t)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
o.buf = append(o.buf, p.tagcode...)
|
||
|
o.EncodeRawBytes(data)
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func size_slice_time(p *Properties, base structPointer) (n int) {
|
||
|
ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(reflect.PtrTo(timeType))).(*[]*time.Time)
|
||
|
tims := *ptims
|
||
|
for i := 0; i < len(tims); i++ {
|
||
|
if tims[i] == nil {
|
||
|
return 0
|
||
|
}
|
||
|
tproto, err := timestampProto(*tims[i])
|
||
|
if err != nil {
|
||
|
return 0
|
||
|
}
|
||
|
size := Size(tproto)
|
||
|
n += len(p.tagcode) + size + sizeVarint(uint64(size))
|
||
|
}
|
||
|
return n
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) enc_slice_time(p *Properties, base structPointer) error {
|
||
|
ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(reflect.PtrTo(timeType))).(*[]*time.Time)
|
||
|
tims := *ptims
|
||
|
for i := 0; i < len(tims); i++ {
|
||
|
if tims[i] == nil {
|
||
|
return errRepeatedHasNil
|
||
|
}
|
||
|
tproto, err := timestampProto(*tims[i])
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
data, err := Marshal(tproto)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
o.buf = append(o.buf, p.tagcode...)
|
||
|
o.EncodeRawBytes(data)
|
||
|
}
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func size_slice_ref_time(p *Properties, base structPointer) (n int) {
|
||
|
ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(timeType)).(*[]time.Time)
|
||
|
tims := *ptims
|
||
|
for i := 0; i < len(tims); i++ {
|
||
|
tproto, err := timestampProto(tims[i])
|
||
|
if err != nil {
|
||
|
return 0
|
||
|
}
|
||
|
size := Size(tproto)
|
||
|
n += len(p.tagcode) + size + sizeVarint(uint64(size))
|
||
|
}
|
||
|
return n
|
||
|
}
|
||
|
|
||
|
func (o *Buffer) enc_slice_ref_time(p *Properties, base structPointer) error {
|
||
|
ptims := structPointer_InterfaceAt(base, p.field, reflect.SliceOf(timeType)).(*[]time.Time)
|
||
|
tims := *ptims
|
||
|
for i := 0; i < len(tims); i++ {
|
||
|
tproto, err := timestampProto(tims[i])
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
data, err := Marshal(tproto)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
o.buf = append(o.buf, p.tagcode...)
|
||
|
o.EncodeRawBytes(data)
|
||
|
}
|
||
|
return nil
|
||
|
}
|