1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
// 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 "googleurl/src/gurl.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 "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_
|