diff options
Diffstat (limited to 'webkit/plugins/ppapi/ppb_file_io_impl.cc')
-rw-r--r-- | webkit/plugins/ppapi/ppb_file_io_impl.cc | 182 |
1 files changed, 163 insertions, 19 deletions
diff --git a/webkit/plugins/ppapi/ppb_file_io_impl.cc b/webkit/plugins/ppapi/ppb_file_io_impl.cc index b68da1b..0989f1e 100644 --- a/webkit/plugins/ppapi/ppb_file_io_impl.cc +++ b/webkit/plugins/ppapi/ppb_file_io_impl.cc @@ -15,8 +15,6 @@ #include "ppapi/c/dev/ppb_file_io_trusted_dev.h" #include "ppapi/c/pp_completion_callback.h" #include "ppapi/c/pp_errors.h" -#include "ppapi/thunk/enter.h" -#include "ppapi/thunk/ppb_file_ref_api.h" #include "webkit/plugins/ppapi/common.h" #include "webkit/plugins/ppapi/file_type_conversions.h" #include "webkit/plugins/ppapi/plugin_module.h" @@ -24,13 +22,163 @@ #include "webkit/plugins/ppapi/ppb_file_ref_impl.h" #include "webkit/plugins/ppapi/resource_tracker.h" -using ppapi::thunk::EnterResourceNoLock; -using ppapi::thunk::PPB_FileIO_API; -using ppapi::thunk::PPB_FileRef_API; - namespace webkit { namespace ppapi { +namespace { + +PP_Resource Create(PP_Instance instance_id) { + PluginInstance* instance = ResourceTracker::Get()->GetInstance(instance_id); + if (!instance) + return 0; + + PPB_FileIO_Impl* file_io = new PPB_FileIO_Impl(instance); + return file_io->GetReference(); +} + +PP_Bool IsFileIO(PP_Resource resource) { + return BoolToPPBool(!!Resource::GetAs<PPB_FileIO_Impl>(resource)); +} + +int32_t Open(PP_Resource file_io_id, + PP_Resource file_ref_id, + int32_t open_flags, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + + scoped_refptr<PPB_FileRef_Impl> file_ref( + Resource::GetAs<PPB_FileRef_Impl>(file_ref_id)); + if (!file_ref) + return PP_ERROR_BADRESOURCE; + + return file_io->Open(file_ref, open_flags, callback); +} + +int32_t Query(PP_Resource file_io_id, + PP_FileInfo_Dev* info, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->Query(info, callback); +} + +int32_t Touch(PP_Resource file_io_id, + PP_Time last_access_time, + PP_Time last_modified_time, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->Touch(last_access_time, last_modified_time, callback); +} + +int32_t Read(PP_Resource file_io_id, + int64_t offset, + char* buffer, + int32_t bytes_to_read, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->Read(offset, buffer, bytes_to_read, callback); +} + +int32_t Write(PP_Resource file_io_id, + int64_t offset, + const char* buffer, + int32_t bytes_to_write, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->Write(offset, buffer, bytes_to_write, callback); +} + +int32_t SetLength(PP_Resource file_io_id, + int64_t length, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->SetLength(length, callback); +} + +int32_t Flush(PP_Resource file_io_id, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->Flush(callback); +} + +void Close(PP_Resource file_io_id) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return; + file_io->Close(); +} + +const PPB_FileIO_Dev ppb_fileio = { + &Create, + &IsFileIO, + &Open, + &Query, + &Touch, + &Read, + &Write, + &SetLength, + &Flush, + &Close +}; + +int32_t GetOSFileDescriptor(PP_Resource file_io_id) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->GetOSFileDescriptor(); +} + +int32_t WillWrite(PP_Resource file_io_id, + int64_t offset, + int32_t bytes_to_write, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->WillWrite(offset, bytes_to_write, callback); +} + +int32_t WillSetLength(PP_Resource file_io_id, + int64_t length, + PP_CompletionCallback callback) { + scoped_refptr<PPB_FileIO_Impl> + file_io(Resource::GetAs<PPB_FileIO_Impl>(file_io_id)); + if (!file_io) + return PP_ERROR_BADRESOURCE; + return file_io->WillSetLength(length, callback); +} + +const PPB_FileIOTrusted_Dev ppb_fileiotrusted = { + &GetOSFileDescriptor, + &WillWrite, + &WillSetLength +}; + +} // namespace + PPB_FileIO_Impl::PPB_FileIO_Impl(PluginInstance* instance) : Resource(instance), ALLOW_THIS_IN_INITIALIZER_LIST(callback_factory_(this)), @@ -45,26 +193,22 @@ PPB_FileIO_Impl::~PPB_FileIO_Impl() { } // static -PP_Resource PPB_FileIO_Impl::Create(PP_Instance pp_instance) { - PluginInstance* instance = ResourceTracker::Get()->GetInstance(pp_instance); - if (!instance) - return 0; - PPB_FileIO_Impl* file_io = new PPB_FileIO_Impl(instance); - return file_io->GetReference(); +const PPB_FileIO_Dev* PPB_FileIO_Impl::GetInterface() { + return &ppb_fileio; } -PPB_FileIO_API* PPB_FileIO_Impl::AsPPB_FileIO_API() { +// static +const PPB_FileIOTrusted_Dev* PPB_FileIO_Impl::GetTrustedInterface() { + return &ppb_fileiotrusted; +} + +PPB_FileIO_Impl* PPB_FileIO_Impl::AsPPB_FileIO_Impl() { return this; } -int32_t PPB_FileIO_Impl::Open(PP_Resource pp_file_ref, +int32_t PPB_FileIO_Impl::Open(PPB_FileRef_Impl* file_ref, int32_t open_flags, PP_CompletionCallback callback) { - EnterResourceNoLock<PPB_FileRef_API> enter(pp_file_ref, true); - if (enter.failed()) - return PP_ERROR_BADRESOURCE; - PPB_FileRef_Impl* file_ref = static_cast<PPB_FileRef_Impl*>(enter.object()); - int32_t rv = CommonCallValidation(false, callback); if (rv != PP_OK) return rv; |