Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(65)

Unified Diff: chrome/browser/chromeos/input_method/input_method_engine.cc

Issue 1771173002: Implement input.ime.sendKeyEvents API. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Fix test failure. Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome/browser/chromeos/input_method/input_method_engine.cc
diff --git a/chrome/browser/chromeos/input_method/input_method_engine.cc b/chrome/browser/chromeos/input_method/input_method_engine.cc
index 0c350007c0d83be77629cfe1529bea3004120e4f..71281f51ddd3ced836019502c39126bf53520699 100644
--- a/chrome/browser/chromeos/input_method/input_method_engine.cc
+++ b/chrome/browser/chromeos/input_method/input_method_engine.cc
@@ -73,50 +73,6 @@ InputMethodEngine::InputMethodEngine()
InputMethodEngine::~InputMethodEngine() {}
-bool InputMethodEngine::SendKeyEvents(
- int context_id,
- const std::vector<KeyboardEvent>& events) {
- if (!IsActive()) {
- return false;
- }
- // context_id == 0, means sending key events to non-input field.
- // context_id_ == -1, means the focus is not in an input field.
- if (context_id != 0 && (context_id != context_id_ || context_id_ == -1)) {
- return false;
- }
-
- ui::EventProcessor* dispatcher =
- ash::Shell::GetPrimaryRootWindow()->GetHost()->event_processor();
-
- for (size_t i = 0; i < events.size(); ++i) {
- const KeyboardEvent& event = events[i];
- const ui::EventType type =
- (event.type == "keyup") ? ui::ET_KEY_RELEASED : ui::ET_KEY_PRESSED;
- ui::KeyboardCode key_code = static_cast<ui::KeyboardCode>(event.key_code);
- if (key_code == ui::VKEY_UNKNOWN)
- key_code = ui::DomKeycodeToKeyboardCode(event.code);
-
- int flags = ui::EF_NONE;
- flags |= event.alt_key ? ui::EF_ALT_DOWN : ui::EF_NONE;
- flags |= event.ctrl_key ? ui::EF_CONTROL_DOWN : ui::EF_NONE;
- flags |= event.shift_key ? ui::EF_SHIFT_DOWN : ui::EF_NONE;
- flags |= event.caps_lock ? ui::EF_CAPS_LOCK_ON : ui::EF_NONE;
-
- ui::KeyEvent ui_event(
- type, key_code,
- ui::KeycodeConverter::CodeStringToDomCode(event.code), flags,
- ui::KeycodeConverter::KeyStringToDomKey(event.key),
- ui::EventTimeForNow());
- base::AutoReset<const ui::KeyEvent*> reset_sent_key(&sent_key_event_,
- &ui_event);
- ui::EventDispatchDetails details = dispatcher->OnEventFromSource(&ui_event);
- if (details.dispatcher_destroyed)
- break;
- }
-
- return true;
-}
-
const InputMethodEngine::CandidateWindowProperty&
InputMethodEngine::GetCandidateWindowProperty() const {
return candidate_window_property_;
@@ -368,4 +324,16 @@ void InputMethodEngine::CommitTextToInputContext(int context_id,
}
}
+bool InputMethodEngine::SendKeyEvent(ui::KeyEvent* event,
+ const std::string& code) {
+ DCHECK(event);
+ if (event->key_code() == ui::VKEY_UNKNOWN)
+ event->set_key_code(ui::DomKeycodeToKeyboardCode(code));
+
+ ui::EventProcessor* dispatcher =
+ ash::Shell::GetPrimaryRootWindow()->GetHost()->event_processor();
+ ui::EventDispatchDetails details = dispatcher->OnEventFromSource(event);
+ return !details.dispatcher_destroyed;
+}
+
} // namespace chromeos
« no previous file with comments | « chrome/browser/chromeos/input_method/input_method_engine.h ('k') | chrome/browser/extensions/api/input_ime/input_ime_api.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698