Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(224)

Unified Diff: content/child/indexed_db/webidbdatabase_impl.cc

Issue 2062203004: IDBObserver: Lifetime Management: Adding Observer (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Post dmurph review Created 4 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/child/indexed_db/webidbdatabase_impl.cc
diff --git a/content/child/indexed_db/webidbdatabase_impl.cc b/content/child/indexed_db/webidbdatabase_impl.cc
index fedb0e7333974ecdce6127249739b0b4ea4ccdae..b5d29363965a8c6dd2673511234a486f58f9db0b 100644
--- a/content/child/indexed_db/webidbdatabase_impl.cc
+++ b/content/child/indexed_db/webidbdatabase_impl.cc
@@ -19,6 +19,7 @@
#include "third_party/WebKit/public/platform/WebVector.h"
#include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBKeyPath.h"
#include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBMetadata.h"
+#include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBObserver.h"
using blink::WebBlobInfo;
using blink::WebIDBCallbacks;
@@ -29,6 +30,7 @@ using blink::WebIDBMetadata;
using blink::WebIDBKey;
using blink::WebIDBKeyPath;
using blink::WebIDBKeyRange;
+using blink::WebIDBObserver;
using blink::WebString;
using blink::WebVector;
@@ -90,6 +92,7 @@ void WebIDBDatabaseImpl::createTransaction(
void WebIDBDatabaseImpl::close() {
IndexedDBDispatcher* dispatcher =
IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
+ dispatcher->RemoveIDBObservers(observer_ids_);
dispatcher->RequestIDBDatabaseClose(ipc_database_id_,
ipc_database_callbacks_id_);
}
@@ -100,6 +103,33 @@ void WebIDBDatabaseImpl::versionChangeIgnored() {
dispatcher->NotifyIDBDatabaseVersionChangeIgnored(ipc_database_id_);
}
+int32_t WebIDBDatabaseImpl::addObserver(blink::WebIDBObserver* observer_ptr,
+ long long transaction_id) {
+ IndexedDBDispatcher* dispatcher =
+ IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
+ std::unique_ptr<WebIDBObserver> observer(observer_ptr);
+
+ int32_t observer_id = dispatcher->AddIDBObserver(
+ ipc_database_id_, transaction_id, observer.release());
+ observer_ids_.insert(observer_id);
+ return observer_id;
+}
+
+bool WebIDBDatabaseImpl::containsObserverId(int32_t id) {
+ return observer_ids_.find(id) != observer_ids_.end();
Marijn Kruisselbrink 2016/06/28 18:58:31 nit: you could write this as ContainsKey(observer_
palakj1 2016/06/29 23:02:41 Done.
+}
+
+void WebIDBDatabaseImpl::removeObservers(
+ const std::vector<int32_t>& observer_ids_to_remove) {
+ for (int32_t id : observer_ids_to_remove)
+ observer_ids_.erase(id);
+
+ IndexedDBDispatcher* dispatcher =
+ IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
+ dispatcher->RemoveIDBObserversFromDatabase(ipc_database_id_,
+ observer_ids_to_remove);
+}
+
void WebIDBDatabaseImpl::get(long long transaction_id,
long long object_store_id,
long long index_id,

Powered by Google App Engine
This is Rietveld 408576698