summaryrefslogtreecommitdiffstats
path: root/chrome/browser/in_process_webkit/webkit_context.cc
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/in_process_webkit/webkit_context.cc')
-rw-r--r--chrome/browser/in_process_webkit/webkit_context.cc27
1 files changed, 10 insertions, 17 deletions
diff --git a/chrome/browser/in_process_webkit/webkit_context.cc b/chrome/browser/in_process_webkit/webkit_context.cc
index ae647d6..0768284 100644
--- a/chrome/browser/in_process_webkit/webkit_context.cc
+++ b/chrome/browser/in_process_webkit/webkit_context.cc
@@ -9,24 +9,17 @@
WebKitContext::WebKitContext(const FilePath& data_path, bool is_incognito)
: data_path_(data_path),
- is_incognito_(is_incognito) {
+ is_incognito_(is_incognito),
+ ALLOW_THIS_IN_INITIALIZER_LIST(
+ dom_storage_context_(new DOMStorageContext(this))) {
}
WebKitContext::~WebKitContext() {
- // If a dom storage context was ever created, we need to destroy it on the
- // WebKit thread. Luckily we're guaranteed that the WebKit thread is still
- // alive since the ResourceDispatcherHost (which owns the WebKit thread) goes
- // away after all the ResourceMessageFilters and the profiles (i.e. all the
- // objects with a reference to us).
- if (dom_storage_context_.get()) {
- MessageLoop* loop = ChromeThread::GetMessageLoop(ChromeThread::WEBKIT);
- loop->DeleteSoon(FROM_HERE, dom_storage_context_.release());
- }
-}
-
-DOMStorageContext* WebKitContext::GetDOMStorageContext() {
- DCHECK(ChromeThread::CurrentlyOn(ChromeThread::WEBKIT));
- if (!dom_storage_context_.get())
- dom_storage_context_.reset(new DOMStorageContext(this));
- return dom_storage_context_.get();
+ // If the WebKit thread was ever spun up, delete the object there. If we're
+ // on the IO thread, this is safe because the WebKit thread goes away after
+ // the IO. If we're on the UI thread, we're safe because the UI thread kills
+ // the WebKit thread.
+ MessageLoop* webkit_loop = ChromeThread::GetMessageLoop(ChromeThread::WEBKIT);
+ if (webkit_loop)
+ webkit_loop->DeleteSoon(FROM_HERE, dom_storage_context_.release());
}