1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153
|
// Copyright (c) 2012 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 "chrome/browser/chromeos/extensions/input_method_api.h"
#include "base/command_line.h"
#include "base/lazy_instance.h"
#include "base/values.h"
#include "chrome/browser/chromeos/extensions/input_method_event_router.h"
#include "chrome/browser/chromeos/input_method/input_method_util.h"
#include "chrome/browser/extensions/api/input_ime/input_ime_api.h"
#include "chromeos/chromeos_switches.h"
#include "extensions/browser/extension_function_registry.h"
#include "extensions/browser/extension_system.h"
#include "extensions/common/value_builder.h"
#include "ui/base/ime/chromeos/extension_ime_util.h"
#include "ui/base/ime/chromeos/input_method_descriptor.h"
#include "ui/base/ime/chromeos/input_method_manager.h"
namespace {
// Prefix, which is used by XKB.
const char kXkbPrefix[] = "xkb:";
} // namespace
namespace extensions {
ExtensionFunction::ResponseAction GetInputMethodConfigFunction::Run() {
#if !defined(OS_CHROMEOS)
EXTENSION_FUNCTION_VALIDATE(false);
#else
base::DictionaryValue* output = new base::DictionaryValue();
output->SetBoolean(
"isPhysicalKeyboardAutocorrectEnabled",
base::CommandLine::ForCurrentProcess()->HasSwitch(
chromeos::switches::kEnablePhysicalKeyboardAutocorrect));
output->SetBoolean("isNewQPInputViewEnabled",
base::CommandLine::ForCurrentProcess()->HasSwitch(
chromeos::switches::kEnableNewQPInputView));
return RespondNow(OneArgument(output));
#endif
}
ExtensionFunction::ResponseAction GetCurrentInputMethodFunction::Run() {
#if !defined(OS_CHROMEOS)
EXTENSION_FUNCTION_VALIDATE(false);
#else
chromeos::input_method::InputMethodManager* manager =
chromeos::input_method::InputMethodManager::Get();
return RespondNow(OneArgument(new base::StringValue(
manager->GetActiveIMEState()->GetCurrentInputMethod().id())));
#endif
}
ExtensionFunction::ResponseAction SetCurrentInputMethodFunction::Run() {
#if !defined(OS_CHROMEOS)
EXTENSION_FUNCTION_VALIDATE(false);
#else
std::string new_input_method;
EXTENSION_FUNCTION_VALIDATE(args_->GetString(0, &new_input_method));
scoped_refptr<chromeos::input_method::InputMethodManager::State> ime_state =
chromeos::input_method::InputMethodManager::Get()->GetActiveIMEState();
const std::vector<std::string>& input_methods =
ime_state->GetActiveInputMethodIds();
for (size_t i = 0; i < input_methods.size(); ++i) {
const std::string& input_method = input_methods[i];
if (input_method == new_input_method) {
ime_state->ChangeInputMethod(new_input_method, false /* show_message */);
return RespondNow(NoArguments());
}
}
return RespondNow(Error("Invalid input method id."));
#endif
}
ExtensionFunction::ResponseAction GetInputMethodsFunction::Run() {
#if !defined(OS_CHROMEOS)
EXTENSION_FUNCTION_VALIDATE(false);
#else
base::ListValue* output = new base::ListValue();
chromeos::input_method::InputMethodManager* manager =
chromeos::input_method::InputMethodManager::Get();
chromeos::input_method::InputMethodUtil* util = manager->GetInputMethodUtil();
scoped_refptr<chromeos::input_method::InputMethodManager::State> ime_state =
manager->GetActiveIMEState();
scoped_ptr<chromeos::input_method::InputMethodDescriptors> input_methods =
ime_state->GetActiveInputMethods();
for (size_t i = 0; i < input_methods->size(); ++i) {
const chromeos::input_method::InputMethodDescriptor& input_method =
(*input_methods)[i];
base::DictionaryValue* val = new base::DictionaryValue();
val->SetString("id", input_method.id());
val->SetString("name", util->GetInputMethodLongName(input_method));
val->SetString("indicator", util->GetInputMethodShortName(input_method));
output->Append(val);
}
return RespondNow(OneArgument(output));
#endif
}
// static
const char InputMethodAPI::kOnInputMethodChanged[] =
"inputMethodPrivate.onChanged";
InputMethodAPI::InputMethodAPI(content::BrowserContext* context)
: context_(context) {
EventRouter::Get(context_)->RegisterObserver(this, kOnInputMethodChanged);
ExtensionFunctionRegistry* registry =
ExtensionFunctionRegistry::GetInstance();
registry->RegisterFunction<GetInputMethodConfigFunction>();
registry->RegisterFunction<GetCurrentInputMethodFunction>();
registry->RegisterFunction<SetCurrentInputMethodFunction>();
registry->RegisterFunction<GetInputMethodsFunction>();
}
InputMethodAPI::~InputMethodAPI() {
}
// static
std::string InputMethodAPI::GetInputMethodForXkb(const std::string& xkb_id) {
std::string xkb_prefix =
chromeos::extension_ime_util::GetInputMethodIDByEngineID(kXkbPrefix);
size_t prefix_length = xkb_prefix.length();
DCHECK(xkb_id.substr(0, prefix_length) == xkb_prefix);
return xkb_id.substr(prefix_length);
}
void InputMethodAPI::Shutdown() {
// UnregisterObserver may have already been called in OnListenerAdded,
// but it is safe to call it more than once.
EventRouter::Get(context_)->UnregisterObserver(this);
}
void InputMethodAPI::OnListenerAdded(
const extensions::EventListenerInfo& details) {
DCHECK(!input_method_event_router_.get());
input_method_event_router_.reset(
new chromeos::ExtensionInputMethodEventRouter(context_));
EventRouter::Get(context_)->UnregisterObserver(this);
}
static base::LazyInstance<BrowserContextKeyedAPIFactory<InputMethodAPI> >
g_factory = LAZY_INSTANCE_INITIALIZER;
// static
BrowserContextKeyedAPIFactory<InputMethodAPI>*
InputMethodAPI::GetFactoryInstance() {
return g_factory.Pointer();
}
} // namespace extensions
|