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/c/trusted/ppb_broker_trusted.h" | 5 #include "ppapi/c/trusted/ppb_broker_trusted.h" |
6 #include "ppapi/c/pp_errors.h" | 6 #include "ppapi/c/pp_errors.h" |
| 7 #include "ppapi/thunk/common.h" |
| 8 #include "ppapi/thunk/enter.h" |
7 #include "ppapi/thunk/thunk.h" | 9 #include "ppapi/thunk/thunk.h" |
8 #include "ppapi/thunk/enter.h" | |
9 #include "ppapi/thunk/ppb_broker_api.h" | 10 #include "ppapi/thunk/ppb_broker_api.h" |
10 #include "ppapi/thunk/resource_creation_api.h" | 11 #include "ppapi/thunk/resource_creation_api.h" |
11 | 12 |
12 namespace ppapi { | 13 namespace ppapi { |
13 namespace thunk { | 14 namespace thunk { |
14 | 15 |
15 namespace { | 16 namespace { |
16 | 17 |
17 PP_Resource CreateTrusted(PP_Instance instance) { | 18 PP_Resource CreateTrusted(PP_Instance instance) { |
18 EnterFunction<ResourceCreationAPI> enter(instance, true); | 19 EnterFunction<ResourceCreationAPI> enter(instance, true); |
19 if (enter.failed()) | 20 if (enter.failed()) |
20 return 0; | 21 return 0; |
21 return enter.functions()->CreateBroker(instance); | 22 return enter.functions()->CreateBroker(instance); |
22 } | 23 } |
23 | 24 |
24 PP_Bool IsBrokerTrusted(PP_Resource resource) { | 25 PP_Bool IsBrokerTrusted(PP_Resource resource) { |
25 EnterResource<PPB_Broker_API> enter(resource, false); | 26 EnterResource<PPB_Broker_API> enter(resource, false); |
26 return PP_FromBool(enter.succeeded()); | 27 return PP_FromBool(enter.succeeded()); |
27 } | 28 } |
28 | 29 |
29 int32_t Connect(PP_Resource resource, | 30 int32_t Connect(PP_Resource resource, |
30 PP_CompletionCallback connect_callback) { | 31 PP_CompletionCallback connect_callback) { |
31 EnterResource<PPB_Broker_API> enter(resource, true); | 32 EnterResource<PPB_Broker_API> enter(resource, true); |
32 if (enter.failed()) | 33 if (enter.failed()) |
33 return PP_ERROR_BADRESOURCE; | 34 return MayForceCallback(connect_callback, PP_ERROR_BADRESOURCE); |
34 return enter.object()->Connect(connect_callback); | 35 int32_t result = enter.object()->Connect(connect_callback); |
| 36 return MayForceCallback(connect_callback, result); |
35 } | 37 } |
36 | 38 |
37 int32_t GetHandle(PP_Resource resource, int32_t* handle) { | 39 int32_t GetHandle(PP_Resource resource, int32_t* handle) { |
38 EnterResource<PPB_Broker_API> enter(resource, true); | 40 EnterResource<PPB_Broker_API> enter(resource, true); |
39 if (enter.failed()) | 41 if (enter.failed()) |
40 return PP_ERROR_BADRESOURCE; | 42 return PP_ERROR_BADRESOURCE; |
41 return enter.object()->GetHandle(handle); | 43 return enter.object()->GetHandle(handle); |
42 } | 44 } |
43 | 45 |
44 const PPB_BrokerTrusted g_ppb_broker_thunk = { | 46 const PPB_BrokerTrusted g_ppb_broker_thunk = { |
45 &CreateTrusted, | 47 &CreateTrusted, |
46 &IsBrokerTrusted, | 48 &IsBrokerTrusted, |
47 &Connect, | 49 &Connect, |
48 &GetHandle, | 50 &GetHandle, |
49 }; | 51 }; |
50 | 52 |
51 } // namespace | 53 } // namespace |
52 | 54 |
53 const PPB_BrokerTrusted* GetPPB_Broker_Thunk() { | 55 const PPB_BrokerTrusted* GetPPB_Broker_Thunk() { |
54 return &g_ppb_broker_thunk; | 56 return &g_ppb_broker_thunk; |
55 } | 57 } |
56 | 58 |
57 } // namespace thunk | 59 } // namespace thunk |
58 } // namespace ppapi | 60 } // namespace ppapi |
OLD | NEW |