Add native php support for Duration. (#3583)
parent
35b852f5b8
commit
7f8b91f552
7 changed files with 261 additions and 0 deletions
@ -0,0 +1,31 @@ |
||||
<?php |
||||
# Generated by the protocol buffer compiler. DO NOT EDIT! |
||||
# source: google/protobuf/duration.proto |
||||
|
||||
namespace GPBMetadata\Google\Protobuf; |
||||
|
||||
class Duration |
||||
{ |
||||
public static $is_initialized = false; |
||||
|
||||
public static function initOnce() { |
||||
$pool = \Google\Protobuf\Internal\DescriptorPool::getGeneratedPool(); |
||||
|
||||
if (static::$is_initialized == true) { |
||||
return; |
||||
} |
||||
$pool->internalAddGeneratedFile(hex2bin( |
||||
"0ae3010a1e676f6f676c652f70726f746f6275662f6475726174696f6e2e" . |
||||
"70726f746f120f676f6f676c652e70726f746f627566222a0a0844757261" . |
||||
"74696f6e120f0a077365636f6e6473180120012803120d0a056e616e6f73" . |
||||
"180220012805427c0a13636f6d2e676f6f676c652e70726f746f62756642" . |
||||
"0d4475726174696f6e50726f746f50015a2a6769746875622e636f6d2f67" . |
||||
"6f6c616e672f70726f746f6275662f7074797065732f6475726174696f6e" . |
||||
"f80101a20203475042aa021e476f6f676c652e50726f746f6275662e5765" . |
||||
"6c6c4b6e6f776e5479706573620670726f746f33" |
||||
)); |
||||
|
||||
static::$is_initialized = true; |
||||
} |
||||
} |
||||
|
@ -0,0 +1,153 @@ |
||||
<?php |
||||
# Generated by the protocol buffer compiler. DO NOT EDIT! |
||||
# source: google/protobuf/duration.proto |
||||
|
||||
namespace Google\Protobuf; |
||||
|
||||
use Google\Protobuf\Internal\GPBType; |
||||
use Google\Protobuf\Internal\RepeatedField; |
||||
use Google\Protobuf\Internal\GPBUtil; |
||||
|
||||
/** |
||||
* 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". |
||||
* |
||||
* Generated from protobuf message <code>google.protobuf.Duration</code> |
||||
*/ |
||||
class Duration extends \Google\Protobuf\Internal\Message |
||||
{ |
||||
/** |
||||
* 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 |
||||
* |
||||
* Generated from protobuf field <code>int64 seconds = 1;</code> |
||||
*/ |
||||
private $seconds = 0; |
||||
/** |
||||
* 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. |
||||
* |
||||
* Generated from protobuf field <code>int32 nanos = 2;</code> |
||||
*/ |
||||
private $nanos = 0; |
||||
|
||||
public function __construct() { |
||||
\GPBMetadata\Google\Protobuf\Duration::initOnce(); |
||||
parent::__construct(); |
||||
} |
||||
|
||||
/** |
||||
* 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 |
||||
* |
||||
* Generated from protobuf field <code>int64 seconds = 1;</code> |
||||
* @return int|string |
||||
*/ |
||||
public function getSeconds() |
||||
{ |
||||
return $this->seconds; |
||||
} |
||||
|
||||
/** |
||||
* 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 |
||||
* |
||||
* Generated from protobuf field <code>int64 seconds = 1;</code> |
||||
* @param int|string $var |
||||
* @return $this |
||||
*/ |
||||
public function setSeconds($var) |
||||
{ |
||||
GPBUtil::checkInt64($var); |
||||
$this->seconds = $var; |
||||
|
||||
return $this; |
||||
} |
||||
|
||||
/** |
||||
* 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. |
||||
* |
||||
* Generated from protobuf field <code>int32 nanos = 2;</code> |
||||
* @return int |
||||
*/ |
||||
public function getNanos() |
||||
{ |
||||
return $this->nanos; |
||||
} |
||||
|
||||
/** |
||||
* 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. |
||||
* |
||||
* Generated from protobuf field <code>int32 nanos = 2;</code> |
||||
* @param int $var |
||||
* @return $this |
||||
*/ |
||||
public function setNanos($var) |
||||
{ |
||||
GPBUtil::checkInt32($var); |
||||
$this->nanos = $var; |
||||
|
||||
return $this; |
||||
} |
||||
} |
||||
|
Loading…
Reference in new issue