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

Side by Side Diff: chrome/renderer/renderer_web_database_observer.cc

Issue 573044: Merge 37594 - Wait for the DB thread to finish posting tasks to the main thre... (Closed) Base URL: svn://svn.chromium.org/chrome/branches/307/src/
Patch Set: Created 10 years, 10 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 | Annotate | Revision Log
« no previous file with comments | « chrome/renderer/renderer_web_database_observer.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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 "chrome/renderer/renderer_web_database_observer.h" 5 #include "chrome/renderer/renderer_web_database_observer.h"
6 6
7 #include "base/auto_reset.h"
8 #include "base/message_loop.h"
9 #include "base/string16.h"
7 #include "chrome/common/render_messages.h" 10 #include "chrome/common/render_messages.h"
8 #include "third_party/WebKit/WebKit/chromium/public/WebDatabase.h" 11 #include "third_party/WebKit/WebKit/chromium/public/WebDatabase.h"
9 12
10 RendererWebDatabaseObserver::RendererWebDatabaseObserver( 13 RendererWebDatabaseObserver::RendererWebDatabaseObserver(
11 IPC::Message::Sender* sender) 14 IPC::Message::Sender* sender)
12 : sender_(sender) { 15 : sender_(sender),
16 waiting_for_dbs_to_close_(false) {
13 } 17 }
14 18
15 void RendererWebDatabaseObserver::databaseOpened( 19 void RendererWebDatabaseObserver::databaseOpened(
16 const WebKit::WebDatabase& database) { 20 const WebKit::WebDatabase& database) {
21 string16 origin_identifier = database.securityOrigin().databaseIdentifier();
22 string16 database_name = database.name();
17 sender_->Send(new ViewHostMsg_DatabaseOpened( 23 sender_->Send(new ViewHostMsg_DatabaseOpened(
18 database.securityOrigin().databaseIdentifier(), database.name(), 24 origin_identifier, database_name,
19 database.displayName(), database.estimatedSize())); 25 database.displayName(), database.estimatedSize()));
26 database_connections_.AddConnection(origin_identifier, database_name);
20 } 27 }
21 28
22 void RendererWebDatabaseObserver::databaseModified( 29 void RendererWebDatabaseObserver::databaseModified(
23 const WebKit::WebDatabase& database) { 30 const WebKit::WebDatabase& database) {
24 sender_->Send(new ViewHostMsg_DatabaseModified( 31 sender_->Send(new ViewHostMsg_DatabaseModified(
25 database.securityOrigin().databaseIdentifier(), database.name())); 32 database.securityOrigin().databaseIdentifier(), database.name()));
26 } 33 }
27 34
28 void RendererWebDatabaseObserver::databaseClosed( 35 void RendererWebDatabaseObserver::databaseClosed(
29 const WebKit::WebDatabase& database) { 36 const WebKit::WebDatabase& database) {
37 string16 origin_identifier = database.securityOrigin().databaseIdentifier();
38 string16 database_name = database.name();
30 sender_->Send(new ViewHostMsg_DatabaseClosed( 39 sender_->Send(new ViewHostMsg_DatabaseClosed(
31 database.securityOrigin().databaseIdentifier(), database.name())); 40 origin_identifier, database_name));
41 database_connections_.RemoveConnection(origin_identifier, database_name);
42 if (waiting_for_dbs_to_close_ && database_connections_.IsEmpty())
43 MessageLoop::current()->Quit();
32 } 44 }
45
46 void RendererWebDatabaseObserver::WaitForAllDatabasesToClose() {
47 if (!database_connections_.IsEmpty()) {
48 AutoReset waiting_for_dbs_auto_reset(&waiting_for_dbs_to_close_, true);
49 MessageLoop::ScopedNestableTaskAllower nestable(MessageLoop::current());
50 MessageLoop::current()->Run();
51 }
52 }
OLDNEW
« no previous file with comments | « chrome/renderer/renderer_web_database_observer.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698