|  | // Copyright 2013 The Chromium Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | #include "base/i18n/timezone.h" | 
|  |  | 
|  | #include <memory> | 
|  | #include <string> | 
|  |  | 
|  | #include "third_party/icu/source/common/unicode/unistr.h" | 
|  | #include "third_party/icu/source/i18n/unicode/timezone.h" | 
|  |  | 
|  | namespace base { | 
|  |  | 
|  | std::string CountryCodeForCurrentTimezone() { | 
|  | std::unique_ptr<icu::TimeZone> zone(icu::TimeZone::createDefault()); | 
|  | icu::UnicodeString id; | 
|  | // ICU returns '001' (world) for Etc/GMT. Preserve the old behavior | 
|  | // only for Etc/GMT while returning an empty string for Etc/UTC and | 
|  | // Etc/UCT because they're less likely to be chosen by mistake in UK in | 
|  | // place of Europe/London (Briitish Time). | 
|  | if (zone->getID(id) == UNICODE_STRING_SIMPLE("Etc/GMT")) | 
|  | return "GB"; | 
|  | char region_code[4]; | 
|  | UErrorCode status = U_ZERO_ERROR; | 
|  | int length = zone->getRegion(id, region_code, 4, status); | 
|  | // Return an empty string if region_code is a 3-digit numeric code such | 
|  | // as 001 (World) for Etc/UTC, Etc/UCT. | 
|  | return (U_SUCCESS(status) && length == 2) | 
|  | ? std::string(region_code, static_cast<size_t>(length)) | 
|  | : std::string(); | 
|  | } | 
|  |  | 
|  | }  // namespace base |