| // 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 |