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

Unified Diff: chrome/browser/in_process_webkit/indexed_db_dispatcher_host.h

Issue 5680007: Make IndexedDBDispatcherHost be a message filter and move its messages into a... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 10 years 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: chrome/browser/in_process_webkit/indexed_db_dispatcher_host.h
===================================================================
--- chrome/browser/in_process_webkit/indexed_db_dispatcher_host.h (revision 68877)
+++ chrome/browser/in_process_webkit/indexed_db_dispatcher_host.h (working copy)
@@ -8,21 +8,19 @@
#include "base/basictypes.h"
#include "base/id_map.h"
-#include "base/process.h"
-#include "base/ref_counted.h"
+#include "chrome/browser/browser_message_filter.h"
#include "chrome/browser/in_process_webkit/webkit_context.h"
-#include "ipc/ipc_message.h"
class HostContentSettingsMap;
class IndexedDBKey;
class Profile;
class SerializedScriptValue;
-struct ViewHostMsg_IDBDatabaseCreateObjectStore_Params;
-struct ViewHostMsg_IDBFactoryOpen_Params;
-struct ViewHostMsg_IDBIndexOpenCursor_Params;
-struct ViewHostMsg_IDBObjectStoreCreateIndex_Params;
-struct ViewHostMsg_IDBObjectStoreOpenCursor_Params;
-struct ViewHostMsg_IDBObjectStorePut_Params;
+struct IndexedDBHostMsg_DatabaseCreateObjectStore_Params;
+struct IndexedDBHostMsg_FactoryOpen_Params;
+struct IndexedDBHostMsg_IndexOpenCursor_Params;
+struct IndexedDBHostMsg_ObjectStoreCreateIndex_Params;
+struct IndexedDBHostMsg_ObjectStoreOpenCursor_Params;
+struct IndexedDBHostMsg_ObjectStorePut_Params;
namespace WebKit {
class WebIDBCursor;
@@ -33,26 +31,18 @@
}
// Handles all IndexedDB related messages from a particular renderer process.
-class IndexedDBDispatcherHost
- : public base::RefCountedThreadSafe<IndexedDBDispatcherHost> {
+class IndexedDBDispatcherHost : public BrowserMessageFilter {
public:
// Only call the constructor from the UI thread.
- IndexedDBDispatcherHost(IPC::Message::Sender* sender, Profile* profile);
+ IndexedDBDispatcherHost(int process_id, Profile* profile);
- // Only call from ResourceMessageFilter on the IO thread.
- void Init(int process_id, base::ProcessHandle process_handle);
+ // BrowserMessageFilter implementation.
+ virtual void OnChannelClosing();
+ virtual void OverrideThreadForMessage(const IPC::Message& message,
+ BrowserThread::ID* thread);
+ virtual bool OnMessageReceived(const IPC::Message& message,
+ bool* message_was_ok);
- // Only call from ResourceMessageFilter on the IO thread. Calls self on the
- // WebKit thread in some cases.
- void Shutdown();
-
- // Only call from ResourceMessageFilter on the IO thread.
- bool OnMessageReceived(const IPC::Message& message);
-
- // Send a message to the renderer process associated with our sender_ via the
- // IO thread. May be called from any thread.
- void Send(IPC::Message* message);
-
// A shortcut for accessing our context.
IndexedDBContext* Context() {
return webkit_context_->indexed_db_context();
@@ -67,13 +57,11 @@
int32 Add(WebKit::WebIDBTransaction* idb_transaction);
private:
- friend class base::RefCountedThreadSafe<IndexedDBDispatcherHost>;
~IndexedDBDispatcherHost();
// Message processing. Most of the work is delegated to the dispatcher hosts
// below.
- void OnMessageReceivedWebKit(const IPC::Message& message);
- void OnIDBFactoryOpen(const ViewHostMsg_IDBFactoryOpen_Params& p);
+ void OnIDBFactoryOpen(const IndexedDBHostMsg_FactoryOpen_Params& p);
// Helper templates.
template <class ReturnType>
@@ -102,7 +90,7 @@
void OnVersion(int32 idb_database_id, IPC::Message* reply_msg);
void OnObjectStoreNames(int32 idb_database_id, IPC::Message* reply_msg);
void OnCreateObjectStore(
- const ViewHostMsg_IDBDatabaseCreateObjectStore_Params& params,
+ const IndexedDBHostMsg_DatabaseCreateObjectStore_Params& params,
IPC::Message* reply_msg);
void OnDeleteObjectStore(int32 idb_database_id,
const string16& name,
@@ -135,9 +123,9 @@
void OnKeyPath(int32 idb_index_id, IPC::Message* reply_msg);
void OnUnique(int32 idb_index_id, IPC::Message* reply_msg);
void OnOpenObjectCursor(
- const ViewHostMsg_IDBIndexOpenCursor_Params& params,
+ const IndexedDBHostMsg_IndexOpenCursor_Params& params,
IPC::Message* reply_msg);
- void OnOpenKeyCursor(const ViewHostMsg_IDBIndexOpenCursor_Params& params,
+ void OnOpenKeyCursor(const IndexedDBHostMsg_IndexOpenCursor_Params& params,
IPC::Message* reply_msg);
void OnGetObject(int idb_index_id,
int32 response_id,
@@ -171,7 +159,7 @@
const IndexedDBKey& key,
int32 transaction_id,
IPC::Message* reply_msg);
- void OnPut(const ViewHostMsg_IDBObjectStorePut_Params& params,
+ void OnPut(const IndexedDBHostMsg_ObjectStorePut_Params& params,
IPC::Message* reply_msg);
void OnDelete(int idb_object_store_id,
int32 response_id,
@@ -179,7 +167,7 @@
int32 transaction_id,
IPC::Message* reply_msg);
void OnCreateIndex(
- const ViewHostMsg_IDBObjectStoreCreateIndex_Params& params,
+ const IndexedDBHostMsg_ObjectStoreCreateIndex_Params& params,
IPC::Message* reply_msg);
void OnIndex(int32 idb_object_store_id,
const string16& name,
@@ -189,7 +177,7 @@
int32 transaction_id,
IPC::Message* reply_msg);
void OnOpenCursor(
- const ViewHostMsg_IDBObjectStoreOpenCursor_Params& params,
+ const IndexedDBHostMsg_ObjectStoreOpenCursor_Params& params,
IPC::Message* reply_msg);
void OnDestroyed(int32 idb_object_store_id);
@@ -247,9 +235,6 @@
MapType map_;
};
- // Only use on the IO thread.
- IPC::Message::Sender* sender_;
-
// Data shared between renderer processes with the same profile.
scoped_refptr<WebKitContext> webkit_context_;
@@ -263,10 +248,6 @@
scoped_ptr<CursorDispatcherHost> cursor_dispatcher_host_;
scoped_ptr<TransactionDispatcherHost> transaction_dispatcher_host_;
- // If we get a corrupt message from a renderer, we need to kill it using this
- // handle.
- base::ProcessHandle process_handle_;
-
// Used to dispatch messages to the correct view host.
int process_id_;

Powered by Google App Engine
This is Rietveld 408576698