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

Side by Side 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: Observer moved to connection 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "content/child/indexed_db/webidbdatabase_impl.h" 5 #include "content/child/indexed_db/webidbdatabase_impl.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <string> 9 #include <string>
10 #include <vector> 10 #include <vector>
11 11
12 #include "content/child/indexed_db/indexed_db_dispatcher.h" 12 #include "content/child/indexed_db/indexed_db_dispatcher.h"
13 #include "content/child/indexed_db/indexed_db_key_builders.h" 13 #include "content/child/indexed_db/indexed_db_key_builders.h"
14 #include "content/child/thread_safe_sender.h" 14 #include "content/child/thread_safe_sender.h"
15 #include "content/child/worker_thread_registry.h" 15 #include "content/child/worker_thread_registry.h"
16 #include "content/common/indexed_db/indexed_db_messages.h" 16 #include "content/common/indexed_db/indexed_db_messages.h"
17 #include "third_party/WebKit/public/platform/WebBlobInfo.h" 17 #include "third_party/WebKit/public/platform/WebBlobInfo.h"
18 #include "third_party/WebKit/public/platform/WebString.h" 18 #include "third_party/WebKit/public/platform/WebString.h"
19 #include "third_party/WebKit/public/platform/WebVector.h" 19 #include "third_party/WebKit/public/platform/WebVector.h"
20 #include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBKeyPath.h" 20 #include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBKeyPath.h"
21 #include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBMetadata.h" 21 #include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBMetadata.h"
22 // #include "third_party/WebKit/Source/modules/indexeddb/IDBObserver.h"
22 23
24 using blink::IDBObserver;
23 using blink::WebBlobInfo; 25 using blink::WebBlobInfo;
24 using blink::WebIDBCallbacks; 26 using blink::WebIDBCallbacks;
25 using blink::WebIDBCursor; 27 using blink::WebIDBCursor;
26 using blink::WebIDBDatabase; 28 using blink::WebIDBDatabase;
27 using blink::WebIDBDatabaseCallbacks; 29 using blink::WebIDBDatabaseCallbacks;
28 using blink::WebIDBMetadata; 30 using blink::WebIDBMetadata;
29 using blink::WebIDBKey; 31 using blink::WebIDBKey;
30 using blink::WebIDBKeyPath; 32 using blink::WebIDBKeyPath;
31 using blink::WebIDBKeyRange; 33 using blink::WebIDBKeyRange;
34 using blink::WebIDBObserver;
32 using blink::WebString; 35 using blink::WebString;
33 using blink::WebVector; 36 using blink::WebVector;
34 37
35 namespace content { 38 namespace content {
36 39
37 WebIDBDatabaseImpl::WebIDBDatabaseImpl(int32_t ipc_database_id, 40 WebIDBDatabaseImpl::WebIDBDatabaseImpl(int32_t ipc_database_id,
38 int32_t ipc_database_callbacks_id, 41 int32_t ipc_database_callbacks_id,
39 ThreadSafeSender* thread_safe_sender) 42 ThreadSafeSender* thread_safe_sender)
40 : ipc_database_id_(ipc_database_id), 43 : ipc_database_id_(ipc_database_id),
41 ipc_database_callbacks_id_(ipc_database_callbacks_id), 44 ipc_database_callbacks_id_(ipc_database_callbacks_id),
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
83 blink::WebIDBTransactionMode mode) { 86 blink::WebIDBTransactionMode mode) {
84 IndexedDBDispatcher* dispatcher = 87 IndexedDBDispatcher* dispatcher =
85 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get()); 88 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
86 dispatcher->RequestIDBDatabaseCreateTransaction( 89 dispatcher->RequestIDBDatabaseCreateTransaction(
87 ipc_database_id_, transaction_id, callbacks, object_store_ids, mode); 90 ipc_database_id_, transaction_id, callbacks, object_store_ids, mode);
88 } 91 }
89 92
90 void WebIDBDatabaseImpl::close() { 93 void WebIDBDatabaseImpl::close() {
91 IndexedDBDispatcher* dispatcher = 94 IndexedDBDispatcher* dispatcher =
92 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get()); 95 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
96 // TODO(palakj): Can pass observers_id along with RequestIDBDatabaseClose.
dmurph 2016/06/22 01:09:50 Yes, you could do that also.
palakj1 2016/06/23 20:56:30 Would you prefer that over the current implementat
97 if (!observers_id_.empty()) {
98 dispatcher->ClearIDBObserver(observers_id_);
99 observers_id_.clear(); // Do I need to do this?
dmurph 2016/06/22 01:09:50 sure.
100 }
93 dispatcher->RequestIDBDatabaseClose(ipc_database_id_, 101 dispatcher->RequestIDBDatabaseClose(ipc_database_id_,
94 ipc_database_callbacks_id_); 102 ipc_database_callbacks_id_);
95 } 103 }
96 104
97 void WebIDBDatabaseImpl::versionChangeIgnored() { 105 void WebIDBDatabaseImpl::versionChangeIgnored() {
98 IndexedDBDispatcher* dispatcher = 106 IndexedDBDispatcher* dispatcher =
99 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get()); 107 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
100 dispatcher->NotifyIDBDatabaseVersionChangeIgnored(ipc_database_id_); 108 dispatcher->NotifyIDBDatabaseVersionChangeIgnored(ipc_database_id_);
101 } 109 }
102 110
111 void WebIDBDatabaseImpl::observe(WebIDBObserver* observer,
112 long long transaction_id) {
113 IndexedDBDispatcher* dispatcher =
114 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
115 int32_t observer_id =
116 dispatcher->AddIDBObserver(ipc_database_id_, transaction_id, observer);
117 observers_id_.push_back(observer_id);
118 }
119
120 void WebIDBDatabaseImpl::unobserve(blink::WebIDBObserver* observer) {
121 IndexedDBDispatcher* dispatcher =
122 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
123 std::vector<int32_t> observersToRemove =
dmurph 2016/06/22 01:09:50 no camelCase.
palakj1 2016/06/23 20:56:30 Changed.
124 dispatcher->RemoveIDBObservers(ipc_database_id_, observer, observers_id_);
125
126 for (uint32_t i = 0; i < observersToRemove.size(); i++) {
127 std::vector<int>::iterator position = std::find(
dmurph 2016/06/22 01:09:50 I think using observer_ids_.find would be simpler.
128 observers_id_.begin(), observers_id_.end(), observersToRemove[i]);
129 observers_id_.erase(position);
130 }
131 }
132
103 void WebIDBDatabaseImpl::get(long long transaction_id, 133 void WebIDBDatabaseImpl::get(long long transaction_id,
104 long long object_store_id, 134 long long object_store_id,
105 long long index_id, 135 long long index_id,
106 const WebIDBKeyRange& key_range, 136 const WebIDBKeyRange& key_range,
107 bool key_only, 137 bool key_only,
108 WebIDBCallbacks* callbacks) { 138 WebIDBCallbacks* callbacks) {
109 IndexedDBDispatcher* dispatcher = 139 IndexedDBDispatcher* dispatcher =
110 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get()); 140 IndexedDBDispatcher::ThreadSpecificInstance(thread_safe_sender_.get());
111 dispatcher->RequestIDBDatabaseGet(ipc_database_id_, 141 dispatcher->RequestIDBDatabaseGet(ipc_database_id_,
112 transaction_id, 142 transaction_id,
(...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after
291 321
292 void WebIDBDatabaseImpl::ackReceivedBlobs(const WebVector<WebString>& uuids) { 322 void WebIDBDatabaseImpl::ackReceivedBlobs(const WebVector<WebString>& uuids) {
293 DCHECK(uuids.size()); 323 DCHECK(uuids.size());
294 std::vector<std::string> param(uuids.size()); 324 std::vector<std::string> param(uuids.size());
295 for (size_t i = 0; i < uuids.size(); ++i) 325 for (size_t i = 0; i < uuids.size(); ++i)
296 param[i] = uuids[i].latin1().data(); 326 param[i] = uuids[i].latin1().data();
297 thread_safe_sender_->Send(new IndexedDBHostMsg_AckReceivedBlobs(param)); 327 thread_safe_sender_->Send(new IndexedDBHostMsg_AckReceivedBlobs(param));
298 } 328 }
299 329
300 } // namespace content 330 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698