diff options
Diffstat (limited to 'app/l10n_util_mac.mm')
-rw-r--r-- | app/l10n_util_mac.mm | 167 |
1 files changed, 0 insertions, 167 deletions
diff --git a/app/l10n_util_mac.mm b/app/l10n_util_mac.mm deleted file mode 100644 index c0be5d8..0000000 --- a/app/l10n_util_mac.mm +++ /dev/null @@ -1,167 +0,0 @@ -// Copyright (c) 2010 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. - -#import <Foundation/Foundation.h> - -#include "app/l10n_util.h" -#include "app/l10n_util_mac.h" -#include "base/sys_string_conversions.h" -#include "base/lazy_instance.h" -#include "base/logging.h" - -namespace { - -class OverrideLocaleHolder { - public: - OverrideLocaleHolder() {} - const std::string& value() const { return value_; } - void set_value(const std::string override_value) { value_ = override_value; } - private: - DISALLOW_COPY_AND_ASSIGN(OverrideLocaleHolder); - std::string value_; -}; - -base::LazyInstance<OverrideLocaleHolder> - override_locale_holder(base::LINKER_INITIALIZED); - -} // namespace - -namespace l10n_util { - -const std::string& GetLocaleOverride() { - return override_locale_holder.Get().value(); -} - -void OverrideLocaleWithCocoaLocale() { - // NSBundle really should only be called on the main thread. - DCHECK([NSThread isMainThread]); - - // Chrome really only has one concept of locale, but Mac OS X has locale and - // language that can be set independently. After talking with Chrome UX folks - // (Cole), the best path from an experience point of view is to map the Mac OS - // X language into the Chrome locale. This way strings like "Yesterday" and - // "Today" are in the same language as raw dates like "March 20, 1999" (Chrome - // strings resources vs ICU generated strings). This also makes the Mac acts - // like other Chrome platforms. - NSArray* languageList = [[NSBundle mainBundle] preferredLocalizations]; - NSString* firstLocale = [languageList objectAtIndex:0]; - // Mac OS X uses "_" instead of "-", so swap to get a real locale value. - std::string locale_value = - [[firstLocale stringByReplacingOccurrencesOfString:@"_" - withString:@"-"] UTF8String]; - - // On disk the "en-US" resources are just "en" (http://crbug.com/25578), so - // the reverse mapping is done here to continue to feed Chrome the same values - // in all cases on all platforms. (l10n_util maps en to en-US if it gets - // passed this on the command line) - if (locale_value == "en") - locale_value = "en-US"; - - override_locale_holder.Get().set_value(locale_value); -} - -// Remove the Windows-style accelerator marker and change "..." into an -// ellipsis. Returns the result in an autoreleased NSString. -NSString* FixUpWindowsStyleLabel(const string16& label) { - const char16 kEllipsisUTF16 = 0x2026; - string16 ret; - size_t label_len = label.length(); - ret.reserve(label_len); - for (size_t i = 0; i < label_len; ++i) { - char16 c = label[i]; - if (c == '&') { - if (i + 1 < label_len && label[i + 1] == '&') { - ret.push_back(c); - ++i; - } - } else if (c == '.' && i + 2 < label_len && label[i + 1] == '.' - && label[i + 2] == '.') { - ret.push_back(kEllipsisUTF16); - i += 2; - } else { - ret.push_back(c); - } - } - - return base::SysUTF16ToNSString(ret); -} - -NSString* GetNSString(int message_id) { - return base::SysUTF16ToNSString(l10n_util::GetStringUTF16(message_id)); -} - -NSString* GetNSStringF(int message_id, - const string16& a) { - return base::SysUTF16ToNSString(l10n_util::GetStringFUTF16(message_id, - a)); -} - -NSString* GetNSStringF(int message_id, - const string16& a, - const string16& b) { - return base::SysUTF16ToNSString(l10n_util::GetStringFUTF16(message_id, - a, b)); -} - -NSString* GetNSStringF(int message_id, - const string16& a, - const string16& b, - const string16& c) { - return base::SysUTF16ToNSString(l10n_util::GetStringFUTF16(message_id, - a, b, c)); -} - -NSString* GetNSStringF(int message_id, - const string16& a, - const string16& b, - const string16& c, - const string16& d) { - return base::SysUTF16ToNSString(l10n_util::GetStringFUTF16(message_id, - a, b, c, d)); -} - -NSString* GetNSStringF(int message_id, - const string16& a, - const string16& b, - std::vector<size_t>* offsets) { - return base::SysUTF16ToNSString(l10n_util::GetStringFUTF16(message_id, - a, b, offsets)); -} - -NSString* GetNSStringWithFixup(int message_id) { - return FixUpWindowsStyleLabel(l10n_util::GetStringUTF16(message_id)); -} - -NSString* GetNSStringFWithFixup(int message_id, - const string16& a) { - return FixUpWindowsStyleLabel(l10n_util::GetStringFUTF16(message_id, - a)); -} - -NSString* GetNSStringFWithFixup(int message_id, - const string16& a, - const string16& b) { - return FixUpWindowsStyleLabel(l10n_util::GetStringFUTF16(message_id, - a, b)); -} - -NSString* GetNSStringFWithFixup(int message_id, - const string16& a, - const string16& b, - const string16& c) { - return FixUpWindowsStyleLabel(l10n_util::GetStringFUTF16(message_id, - a, b, c)); -} - -NSString* GetNSStringFWithFixup(int message_id, - const string16& a, - const string16& b, - const string16& c, - const string16& d) { - return FixUpWindowsStyleLabel(l10n_util::GetStringFUTF16(message_id, - a, b, c, d)); -} - - -} // namespace l10n_util |