From 314c3e2d86a4595db7b1ab02b2acd4decf21d65f Mon Sep 17 00:00:00 2001 From: "jam@chromium.org" Date: Tue, 21 Feb 2012 03:57:42 +0000 Subject: Remove getters for HTML5 related objects from the ResourceContext interface. Half of them weren't used by chrome, so they can be hidden from chrome. The rest were accessed by chrome, but we don't need every embedder to store this data on their ResourceContext implementation. Instead have content associate the data itself to simplify the work for embedders. BUG=98716 Review URL: https://chromiumcodereview.appspot.com/9425026 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@122790 0039d316-1c4b-4281-b951-d872f2087c98 --- content/browser/resource_context_impl.cc | 92 ++++++++++++++++++++++++++++++++ 1 file changed, 92 insertions(+) create mode 100644 content/browser/resource_context_impl.cc (limited to 'content/browser/resource_context_impl.cc') diff --git a/content/browser/resource_context_impl.cc b/content/browser/resource_context_impl.cc new file mode 100644 index 0000000..d7cbeab --- /dev/null +++ b/content/browser/resource_context_impl.cc @@ -0,0 +1,92 @@ +// Copyright (c) 2012 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "content/browser/resource_context_impl.h" + +#include "content/browser/appcache/chrome_appcache_service.h" +#include "content/browser/chrome_blob_storage_context.h" +#include "content/browser/file_system/browser_file_system_helper.h" +#include "content/browser/in_process_webkit/webkit_context.h" +#include "content/public/browser/browser_context.h" +#include "content/public/browser/browser_thread.h" +#include "webkit/database/database_tracker.h" + +// Key names on ResourceContext. +static const char* kAppCacheServicKeyName = "content_appcache_service_tracker"; +static const char* kBlobStorageContextKeyName = "content_blob_storage_context"; +static const char* kDatabaseTrackerKeyName = "content_database_tracker"; +static const char* kFileSystemContextKeyName = "content_file_system_context"; +static const char* kWebKitContextKeyName = "content_webkit_context"; + +using appcache::AppCacheService; +using base::UserDataAdapter; +using content::BrowserThread; +using fileapi::FileSystemContext; +using webkit_blob::BlobStorageController; +using webkit_database::DatabaseTracker; + +namespace content { + +AppCacheService* ResourceContext::GetAppCacheService(ResourceContext* context) { + return UserDataAdapter::Get( + context, kAppCacheServicKeyName); +} + +FileSystemContext* ResourceContext::GetFileSystemContext( + ResourceContext* resource_context) { + return UserDataAdapter::Get( + resource_context, kFileSystemContextKeyName); +} + +BlobStorageController* ResourceContext::GetBlobStorageController( + ResourceContext* resource_context) { + return GetChromeBlobStorageContextForResourceContext(resource_context)-> + controller(); +} + +DatabaseTracker* GetDatabaseTrackerForResourceContext( + ResourceContext* resource_context) { + return UserDataAdapter::Get( + resource_context, kDatabaseTrackerKeyName); +} + +WebKitContext* GetWebKitContextForResourceContext( + ResourceContext* resource_context) { + return UserDataAdapter::Get( + resource_context, kWebKitContextKeyName); +} + +ChromeBlobStorageContext* GetChromeBlobStorageContextForResourceContext( + ResourceContext* resource_context) { + return UserDataAdapter::Get( + resource_context, kBlobStorageContextKeyName); +} + +void InitializeResourceContext(BrowserContext* browser_context) { + ResourceContext* resource_context = browser_context->GetResourceContext(); + DCHECK(!resource_context->GetUserData(kWebKitContextKeyName)); + resource_context->SetUserData( + kWebKitContextKeyName, + new UserDataAdapter( + BrowserContext::GetWebKitContext(browser_context))); + resource_context->SetUserData( + kDatabaseTrackerKeyName, + new UserDataAdapter( + BrowserContext::GetDatabaseTracker(browser_context))); + resource_context->SetUserData( + kAppCacheServicKeyName, + new UserDataAdapter( + static_cast( + BrowserContext::GetAppCacheService(browser_context)))); + resource_context->SetUserData( + kFileSystemContextKeyName, + new UserDataAdapter( + BrowserContext::GetFileSystemContext(browser_context))); + resource_context->SetUserData( + kBlobStorageContextKeyName, + new UserDataAdapter( + ChromeBlobStorageContext::GetFor(browser_context))); +} + +} // namespace content -- cgit v1.1