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 #include "ppapi/shared_impl/ppp_instance_combined.h" | 5 #include "ppapi/shared_impl/ppp_instance_combined.h" |
| 6 #include "ppapi/shared_impl/proxy_lock.h" |
6 | 7 |
7 namespace ppapi { | 8 namespace ppapi { |
8 | 9 |
9 PPP_Instance_Combined::PPP_Instance_Combined( | 10 PPP_Instance_Combined::PPP_Instance_Combined( |
10 const PPP_Instance_1_0& instance_if) | 11 const PPP_Instance_1_0& instance_if) |
11 : did_change_view_1_0_(instance_if.DidChangeView) { | 12 : did_change_view_1_0_(instance_if.DidChangeView) { |
12 instance_1_1_.DidCreate = instance_if.DidCreate; | 13 instance_1_1_.DidCreate = instance_if.DidCreate; |
13 instance_1_1_.DidDestroy = instance_if.DidDestroy; | 14 instance_1_1_.DidDestroy = instance_if.DidDestroy; |
14 instance_1_1_.DidChangeView = NULL; | 15 instance_1_1_.DidChangeView = NULL; |
15 instance_1_1_.DidChangeFocus = instance_if.DidChangeFocus; | 16 instance_1_1_.DidChangeFocus = instance_if.DidChangeFocus; |
16 instance_1_1_.HandleDocumentLoad = instance_if.HandleDocumentLoad; | 17 instance_1_1_.HandleDocumentLoad = instance_if.HandleDocumentLoad; |
17 } | 18 } |
18 | 19 |
19 PPP_Instance_Combined::PPP_Instance_Combined( | 20 PPP_Instance_Combined::PPP_Instance_Combined( |
20 const PPP_Instance_1_1& instance_if) | 21 const PPP_Instance_1_1& instance_if) |
21 : instance_1_1_(instance_if), | 22 : instance_1_1_(instance_if), |
22 did_change_view_1_0_(NULL) { | 23 did_change_view_1_0_(NULL) { |
23 } | 24 } |
24 | 25 |
25 PP_Bool PPP_Instance_Combined::DidCreate(PP_Instance instance, | 26 PP_Bool PPP_Instance_Combined::DidCreate(PP_Instance instance, |
26 uint32_t argc, | 27 uint32_t argc, |
27 const char* argn[], | 28 const char* argn[], |
28 const char* argv[]) { | 29 const char* argv[]) { |
29 return instance_1_1_.DidCreate(instance, argc, argn, argv); | 30 return CallWhileUnlocked(instance_1_1_.DidCreate, instance, argc, argn, argv); |
30 } | 31 } |
31 | 32 |
32 void PPP_Instance_Combined::DidDestroy(PP_Instance instance) { | 33 void PPP_Instance_Combined::DidDestroy(PP_Instance instance) { |
33 return instance_1_1_.DidDestroy(instance); | 34 return CallWhileUnlocked(instance_1_1_.DidDestroy, instance); |
34 } | 35 } |
35 | 36 |
36 void PPP_Instance_Combined::DidChangeView(PP_Instance instance, | 37 void PPP_Instance_Combined::DidChangeView(PP_Instance instance, |
37 PP_Resource view_changed_resource, | 38 PP_Resource view_changed_resource, |
38 const struct PP_Rect* position, | 39 const struct PP_Rect* position, |
39 const struct PP_Rect* clip) { | 40 const struct PP_Rect* clip) { |
40 if (instance_1_1_.DidChangeView) | 41 if (instance_1_1_.DidChangeView) { |
41 instance_1_1_.DidChangeView(instance, view_changed_resource); | 42 CallWhileUnlocked(instance_1_1_.DidChangeView, |
42 else | 43 instance, |
43 did_change_view_1_0_(instance, position, clip); | 44 view_changed_resource); |
| 45 } else { |
| 46 CallWhileUnlocked(did_change_view_1_0_, instance, position, clip); |
| 47 } |
44 } | 48 } |
45 | 49 |
46 void PPP_Instance_Combined::DidChangeFocus(PP_Instance instance, | 50 void PPP_Instance_Combined::DidChangeFocus(PP_Instance instance, |
47 PP_Bool has_focus) { | 51 PP_Bool has_focus) { |
48 instance_1_1_.DidChangeFocus(instance, has_focus); | 52 CallWhileUnlocked(instance_1_1_.DidChangeFocus, instance, has_focus); |
49 } | 53 } |
50 | 54 |
51 PP_Bool PPP_Instance_Combined::HandleDocumentLoad(PP_Instance instance, | 55 PP_Bool PPP_Instance_Combined::HandleDocumentLoad(PP_Instance instance, |
52 PP_Resource url_loader) { | 56 PP_Resource url_loader) { |
53 return instance_1_1_.HandleDocumentLoad(instance, url_loader); | 57 return CallWhileUnlocked(instance_1_1_.HandleDocumentLoad, |
| 58 instance, |
| 59 url_loader); |
54 } | 60 } |
55 | 61 |
56 } // namespace ppapi | 62 } // namespace ppapi |
57 | 63 |
OLD | NEW |