| Index: webkit/plugins/ppapi/ppb_file_ref_impl.h
|
| diff --git a/webkit/plugins/ppapi/ppb_file_ref_impl.h b/webkit/plugins/ppapi/ppb_file_ref_impl.h
|
| index 1b99969703904ad2e27c8999b6eecfbfd4a38921..5d6bccf2787b48c261fcc68553388e567c5a96c7 100644
|
| --- a/webkit/plugins/ppapi/ppb_file_ref_impl.h
|
| +++ b/webkit/plugins/ppapi/ppb_file_ref_impl.h
|
| @@ -12,6 +12,7 @@
|
| #include "ppapi/c/pp_file_info.h"
|
| #include "ppapi/c/ppb_file_ref.h"
|
| #include "ppapi/shared_impl/ppb_file_ref_shared.h"
|
| +#include "ppapi/shared_impl/scoped_pp_resource.h"
|
| #include "ppapi/shared_impl/var.h"
|
| #include "webkit/glue/webkit_glue_export.h"
|
|
|
| @@ -26,19 +27,21 @@ class WEBKIT_GLUE_EXPORT PPB_FileRef_Impl
|
| : public ::ppapi::PPB_FileRef_Shared {
|
| public:
|
| PPB_FileRef_Impl(const ::ppapi::PPB_FileRef_CreateInfo& info,
|
| - PPB_FileSystem_Impl* file_system);
|
| + PP_Resource file_system);
|
| PPB_FileRef_Impl(const ::ppapi::PPB_FileRef_CreateInfo& info,
|
| const base::FilePath& external_file_path);
|
| virtual ~PPB_FileRef_Impl();
|
|
|
| // The returned object will have a refcount of 0 (just like "new").
|
| - static PPB_FileRef_Impl* CreateInternal(PP_Resource pp_file_system,
|
| + static PPB_FileRef_Impl* CreateInternal(PP_Instance instance,
|
| + PP_Resource pp_file_system,
|
| const std::string& path);
|
|
|
| // The returned object will have a refcount of 0 (just like "new").
|
| - static PPB_FileRef_Impl* CreateExternal(PP_Instance instance,
|
| - const base::FilePath& external_file_path,
|
| - const std::string& display_name);
|
| + static PPB_FileRef_Impl* CreateExternal(
|
| + PP_Instance instance,
|
| + const base::FilePath& external_file_path,
|
| + const std::string& display_name);
|
|
|
| // PPB_FileRef_API implementation (not provided by PPB_FileRef_Shared).
|
| virtual PP_Resource GetParent() OVERRIDE;
|
| @@ -59,7 +62,7 @@ class WEBKIT_GLUE_EXPORT PPB_FileRef_Impl
|
| scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE;
|
| virtual PP_Var GetAbsolutePath();
|
|
|
| - PPB_FileSystem_Impl* file_system() const { return file_system_.get(); }
|
| + PP_Resource file_system_resource() const { return file_system_; }
|
|
|
| // Returns the system path corresponding to this file. Valid only for
|
| // external filesystems.
|
| @@ -70,14 +73,31 @@ class WEBKIT_GLUE_EXPORT PPB_FileRef_Impl
|
|
|
| // Checks if file ref has file system instance and if the instance is opened.
|
| bool HasValidFileSystem() const;
|
| +
|
| + void AddFileSystemRefCount() {
|
| + file_system_ref_ = file_system_;
|
| + }
|
| +
|
| private:
|
| // Many mutation functions are allow only to non-external filesystems, This
|
| // function returns true if the filesystem is opened and isn't external as an
|
| // access check for these functions.
|
| bool IsValidNonExternalFileSystem() const;
|
|
|
| - // Null for external filesystems.
|
| - scoped_refptr<PPB_FileSystem_Impl> file_system_;
|
| + // 0 for external filesystems. This is a plugin side resource that we don't
|
| + // hold a reference here, so file_system_ could be destroyed earlier than
|
| + // this object. Right now we checked the existance in plugin delegate before
|
| + // use. But it's better to hold a reference once we migrate FileRef to the
|
| + // new design.
|
| + PP_Resource file_system_;
|
| +
|
| + // Holds a reference of FileSystem when running in process. See
|
| + // PPB_FileRef_Proxy for corresponding code for out-of-process mode. Note
|
| + // that this ScopedPPResource is only expected to be used when running in
|
| + // process (since PPB_FileRef_Proxy takes care of out-of-process case).
|
| + // Also note that this workaround will be no longer needed after FileRef
|
| + // refactoring.
|
| + ::ppapi::ScopedPPResource file_system_ref_;
|
|
|
| // Used only for external filesystems.
|
| base::FilePath external_file_system_path_;
|
|
|