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

Unified Diff: ppapi/native_client/src/shared/ppapi_proxy/browser_ppb_file_ref_rpc_server.cc

Issue 7740013: Cloning a bunch of stuff from the native_client repository at r6528 (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 9 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: ppapi/native_client/src/shared/ppapi_proxy/browser_ppb_file_ref_rpc_server.cc
===================================================================
--- ppapi/native_client/src/shared/ppapi_proxy/browser_ppb_file_ref_rpc_server.cc (revision 0)
+++ ppapi/native_client/src/shared/ppapi_proxy/browser_ppb_file_ref_rpc_server.cc (revision 0)
@@ -0,0 +1,213 @@
+// Copyright (c) 2011 The Native Client 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 "native_client/src/shared/ppapi_proxy/browser_callback.h"
+#include "native_client/src/shared/ppapi_proxy/browser_globals.h"
+#include "native_client/src/shared/ppapi_proxy/object_serialize.h"
+#include "native_client/src/shared/ppapi_proxy/utility.h"
+#include "ppapi/c/pp_errors.h"
+#include "srpcgen/ppb_rpc.h"
+
+using ppapi_proxy::DebugPrintf;
+using ppapi_proxy::DeleteRemoteCallbackInfo;
+using ppapi_proxy::MakeRemoteCompletionCallback;
+using ppapi_proxy::PPBFileRefInterface;
+using ppapi_proxy::SerializeTo;
+
+void PpbFileRefRpcServer::PPB_FileRef_Create(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_system,
+ nacl_abi_size_t path_size,
+ char* path_bytes,
+ PP_Resource* resource) {
+ UNREFERENCED_PARAMETER(path_size);
+
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_OK;
+
+ *resource = PPBFileRefInterface()->Create(file_system, path_bytes);
+ DebugPrintf("PPB_FileRef::Create: resource=%"NACL_PRId32"\n", *resource);
+}
+
+// TODO(sanga): Use a caching resource tracker instead of going over the proxy
+// to determine if the given resource is a file ref.
+void PpbFileRefRpcServer::PPB_FileRef_IsFileRef(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource resource,
+ int32_t* pp_success) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_OK;
+
+ *pp_success = PPBFileRefInterface()->IsFileRef(resource);
+ DebugPrintf("PPB_FileRef::IsFileRef: pp_success=%d\n", *pp_success);
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_GetFileSystemType(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_ref,
+ int32_t* file_system_type) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_OK;
+
+ *file_system_type = PPBFileRefInterface()->GetFileSystemType(file_ref);
+ DebugPrintf("PPB_FileRef::GetFileSystemType: file_system_type=%d\n",
+ file_system_type);
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_GetName(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_ref,
+ nacl_abi_size_t* name_size,
+ char* name_bytes) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_APP_ERROR;
+
+ PP_Var name = PPBFileRefInterface()->GetName(file_ref);
+ DebugPrintf("PPB_FileRef::GetName: name.type=%d\n", name.type);
+
+ if (SerializeTo(&name, name_bytes, name_size))
+ rpc->result = NACL_SRPC_RESULT_OK;
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_GetPath(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_ref,
+ nacl_abi_size_t* path_size,
+ char* path_bytes) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_APP_ERROR;
+
+ PP_Var path = PPBFileRefInterface()->GetPath(file_ref);
+ DebugPrintf("PPB_FileRef::GetName: path.type=%d\n", path.type);
+
+ if (SerializeTo(&path, path_bytes, path_size))
+ rpc->result = NACL_SRPC_RESULT_OK;
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_GetParent(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_ref,
+ PP_Resource* parent) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_OK;
+
+ *parent = PPBFileRefInterface()->GetParent(file_ref);
+ DebugPrintf("PPB_FileRef::GetParent: parent=%"NACL_PRId32"\n", *parent);
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_MakeDirectory(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource directory_ref,
+ int32_t make_ancestors,
+ int32_t callback_id,
+ int32_t* pp_error) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_APP_ERROR;
+
+ PP_CompletionCallback remote_callback = MakeRemoteCompletionCallback(
+ rpc->channel,
+ callback_id);
+ if (remote_callback.func == NULL)
+ return;
+
+ *pp_error = PPBFileRefInterface()->MakeDirectory(
+ directory_ref,
+ make_ancestors ? PP_TRUE : PP_FALSE,
+ remote_callback);
+ DebugPrintf("PPB_FileRef::MakeDirectory: pp_error=%"NACL_PRId32"\n",
+ *pp_error);
+ CHECK(*pp_error != PP_OK); // MakeDirectory does not complete synchronously
+
+ if (*pp_error != PP_OK_COMPLETIONPENDING)
+ DeleteRemoteCallbackInfo(remote_callback);
+ rpc->result = NACL_SRPC_RESULT_OK;
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_Touch(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_ref,
+ double last_access_time,
+ double last_modified_time,
+ int32_t callback_id,
+ int32_t* pp_error) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_APP_ERROR;
+
+ PP_CompletionCallback remote_callback = MakeRemoteCompletionCallback(
+ rpc->channel,
+ callback_id);
+ if (remote_callback.func == NULL)
+ return;
+
+ *pp_error = PPBFileRefInterface()->Touch(
+ file_ref,
+ last_access_time,
+ last_modified_time,
+ remote_callback);
+ DebugPrintf("PPB_FileRef::Touch: pp_error=%"NACL_PRId32"\n", *pp_error);
+ CHECK(*pp_error != PP_OK); // Touch does not complete synchronously
+
+ if (*pp_error != PP_OK_COMPLETIONPENDING)
+ DeleteRemoteCallbackInfo(remote_callback);
+ rpc->result = NACL_SRPC_RESULT_OK;
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_Delete(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_ref,
+ int32_t callback_id,
+ int32_t* pp_error) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_APP_ERROR;
+
+ PP_CompletionCallback remote_callback = MakeRemoteCompletionCallback(
+ rpc->channel,
+ callback_id);
+ if (remote_callback.func == NULL)
+ return;
+
+ *pp_error = PPBFileRefInterface()->Delete(file_ref, remote_callback);
+ DebugPrintf("PPB_FileRef::Delete: pp_error=%"NACL_PRId32"\n", *pp_error);
+ CHECK(*pp_error != PP_OK); // Delete does not complete synchronously
+
+ if (*pp_error != PP_OK_COMPLETIONPENDING)
+ DeleteRemoteCallbackInfo(remote_callback);
+ rpc->result = NACL_SRPC_RESULT_OK;
+}
+
+void PpbFileRefRpcServer::PPB_FileRef_Rename(
+ NaClSrpcRpc* rpc,
+ NaClSrpcClosure* done,
+ PP_Resource file_ref,
+ PP_Resource new_file_ref,
+ int32_t callback_id,
+ int32_t* pp_error) {
+ NaClSrpcClosureRunner runner(done);
+ rpc->result = NACL_SRPC_RESULT_APP_ERROR;
+
+ PP_CompletionCallback remote_callback = MakeRemoteCompletionCallback(
+ rpc->channel,
+ callback_id);
+ if (remote_callback.func == NULL)
+ return;
+
+ *pp_error = PPBFileRefInterface()->Rename(file_ref, new_file_ref,
+ remote_callback);
+ DebugPrintf("PPB_FileRef::Rename: pp_error=%"NACL_PRId32"\n", *pp_error);
+ CHECK(*pp_error != PP_OK); // Rename does not complete synchronously
+
+ if (*pp_error != PP_OK_COMPLETIONPENDING)
+ DeleteRemoteCallbackInfo(remote_callback);
+ rpc->result = NACL_SRPC_RESULT_OK;
+}

Powered by Google App Engine
This is Rietveld 408576698