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 |
+ |