Index: webkit/plugins/ppapi/ppb_file_ref_impl.h |
=================================================================== |
--- webkit/plugins/ppapi/ppb_file_ref_impl.h (revision 213561) |
+++ webkit/plugins/ppapi/ppb_file_ref_impl.h (working copy) |
@@ -1,127 +0,0 @@ |
-// Copyright (c) 2012 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. |
- |
-#ifndef WEBKIT_PLUGINS_PPAPI_PPB_FILE_REF_IMPL_H_ |
-#define WEBKIT_PLUGINS_PPAPI_PPB_FILE_REF_IMPL_H_ |
- |
-#include <string> |
-#include <vector> |
- |
-#include "base/files/file_path.h" |
-#include "base/memory/linked_ptr.h" |
-#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 "url/gurl.h" |
-#include "webkit/plugins/webkit_plugins_export.h" |
- |
-namespace webkit { |
-namespace ppapi { |
- |
-using ::ppapi::StringVar; |
- |
-class PPB_FileSystem_Impl; |
- |
-class WEBKIT_PLUGINS_EXPORT PPB_FileRef_Impl |
- : public ::ppapi::PPB_FileRef_Shared { |
- public: |
- PPB_FileRef_Impl(const ::ppapi::PPB_FileRef_CreateInfo& info, |
- 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_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); |
- |
- // PPB_FileRef_API implementation (not provided by PPB_FileRef_Shared). |
- virtual PP_Resource GetParent() OVERRIDE; |
- virtual int32_t MakeDirectory( |
- PP_Bool make_ancestors, |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual int32_t Touch( |
- PP_Time last_access_time, |
- PP_Time last_modified_time, |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual int32_t Delete( |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual int32_t Rename( |
- PP_Resource new_file_ref, |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual int32_t Query( |
- PP_FileInfo* info, |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual int32_t ReadDirectoryEntries( |
- const PP_ArrayOutput& output, |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual int32_t QueryInHost( |
- linked_ptr<PP_FileInfo> info, |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual int32_t ReadDirectoryEntriesInHost( |
- linked_ptr<std::vector< ::ppapi::PPB_FileRef_CreateInfo> > files, |
- linked_ptr<std::vector<PP_FileType> > file_types, |
- scoped_refptr< ::ppapi::TrackedCallback> callback) OVERRIDE; |
- virtual PP_Var GetAbsolutePath(); |
- |
- PP_Resource file_system_resource() const { return file_system_; } |
- |
- // Returns the system path corresponding to this file. Valid only for |
- // external filesystems. |
- base::FilePath GetSystemPath() const; |
- |
- // Returns the FileSystem API URL corresponding to this file. |
- GURL GetFileSystemURL() const; |
- |
- // 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; |
- |
- // 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_; |
- |
- // Lazily initialized var created from the external path. This is so we can |
- // return the identical string object every time it is requested. |
- scoped_refptr<StringVar> external_path_var_; |
- |
- DISALLOW_COPY_AND_ASSIGN(PPB_FileRef_Impl); |
-}; |
- |
-} // namespace ppapi |
-} // namespace webkit |
- |
-#endif // WEBKIT_PLUGINS_PPAPI_PPB_FILE_REF_IMPL_H_ |