Chromium Code Reviews| Index: ppapi/thunk/ppb_flash_udp_socket_thunk.cc |
| diff --git a/ppapi/thunk/ppb_flash_udp_socket_thunk.cc b/ppapi/thunk/ppb_flash_udp_socket_thunk.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..c42b8017c34106bab19f0081c2eb095c559eb0a4 |
| --- /dev/null |
| +++ b/ppapi/thunk/ppb_flash_udp_socket_thunk.cc |
| @@ -0,0 +1,97 @@ |
| +// Copyright (c) 2011 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "ppapi/c/pp_completion_callback.h" |
| +#include "ppapi/c/pp_errors.h" |
| +#include "ppapi/c/private/ppb_flash_udp_socket.h" |
| +#include "ppapi/thunk/common.h" |
| +#include "ppapi/thunk/enter.h" |
| +#include "ppapi/thunk/ppb_flash_udp_socket_api.h" |
| +#include "ppapi/thunk/resource_creation_api.h" |
| +#include "ppapi/thunk/thunk.h" |
| + |
| +namespace ppapi { |
| +namespace thunk { |
| + |
| +namespace { |
| + |
| +PP_Resource Create(PP_Instance instance, int32_t family) { |
| + EnterFunction<ResourceCreationAPI> enter(instance, true); |
| + if (enter.failed()) |
| + return 0; |
| + return enter.functions()->CreateFlashUDPSocket(instance, family); |
| +} |
| + |
| +PP_Bool IsFlashUDPSocket(PP_Resource resource) { |
| + EnterResource<PPB_Flash_UDPSocket_API> enter(resource, false); |
| + return PP_FromBool(enter.succeeded()); |
| +} |
| + |
| +int32_t Bind(PP_Resource udp_socket, |
| + const PP_Flash_NetAddress *addr, |
| + PP_CompletionCallback callback) { |
| + EnterResource<PPB_Flash_UDPSocket_API> enter(udp_socket, true); |
|
brettw
2011/09/16 17:50:17
Check you're using 2-space indents consistently in
mtilburg
2011/09/21 01:46:43
Done.
|
| + if (enter.failed()) |
| + return PP_FALSE; |
|
yzshen1
2011/09/17 02:10:07
MayForceCallback
and you need to return PP_ERROR_B
mtilburg
2011/09/21 01:46:43
Done.
|
| + return enter.object()->Bind(addr, callback); |
|
yzshen1
2011/09/17 02:10:07
MayForceCallback
mtilburg
2011/09/21 01:46:43
Done.
|
| +} |
| + |
| +int32_t RecvFrom(PP_Resource udp_socket, |
| + char* buffer, |
| + int32_t num_bytes, |
| + PP_CompletionCallback callback) { |
| + EnterResource<PPB_Flash_UDPSocket_API> enter(udp_socket, true); |
| + if (enter.failed()) |
| + return MayForceCallback(callback, PP_ERROR_BADRESOURCE); |
| + int32_t result = enter.object()->RecvFrom(buffer, |
| + num_bytes, |
| + callback); |
| + return MayForceCallback(callback, result); |
| +} |
| + |
| +PP_Bool GetRecvFromAddress(PP_Resource udp_socket, |
| + PP_Flash_NetAddress* addr) { |
| + EnterResource<PPB_Flash_UDPSocket_API> enter(udp_socket, true); |
| + if (enter.failed()) |
| + return PP_FALSE; |
| + return enter.object()->GetRecvFromAddress(addr); |
| +} |
| + |
| +int32_t SendTo(PP_Resource udp_socket, |
| + const char* buffer, |
| + int32_t num_bytes, |
| + const PP_Flash_NetAddress* addr, |
| + PP_CompletionCallback callback) { |
| + EnterResource<PPB_Flash_UDPSocket_API> enter(udp_socket, true); |
| + if (enter.failed()) |
| + return MayForceCallback(callback, PP_ERROR_BADRESOURCE); |
| + int32_t result = enter.object()->SendTo(buffer, num_bytes, addr, callback); |
| + return MayForceCallback(callback, result); |
| +} |
| + |
| +void Disconnect(PP_Resource udp_socket) { |
| + EnterResource<PPB_Flash_UDPSocket_API> enter(udp_socket, true); |
| + if (enter.succeeded()) |
| + enter.object()->Disconnect(); |
| +} |
| + |
| +const PPB_Flash_UDPSocket g_ppb_flash_udp_socket_thunk = { |
| + &Create, |
| + &IsFlashUDPSocket, |
| + &Bind, |
| + &RecvFrom, |
| + &GetRecvFromAddress, |
| + &SendTo, |
| + &Disconnect |
| +}; |
| + |
| +} // namespace |
| + |
| +const PPB_Flash_UDPSocket* GetPPB_Flash_UDPSocket_Thunk() { |
| + return &g_ppb_flash_udp_socket_thunk; |
| +} |
| + |
| +} // namespace thunk |
| +} // namespace ppapi |
| + |