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

Side by Side Diff: ppapi/cpp/file_ref.cc

Issue 12817009: Add Query() support to FileRef (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Use the newest interface for every cpp FileRef call. Created 7 years, 9 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 unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ppapi/cpp/file_ref.h" 5 #include "ppapi/cpp/file_ref.h"
6 6
7 #include "ppapi/c/pp_errors.h" 7 #include "ppapi/c/pp_errors.h"
8 #include "ppapi/cpp/completion_callback.h" 8 #include "ppapi/cpp/completion_callback.h"
9 #include "ppapi/cpp/file_system.h" 9 #include "ppapi/cpp/file_system.h"
10 #include "ppapi/cpp/module_impl.h" 10 #include "ppapi/cpp/module_impl.h"
11 11
12 12
13 namespace pp { 13 namespace pp {
14 14
15 namespace { 15 namespace {
16 16
17 template <> const char* interface_name<PPB_FileRef_1_0>() { 17 template <> const char* interface_name<PPB_FileRef_1_0>() {
18 return PPB_FILEREF_INTERFACE_1_0; 18 return PPB_FILEREF_INTERFACE_1_0;
19 } 19 }
20 20
21 template <> const char* interface_name<PPB_FileRef_1_1>() {
22 return PPB_FILEREF_INTERFACE_1_1;
23 }
24
21 } // namespace 25 } // namespace
22 26
23 FileRef::FileRef(PP_Resource resource) : Resource(resource) { 27 FileRef::FileRef(PP_Resource resource) : Resource(resource) {
24 } 28 }
25 29
26 FileRef::FileRef(PassRef, PP_Resource resource) : Resource(PASS_REF, resource) { 30 FileRef::FileRef(PassRef, PP_Resource resource) : Resource(PASS_REF, resource) {
27 } 31 }
28 32
29 FileRef::FileRef(const FileSystem& file_system, 33 FileRef::FileRef(const FileSystem& file_system,
30 const char* path) { 34 const char* path) {
31 if (!has_interface<PPB_FileRef_1_0>()) 35 if (has_interface<PPB_FileRef_1_1>()) {
32 return; 36 PassRefFromConstructor(get_interface<PPB_FileRef_1_1>()->Create(
33 PassRefFromConstructor(get_interface<PPB_FileRef_1_0>()->Create( 37 file_system.pp_resource(), path));
34 file_system.pp_resource(), path)); 38 } else if (has_interface<PPB_FileRef_1_0>()) {
39 PassRefFromConstructor(get_interface<PPB_FileRef_1_0>()->Create(
40 file_system.pp_resource(), path));
41 }
35 } 42 }
36 43
37 FileRef::FileRef(const FileRef& other) 44 FileRef::FileRef(const FileRef& other)
38 : Resource(other) { 45 : Resource(other) {
39 } 46 }
40 47
41 PP_FileSystemType FileRef::GetFileSystemType() const { 48 PP_FileSystemType FileRef::GetFileSystemType() const {
42 if (!has_interface<PPB_FileRef_1_0>()) 49 if (has_interface<PPB_FileRef_1_1>())
50 return get_interface<PPB_FileRef_1_1>()->GetFileSystemType(pp_resource());
51 else if (has_interface<PPB_FileRef_1_0>())
yzshen1 2013/03/26 23:32:42 I remember that the preferred style is: (And pleas
52 return get_interface<PPB_FileRef_1_0>()->GetFileSystemType(pp_resource());
53 else
43 return PP_FILESYSTEMTYPE_EXTERNAL; 54 return PP_FILESYSTEMTYPE_EXTERNAL;
44 return get_interface<PPB_FileRef_1_0>()->GetFileSystemType(pp_resource());
45 } 55 }
46 56
47 Var FileRef::GetName() const { 57 Var FileRef::GetName() const {
48 if (!has_interface<PPB_FileRef_1_0>()) 58 if (has_interface<PPB_FileRef_1_1>()) {
59 return Var(PASS_REF,
60 get_interface<PPB_FileRef_1_1>()->GetName(pp_resource()));
61 } else if (has_interface<PPB_FileRef_1_0>()) {
62 return Var(PASS_REF,
63 get_interface<PPB_FileRef_1_0>()->GetName(pp_resource()));
64 } else {
49 return Var(); 65 return Var();
50 return Var(PASS_REF, 66 }
51 get_interface<PPB_FileRef_1_0>()->GetName(pp_resource()));
52 } 67 }
53 68
54 Var FileRef::GetPath() const { 69 Var FileRef::GetPath() const {
55 if (!has_interface<PPB_FileRef_1_0>()) 70 if (has_interface<PPB_FileRef_1_1>()) {
71 return Var(PASS_REF,
72 get_interface<PPB_FileRef_1_1>()->GetPath(pp_resource()));
73 } else if (has_interface<PPB_FileRef_1_0>()) {
74 return Var(PASS_REF,
75 get_interface<PPB_FileRef_1_0>()->GetPath(pp_resource()));
76 } else {
56 return Var(); 77 return Var();
57 return Var(PASS_REF, 78 }
58 get_interface<PPB_FileRef_1_0>()->GetPath(pp_resource()));
59 } 79 }
60 80
61 FileRef FileRef::GetParent() const { 81 FileRef FileRef::GetParent() const {
62 if (!has_interface<PPB_FileRef_1_0>()) 82 if (has_interface<PPB_FileRef_1_1>()) {
83 return FileRef(PASS_REF,
84 get_interface<PPB_FileRef_1_1>()->GetParent(pp_resource()));
85 } else if (has_interface<PPB_FileRef_1_0>()) {
86 return FileRef(PASS_REF,
87 get_interface<PPB_FileRef_1_0>()->GetParent(pp_resource()));
88 } else {
63 return FileRef(); 89 return FileRef();
64 return FileRef(PASS_REF, 90 }
65 get_interface<PPB_FileRef_1_0>()->GetParent(pp_resource()));
66 } 91 }
67 92
68 int32_t FileRef::MakeDirectory(const CompletionCallback& cc) { 93 int32_t FileRef::MakeDirectory(const CompletionCallback& cc) {
69 if (!has_interface<PPB_FileRef_1_0>()) 94 if (has_interface<PPB_FileRef_1_1>()) {
95 return get_interface<PPB_FileRef_1_1>()->MakeDirectory(
96 pp_resource(),
97 PP_FALSE, // make_ancestors
98 cc.pp_completion_callback());
99 } else if (has_interface<PPB_FileRef_1_0>()) {
100 return get_interface<PPB_FileRef_1_0>()->MakeDirectory(
101 pp_resource(),
102 PP_FALSE, // make_ancestors
103 cc.pp_completion_callback());
104 } else {
70 return cc.MayForce(PP_ERROR_NOINTERFACE); 105 return cc.MayForce(PP_ERROR_NOINTERFACE);
71 return get_interface<PPB_FileRef_1_0>()->MakeDirectory( 106 }
72 pp_resource(),
73 PP_FALSE, // make_ancestors
74 cc.pp_completion_callback());
75 } 107 }
76 108
77 int32_t FileRef::MakeDirectoryIncludingAncestors( 109 int32_t FileRef::MakeDirectoryIncludingAncestors(
78 const CompletionCallback& cc) { 110 const CompletionCallback& cc) {
79 if (!has_interface<PPB_FileRef_1_0>()) 111 if (has_interface<PPB_FileRef_1_1>()) {
112 return get_interface<PPB_FileRef_1_1>()->MakeDirectory(
113 pp_resource(),
114 PP_TRUE, // make_ancestors
115 cc.pp_completion_callback());
116 } else if (has_interface<PPB_FileRef_1_0>()) {
117 return get_interface<PPB_FileRef_1_0>()->MakeDirectory(
118 pp_resource(),
119 PP_TRUE, // make_ancestors
120 cc.pp_completion_callback());
121 } else {
80 return cc.MayForce(PP_ERROR_NOINTERFACE); 122 return cc.MayForce(PP_ERROR_NOINTERFACE);
81 return get_interface<PPB_FileRef_1_0>()->MakeDirectory( 123 }
82 pp_resource(),
83 PP_TRUE, // make_ancestors
84 cc.pp_completion_callback());
85 } 124 }
86 125
87 int32_t FileRef::Touch(PP_Time last_access_time, 126 int32_t FileRef::Touch(PP_Time last_access_time,
88 PP_Time last_modified_time, 127 PP_Time last_modified_time,
89 const CompletionCallback& cc) { 128 const CompletionCallback& cc) {
90 if (!has_interface<PPB_FileRef_1_0>()) 129 if (has_interface<PPB_FileRef_1_1>()) {
130 return get_interface<PPB_FileRef_1_1>()->Touch(
131 pp_resource(), last_access_time, last_modified_time,
132 cc.pp_completion_callback());
133 } else if (has_interface<PPB_FileRef_1_0>()) {
134 return get_interface<PPB_FileRef_1_0>()->Touch(
135 pp_resource(), last_access_time, last_modified_time,
136 cc.pp_completion_callback());
137 } else {
91 return cc.MayForce(PP_ERROR_NOINTERFACE); 138 return cc.MayForce(PP_ERROR_NOINTERFACE);
92 return get_interface<PPB_FileRef_1_0>()->Touch( 139 }
93 pp_resource(), last_access_time, last_modified_time,
94 cc.pp_completion_callback());
95 } 140 }
96 141
97 int32_t FileRef::Delete(const CompletionCallback& cc) { 142 int32_t FileRef::Delete(const CompletionCallback& cc) {
98 if (!has_interface<PPB_FileRef_1_0>()) 143 if (has_interface<PPB_FileRef_1_1>()) {
144 return get_interface<PPB_FileRef_1_1>()->Delete(
145 pp_resource(), cc.pp_completion_callback());
146 } else if (has_interface<PPB_FileRef_1_0>()) {
147 return get_interface<PPB_FileRef_1_0>()->Delete(
148 pp_resource(), cc.pp_completion_callback());
149 } else {
99 return cc.MayForce(PP_ERROR_NOINTERFACE); 150 return cc.MayForce(PP_ERROR_NOINTERFACE);
100 return get_interface<PPB_FileRef_1_0>()->Delete( 151 }
101 pp_resource(), cc.pp_completion_callback());
102 } 152 }
103 153
104 int32_t FileRef::Rename(const FileRef& new_file_ref, 154 int32_t FileRef::Rename(const FileRef& new_file_ref,
105 const CompletionCallback& cc) { 155 const CompletionCallback& cc) {
106 if (!has_interface<PPB_FileRef_1_0>()) 156 if (has_interface<PPB_FileRef_1_1>()) {
157 return get_interface<PPB_FileRef_1_1>()->Rename(
158 pp_resource(), new_file_ref.pp_resource(), cc.pp_completion_callback());
159 } else if (has_interface<PPB_FileRef_1_0>()) {
160 return get_interface<PPB_FileRef_1_0>()->Rename(
161 pp_resource(), new_file_ref.pp_resource(), cc.pp_completion_callback());
162 } else {
107 return cc.MayForce(PP_ERROR_NOINTERFACE); 163 return cc.MayForce(PP_ERROR_NOINTERFACE);
108 return get_interface<PPB_FileRef_1_0>()->Rename( 164 }
109 pp_resource(), new_file_ref.pp_resource(), cc.pp_completion_callback());
110 } 165 }
111 166
167 int32_t FileRef::Query(const CompletionCallbackWithOutput<PP_FileInfo>& cc) {
168 if (!has_interface<PPB_FileRef_1_1>())
169 return cc.MayForce(PP_ERROR_NOINTERFACE);
170 return get_interface<PPB_FileRef_1_1>()->Query(
171 pp_resource(), cc.output(), cc.pp_completion_callback());
172 }
173
174
112 } // namespace pp 175 } // namespace pp
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698