diff options
author | kinaba@chromium.org <kinaba@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-09-29 04:23:09 +0000 |
---|---|---|
committer | kinaba@chromium.org <kinaba@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-09-29 04:23:09 +0000 |
commit | 2daba2f3623744b78f1880d8ebb0a673d03f52d3 (patch) | |
tree | 5bdad577cacfe4147ffceddcb1b1d0e1b6955232 /ppapi/proxy/ppb_text_input_proxy.cc | |
parent | 47d09f6e03e6d8ee179e479095c5afd9564921e0 (diff) | |
download | chromium_src-2daba2f3623744b78f1880d8ebb0a673d03f52d3.zip chromium_src-2daba2f3623744b78f1880d8ebb0a673d03f52d3.tar.gz chromium_src-2daba2f3623744b78f1880d8ebb0a673d03f52d3.tar.bz2 |
Additional update on Pepper IME API and boilerplate thunk/proxy implementation.
BUG=59425
TEST=Check that ppapi_tests compile (with GYP_DEFINES=shared_library, too).
This CL is the second (out of three) part for adding IME support for PPAPI.
It reflects comments from James Su to the previous CL:
http://codereview.chromium.org/7882004.
- Renamed ..._COMPOSTION_START to _IME_COMPOSITON_START.
- Changed to assure GetSegment to return a strictly increasing sequence of
segmentation points from 0 to the length.
and,
- Added the mostly boilerplate code for interfacing with
in-process & out-of-process plugins.
The actual implementation of the IME support will come as
the next and the last part of this series of patches.
Review URL: http://codereview.chromium.org/8059006
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@103234 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi/proxy/ppb_text_input_proxy.cc')
-rw-r--r-- | ppapi/proxy/ppb_text_input_proxy.cc | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/ppapi/proxy/ppb_text_input_proxy.cc b/ppapi/proxy/ppb_text_input_proxy.cc new file mode 100644 index 0000000..e4ada9b --- /dev/null +++ b/ppapi/proxy/ppb_text_input_proxy.cc @@ -0,0 +1,84 @@ +// Copyright (c) 2011 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 "ppapi/proxy/ppb_text_input_proxy.h" + +#include "ppapi/proxy/plugin_dispatcher.h" +#include "ppapi/proxy/ppapi_messages.h" +#include "ppapi/thunk/enter.h" +#include "ppapi/thunk/thunk.h" + +namespace ppapi { +namespace proxy { + +PPB_TextInput_Proxy::PPB_TextInput_Proxy(Dispatcher* dispatcher) + : InterfaceProxy(dispatcher) { +} + +PPB_TextInput_Proxy::~PPB_TextInput_Proxy() { +} + +ppapi::thunk::PPB_TextInput_FunctionAPI* +PPB_TextInput_Proxy::AsPPB_TextInput_FunctionAPI() { + return this; +} + +void PPB_TextInput_Proxy::SetTextInputType(PP_Instance instance, + PP_TextInput_Type type) { + dispatcher()->Send(new PpapiHostMsg_PPBTextInput_SetTextInputType( + INTERFACE_ID_PPB_TEXT_INPUT, instance, type)); +} + +void PPB_TextInput_Proxy::UpdateCaretPosition(PP_Instance instance, + const PP_Rect& caret, + const PP_Rect& bounding_box) { + dispatcher()->Send(new PpapiHostMsg_PPBTextInput_UpdateCaretPosition( + INTERFACE_ID_PPB_TEXT_INPUT, instance, caret, bounding_box)); +} + +void PPB_TextInput_Proxy::CancelCompositionText(PP_Instance instance) { + dispatcher()->Send(new PpapiHostMsg_PPBTextInput_CancelCompositionText( + INTERFACE_ID_PPB_TEXT_INPUT, instance)); +} + +bool PPB_TextInput_Proxy::OnMessageReceived(const IPC::Message& msg) { + bool handled = true; + IPC_BEGIN_MESSAGE_MAP(PPB_TextInput_Proxy, msg) + IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBTextInput_SetTextInputType, + OnMsgSetTextInputType) + IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBTextInput_UpdateCaretPosition, + OnMsgUpdateCaretPosition) + IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBTextInput_CancelCompositionText, + OnMsgCancelCompositionText) + IPC_MESSAGE_UNHANDLED(handled = false) + IPC_END_MESSAGE_MAP() + return handled; +} + +void PPB_TextInput_Proxy::OnMsgSetTextInputType(PP_Instance instance, + PP_TextInput_Type type) { + ppapi::thunk::EnterFunctionNoLock<PPB_TextInput_FunctionAPI> enter(instance, + true); + if (enter.succeeded()) + enter.functions()->SetTextInputType(instance, type); +} + +void PPB_TextInput_Proxy::OnMsgUpdateCaretPosition(PP_Instance instance, + PP_Rect caret, + PP_Rect bounding_box) { + ppapi::thunk::EnterFunctionNoLock<PPB_TextInput_FunctionAPI> enter(instance, + true); + if (enter.succeeded()) + enter.functions()->UpdateCaretPosition(instance, caret, bounding_box); +} + +void PPB_TextInput_Proxy::OnMsgCancelCompositionText(PP_Instance instance) { + ppapi::thunk::EnterFunctionNoLock<PPB_TextInput_FunctionAPI> enter(instance, + true); + if (enter.succeeded()) + enter.functions()->CancelCompositionText(instance); +} + +} // namespace proxy +} // namespace ppapi |