26b789f9a5
- acd95f8ec4e6ec1587cb198c7f40af3c81094d92 Release container benchmarks. by Alex Strelnikov <strel@google.com> - 80f596b6b7c5e06453e778c16527d5a0e85f8413 Allow absl::base_internal::AtomicHook to have a default v... by Derek Mauro <dmauro@google.com> - 8402631546af8bcbd4acdf897d0cdfb805ad544a Release thread_identity benchmark. by Alex Strelnikov <strel@google.com> - 6dcb1e90fefb8556ce4654983d3a73c7585b4b99 Fix spelling error in variant.h by Abseil Team <absl-team@google.com> - faa8a81e1442018c0d400b09a595a5be55074715 Run tests from CMake. The CI is currently Linux only, fo... by Jon Cohen <cohenjon@google.com> - 745ed6db574f931f2ec3a88e964fb03a5f22f816 Internal change. by Derek Mauro <dmauro@google.com> - 23facd7d1c5f43ac8181b016ee4acc5955f048c1 absl::variant exception safety test. by Xiaoyi Zhang <zhangxy@google.com> - c18e21e7cf8f6e83ae9d90e536e886409dd6cf68 Reinstate the syntax check on time-zone abbreviations now... by Abseil Team <absl-team@google.com> - da469f4314f0c820665a2b5b9477af9462b23e42 Import CCTZ changes to internal copy. by Shaindel Schwartz <shaindel@google.com> - 44ea35843517be03ab256b69449ccfea64352621 Import CCTZ changes to internal copy. by Abseil Team <absl-team@google.com> - 55d1105312687c6093950fac831c7540f49045b5 Import CCTZ changes to internal copy. by Greg Falcon <gfalcon@google.com> - 58d7965ad274406410b6d833213eca04d41c6867 Add zoneinfo as a data dependency to the //absl/time tests. by Shaindel Schwartz <shaindel@google.com> - 6acc50146f9ff29015bfaaa5bf9900691f839da5 Change benchmark target type from cc_test to cc_binary. by Alex Strelnikov <strel@google.com> - db3fbdae8f9f285a466f7a070326b1ce43b6a0dd Update WORKSPACE for C++ microbenchmarks and release algo... by Alex Strelnikov <strel@google.com> - 0869ae168255242af651853ed01719166d8cebf6 Update to Bazel version 0.13.0. by Abseil Team <absl-team@google.com> - e507dd53ab788964207fdf27d31b72a33c296fab Add missing include of cstdio by Abseil Team <absl-team@google.com> GitOrigin-RevId: 07191b0f52301e1e4a790e236f7b7c2fd90561ae Change-Id: I90994cf2b438fbec894724dcd9b90882281eef56
145 lines
4.1 KiB
C++
145 lines
4.1 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
|
|
//
|
|
// 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.
|
|
|
|
#include "absl/time/internal/cctz/include/cctz/time_zone.h"
|
|
|
|
#if defined(__ANDROID__)
|
|
#include <sys/system_properties.h>
|
|
#if __ANDROID_API__ >= 21
|
|
#include <dlfcn.h>
|
|
#endif
|
|
#endif
|
|
#include <cstdlib>
|
|
#include <cstring>
|
|
#include <string>
|
|
|
|
#include "time_zone_fixed.h"
|
|
#include "time_zone_impl.h"
|
|
|
|
namespace absl {
|
|
namespace time_internal {
|
|
namespace cctz {
|
|
|
|
#if defined(__ANDROID__) && __ANDROID_API__ >= 21
|
|
namespace {
|
|
// Android 'L' removes __system_property_get() from the NDK, however
|
|
// it is still a hidden symbol in libc so we use dlsym() to access it.
|
|
// See Chromium's base/sys_info_android.cc for a similar example.
|
|
|
|
using property_get_func = int (*)(const char*, char*);
|
|
|
|
property_get_func LoadSystemPropertyGet() {
|
|
int flag = RTLD_LAZY | RTLD_GLOBAL;
|
|
#if defined(RTLD_NOLOAD)
|
|
flag |= RTLD_NOLOAD; // libc.so should already be resident
|
|
#endif
|
|
if (void* handle = dlopen("libc.so", flag)) {
|
|
void* sym = dlsym(handle, "__system_property_get");
|
|
dlclose(handle);
|
|
return reinterpret_cast<property_get_func>(sym);
|
|
}
|
|
return nullptr;
|
|
}
|
|
|
|
int __system_property_get(const char* name, char* value) {
|
|
static property_get_func system_property_get = LoadSystemPropertyGet();
|
|
return system_property_get ? system_property_get(name, value) : -1;
|
|
}
|
|
|
|
} // namespace
|
|
#endif
|
|
|
|
std::string time_zone::name() const {
|
|
return time_zone::Impl::get(*this).name();
|
|
}
|
|
|
|
time_zone::absolute_lookup time_zone::lookup(
|
|
const time_point<sys_seconds>& tp) const {
|
|
return time_zone::Impl::get(*this).BreakTime(tp);
|
|
}
|
|
|
|
time_zone::civil_lookup time_zone::lookup(const civil_second& cs) const {
|
|
return time_zone::Impl::get(*this).MakeTime(cs);
|
|
}
|
|
|
|
bool operator==(time_zone lhs, time_zone rhs) {
|
|
return &time_zone::Impl::get(lhs) == &time_zone::Impl::get(rhs);
|
|
}
|
|
|
|
bool load_time_zone(const std::string& name, time_zone* tz) {
|
|
return time_zone::Impl::LoadTimeZone(name, tz);
|
|
}
|
|
|
|
time_zone utc_time_zone() {
|
|
return time_zone::Impl::UTC(); // avoid name lookup
|
|
}
|
|
|
|
time_zone fixed_time_zone(const sys_seconds& offset) {
|
|
time_zone tz;
|
|
load_time_zone(FixedOffsetToName(offset), &tz);
|
|
return tz;
|
|
}
|
|
|
|
time_zone local_time_zone() {
|
|
const char* zone = ":localtime";
|
|
|
|
// Allow ${TZ} to override to default zone.
|
|
char* tz_env = nullptr;
|
|
#if defined(_MSC_VER)
|
|
_dupenv_s(&tz_env, nullptr, "TZ");
|
|
#else
|
|
tz_env = std::getenv("TZ");
|
|
#endif
|
|
#if defined(__ANDROID__)
|
|
char sysprop[PROP_VALUE_MAX];
|
|
if (tz_env == nullptr)
|
|
if (__system_property_get("persist.sys.timezone", sysprop) > 0)
|
|
tz_env = sysprop;
|
|
#endif
|
|
if (tz_env) zone = tz_env;
|
|
|
|
// We only support the "[:]<zone-name>" form.
|
|
if (*zone == ':') ++zone;
|
|
|
|
// Map "localtime" to a system-specific name, but
|
|
// allow ${LOCALTIME} to override the default name.
|
|
char* localtime_env = nullptr;
|
|
if (strcmp(zone, "localtime") == 0) {
|
|
#if defined(_MSC_VER)
|
|
// System-specific default is just "localtime".
|
|
_dupenv_s(&localtime_env, nullptr, "LOCALTIME");
|
|
#else
|
|
zone = "/etc/localtime"; // System-specific default.
|
|
localtime_env = std::getenv("LOCALTIME");
|
|
#endif
|
|
if (localtime_env) zone = localtime_env;
|
|
}
|
|
|
|
const std::string name = zone;
|
|
#if defined(_MSC_VER)
|
|
free(localtime_env);
|
|
free(tz_env);
|
|
#endif
|
|
|
|
time_zone tz;
|
|
load_time_zone(name, &tz); // Falls back to UTC.
|
|
// TODO: Follow the RFC3339 "Unknown Local Offset Convention" and
|
|
// arrange for %z to generate "-0000" when we don't know the local
|
|
// offset because the load_time_zone() failed and we're using UTC.
|
|
return tz;
|
|
}
|
|
|
|
} // namespace cctz
|
|
} // namespace time_internal
|
|
} // namespace absl
|