Index: ppapi/cpp/file_ref.cc |
=================================================================== |
--- ppapi/cpp/file_ref.cc (revision 0) |
+++ ppapi/cpp/file_ref.cc (revision 0) |
@@ -0,0 +1,114 @@ |
+// Copyright (c) 2011 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. |
+ |
+#include "ppapi/cpp/file_ref.h" |
+ |
+#include "ppapi/c/pp_errors.h" |
+#include "ppapi/cpp/completion_callback.h" |
+#include "ppapi/cpp/file_system.h" |
+#include "ppapi/cpp/module_impl.h" |
+ |
+ |
+namespace pp { |
+ |
+namespace { |
+ |
+template <> const char* interface_name<PPB_FileRef>() { |
+ return PPB_FILEREF_INTERFACE; |
+} |
+ |
+} // namespace |
+ |
+FileRef::FileRef(PP_Resource resource) : Resource(resource) { |
+} |
+ |
+FileRef::FileRef(PassRef, PP_Resource resource) { |
+ PassRefFromConstructor(resource); |
+} |
+ |
+FileRef::FileRef(const FileSystem& file_system, |
+ const char* path) { |
+ if (!has_interface<PPB_FileRef>()) |
+ return; |
+ PassRefFromConstructor(get_interface<PPB_FileRef>()->Create( |
+ file_system.pp_resource(), path)); |
+} |
+ |
+FileRef::FileRef(const FileRef& other) |
+ : Resource(other) { |
+} |
+ |
+PP_FileSystemType FileRef::GetFileSystemType() const { |
+ if (!has_interface<PPB_FileRef>()) |
+ return PP_FILESYSTEMTYPE_EXTERNAL; |
+ return get_interface<PPB_FileRef>()->GetFileSystemType(pp_resource()); |
+} |
+ |
+Var FileRef::GetName() const { |
+ if (!has_interface<PPB_FileRef>()) |
+ return Var(); |
+ return Var(Var::PassRef(), |
+ get_interface<PPB_FileRef>()->GetName(pp_resource())); |
+} |
+ |
+Var FileRef::GetPath() const { |
+ if (!has_interface<PPB_FileRef>()) |
+ return Var(); |
+ return Var(Var::PassRef(), |
+ get_interface<PPB_FileRef>()->GetPath(pp_resource())); |
+} |
+ |
+FileRef FileRef::GetParent() const { |
+ if (!has_interface<PPB_FileRef>()) |
+ return FileRef(); |
+ return FileRef(PassRef(), |
+ get_interface<PPB_FileRef>()->GetParent( |
+ pp_resource())); |
+} |
+ |
+int32_t FileRef::MakeDirectory(const CompletionCallback& cc) { |
+ if (!has_interface<PPB_FileRef>()) |
+ return PP_ERROR_NOINTERFACE; |
+ return get_interface<PPB_FileRef>()->MakeDirectory( |
+ pp_resource(), |
+ PP_FALSE, // make_ancestors |
+ cc.pp_completion_callback()); |
+} |
+ |
+int32_t FileRef::MakeDirectoryIncludingAncestors( |
+ const CompletionCallback& cc) { |
+ if (!has_interface<PPB_FileRef>()) |
+ return PP_ERROR_NOINTERFACE; |
+ return get_interface<PPB_FileRef>()->MakeDirectory( |
+ pp_resource(), |
+ PP_TRUE, // make_ancestors |
+ cc.pp_completion_callback()); |
+} |
+ |
+int32_t FileRef::Touch(PP_Time last_access_time, |
+ PP_Time last_modified_time, |
+ const CompletionCallback& cc) { |
+ if (!has_interface<PPB_FileRef>()) |
+ return PP_ERROR_NOINTERFACE; |
+ return get_interface<PPB_FileRef>()->Touch( |
+ pp_resource(), last_access_time, last_modified_time, |
+ cc.pp_completion_callback()); |
+} |
+ |
+int32_t FileRef::Delete(const CompletionCallback& cc) { |
+ if (!has_interface<PPB_FileRef>()) |
+ return PP_ERROR_NOINTERFACE; |
+ return get_interface<PPB_FileRef>()->Delete( |
+ pp_resource(), cc.pp_completion_callback()); |
+} |
+ |
+int32_t FileRef::Rename(const FileRef& new_file_ref, |
+ const CompletionCallback& cc) { |
Sang Ahn
2011/06/22 23:34:25
Funny indent.
|
+ if (!has_interface<PPB_FileRef>()) |
+ return PP_ERROR_NOINTERFACE; |
+ return get_interface<PPB_FileRef>()->Rename( |
+ pp_resource(), new_file_ref.pp_resource(), cc.pp_completion_callback()); |
+} |
+ |
+} // namespace pp |