diff options
author | dmichael@chromium.org <dmichael@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-06-23 14:27:42 +0000 |
---|---|---|
committer | dmichael@chromium.org <dmichael@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-06-23 14:27:42 +0000 |
commit | aed965375dec978e7feb8722b1b94250a2a6e039 (patch) | |
tree | 9f8ccdf7a3902fa1db54e0c036f7cb9ca96775fb /ppapi/thunk/ppb_file_io_api.h | |
parent | 94bd0a2e94c1f07ccc0236a95e57a2e16b94038a (diff) | |
download | chromium_src-aed965375dec978e7feb8722b1b94250a2a6e039.zip chromium_src-aed965375dec978e7feb8722b1b94250a2a6e039.tar.gz chromium_src-aed965375dec978e7feb8722b1b94250a2a6e039.tar.bz2 |
PPAPI: Make blocking completion callbacks work.
This also makes scoped_refptr<TrackedCallback> the "new" way to pass completion callbacks in an API. This allows the Enter object to handle checking for blocking callbacks on the main thread to report error, and blocking if on the background thread. This way, interfaces don't have to write any special cases for blocking callbacks.
When built with enable_pepper_threading=1 locally, URLLoader tests all pass for blocking completion callbacks. I haven't updated all tests yet.
BUG=92909
TEST=
Review URL: https://chromiumcodereview.appspot.com/10081020
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@143806 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'ppapi/thunk/ppb_file_io_api.h')
-rw-r--r-- | ppapi/thunk/ppb_file_io_api.h | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/ppapi/thunk/ppb_file_io_api.h b/ppapi/thunk/ppb_file_io_api.h index f49e809..1e6e3ad 100644 --- a/ppapi/thunk/ppb_file_io_api.h +++ b/ppapi/thunk/ppb_file_io_api.h @@ -1,14 +1,18 @@ -// Copyright (c) 2011 The Chromium Authors. All rights reserved. +// 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 PPAPI_THUNK_PPB_FILE_IO_API_H_ #define PPAPI_THUNK_PPB_FILE_IO_API_H_ +#include "base/memory/ref_counted.h" #include "ppapi/c/ppb_file_io.h" #include "ppapi/thunk/ppapi_thunk_export.h" namespace ppapi { + +class TrackedCallback; + namespace thunk { class PPAPI_THUNK_EXPORT PPB_FileIO_API { @@ -17,32 +21,32 @@ class PPAPI_THUNK_EXPORT PPB_FileIO_API { virtual int32_t Open(PP_Resource file_ref, int32_t open_flags, - PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; virtual int32_t Query(PP_FileInfo* info, - PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; virtual int32_t Touch(PP_Time last_access_time, PP_Time last_modified_time, - PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; virtual int32_t Read(int64_t offset, char* buffer, int32_t bytes_to_read, - PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; virtual int32_t Write(int64_t offset, const char* buffer, int32_t bytes_to_write, - PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; virtual int32_t SetLength(int64_t length, - PP_CompletionCallback callback) = 0; - virtual int32_t Flush(PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; + virtual int32_t Flush(scoped_refptr<TrackedCallback> callback) = 0; virtual void Close() = 0; // Trusted API. virtual int32_t GetOSFileDescriptor() = 0; virtual int32_t WillWrite(int64_t offset, int32_t bytes_to_write, - PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; virtual int32_t WillSetLength(int64_t length, - PP_CompletionCallback callback) = 0; + scoped_refptr<TrackedCallback> callback) = 0; }; } // namespace thunk |