OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 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 | 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 #ifndef CONTENT_RENDERER_PEPPER_PLUGIN_DELEGATE_IMPL_H_ | 5 #ifndef CONTENT_RENDERER_PEPPER_PLUGIN_DELEGATE_IMPL_H_ |
6 #define CONTENT_RENDERER_PEPPER_PLUGIN_DELEGATE_IMPL_H_ | 6 #define CONTENT_RENDERER_PEPPER_PLUGIN_DELEGATE_IMPL_H_ |
7 #pragma once | 7 #pragma once |
8 | 8 |
9 #include <set> | 9 #include <set> |
10 #include <map> | 10 #include <map> |
11 #include <string> | 11 #include <string> |
12 | 12 |
13 #include "base/basictypes.h" | 13 #include "base/basictypes.h" |
14 #include "base/id_map.h" | 14 #include "base/id_map.h" |
15 #include "base/memory/ref_counted.h" | 15 #include "base/memory/ref_counted.h" |
16 #include "base/memory/weak_ptr.h" | 16 #include "base/memory/weak_ptr.h" |
17 #include "content/common/content_export.h" | 17 #include "content/common/content_export.h" |
18 #include "ppapi/proxy/broker_dispatcher.h" | 18 #include "ppapi/proxy/broker_dispatcher.h" |
19 #include "ppapi/proxy/proxy_channel.h" | 19 #include "ppapi/proxy/proxy_channel.h" |
20 #include "ui/base/ime/text_input_type.h" | |
20 #include "webkit/plugins/ppapi/plugin_delegate.h" | 21 #include "webkit/plugins/ppapi/plugin_delegate.h" |
21 #include "webkit/plugins/ppapi/ppb_broker_impl.h" | 22 #include "webkit/plugins/ppapi/ppb_broker_impl.h" |
22 #include "webkit/plugins/ppapi/ppb_flash_menu_impl.h" | 23 #include "webkit/plugins/ppapi/ppb_flash_menu_impl.h" |
23 | 24 |
24 class FilePath; | 25 class FilePath; |
25 class PepperPluginDelegateImpl; | 26 class PepperPluginDelegateImpl; |
26 class RenderView; | 27 class RenderView; |
27 | 28 |
28 namespace gfx { | 29 namespace gfx { |
29 class Point; | 30 class Point; |
30 class Rect; | 31 class Rect; |
31 } | 32 } |
32 | 33 |
33 namespace IPC { | 34 namespace IPC { |
34 struct ChannelHandle; | 35 struct ChannelHandle; |
35 } | 36 } |
36 | 37 |
37 namespace webkit { | 38 namespace webkit { |
38 struct WebPluginInfo; | 39 struct WebPluginInfo; |
39 namespace ppapi { | 40 namespace ppapi { |
40 class PepperFilePath; | 41 class PepperFilePath; |
41 class PluginInstance; | 42 class PluginInstance; |
42 class PluginModule; | 43 class PluginModule; |
43 } | 44 } |
44 } | 45 } |
45 | 46 |
46 namespace WebKit { | 47 namespace WebKit { |
48 struct WebCompositionUnderline; | |
kochi
2011/10/04 08:52:45
Move after 'class WebMouseEvent;' line.
kinaba
2011/10/05 04:43:19
Done.
| |
47 class WebFileChooserCompletion; | 49 class WebFileChooserCompletion; |
48 class WebMouseEvent; | 50 class WebMouseEvent; |
49 struct WebFileChooserParams; | 51 struct WebFileChooserParams; |
50 } | 52 } |
51 | 53 |
52 namespace webkit_glue { | 54 namespace webkit_glue { |
53 struct CustomContextMenuContext; | 55 struct CustomContextMenuContext; |
54 } | 56 } |
55 | 57 |
56 class TransportDIB; | 58 class TransportDIB; |
(...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
159 base::ProcessHandle broker_process_handle, | 161 base::ProcessHandle broker_process_handle, |
160 const IPC::ChannelHandle& handle); | 162 const IPC::ChannelHandle& handle); |
161 | 163 |
162 // Removes broker from pending_connect_broker_ if present. Returns true if so. | 164 // Removes broker from pending_connect_broker_ if present. Returns true if so. |
163 bool StopWaitingForPpapiBrokerConnection(PpapiBrokerImpl* broker); | 165 bool StopWaitingForPpapiBrokerConnection(PpapiBrokerImpl* broker); |
164 | 166 |
165 // Notification that the render view has been focused or defocused. This | 167 // Notification that the render view has been focused or defocused. This |
166 // notifies all of the plugins. | 168 // notifies all of the plugins. |
167 void OnSetFocus(bool has_focus); | 169 void OnSetFocus(bool has_focus); |
168 | 170 |
169 // Returns whether or not a Pepper plugin is focused. | 171 // IME status. |
170 bool IsPluginFocused() const; | 172 bool IsPluginFocused() const; |
173 gfx::Rect GetCaretBounds() const; | |
174 ui::TextInputType GetTextInputType() const; | |
175 bool IsPluginAcceptingCompositionEvents() const; | |
176 bool CanComposeInline() const; | |
177 | |
178 // IME events. | |
179 void OnImeSetComposition( | |
180 const string16& text, | |
181 const std::vector<WebKit::WebCompositionUnderline>& underlines, | |
182 int selection_start, | |
183 int selection_end); | |
184 void OnImeConfirmComposition(const string16& text); | |
171 | 185 |
172 // Notification that the request to lock the mouse has completed. | 186 // Notification that the request to lock the mouse has completed. |
173 void OnLockMouseACK(bool succeeded); | 187 void OnLockMouseACK(bool succeeded); |
174 // Notification that the plugin instance has lost the mouse lock. | 188 // Notification that the plugin instance has lost the mouse lock. |
175 void OnMouseLockLost(); | 189 void OnMouseLockLost(); |
176 // Dispatches mouse events directly to the owner of the mouse lock. | 190 // Dispatches mouse events directly to the owner of the mouse lock. |
177 // True indicates currently the mouse is locked and the event has been | 191 // True indicates currently the mouse is locked and the event has been |
178 // dispatched to the owner. | 192 // dispatched to the owner. |
179 bool DispatchLockedMouseEvent(const WebKit::WebMouseEvent& event); | 193 bool DispatchLockedMouseEvent(const WebKit::WebMouseEvent& event); |
180 | 194 |
181 // PluginDelegate implementation. | 195 // PluginDelegate implementation. |
182 virtual void PluginFocusChanged(bool focused) OVERRIDE; | 196 virtual void PluginFocusChanged(webkit::ppapi::PluginInstance* instance, |
197 bool focused) OVERRIDE; | |
198 virtual void PluginTextInputTypeChanged( | |
199 webkit::ppapi::PluginInstance* instance) OVERRIDE; | |
200 virtual void PluginRequestedCancelComposition( | |
201 webkit::ppapi::PluginInstance* instance) OVERRIDE; | |
183 virtual void PluginCrashed(webkit::ppapi::PluginInstance* instance); | 202 virtual void PluginCrashed(webkit::ppapi::PluginInstance* instance); |
184 virtual void InstanceCreated( | 203 virtual void InstanceCreated( |
185 webkit::ppapi::PluginInstance* instance); | 204 webkit::ppapi::PluginInstance* instance); |
186 virtual void InstanceDeleted( | 205 virtual void InstanceDeleted( |
187 webkit::ppapi::PluginInstance* instance); | 206 webkit::ppapi::PluginInstance* instance); |
188 virtual SkBitmap* GetSadPluginBitmap(); | 207 virtual SkBitmap* GetSadPluginBitmap(); |
189 virtual PlatformAudio* CreateAudio( | 208 virtual PlatformAudio* CreateAudio( |
190 uint32_t sample_rate, | 209 uint32_t sample_rate, |
191 uint32_t sample_count, | 210 uint32_t sample_count, |
192 PlatformAudio::Client* client); | 211 PlatformAudio::Client* client); |
(...skipping 156 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
349 IDMap<scoped_refptr<webkit::ppapi::PPB_Flash_NetConnector_Impl>, | 368 IDMap<scoped_refptr<webkit::ppapi::PPB_Flash_NetConnector_Impl>, |
350 IDMapOwnPointer> pending_connect_tcps_; | 369 IDMapOwnPointer> pending_connect_tcps_; |
351 | 370 |
352 IDMap<scoped_refptr<webkit::ppapi::PPB_Flash_Menu_Impl>, | 371 IDMap<scoped_refptr<webkit::ppapi::PPB_Flash_Menu_Impl>, |
353 IDMapOwnPointer> pending_context_menus_; | 372 IDMapOwnPointer> pending_context_menus_; |
354 | 373 |
355 typedef IDMap<scoped_refptr<PpapiBrokerImpl>, IDMapOwnPointer> BrokerMap; | 374 typedef IDMap<scoped_refptr<PpapiBrokerImpl>, IDMapOwnPointer> BrokerMap; |
356 BrokerMap pending_connect_broker_; | 375 BrokerMap pending_connect_broker_; |
357 | 376 |
358 // Whether or not the focus is on a PPAPI plugin | 377 // Whether or not the focus is on a PPAPI plugin |
359 bool is_pepper_plugin_focused_; | 378 webkit::ppapi::PluginInstance* focused_plugin_; |
379 | |
380 // Current text input composition text. Empty if no composition is on process. | |
brettw
2011/10/03 16:46:01
is on process -> is in progress (I think that's wh
kinaba
2011/10/05 04:43:19
Done.
| |
381 string16 composition_text_; | |
360 | 382 |
361 // Set of instances to receive a notification when the enterprise policy has | 383 // Set of instances to receive a notification when the enterprise policy has |
362 // been updated. | 384 // been updated. |
363 std::set<webkit::ppapi::PluginInstance*> subscribed_to_policy_updates_; | 385 std::set<webkit::ppapi::PluginInstance*> subscribed_to_policy_updates_; |
364 | 386 |
365 // |mouse_lock_owner_| is not owned by this class. We can know about when it | 387 // |mouse_lock_owner_| is not owned by this class. We can know about when it |
366 // is destroyed via InstanceDeleted(). | 388 // is destroyed via InstanceDeleted(). |
367 // |mouse_lock_owner_| being non-NULL doesn't indicate that currently the | 389 // |mouse_lock_owner_| being non-NULL doesn't indicate that currently the |
368 // mouse has been locked. It is possible that a request to lock the mouse has | 390 // mouse has been locked. It is possible that a request to lock the mouse has |
369 // been sent, but the response hasn't arrived yet. | 391 // been sent, but the response hasn't arrived yet. |
370 webkit::ppapi::PluginInstance* mouse_lock_owner_; | 392 webkit::ppapi::PluginInstance* mouse_lock_owner_; |
371 bool mouse_locked_; | 393 bool mouse_locked_; |
372 // If both |pending_lock_request_| and |pending_unlock_request_| are true, | 394 // If both |pending_lock_request_| and |pending_unlock_request_| are true, |
373 // it means a lock request was sent before an unlock request and we haven't | 395 // it means a lock request was sent before an unlock request and we haven't |
374 // received responses for them. | 396 // received responses for them. |
375 // The logic in LockMouse() makes sure that a lock request won't be sent when | 397 // The logic in LockMouse() makes sure that a lock request won't be sent when |
376 // there is a pending unlock request. | 398 // there is a pending unlock request. |
377 bool pending_lock_request_; | 399 bool pending_lock_request_; |
378 bool pending_unlock_request_; | 400 bool pending_unlock_request_; |
379 | 401 |
380 DISALLOW_COPY_AND_ASSIGN(PepperPluginDelegateImpl); | 402 DISALLOW_COPY_AND_ASSIGN(PepperPluginDelegateImpl); |
381 }; | 403 }; |
382 | 404 |
383 #endif // CONTENT_RENDERER_PEPPER_PLUGIN_DELEGATE_IMPL_H_ | 405 #endif // CONTENT_RENDERER_PEPPER_PLUGIN_DELEGATE_IMPL_H_ |
OLD | NEW |