2019-01-18 01:50:10 +00:00
|
|
|
// Code generated by protoc-gen-go. DO NOT EDIT.
|
|
|
|
// source: google/protobuf/duration.proto
|
|
|
|
|
2019-05-03 10:50:21 +00:00
|
|
|
package duration
|
2019-01-18 01:50:10 +00:00
|
|
|
|
2019-05-03 10:50:21 +00:00
|
|
|
import (
|
|
|
|
fmt "fmt"
|
|
|
|
proto "github.com/golang/protobuf/proto"
|
|
|
|
math "math"
|
|
|
|
)
|
2019-01-18 01:50:10 +00:00
|
|
|
|
|
|
|
// 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.
|
2019-05-03 10:50:21 +00:00
|
|
|
const _ = proto.ProtoPackageIsVersion3 // please upgrade the proto package
|
2019-01-18 01:50:10 +00:00
|
|
|
|
|
|
|
// A Duration represents a signed, fixed-length span of time represented
|
|
|
|
// as a count of seconds and fractions of seconds at nanosecond
|
|
|
|
// resolution. It is independent of any calendar and concepts like "day"
|
|
|
|
// or "month". It is related to Timestamp in that the difference between
|
|
|
|
// two Timestamp values is a Duration and it can be added or subtracted
|
|
|
|
// from a Timestamp. Range is approximately +-10,000 years.
|
|
|
|
//
|
|
|
|
// # Examples
|
|
|
|
//
|
|
|
|
// Example 1: Compute Duration from two Timestamps in pseudo code.
|
|
|
|
//
|
|
|
|
// Timestamp start = ...;
|
|
|
|
// Timestamp end = ...;
|
|
|
|
// Duration duration = ...;
|
|
|
|
//
|
|
|
|
// duration.seconds = end.seconds - start.seconds;
|
|
|
|
// duration.nanos = end.nanos - start.nanos;
|
|
|
|
//
|
|
|
|
// if (duration.seconds < 0 && duration.nanos > 0) {
|
|
|
|
// duration.seconds += 1;
|
|
|
|
// duration.nanos -= 1000000000;
|
|
|
|
// } else if (durations.seconds > 0 && duration.nanos < 0) {
|
|
|
|
// duration.seconds -= 1;
|
|
|
|
// duration.nanos += 1000000000;
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// Example 2: Compute Timestamp from Timestamp + Duration in pseudo code.
|
|
|
|
//
|
|
|
|
// Timestamp start = ...;
|
|
|
|
// Duration duration = ...;
|
|
|
|
// Timestamp end = ...;
|
|
|
|
//
|
|
|
|
// end.seconds = start.seconds + duration.seconds;
|
|
|
|
// end.nanos = start.nanos + duration.nanos;
|
|
|
|
//
|
|
|
|
// if (end.nanos < 0) {
|
|
|
|
// end.seconds -= 1;
|
|
|
|
// end.nanos += 1000000000;
|
|
|
|
// } else if (end.nanos >= 1000000000) {
|
|
|
|
// end.seconds += 1;
|
|
|
|
// end.nanos -= 1000000000;
|
|
|
|
// }
|
|
|
|
//
|
|
|
|
// Example 3: Compute Duration from datetime.timedelta in Python.
|
|
|
|
//
|
|
|
|
// td = datetime.timedelta(days=3, minutes=10)
|
|
|
|
// duration = Duration()
|
|
|
|
// duration.FromTimedelta(td)
|
|
|
|
//
|
|
|
|
// # JSON Mapping
|
|
|
|
//
|
|
|
|
// In JSON format, the Duration type is encoded as a string rather than an
|
|
|
|
// object, where the string ends in the suffix "s" (indicating seconds) and
|
|
|
|
// is preceded by the number of seconds, with nanoseconds expressed as
|
|
|
|
// fractional seconds. For example, 3 seconds with 0 nanoseconds should be
|
|
|
|
// encoded in JSON format as "3s", while 3 seconds and 1 nanosecond should
|
|
|
|
// be expressed in JSON format as "3.000000001s", and 3 seconds and 1
|
|
|
|
// microsecond should be expressed in JSON format as "3.000001s".
|
|
|
|
//
|
|
|
|
//
|
|
|
|
type Duration struct {
|
|
|
|
// Signed seconds of the span of time. Must be from -315,576,000,000
|
|
|
|
// to +315,576,000,000 inclusive. Note: these bounds are computed from:
|
|
|
|
// 60 sec/min * 60 min/hr * 24 hr/day * 365.25 days/year * 10000 years
|
|
|
|
Seconds int64 `protobuf:"varint,1,opt,name=seconds,proto3" json:"seconds,omitempty"`
|
|
|
|
// Signed fractions of a second at nanosecond resolution of the span
|
|
|
|
// of time. Durations less than one second are represented with a 0
|
|
|
|
// `seconds` field and a positive or negative `nanos` field. For durations
|
|
|
|
// of one second or more, a non-zero value for the `nanos` field must be
|
|
|
|
// of the same sign as the `seconds` field. Must be from -999,999,999
|
|
|
|
// to +999,999,999 inclusive.
|
|
|
|
Nanos int32 `protobuf:"varint,2,opt,name=nanos,proto3" json:"nanos,omitempty"`
|
|
|
|
XXX_NoUnkeyedLiteral struct{} `json:"-"`
|
|
|
|
XXX_unrecognized []byte `json:"-"`
|
|
|
|
XXX_sizecache int32 `json:"-"`
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Duration) Reset() { *m = Duration{} }
|
|
|
|
func (m *Duration) String() string { return proto.CompactTextString(m) }
|
|
|
|
func (*Duration) ProtoMessage() {}
|
|
|
|
func (*Duration) Descriptor() ([]byte, []int) {
|
2019-05-03 10:50:21 +00:00
|
|
|
return fileDescriptor_23597b2ebd7ac6c5, []int{0}
|
2019-01-18 01:50:10 +00:00
|
|
|
}
|
2019-05-03 10:50:21 +00:00
|
|
|
|
2019-01-18 01:50:10 +00:00
|
|
|
func (*Duration) XXX_WellKnownType() string { return "Duration" }
|
2019-05-03 10:50:21 +00:00
|
|
|
|
2019-01-18 01:50:10 +00:00
|
|
|
func (m *Duration) XXX_Unmarshal(b []byte) error {
|
|
|
|
return xxx_messageInfo_Duration.Unmarshal(m, b)
|
|
|
|
}
|
|
|
|
func (m *Duration) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) {
|
|
|
|
return xxx_messageInfo_Duration.Marshal(b, m, deterministic)
|
|
|
|
}
|
2019-05-03 10:50:21 +00:00
|
|
|
func (m *Duration) XXX_Merge(src proto.Message) {
|
|
|
|
xxx_messageInfo_Duration.Merge(m, src)
|
2019-01-18 01:50:10 +00:00
|
|
|
}
|
|
|
|
func (m *Duration) XXX_Size() int {
|
|
|
|
return xxx_messageInfo_Duration.Size(m)
|
|
|
|
}
|
|
|
|
func (m *Duration) XXX_DiscardUnknown() {
|
|
|
|
xxx_messageInfo_Duration.DiscardUnknown(m)
|
|
|
|
}
|
|
|
|
|
|
|
|
var xxx_messageInfo_Duration proto.InternalMessageInfo
|
|
|
|
|
|
|
|
func (m *Duration) GetSeconds() int64 {
|
|
|
|
if m != nil {
|
|
|
|
return m.Seconds
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func (m *Duration) GetNanos() int32 {
|
|
|
|
if m != nil {
|
|
|
|
return m.Nanos
|
|
|
|
}
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
proto.RegisterType((*Duration)(nil), "google.protobuf.Duration")
|
|
|
|
}
|
|
|
|
|
2019-05-03 10:50:21 +00:00
|
|
|
func init() { proto.RegisterFile("google/protobuf/duration.proto", fileDescriptor_23597b2ebd7ac6c5) }
|
2019-01-18 01:50:10 +00:00
|
|
|
|
2019-05-03 10:50:21 +00:00
|
|
|
var fileDescriptor_23597b2ebd7ac6c5 = []byte{
|
2019-01-18 01:50:10 +00:00
|
|
|
// 190 bytes of a gzipped FileDescriptorProto
|
|
|
|
0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe2, 0x92, 0x4b, 0xcf, 0xcf, 0x4f,
|
|
|
|
0xcf, 0x49, 0xd5, 0x2f, 0x28, 0xca, 0x2f, 0xc9, 0x4f, 0x2a, 0x4d, 0xd3, 0x4f, 0x29, 0x2d, 0x4a,
|
|
|
|
0x2c, 0xc9, 0xcc, 0xcf, 0xd3, 0x03, 0x8b, 0x08, 0xf1, 0x43, 0xe4, 0xf5, 0x60, 0xf2, 0x4a, 0x56,
|
|
|
|
0x5c, 0x1c, 0x2e, 0x50, 0x25, 0x42, 0x12, 0x5c, 0xec, 0xc5, 0xa9, 0xc9, 0xf9, 0x79, 0x29, 0xc5,
|
|
|
|
0x12, 0x8c, 0x0a, 0x8c, 0x1a, 0xcc, 0x41, 0x30, 0xae, 0x90, 0x08, 0x17, 0x6b, 0x5e, 0x62, 0x5e,
|
|
|
|
0x7e, 0xb1, 0x04, 0x93, 0x02, 0xa3, 0x06, 0x6b, 0x10, 0x84, 0xe3, 0x54, 0xc3, 0x25, 0x9c, 0x9c,
|
|
|
|
0x9f, 0xab, 0x87, 0x66, 0xa4, 0x13, 0x2f, 0xcc, 0xc0, 0x00, 0x90, 0x48, 0x00, 0x63, 0x94, 0x56,
|
|
|
|
0x7a, 0x66, 0x49, 0x46, 0x69, 0x92, 0x5e, 0x72, 0x7e, 0xae, 0x7e, 0x7a, 0x7e, 0x4e, 0x62, 0x5e,
|
|
|
|
0x3a, 0xc2, 0x7d, 0x05, 0x25, 0x95, 0x05, 0xa9, 0xc5, 0x70, 0x67, 0xfe, 0x60, 0x64, 0x5c, 0xc4,
|
|
|
|
0xc4, 0xec, 0x1e, 0xe0, 0xb4, 0x8a, 0x49, 0xce, 0x1d, 0x62, 0x6e, 0x00, 0x54, 0xa9, 0x5e, 0x78,
|
|
|
|
0x6a, 0x4e, 0x8e, 0x77, 0x5e, 0x7e, 0x79, 0x5e, 0x08, 0x48, 0x4b, 0x12, 0x1b, 0xd8, 0x0c, 0x63,
|
|
|
|
0x40, 0x00, 0x00, 0x00, 0xff, 0xff, 0xdc, 0x84, 0x30, 0xff, 0xf3, 0x00, 0x00, 0x00,
|
|
|
|
}
|