sql_utils/base/time_proto_util.h (13 lines of code) (raw):

/* * Copyright 2023 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef THIRD_PARTY_PY_BIGQUERY_ML_UTILS_SQL_UTILS_BASE_TIME_PROTO_UTIL_H_ #define THIRD_PARTY_PY_BIGQUERY_ML_UTILS_SQL_UTILS_BASE_TIME_PROTO_UTIL_H_ #include "google/protobuf/timestamp.pb.h" #include "absl/status/status.h" #include "absl/status/statusor.h" #include "absl/time/time.h" namespace bigquery_ml_utils_base { // Encodes an absl::Time as a google::protobuf::Timestamp, following the // encoding rules specified at (broken link) // Returns an error if the given absl::Time is beyond the range allowed by the // protobuf. Otherwise, truncates toward infinite past with nanosecond precision // and returns the google::protobuf::Timestamp. // // See also: (broken link) // // Note: absl::InfiniteFuture/absl::InfinitePast() cannot be encoded because // they are not representable in the protobuf. absl::Status EncodeGoogleApiProto(absl::Time t, google::protobuf::Timestamp* proto); // Decodes the given protobuf and returns an absl::Time, or returns an error // status if the argument is invalid according to // (broken link) absl::StatusOr<absl::Time> DecodeGoogleApiProto( const google::protobuf::Timestamp& proto); } // namespace bigquery_ml_utils_base #endif // THIRD_PARTY_PY_BIGQUERY_ML_UTILS_SQL_UTILS_BASE_TIME_PROTO_UTIL_H_