Index: ppapi/proxy/file_io_resource.cc |
=================================================================== |
--- ppapi/proxy/file_io_resource.cc (revision 243312) |
+++ ppapi/proxy/file_io_resource.cc (working copy) |
@@ -18,10 +18,12 @@ |
#include "ppapi/shared_impl/resource_tracker.h" |
#include "ppapi/thunk/enter.h" |
#include "ppapi/thunk/ppb_file_ref_api.h" |
+#include "ppapi/thunk/ppb_file_system_api.h" |
using ppapi::thunk::EnterResourceNoLock; |
using ppapi::thunk::PPB_FileIO_API; |
using ppapi::thunk::PPB_FileRef_API; |
+using ppapi::thunk::PPB_FileSystem_API; |
namespace { |
@@ -80,11 +82,13 @@ |
FileIOResource::FileIOResource(Connection connection, PP_Instance instance) |
: PluginResource(connection, instance), |
- file_system_type_(PP_FILESYSTEMTYPE_INVALID) { |
+ file_system_type_(PP_FILESYSTEMTYPE_INVALID), |
+ called_close_(false) { |
SendCreate(BROWSER, PpapiHostMsg_FileIO_Create()); |
} |
FileIOResource::~FileIOResource() { |
+ Close(); |
} |
PPB_FileIO_API* FileIOResource::AsPPB_FileIO_API() { |
@@ -94,30 +98,36 @@ |
int32_t FileIOResource::Open(PP_Resource file_ref, |
int32_t open_flags, |
scoped_refptr<TrackedCallback> callback) { |
- EnterResourceNoLock<PPB_FileRef_API> enter(file_ref, true); |
- if (enter.failed()) |
+ EnterResourceNoLock<PPB_FileRef_API> enter_file_ref(file_ref, true); |
+ if (enter_file_ref.failed()) |
return PP_ERROR_BADRESOURCE; |
- PPB_FileRef_API* file_ref_api = enter.object(); |
+ PPB_FileRef_API* file_ref_api = enter_file_ref.object(); |
const FileRefCreateInfo& create_info = file_ref_api->GetCreateInfo(); |
if (!FileSystemTypeIsValid(create_info.file_system_type)) { |
NOTREACHED(); |
return PP_ERROR_FAILED; |
} |
- |
int32_t rv = state_manager_.CheckOperationState( |
FileIOStateManager::OPERATION_EXCLUSIVE, false); |
if (rv != PP_OK) |
return rv; |
file_system_type_ = create_info.file_system_type; |
- // Keep the FileSystem host alive by taking a reference to its resource. The |
- // FileIO host uses the FileSystem host for running tasks. |
- file_system_resource_ = create_info.file_system_plugin_resource; |
+ if (create_info.file_system_plugin_resource) { |
+ EnterResourceNoLock<PPB_FileSystem_API> enter_file_system( |
+ create_info.file_system_plugin_resource, true); |
+ if (enter_file_system.failed()) |
+ return PP_ERROR_FAILED; |
+ // Take a reference on the FileSystem resource. The FileIO host uses the |
+ // FileSystem host for running tasks and checking quota. |
+ file_system_resource_ = enter_file_system.resource(); |
+ } |
+ |
// Take a reference on the FileRef resource while we're opening the file; we |
// don't want the plugin destroying it during the Open operation. |
- file_ref_ = enter.resource(); |
+ file_ref_ = enter_file_ref.resource(); |
Call<PpapiPluginMsg_FileIO_OpenReply>(BROWSER, |
PpapiHostMsg_FileIO_Open( |
@@ -279,9 +289,13 @@ |
} |
void FileIOResource::Close() { |
- if (file_handle_) { |
+ if (called_close_) |
+ return; |
+ |
+ called_close_ = true; |
+ if (file_handle_) |
file_handle_ = NULL; |
- } |
+ |
Post(BROWSER, PpapiHostMsg_FileIO_Close()); |
} |