-- 00d42e3d5433aaf29c2ed293520b2ba178ae8bdb by Greg Falcon <gfalcon@google.com>: Import of CCTZ from GitHub. PiperOrigin-RevId: 238061818 -- 867a7ca318fac2991ea9a4107dbae3cc9fbf974a by Abseil Team <absl-team@google.com>: Added a IWYU export pragma when including a standard header for the purpose of aliasing its symbols. PiperOrigin-RevId: 238022277 -- 17047745058f2f151cd986ea9f649512542d3876 by Matt Armstrong <marmstrong@google.com>: Clarify the comment discouraging WrapUnique<T>(x) calls. PiperOrigin-RevId: 237873803 -- 3dcb2e4968243d33ca0ce53280c445df50f4a7ec by Samuel Benzaquen <sbenza@google.com>: Workaround clang bug https://bugs.llvm.org/show_bug.cgi?id=38289 PiperOrigin-RevId: 237873551 -- f348d2dc7087a990cbdfb95aa51fd7ff478ae40e by Samuel Benzaquen <sbenza@google.com>: Reduce minimum capacity to 1. This reduces memory usage for small tables. A flat_hash_set<int> of 1 element goes from 92 bytes to 24. A flat_hash_set<string> of 1 element goes from 512 bytes to 56. PiperOrigin-RevId: 237859811 -- 9c8125be5e4e5d22a7bb62bdec8c323338385c1b by Jon Cohen <cohenjon@google.com>: Bump to CMake 3.5. This is the oldest modern cmake being included by default in most popular OS distributions according to https://repology.org/project/cmake/versions. Specifically, Ubuntu LTS 16.04 uses cmake 3.5 (https://packages.ubuntu.com/xenial/cmake) PiperOrigin-RevId: 237859345 -- 07638d672e0a4dced986a62750cfd8318ed36ffa by Derek Mauro <dmauro@google.com>: Import of CCTZ from GitHub. PiperOrigin-RevId: 237714597 GitOrigin-RevId: 00d42e3d5433aaf29c2ed293520b2ba178ae8bdb Change-Id: I5faecc45add4a5a774d4f9baf06e5519091f2ccc
90 lines
3.2 KiB
C++
90 lines
3.2 KiB
C++
// Copyright 2016 Google Inc. All Rights Reserved.
|
|
//
|
|
// 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
|
|
//
|
|
// https://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 ABSL_TIME_INTERNAL_CCTZ_TIME_ZONE_IMPL_H_
|
|
#define ABSL_TIME_INTERNAL_CCTZ_TIME_ZONE_IMPL_H_
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
|
|
#include "absl/time/internal/cctz/include/cctz/civil_time.h"
|
|
#include "absl/time/internal/cctz/include/cctz/time_zone.h"
|
|
#include "time_zone_if.h"
|
|
#include "time_zone_info.h"
|
|
|
|
namespace absl {
|
|
namespace time_internal {
|
|
namespace cctz {
|
|
|
|
// time_zone::Impl is the internal object referenced by a cctz::time_zone.
|
|
class time_zone::Impl {
|
|
public:
|
|
// The UTC time zone. Also used for other time zones that fail to load.
|
|
static time_zone UTC();
|
|
|
|
// Load a named time zone. Returns false if the name is invalid, or if
|
|
// some other kind of error occurs. Note that loading "UTC" never fails.
|
|
static bool LoadTimeZone(const std::string& name, time_zone* tz);
|
|
|
|
// Clears the map of cached time zones. Primarily for use in benchmarks
|
|
// that gauge the performance of loading/parsing the time-zone data.
|
|
static void ClearTimeZoneMapTestOnly();
|
|
|
|
// The primary key is the time-zone ID (e.g., "America/New_York").
|
|
const std::string& Name() const {
|
|
// TODO: It would nice if the zoneinfo data included the zone name.
|
|
return name_;
|
|
}
|
|
|
|
// Breaks a time_point down to civil-time components in this time zone.
|
|
time_zone::absolute_lookup BreakTime(const time_point<seconds>& tp) const {
|
|
return zone_->BreakTime(tp);
|
|
}
|
|
|
|
// Converts the civil-time components in this time zone into a time_point.
|
|
// That is, the opposite of BreakTime(). The requested civil time may be
|
|
// ambiguous or illegal due to a change of UTC offset.
|
|
time_zone::civil_lookup MakeTime(const civil_second& cs) const {
|
|
return zone_->MakeTime(cs);
|
|
}
|
|
|
|
// Finds the time of the next/previous offset change in this time zone.
|
|
bool NextTransition(const time_point<seconds>& tp,
|
|
time_zone::civil_transition* trans) const {
|
|
return zone_->NextTransition(tp, trans);
|
|
}
|
|
bool PrevTransition(const time_point<seconds>& tp,
|
|
time_zone::civil_transition* trans) const {
|
|
return zone_->PrevTransition(tp, trans);
|
|
}
|
|
|
|
// Returns an implementation-defined version std::string for this time zone.
|
|
std::string Version() const { return zone_->Version(); }
|
|
|
|
// Returns an implementation-defined description of this time zone.
|
|
std::string Description() const { return zone_->Description(); }
|
|
|
|
private:
|
|
explicit Impl(const std::string& name);
|
|
static const Impl* UTCImpl();
|
|
|
|
const std::string name_;
|
|
std::unique_ptr<TimeZoneIf> zone_;
|
|
};
|
|
|
|
} // namespace cctz
|
|
} // namespace time_internal
|
|
} // namespace absl
|
|
|
|
#endif // ABSL_TIME_INTERNAL_CCTZ_TIME_ZONE_IMPL_H_
|