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

Side by Side Diff: content/browser/indexed_db/indexed_db_transaction.cc

Issue 2125213002: [IndexedDB] Propogating changes to observers : Renderer (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@lifetime
Patch Set: Minor bugs fixed Created 4 years, 5 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 (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 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/browser/indexed_db/indexed_db_transaction.h" 5 #include "content/browser/indexed_db/indexed_db_transaction.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/location.h" 8 #include "base/location.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/memory/ptr_util.h" 10 #include "base/memory/ptr_util.h"
11 #include "base/single_thread_task_runner.h" 11 #include "base/single_thread_task_runner.h"
12 #include "base/stl_util.h" 12 #include "base/stl_util.h"
13 #include "base/strings/utf_string_conversions.h" 13 #include "base/strings/utf_string_conversions.h"
14 #include "base/threading/thread_task_runner_handle.h" 14 #include "base/threading/thread_task_runner_handle.h"
15 #include "content/browser/indexed_db/indexed_db_backing_store.h" 15 #include "content/browser/indexed_db/indexed_db_backing_store.h"
16 #include "content/browser/indexed_db/indexed_db_cursor.h" 16 #include "content/browser/indexed_db/indexed_db_cursor.h"
17 #include "content/browser/indexed_db/indexed_db_database.h" 17 #include "content/browser/indexed_db/indexed_db_database.h"
18 #include "content/browser/indexed_db/indexed_db_database_callbacks.h" 18 #include "content/browser/indexed_db/indexed_db_database_callbacks.h"
19 #include "content/browser/indexed_db/indexed_db_observation.h"
19 #include "content/browser/indexed_db/indexed_db_observer.h" 20 #include "content/browser/indexed_db/indexed_db_observer.h"
21 #include "content/browser/indexed_db/indexed_db_observer_changes.h"
20 #include "content/browser/indexed_db/indexed_db_tracing.h" 22 #include "content/browser/indexed_db/indexed_db_tracing.h"
21 #include "content/browser/indexed_db/indexed_db_transaction_coordinator.h" 23 #include "content/browser/indexed_db/indexed_db_transaction_coordinator.h"
22 #include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBDatabaseExc eption.h" 24 #include "third_party/WebKit/public/platform/modules/indexeddb/WebIDBDatabaseExc eption.h"
23 #include "third_party/leveldatabase/env_chromium.h" 25 #include "third_party/leveldatabase/env_chromium.h"
24 26
25 namespace content { 27 namespace content {
26 28
27 namespace { 29 namespace {
28 30
29 const int64_t kInactivityTimeoutPeriodSeconds = 60; 31 const int64_t kInactivityTimeoutPeriodSeconds = 60;
(...skipping 309 matching lines...) Expand 10 before | Expand all | Expand 10 after
339 // released, and order is critical. 341 // released, and order is critical.
340 CloseOpenCursors(); 342 CloseOpenCursors();
341 transaction_->Reset(); 343 transaction_->Reset();
342 344
343 // Transactions must also be marked as completed before the 345 // Transactions must also be marked as completed before the
344 // front-end is notified, as the transaction completion unblocks 346 // front-end is notified, as the transaction completion unblocks
345 // operations like closing connections. 347 // operations like closing connections.
346 database_->transaction_coordinator().DidFinishTransaction(this); 348 database_->transaction_coordinator().DidFinishTransaction(this);
347 349
348 if (committed) { 350 if (committed) {
349 // TODO (palakj) : Send Observations to observers
350 if (!pending_observers_.empty() && connection_)
351 connection_->ActivatePendingObservers(std::move(pending_observers_));
352 abort_task_stack_.clear(); 351 abort_task_stack_.clear();
352
353 // SendObservations must happen before Oncomplete is fired to align with the
jsbell 2016/07/14 20:08:13 nit: OnComplete Also, maybe: "happen" -> "be call
palakj1 2016/07/15 20:16:04 My bad. Corrected.
354 // spec.
355 if (!connection_changes_map_.empty()) {
356 database_->SendObservations(std::move(connection_changes_map_));
357 connection_changes_map_.clear();
358 }
353 { 359 {
354 IDB_TRACE1( 360 IDB_TRACE1(
355 "IndexedDBTransaction::CommitPhaseTwo.TransactionCompleteCallbacks", 361 "IndexedDBTransaction::CommitPhaseTwo.TransactionCompleteCallbacks",
356 "txn.id", id()); 362 "txn.id", id());
357 callbacks_->OnComplete(id_); 363 callbacks_->OnComplete(id_);
358 } 364 }
365 if (!pending_observers_.empty() && connection_) {
366 connection_->ActivatePendingObservers(std::move(pending_observers_));
367 pending_observers_.clear();
368 }
369
359 database_->TransactionFinished(this, true); 370 database_->TransactionFinished(this, true);
360 } else { 371 } else {
361 while (!abort_task_stack_.empty()) 372 while (!abort_task_stack_.empty())
362 abort_task_stack_.pop().Run(NULL); 373 abort_task_stack_.pop().Run(NULL);
363 374
364 IndexedDBDatabaseError error; 375 IndexedDBDatabaseError error;
365 if (leveldb_env::IndicatesDiskFull(s)) { 376 if (leveldb_env::IndicatesDiskFull(s)) {
366 error = IndexedDBDatabaseError( 377 error = IndexedDBDatabaseError(
367 blink::WebIDBDatabaseExceptionQuotaError, 378 blink::WebIDBDatabaseExceptionQuotaError,
368 "Encountered disk full while committing transaction."); 379 "Encountered disk full while committing transaction.");
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after
448 base::ASCIIToUTF16("Transaction timed out due to inactivity."))); 459 base::ASCIIToUTF16("Transaction timed out due to inactivity.")));
449 } 460 }
450 461
451 void IndexedDBTransaction::CloseOpenCursors() { 462 void IndexedDBTransaction::CloseOpenCursors() {
452 IDB_TRACE1("IndexedDBTransaction::CloseOpenCursors", "txn.id", id()); 463 IDB_TRACE1("IndexedDBTransaction::CloseOpenCursors", "txn.id", id());
453 for (auto* cursor : open_cursors_) 464 for (auto* cursor : open_cursors_)
454 cursor->Close(); 465 cursor->Close();
455 open_cursors_.clear(); 466 open_cursors_.clear();
456 } 467 }
457 468
458 void IndexedDBTransaction::AddPendingObserver(int32_t observer_id) { 469 void IndexedDBTransaction::AddPendingObserver(int32_t observer_id,
cmumford 2016/07/14 21:11:35 Nothing wrong here, but you need to fix all calls
palakj1 2016/07/15 20:16:04 Done. thanks for pointing that out.
459 pending_observers_.push_back( 470 bool includeTransaction,
460 base::WrapUnique(new IndexedDBObserver(observer_id))); 471 bool noRecords,
472 bool values) {
473 pending_observers_.push_back(base::WrapUnique(new IndexedDBObserver(
474 observer_id, object_store_ids_, includeTransaction, noRecords, values)));
461 } 475 }
462 476
463 void IndexedDBTransaction::RemovePendingObservers( 477 void IndexedDBTransaction::RemovePendingObservers(
464 const std::vector<int32_t>& pending_observer_ids) { 478 const std::vector<int32_t>& pending_observer_ids) {
465 const auto& it = std::remove_if( 479 const auto& it = std::remove_if(
466 pending_observers_.begin(), pending_observers_.end(), 480 pending_observers_.begin(), pending_observers_.end(),
467 [&pending_observer_ids](const std::unique_ptr<IndexedDBObserver>& o) { 481 [&pending_observer_ids](const std::unique_ptr<IndexedDBObserver>& o) {
468 return ContainsValue(pending_observer_ids, o->id()); 482 return ContainsValue(pending_observer_ids, o->id());
469 }); 483 });
470 if (it != pending_observers_.end()) 484 if (it != pending_observers_.end())
471 pending_observers_.erase(it, pending_observers_.end()); 485 pending_observers_.erase(it, pending_observers_.end());
472 } 486 }
473 487
488 void IndexedDBTransaction::AddObservation(
489 int32_t connection_id,
490 std::unique_ptr<IndexedDBObservation> observation) {
491 auto it = connection_changes_map_.find(connection_id);
492 if (it == connection_changes_map_.end()) {
493 it = connection_changes_map_
494 .insert(std::make_pair(
495 connection_id,
496 base::WrapUnique(new IndexedDBObserverChanges())))
497 .first;
498 }
499 it->second->AddObservation(std::move(observation));
500 }
501
502 void IndexedDBTransaction::RecordObserverForLastObservation(
503 int32_t connection_id,
504 int32_t observer_id) {
505 auto it = connection_changes_map_.find(connection_id);
506 DCHECK(it != connection_changes_map_.end());
507 it->second->RecordObserverForLastObservation(observer_id);
508 }
509
474 } // namespace content 510 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698