| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/chromeos/preferences.h" | 5 #include "chrome/browser/chromeos/preferences.h" |
| 6 | 6 |
| 7 #include "base/string_util.h" | 7 #include "base/string_util.h" |
| 8 #include "base/utf_string_conversions.h" | 8 #include "base/utf_string_conversions.h" |
| 9 #include "chrome/browser/browser_process.h" | 9 #include "chrome/browser/browser_process.h" |
| 10 #include "chrome/browser/chromeos/cros/cros_library.h" | 10 #include "chrome/browser/chromeos/cros/cros_library.h" |
| 11 #include "chrome/browser/chromeos/cros/keyboard_library.h" |
| 11 #include "chrome/browser/chromeos/cros/input_method_library.h" | 12 #include "chrome/browser/chromeos/cros/input_method_library.h" |
| 12 #include "chrome/browser/chromeos/cros/synaptics_library.h" | 13 #include "chrome/browser/chromeos/cros/synaptics_library.h" |
| 13 #include "chrome/browser/chromeos/input_method/input_method_util.h" | 14 #include "chrome/browser/chromeos/input_method/input_method_util.h" |
| 14 #include "chrome/browser/pref_member.h" | 15 #include "chrome/browser/pref_member.h" |
| 15 #include "chrome/browser/pref_service.h" | 16 #include "chrome/browser/pref_service.h" |
| 16 #include "chrome/common/notification_service.h" | 17 #include "chrome/common/notification_service.h" |
| 17 #include "chrome/common/pref_names.h" | 18 #include "chrome/common/pref_names.h" |
| 18 #include "unicode/timezone.h" | 19 #include "unicode/timezone.h" |
| 19 | 20 |
| 20 namespace chromeos { | 21 namespace chromeos { |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 76 } | 77 } |
| 77 for (size_t i = 0; i < kNumMozcMultipleChoicePrefs; ++i) { | 78 for (size_t i = 0; i < kNumMozcMultipleChoicePrefs; ++i) { |
| 78 prefs->RegisterStringPref( | 79 prefs->RegisterStringPref( |
| 79 kMozcMultipleChoicePrefs[i].pref_name, | 80 kMozcMultipleChoicePrefs[i].pref_name, |
| 80 kMozcMultipleChoicePrefs[i].default_pref_value); | 81 kMozcMultipleChoicePrefs[i].default_pref_value); |
| 81 } | 82 } |
| 82 for (size_t i = 0; i < kNumMozcIntegerPrefs; ++i) { | 83 for (size_t i = 0; i < kNumMozcIntegerPrefs; ++i) { |
| 83 prefs->RegisterIntegerPref(kMozcIntegerPrefs[i].pref_name, | 84 prefs->RegisterIntegerPref(kMozcIntegerPrefs[i].pref_name, |
| 84 kMozcIntegerPrefs[i].default_pref_value); | 85 kMozcIntegerPrefs[i].default_pref_value); |
| 85 } | 86 } |
| 87 prefs->RegisterIntegerPref( |
| 88 kXkbModifierMultipleChoicePrefs.pref_name, |
| 89 kXkbModifierMultipleChoicePrefs.default_pref_value); |
| 86 } | 90 } |
| 87 | 91 |
| 88 void Preferences::Init(PrefService* prefs) { | 92 void Preferences::Init(PrefService* prefs) { |
| 89 tap_to_click_enabled_.Init(prefs::kTapToClickEnabled, prefs, this); | 93 tap_to_click_enabled_.Init(prefs::kTapToClickEnabled, prefs, this); |
| 90 accessibility_enabled_.Init(prefs::kAccessibilityEnabled, prefs, this); | 94 accessibility_enabled_.Init(prefs::kAccessibilityEnabled, prefs, this); |
| 91 vert_edge_scroll_enabled_.Init(prefs::kVertEdgeScrollEnabled, prefs, this); | 95 vert_edge_scroll_enabled_.Init(prefs::kVertEdgeScrollEnabled, prefs, this); |
| 92 speed_factor_.Init(prefs::kTouchpadSpeedFactor, prefs, this); | 96 speed_factor_.Init(prefs::kTouchpadSpeedFactor, prefs, this); |
| 93 sensitivity_.Init(prefs::kTouchpadSensitivity, prefs, this); | 97 sensitivity_.Init(prefs::kTouchpadSensitivity, prefs, this); |
| 94 language_hotkey_next_engine_in_menu_.Init( | 98 language_hotkey_next_engine_in_menu_.Init( |
| 95 prefs::kLanguageHotkeyNextEngineInMenu, prefs, this); | 99 prefs::kLanguageHotkeyNextEngineInMenu, prefs, this); |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 130 kMozcBooleanPrefs[i].pref_name, prefs, this); | 134 kMozcBooleanPrefs[i].pref_name, prefs, this); |
| 131 } | 135 } |
| 132 for (size_t i = 0; i < kNumMozcMultipleChoicePrefs; ++i) { | 136 for (size_t i = 0; i < kNumMozcMultipleChoicePrefs; ++i) { |
| 133 language_mozc_multiple_choice_prefs_[i].Init( | 137 language_mozc_multiple_choice_prefs_[i].Init( |
| 134 kMozcMultipleChoicePrefs[i].pref_name, prefs, this); | 138 kMozcMultipleChoicePrefs[i].pref_name, prefs, this); |
| 135 } | 139 } |
| 136 for (size_t i = 0; i < kNumMozcIntegerPrefs; ++i) { | 140 for (size_t i = 0; i < kNumMozcIntegerPrefs; ++i) { |
| 137 language_mozc_integer_prefs_[i].Init( | 141 language_mozc_integer_prefs_[i].Init( |
| 138 kMozcIntegerPrefs[i].pref_name, prefs, this); | 142 kMozcIntegerPrefs[i].pref_name, prefs, this); |
| 139 } | 143 } |
| 144 language_xkb_modifier_remap_.Init( |
| 145 kXkbModifierMultipleChoicePrefs.pref_name, prefs, this); |
| 140 | 146 |
| 141 std::string locale(g_browser_process->GetApplicationLocale()); | 147 std::string locale(g_browser_process->GetApplicationLocale()); |
| 142 // Add input methods based on the application locale when the user first | 148 // Add input methods based on the application locale when the user first |
| 143 // logs in. For instance, if the user chooses Japanese as the UI | 149 // logs in. For instance, if the user chooses Japanese as the UI |
| 144 // language at the first login, we'll add input methods associated with | 150 // language at the first login, we'll add input methods associated with |
| 145 // Japanese, such as mozc. | 151 // Japanese, such as mozc. |
| 146 if (locale != kFallbackInputMethodLocale && | 152 if (locale != kFallbackInputMethodLocale && |
| 147 !prefs->HasPrefPath(prefs::kLanguagePreloadEngines)) { | 153 !prefs->HasPrefPath(prefs::kLanguagePreloadEngines)) { |
| 148 std::string preload_engines(language_preload_engines_.GetValue()); | 154 std::string preload_engines(language_preload_engines_.GetValue()); |
| 149 std::vector<std::string> input_method_ids; | 155 std::vector<std::string> input_method_ids; |
| (...skipping 139 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 289 language_mozc_multiple_choice_prefs_[i].GetValue()); | 295 language_mozc_multiple_choice_prefs_[i].GetValue()); |
| 290 } | 296 } |
| 291 } | 297 } |
| 292 for (size_t i = 0; i < kNumMozcIntegerPrefs; ++i) { | 298 for (size_t i = 0; i < kNumMozcIntegerPrefs; ++i) { |
| 293 if (!pref_name || *pref_name == kMozcIntegerPrefs[i].pref_name) { | 299 if (!pref_name || *pref_name == kMozcIntegerPrefs[i].pref_name) { |
| 294 SetLanguageConfigInteger(kMozcSectionName, | 300 SetLanguageConfigInteger(kMozcSectionName, |
| 295 kMozcIntegerPrefs[i].ibus_config_name, | 301 kMozcIntegerPrefs[i].ibus_config_name, |
| 296 language_mozc_integer_prefs_[i].GetValue()); | 302 language_mozc_integer_prefs_[i].GetValue()); |
| 297 } | 303 } |
| 298 } | 304 } |
| 305 if (!pref_name || *pref_name == kXkbModifierMultipleChoicePrefs.pref_name) { |
| 306 chromeos::ModifierMap modifier_map; |
| 307 const int remap_type = language_xkb_modifier_remap_.GetValue(); |
| 308 switch (remap_type) { |
| 309 default: |
| 310 LOG(ERROR) << "Unknown XKB remapping type: " << remap_type; |
| 311 /* fall through */ |
| 312 case kNoRemap: |
| 313 modifier_map.push_back(ModifierKeyPair(kSearchKey, kSearchKey)); |
| 314 modifier_map.push_back( |
| 315 ModifierKeyPair(kLeftControlKey, kLeftControlKey)); |
| 316 modifier_map.push_back(ModifierKeyPair(kLeftAltKey, kLeftAltKey)); |
| 317 break; |
| 318 case kSwapCtrlAndAlt: |
| 319 modifier_map.push_back(ModifierKeyPair(kSearchKey, kSearchKey)); |
| 320 modifier_map.push_back(ModifierKeyPair(kLeftControlKey, kLeftAltKey)); |
| 321 modifier_map.push_back(ModifierKeyPair(kLeftAltKey, kLeftControlKey)); |
| 322 break; |
| 323 case kSwapSearchAndCtrl: |
| 324 modifier_map.push_back(ModifierKeyPair(kSearchKey, kLeftControlKey)); |
| 325 modifier_map.push_back(ModifierKeyPair(kLeftControlKey, kSearchKey)); |
| 326 modifier_map.push_back(ModifierKeyPair(kLeftAltKey, kLeftAltKey)); |
| 327 break; |
| 328 } |
| 329 CrosLibrary::Get()->GetKeyboardLibrary()->RemapModifierKeys(modifier_map); |
| 330 } |
| 299 } | 331 } |
| 300 | 332 |
| 301 void Preferences::SetLanguageConfigBoolean(const char* section, | 333 void Preferences::SetLanguageConfigBoolean(const char* section, |
| 302 const char* name, | 334 const char* name, |
| 303 bool value) { | 335 bool value) { |
| 304 ImeConfigValue config; | 336 ImeConfigValue config; |
| 305 config.type = ImeConfigValue::kValueTypeBool; | 337 config.type = ImeConfigValue::kValueTypeBool; |
| 306 config.bool_value = value; | 338 config.bool_value = value; |
| 307 CrosLibrary::Get()->GetInputMethodLibrary()-> | 339 CrosLibrary::Get()->GetInputMethodLibrary()-> |
| 308 SetImeConfig(section, name, config); | 340 SetImeConfig(section, name, config); |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 349 std::vector<std::string> split_values; | 381 std::vector<std::string> split_values; |
| 350 if (!value.empty()) | 382 if (!value.empty()) |
| 351 SplitString(value, ',', &split_values); | 383 SplitString(value, ',', &split_values); |
| 352 | 384 |
| 353 // We should call the cros API even when |value| is empty, to disable default | 385 // We should call the cros API even when |value| is empty, to disable default |
| 354 // config. | 386 // config. |
| 355 SetLanguageConfigStringList(section, name, split_values); | 387 SetLanguageConfigStringList(section, name, split_values); |
| 356 } | 388 } |
| 357 | 389 |
| 358 } // namespace chromeos | 390 } // namespace chromeos |
| OLD | NEW |