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

Side by Side Diff: ppapi/thunk/ppb_udp_socket_private_thunk.cc

Issue 9113044: Convert to new enter method (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: PATCH DESCRIPTIONS ARE A STUPID WASTE OF TIME Created 8 years, 10 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
« no previous file with comments | « ppapi/thunk/ppb_transport_thunk.cc ('k') | ppapi/thunk/ppb_url_loader_thunk.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/pp_completion_callback.h" 5 #include "ppapi/c/pp_completion_callback.h"
6 #include "ppapi/c/pp_errors.h" 6 #include "ppapi/c/pp_errors.h"
7 #include "ppapi/c/private/ppb_udp_socket_private.h" 7 #include "ppapi/c/private/ppb_udp_socket_private.h"
8 #include "ppapi/thunk/common.h"
9 #include "ppapi/thunk/enter.h" 8 #include "ppapi/thunk/enter.h"
10 #include "ppapi/thunk/ppb_udp_socket_private_api.h" 9 #include "ppapi/thunk/ppb_udp_socket_private_api.h"
11 #include "ppapi/thunk/resource_creation_api.h" 10 #include "ppapi/thunk/resource_creation_api.h"
12 #include "ppapi/thunk/thunk.h" 11 #include "ppapi/thunk/thunk.h"
13 12
14 namespace ppapi { 13 namespace ppapi {
15 namespace thunk { 14 namespace thunk {
16 15
17 namespace { 16 namespace {
18 17
18 typedef EnterResource<PPB_UDPSocket_Private_API> EnterUDP;
19
19 PP_Resource Create(PP_Instance instance) { 20 PP_Resource Create(PP_Instance instance) {
20 EnterFunction<ResourceCreationAPI> enter(instance, true); 21 EnterFunction<ResourceCreationAPI> enter(instance, true);
21 if (enter.failed()) 22 if (enter.failed())
22 return 0; 23 return 0;
23 return enter.functions()->CreateUDPSocketPrivate(instance); 24 return enter.functions()->CreateUDPSocketPrivate(instance);
24 } 25 }
25 26
26 PP_Bool IsUDPSocket(PP_Resource resource) { 27 PP_Bool IsUDPSocket(PP_Resource resource) {
27 EnterResource<PPB_UDPSocket_Private_API> enter(resource, false); 28 EnterUDP enter(resource, false);
28 return PP_FromBool(enter.succeeded()); 29 return PP_FromBool(enter.succeeded());
29 } 30 }
30 31
31 int32_t Bind(PP_Resource udp_socket, 32 int32_t Bind(PP_Resource udp_socket,
32 const PP_NetAddress_Private *addr, 33 const PP_NetAddress_Private *addr,
33 PP_CompletionCallback callback) { 34 PP_CompletionCallback callback) {
34 EnterResource<PPB_UDPSocket_Private_API> enter(udp_socket, true); 35 EnterUDP enter(udp_socket, callback, true);
35 if (enter.failed()) 36 if (enter.failed())
36 return MayForceCallback(callback, PP_ERROR_BADRESOURCE); 37 return enter.retval();
37 int32_t result = enter.object()->Bind(addr, callback); 38 return enter.SetResult(enter.object()->Bind(addr, callback));
38 return MayForceCallback(callback, result);
39 } 39 }
40 40
41 int32_t RecvFrom(PP_Resource udp_socket, 41 int32_t RecvFrom(PP_Resource udp_socket,
42 char* buffer, 42 char* buffer,
43 int32_t num_bytes, 43 int32_t num_bytes,
44 PP_CompletionCallback callback) { 44 PP_CompletionCallback callback) {
45 EnterResource<PPB_UDPSocket_Private_API> enter(udp_socket, true); 45 EnterUDP enter(udp_socket, callback, true);
46 if (enter.failed()) 46 if (enter.failed())
47 return MayForceCallback(callback, PP_ERROR_BADRESOURCE); 47 return enter.retval();
48 int32_t result = enter.object()->RecvFrom(buffer, 48 return enter.SetResult(enter.object()->RecvFrom(buffer, num_bytes, callback));
49 num_bytes,
50 callback);
51 return MayForceCallback(callback, result);
52 } 49 }
53 50
54 PP_Bool GetRecvFromAddress(PP_Resource udp_socket, 51 PP_Bool GetRecvFromAddress(PP_Resource udp_socket,
55 PP_NetAddress_Private* addr) { 52 PP_NetAddress_Private* addr) {
56 EnterResource<PPB_UDPSocket_Private_API> enter(udp_socket, true); 53 EnterUDP enter(udp_socket, true);
57 if (enter.failed()) 54 if (enter.failed())
58 return PP_FALSE; 55 return PP_FALSE;
59 return enter.object()->GetRecvFromAddress(addr); 56 return enter.object()->GetRecvFromAddress(addr);
60 } 57 }
61 58
62 int32_t SendTo(PP_Resource udp_socket, 59 int32_t SendTo(PP_Resource udp_socket,
63 const char* buffer, 60 const char* buffer,
64 int32_t num_bytes, 61 int32_t num_bytes,
65 const PP_NetAddress_Private* addr, 62 const PP_NetAddress_Private* addr,
66 PP_CompletionCallback callback) { 63 PP_CompletionCallback callback) {
67 EnterResource<PPB_UDPSocket_Private_API> enter(udp_socket, true); 64 EnterUDP enter(udp_socket, callback, true);
68 if (enter.failed()) 65 if (enter.failed())
69 return MayForceCallback(callback, PP_ERROR_BADRESOURCE); 66 return enter.retval();
70 int32_t result = enter.object()->SendTo(buffer, num_bytes, addr, callback); 67 return enter.SetResult(enter.object()->SendTo(buffer, num_bytes, addr,
71 return MayForceCallback(callback, result); 68 callback));
72 } 69 }
73 70
74 void Close(PP_Resource udp_socket) { 71 void Close(PP_Resource udp_socket) {
75 EnterResource<PPB_UDPSocket_Private_API> enter(udp_socket, true); 72 EnterUDP enter(udp_socket, true);
76 if (enter.succeeded()) 73 if (enter.succeeded())
77 enter.object()->Close(); 74 enter.object()->Close();
78 } 75 }
79 76
80 const PPB_UDPSocket_Private g_ppb_udp_socket_thunk = { 77 const PPB_UDPSocket_Private g_ppb_udp_socket_thunk = {
81 &Create, 78 &Create,
82 &IsUDPSocket, 79 &IsUDPSocket,
83 &Bind, 80 &Bind,
84 &RecvFrom, 81 &RecvFrom,
85 &GetRecvFromAddress, 82 &GetRecvFromAddress,
86 &SendTo, 83 &SendTo,
87 &Close 84 &Close
88 }; 85 };
89 86
90 } // namespace 87 } // namespace
91 88
92 const PPB_UDPSocket_Private_0_2* GetPPB_UDPSocket_Private_0_2_Thunk() { 89 const PPB_UDPSocket_Private_0_2* GetPPB_UDPSocket_Private_0_2_Thunk() {
93 return &g_ppb_udp_socket_thunk; 90 return &g_ppb_udp_socket_thunk;
94 } 91 }
95 92
96 } // namespace thunk 93 } // namespace thunk
97 } // namespace ppapi 94 } // namespace ppapi
OLDNEW
« no previous file with comments | « ppapi/thunk/ppb_transport_thunk.cc ('k') | ppapi/thunk/ppb_url_loader_thunk.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698