| OLD | NEW |
| 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" |
| (...skipping 208 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 219 // re-entrantly as that may renter the coordinator. | 219 // re-entrantly as that may renter the coordinator. |
| 220 base::ThreadTaskRunnerHandle::Get()->PostTask( | 220 base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 221 FROM_HERE, base::Bind(&CommitUnused, ptr_factory_.GetWeakPtr())); | 221 FROM_HERE, base::Bind(&CommitUnused, ptr_factory_.GetWeakPtr())); |
| 222 } | 222 } |
| 223 return; | 223 return; |
| 224 } | 224 } |
| 225 | 225 |
| 226 RunTasksIfStarted(); | 226 RunTasksIfStarted(); |
| 227 } | 227 } |
| 228 | 228 |
| 229 void IndexedDBTransaction::GrabSnapshotThenStart() { |
| 230 DCHECK(!backing_store_transaction_begun_); |
| 231 transaction_->Begin(); |
| 232 backing_store_transaction_begun_ = true; |
| 233 Start(); |
| 234 } |
| 235 |
| 229 class BlobWriteCallbackImpl : public IndexedDBBackingStore::BlobWriteCallback { | 236 class BlobWriteCallbackImpl : public IndexedDBBackingStore::BlobWriteCallback { |
| 230 public: | 237 public: |
| 231 explicit BlobWriteCallbackImpl( | 238 explicit BlobWriteCallbackImpl( |
| 232 base::WeakPtr<IndexedDBTransaction> transaction) | 239 base::WeakPtr<IndexedDBTransaction> transaction) |
| 233 : transaction_(std::move(transaction)) {} | 240 : transaction_(std::move(transaction)) {} |
| 234 | 241 |
| 235 leveldb::Status Run(IndexedDBBackingStore::BlobWriteResult result) override { | 242 leveldb::Status Run(IndexedDBBackingStore::BlobWriteResult result) override { |
| 236 if (!transaction_) | 243 if (!transaction_) |
| 237 return leveldb::Status::OK(); | 244 return leveldb::Status::OK(); |
| 238 return transaction_->BlobWriteComplete(result); | 245 return transaction_->BlobWriteComplete(result); |
| (...skipping 117 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 356 if (!connection_changes_map_.empty()) { | 363 if (!connection_changes_map_.empty()) { |
| 357 database_->SendObservations(std::move(connection_changes_map_)); | 364 database_->SendObservations(std::move(connection_changes_map_)); |
| 358 connection_changes_map_.clear(); | 365 connection_changes_map_.clear(); |
| 359 } | 366 } |
| 360 { | 367 { |
| 361 IDB_TRACE1( | 368 IDB_TRACE1( |
| 362 "IndexedDBTransaction::CommitPhaseTwo.TransactionCompleteCallbacks", | 369 "IndexedDBTransaction::CommitPhaseTwo.TransactionCompleteCallbacks", |
| 363 "txn.id", id()); | 370 "txn.id", id()); |
| 364 callbacks_->OnComplete(*this); | 371 callbacks_->OnComplete(*this); |
| 365 } | 372 } |
| 366 if (!pending_observers_.empty() && connection_) { | 373 if (!pending_observers_.empty() && connection_) |
| 367 connection_->ActivatePendingObservers(std::move(pending_observers_)); | 374 connection_->ActivatePendingObservers(std::move(pending_observers_)); |
| 368 pending_observers_.clear(); | |
| 369 } | |
| 370 | 375 |
| 371 database_->TransactionFinished(this, true); | 376 database_->TransactionFinished(this, true); |
| 372 // RemoveTransaction will delete |this|. | 377 // RemoveTransaction will delete |this|. |
| 373 connection_->RemoveTransaction(id_); | 378 connection_->RemoveTransaction(id_); |
| 374 return s; | 379 return s; |
| 375 } else { | 380 } else { |
| 376 while (!abort_task_stack_.empty()) | 381 while (!abort_task_stack_.empty()) |
| 377 abort_task_stack_.pop().Run(); | 382 abort_task_stack_.pop().Run(); |
| 378 | 383 |
| 379 IndexedDBDatabaseError error; | 384 IndexedDBDatabaseError error; |
| (...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 474 void IndexedDBTransaction::CloseOpenCursors() { | 479 void IndexedDBTransaction::CloseOpenCursors() { |
| 475 IDB_TRACE1("IndexedDBTransaction::CloseOpenCursors", "txn.id", id()); | 480 IDB_TRACE1("IndexedDBTransaction::CloseOpenCursors", "txn.id", id()); |
| 476 for (auto* cursor : open_cursors_) | 481 for (auto* cursor : open_cursors_) |
| 477 cursor->Close(); | 482 cursor->Close(); |
| 478 open_cursors_.clear(); | 483 open_cursors_.clear(); |
| 479 } | 484 } |
| 480 | 485 |
| 481 void IndexedDBTransaction::AddPendingObserver( | 486 void IndexedDBTransaction::AddPendingObserver( |
| 482 int32_t observer_id, | 487 int32_t observer_id, |
| 483 const IndexedDBObserver::Options& options) { | 488 const IndexedDBObserver::Options& options) { |
| 489 DCHECK_NE(mode(), blink::WebIDBTransactionModeVersionChange); |
| 484 pending_observers_.push_back(base::MakeUnique<IndexedDBObserver>( | 490 pending_observers_.push_back(base::MakeUnique<IndexedDBObserver>( |
| 485 observer_id, object_store_ids_, options)); | 491 observer_id, object_store_ids_, options)); |
| 486 } | 492 } |
| 487 | 493 |
| 488 void IndexedDBTransaction::RemovePendingObservers( | 494 void IndexedDBTransaction::RemovePendingObservers( |
| 489 const std::vector<int32_t>& pending_observer_ids) { | 495 const std::vector<int32_t>& pending_observer_ids) { |
| 490 const auto& it = std::remove_if( | 496 const auto& it = std::remove_if( |
| 491 pending_observers_.begin(), pending_observers_.end(), | 497 pending_observers_.begin(), pending_observers_.end(), |
| 492 [&pending_observer_ids](const std::unique_ptr<IndexedDBObserver>& o) { | 498 [&pending_observer_ids](const std::unique_ptr<IndexedDBObserver>& o) { |
| 493 return base::ContainsValue(pending_observer_ids, o->id()); | 499 return base::ContainsValue(pending_observer_ids, o->id()); |
| 494 }); | 500 }); |
| 495 if (it != pending_observers_.end()) | 501 if (it != pending_observers_.end()) |
| 496 pending_observers_.erase(it, pending_observers_.end()); | 502 pending_observers_.erase(it, pending_observers_.end()); |
| 497 } | 503 } |
| 498 | 504 |
| 499 void IndexedDBTransaction::AddObservation( | 505 void IndexedDBTransaction::AddObservation( |
| 500 int32_t connection_id, | 506 int32_t connection_id, |
| 501 ::indexed_db::mojom::ObservationPtr observation) { | 507 ::indexed_db::mojom::ObservationPtr observation) { |
| 502 auto it = connection_changes_map_.find(connection_id); | 508 auto it = connection_changes_map_.find(connection_id); |
| 503 if (it == connection_changes_map_.end()) { | 509 if (it == connection_changes_map_.end()) { |
| 504 it = connection_changes_map_ | 510 it = connection_changes_map_ |
| 505 .insert(std::make_pair( | 511 .insert(std::make_pair( |
| 506 connection_id, ::indexed_db::mojom::ObserverChanges::New())) | 512 connection_id, ::indexed_db::mojom::ObserverChanges::New())) |
| 507 .first; | 513 .first; |
| 508 } | 514 } |
| 509 it->second->observations.push_back(std::move(observation)); | 515 it->second->observations.push_back(std::move(observation)); |
| 510 } | 516 } |
| 511 | 517 |
| 512 void IndexedDBTransaction::RecordObserverForLastObservation( | 518 ::indexed_db::mojom::ObserverChangesPtr* |
| 513 int32_t connection_id, | 519 IndexedDBTransaction::GetPendingChangesForConnection(int32_t connection_id) { |
| 514 int32_t observer_id) { | |
| 515 auto it = connection_changes_map_.find(connection_id); | 520 auto it = connection_changes_map_.find(connection_id); |
| 516 DCHECK(it != connection_changes_map_.end()); | 521 if (it != connection_changes_map_.end()) |
| 517 it->second->observation_index_map[observer_id].push_back( | 522 return &it->second; |
| 518 it->second->observations.size() - 1); | 523 return nullptr; |
| 519 } | 524 } |
| 520 | 525 |
| 521 } // namespace content | 526 } // namespace content |
| OLD | NEW |