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

Side by Side Diff: ppapi/proxy/ppb_text_input_proxy.cc

Issue 7977017: Never submit: tentative Pepper IME. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 9 years, 3 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "ppapi/proxy/ppb_text_input_proxy.h"
6
7 #include "ppapi/proxy/plugin_dispatcher.h"
8 #include "ppapi/proxy/ppapi_messages.h"
9 #include "ppapi/thunk/enter.h"
10 #include "ppapi/thunk/thunk.h"
11
12 namespace ppapi {
13 namespace proxy {
14
15 PPB_TextInput_Proxy::PPB_TextInput_Proxy(Dispatcher* dispatcher)
16 : InterfaceProxy(dispatcher) {
17 }
18
19 PPB_TextInput_Proxy::~PPB_TextInput_Proxy() {
20 }
21
22 ppapi::thunk::PPB_TextInput_FunctionAPI*
23 PPB_TextInput_Proxy::AsPPB_TextInput_FunctionAPI() {
24 return this;
25 }
26
27 void PPB_TextInput_Proxy::SetTextInputType(PP_Instance instance,
28 PP_TextInput_Type type) {
29 dispatcher()->Send(new PpapiHostMsg_PPBTextInput_SetTextInputType(
30 INTERFACE_ID_PPB_TEXT_INPUT, instance, type));
31 }
32
33 void PPB_TextInput_Proxy::UpdateCaretPosition(PP_Instance instance,
34 const PP_Rect& caret,
35 const PP_Rect& boundingBox) {
36 dispatcher()->Send(new PpapiHostMsg_PPBTextInput_UpdateCaretPosition(
37 INTERFACE_ID_PPB_TEXT_INPUT, instance, caret, boundingBox));
38 }
39
40 void PPB_TextInput_Proxy::ConfirmCompositionText(PP_Instance instance) {
41 dispatcher()->Send(new PpapiHostMsg_PPBTextInput_ConfirmCompositionText(
42 INTERFACE_ID_PPB_TEXT_INPUT, instance));
43 }
44
45 void PPB_TextInput_Proxy::CancelCompositionText(PP_Instance instance) {
46 dispatcher()->Send(new PpapiHostMsg_PPBTextInput_CancelCompositionText(
47 INTERFACE_ID_PPB_TEXT_INPUT, instance));
48 }
49
50 bool PPB_TextInput_Proxy::OnMessageReceived(const IPC::Message& msg) {
51 bool handled = true;
52 IPC_BEGIN_MESSAGE_MAP(PPB_TextInput_Proxy, msg)
53 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBTextInput_SetTextInputType,
54 OnMsgSetTextInputType)
55 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBTextInput_UpdateCaretPosition,
56 OnMsgUpdateCaretPosition)
57 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBTextInput_ConfirmCompositionText,
58 OnMsgConfirmCompositionText)
59 IPC_MESSAGE_HANDLER(PpapiHostMsg_PPBTextInput_CancelCompositionText,
60 OnMsgCancelCompositionText)
61 IPC_MESSAGE_UNHANDLED(handled = false)
62 IPC_END_MESSAGE_MAP()
63 return handled;
64 }
65
66 void PPB_TextInput_Proxy::OnMsgSetTextInputType(PP_Instance instance,
67 PP_TextInput_Type type) {
68 ppapi::thunk::EnterFunctionNoLock<PPB_TextInput_FunctionAPI> enter(instance,
69 true);
70 if (enter.succeeded())
71 enter.functions()->SetTextInputType(instance, type);
72 }
73
74 void PPB_TextInput_Proxy::OnMsgUpdateCaretPosition(PP_Instance instance,
75 PP_Rect caret,
76 PP_Rect boundingBox) {
77 ppapi::thunk::EnterFunctionNoLock<PPB_TextInput_FunctionAPI> enter(instance,
78 true);
79 if (enter.succeeded())
80 enter.functions()->UpdateCaretPosition(instance, caret, boundingBox);
81 }
82
83 void PPB_TextInput_Proxy::OnMsgConfirmCompositionText(PP_Instance instance) {
84 ppapi::thunk::EnterFunctionNoLock<PPB_TextInput_FunctionAPI> enter(instance,
85 true);
86 if (enter.succeeded())
87 enter.functions()->ConfirmCompositionText(instance);
88 }
89
90 void PPB_TextInput_Proxy::OnMsgCancelCompositionText(PP_Instance instance) {
91 ppapi::thunk::EnterFunctionNoLock<PPB_TextInput_FunctionAPI> enter(instance,
92 true);
93 if (enter.succeeded())
94 enter.functions()->CancelCompositionText(instance);
95 }
96
97 } // namespace proxy
98 } // namespace ppapi
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698