// 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. #ifndef PPAPI_SHARED_IMPL_PPB_FILE_IO_SHARED_H_ #define PPAPI_SHARED_IMPL_PPB_FILE_IO_SHARED_H_ #include #include "base/compiler_specific.h" #include "ppapi/shared_impl/ppapi_shared_export.h" #include "ppapi/shared_impl/resource.h" #include "ppapi/shared_impl/tracked_callback.h" #include "ppapi/thunk/ppb_file_io_api.h" namespace ppapi { namespace thunk { class PPB_FileRef_API; } class PPAPI_SHARED_EXPORT PPB_FileIO_Shared : public Resource, public thunk::PPB_FileIO_API { public: PPB_FileIO_Shared(PP_Instance instance); PPB_FileIO_Shared(const HostResource& host_resource); ~PPB_FileIO_Shared(); // Resource overrides. virtual thunk::PPB_FileIO_API* AsPPB_FileIO_API() OVERRIDE; // PPB_FileIO_API implementation. virtual int32_t Open(PP_Resource file_ref, int32_t open_flags, PP_CompletionCallback callback) OVERRIDE; virtual int32_t Query(PP_FileInfo* info, PP_CompletionCallback callback) OVERRIDE; virtual int32_t Touch(PP_Time last_access_time, PP_Time last_modified_time, PP_CompletionCallback callback) OVERRIDE; virtual int32_t Read(int64_t offset, char* buffer, int32_t bytes_to_read, PP_CompletionCallback callback) OVERRIDE; virtual int32_t Write(int64_t offset, const char* buffer, int32_t bytes_to_write, PP_CompletionCallback callback) OVERRIDE; virtual int32_t SetLength(int64_t length, PP_CompletionCallback callback) OVERRIDE; virtual int32_t Flush(PP_CompletionCallback callback) OVERRIDE; // Callback handler for different types of operations. void ExecuteGeneralCallback(int32_t pp_error); void ExecuteOpenFileCallback(int32_t pp_error); void ExecuteQueryCallback(int32_t pp_error, const PP_FileInfo& info); void ExecuteReadCallback(int32_t pp_error, const char* data); protected: struct CallbackEntry { CallbackEntry(); CallbackEntry(const CallbackEntry& entry); ~CallbackEntry(); scoped_refptr callback; // Pointer back to the caller's read buffer; only used by |Read()|, NULL // for non-read operations. Not owned. char* read_buffer; // Pointer back to the caller's PP_FileInfo structure for Query operations. // NULL for non-query operations. Not owned. PP_FileInfo* info; }; enum OperationType { // There is no pending operation right now. OPERATION_NONE, // If there are pending reads, any other kind of async operation is not // allowed. OPERATION_READ, // If there are pending writes, any other kind of async operation is not // allowed. OPERATION_WRITE, // If there is a pending operation that is neither read nor write, no // further async operation is allowed. OPERATION_EXCLUSIVE }; // Validated versions of the FileIO API. Subclasses in the proxy and impl // implement these so the common error checking stays here. virtual int32_t OpenValidated(PP_Resource file_ref_resource, thunk::PPB_FileRef_API* file_ref_api, int32_t open_flags, PP_CompletionCallback callback) = 0; virtual int32_t QueryValidated(PP_FileInfo* info, PP_CompletionCallback callback) = 0; virtual int32_t TouchValidated(PP_Time last_access_time, PP_Time last_modified_time, PP_CompletionCallback callback) = 0; virtual int32_t ReadValidated(int64_t offset, char* buffer, int32_t bytes_to_read, PP_CompletionCallback callback) = 0; virtual int32_t WriteValidated(int64_t offset, const char* buffer, int32_t bytes_to_write, PP_CompletionCallback callback) = 0; virtual int32_t SetLengthValidated(int64_t length, PP_CompletionCallback callback) = 0; virtual int32_t FlushValidated(PP_CompletionCallback callback) = 0; // Called for every "Validated" function. // // This verifies that the callback is valid and that no callback is already // pending, or it is a read(write) request and currently the pending // operations are reads(writes). // // Returns |PP_OK| to indicate that everything is valid or |PP_ERROR_...| if // the call should be aborted and that code returned to the plugin. int32_t CommonCallValidation(bool should_be_open, OperationType new_op, PP_CompletionCallback callback); // Sets up a pending callback. This should only be called once it is certain // that |PP_OK_COMPLETIONPENDING| will be returned. // // |read_buffer| is only used by read operations, |info| is used only by // query operations. void RegisterCallback(OperationType op, PP_CompletionCallback callback, char* read_buffer, PP_FileInfo* info); // Pops the oldest callback from the queue and runs it. void RunAndRemoveFirstPendingCallback(int32_t result); // The file system type specified in the Open() call. This will be // PP_FILESYSTEMTYPE_INVALID before open was called. This value does not // indicate that the open command actually succeeded. PP_FileSystemType file_system_type_; // Set to true when the file has been successfully opened. bool file_open_; std::deque callbacks_; OperationType pending_op_; DISALLOW_COPY_AND_ASSIGN(PPB_FileIO_Shared); }; } // namespace ppapi #endif // PPAPI_SHARED_IMPL_PPB_FILE_IO_SHARED_H_