Index: content/browser/indexed_db/indexed_db_database_callbacks.cc |
diff --git a/content/browser/indexed_db/indexed_db_database_callbacks.cc b/content/browser/indexed_db/indexed_db_database_callbacks.cc |
index ab09e9074deda5ce5b92e1d4084bb428b06468af..a7e98c91a9838dea6e7e61eb83ec9d709a184e0e 100644 |
--- a/content/browser/indexed_db/indexed_db_database_callbacks.cc |
+++ b/content/browser/indexed_db/indexed_db_database_callbacks.cc |
@@ -9,25 +9,47 @@ |
#include "content/browser/indexed_db/indexed_db_observer_changes.h" |
#include "content/common/indexed_db/indexed_db_messages.h" |
+using ::indexed_db::mojom::DatabaseCallbacksAssociatedPtrInfo; |
+ |
namespace content { |
+class IndexedDBDatabaseCallbacks::IOThreadHelper { |
+ public: |
+ IOThreadHelper(DatabaseCallbacksAssociatedPtrInfo callbacks_info); |
+ ~IOThreadHelper(); |
+ |
+ void SendForcedClose(); |
+ void SendVersionChange(int64_t old_version, int64_t new_version); |
+ void SendAbort(int64_t transaction_id, const IndexedDBDatabaseError& error); |
+ void SendComplete(int64_t transaction_id); |
+ |
+ private: |
+ ::indexed_db::mojom::DatabaseCallbacksAssociatedPtr callbacks_; |
+}; |
+ |
IndexedDBDatabaseCallbacks::IndexedDBDatabaseCallbacks( |
- IndexedDBDispatcherHost* dispatcher_host, |
- int ipc_thread_id, |
- int ipc_database_callbacks_id) |
- : dispatcher_host_(dispatcher_host), |
+ scoped_refptr<IndexedDBDispatcherHost> dispatcher_host, |
+ int32_t ipc_thread_id, |
+ DatabaseCallbacksAssociatedPtrInfo callbacks_info) |
+ : dispatcher_host_(std::move(dispatcher_host)), |
ipc_thread_id_(ipc_thread_id), |
- ipc_database_callbacks_id_(ipc_database_callbacks_id) {} |
+ helper_(nullptr) { |
+ if (callbacks_info.is_valid()) |
+ helper_ = new IOThreadHelper(std::move(callbacks_info)); |
+} |
-IndexedDBDatabaseCallbacks::~IndexedDBDatabaseCallbacks() {} |
+IndexedDBDatabaseCallbacks::~IndexedDBDatabaseCallbacks() { |
+ if (helper_) |
+ BrowserThread::DeleteSoon(BrowserThread::IO, FROM_HERE, helper_); |
+} |
void IndexedDBDatabaseCallbacks::OnForcedClose() { |
if (!dispatcher_host_.get()) |
return; |
- dispatcher_host_->Send(new IndexedDBMsg_DatabaseCallbacksForcedClose( |
- ipc_thread_id_, ipc_database_callbacks_id_)); |
- |
+ BrowserThread::PostTask( |
+ BrowserThread::IO, FROM_HERE, |
+ base::Bind(&IOThreadHelper::SendForcedClose, base::Unretained(helper_))); |
dispatcher_host_ = NULL; |
} |
@@ -36,8 +58,10 @@ void IndexedDBDatabaseCallbacks::OnVersionChange(int64_t old_version, |
if (!dispatcher_host_.get()) |
return; |
- dispatcher_host_->Send(new IndexedDBMsg_DatabaseCallbacksVersionChange( |
- ipc_thread_id_, ipc_database_callbacks_id_, old_version, new_version)); |
+ BrowserThread::PostTask( |
+ BrowserThread::IO, FROM_HERE, |
+ base::Bind(&IOThreadHelper::SendVersionChange, base::Unretained(helper_), |
+ old_version, new_version)); |
} |
void IndexedDBDatabaseCallbacks::OnAbort(int64_t host_transaction_id, |
@@ -46,12 +70,11 @@ void IndexedDBDatabaseCallbacks::OnAbort(int64_t host_transaction_id, |
return; |
dispatcher_host_->FinishTransaction(host_transaction_id, false); |
- dispatcher_host_->Send(new IndexedDBMsg_DatabaseCallbacksAbort( |
- ipc_thread_id_, |
- ipc_database_callbacks_id_, |
- dispatcher_host_->RendererTransactionId(host_transaction_id), |
- error.code(), |
- error.message())); |
+ BrowserThread::PostTask( |
+ BrowserThread::IO, FROM_HERE, |
+ base::Bind(&IOThreadHelper::SendAbort, base::Unretained(helper_), |
+ dispatcher_host_->RendererTransactionId(host_transaction_id), |
+ error)); |
} |
void IndexedDBDatabaseCallbacks::OnComplete(int64_t host_transaction_id) { |
@@ -59,10 +82,10 @@ void IndexedDBDatabaseCallbacks::OnComplete(int64_t host_transaction_id) { |
return; |
dispatcher_host_->FinishTransaction(host_transaction_id, true); |
- dispatcher_host_->Send(new IndexedDBMsg_DatabaseCallbacksComplete( |
- ipc_thread_id_, |
- ipc_database_callbacks_id_, |
- dispatcher_host_->RendererTransactionId(host_transaction_id))); |
+ BrowserThread::PostTask( |
+ BrowserThread::IO, FROM_HERE, |
+ base::Bind(&IOThreadHelper::SendComplete, base::Unretained(helper_), |
+ dispatcher_host_->RendererTransactionId(host_transaction_id))); |
} |
void IndexedDBDatabaseCallbacks::OnDatabaseChange( |
@@ -73,4 +96,32 @@ void IndexedDBDatabaseCallbacks::OnDatabaseChange( |
IndexedDBDispatcherHost::ConvertObserverChanges(std::move(changes)))); |
} |
+IndexedDBDatabaseCallbacks::IOThreadHelper::IOThreadHelper( |
+ DatabaseCallbacksAssociatedPtrInfo callbacks_info) { |
+ callbacks_.Bind(std::move(callbacks_info)); |
+} |
+ |
+IndexedDBDatabaseCallbacks::IOThreadHelper::~IOThreadHelper() {} |
+ |
+void IndexedDBDatabaseCallbacks::IOThreadHelper::SendForcedClose() { |
+ callbacks_->ForcedClose(); |
+} |
+ |
+void IndexedDBDatabaseCallbacks::IOThreadHelper::SendVersionChange( |
+ int64_t old_version, |
+ int64_t new_version) { |
+ callbacks_->VersionChange(old_version, new_version); |
+} |
+ |
+void IndexedDBDatabaseCallbacks::IOThreadHelper::SendAbort( |
+ int64_t transaction_id, |
+ const IndexedDBDatabaseError& error) { |
+ callbacks_->Abort(transaction_id, error.code(), error.message()); |
+} |
+ |
+void IndexedDBDatabaseCallbacks::IOThreadHelper::SendComplete( |
+ int64_t transaction_id) { |
+ callbacks_->Complete(transaction_id); |
+} |
+ |
} // namespace content |