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

Side by Side Diff: content/browser/resource_context_impl.cc

Issue 17653005: Merge StreamContext into ChromeBlobStorageContext (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 6 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 | « content/browser/resource_context_impl.h ('k') | content/browser/storage_partition_impl_map.cc » ('j') | 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) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/resource_context_impl.h" 5 #include "content/browser/resource_context_impl.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "content/browser/fileapi/chrome_blob_storage_context.h" 8 #include "content/browser/fileapi/chrome_blob_storage_context.h"
9 #include "content/browser/host_zoom_map_impl.h" 9 #include "content/browser/host_zoom_map_impl.h"
10 #include "content/browser/loader/resource_dispatcher_host_impl.h" 10 #include "content/browser/loader/resource_dispatcher_host_impl.h"
11 #include "content/browser/loader/resource_request_info_impl.h" 11 #include "content/browser/loader/resource_request_info_impl.h"
12 #include "content/browser/streams/stream_context.h"
13 #include "content/browser/webui/url_data_manager_backend.h" 12 #include "content/browser/webui/url_data_manager_backend.h"
14 #include "content/public/browser/browser_context.h" 13 #include "content/public/browser/browser_context.h"
15 #include "content/public/browser/browser_thread.h" 14 #include "content/public/browser/browser_thread.h"
16 15
17 using base::UserDataAdapter; 16 using base::UserDataAdapter;
18 17
19 namespace content { 18 namespace content {
20 19
21 namespace { 20 namespace {
22 21
23 // Key names on ResourceContext. 22 // Key names on ResourceContext.
24 const char kBlobStorageContextKeyName[] = "content_blob_storage_context"; 23 const char kBlobStorageContextKeyName[] = "content_blob_storage_context";
25 const char kHostZoomMapKeyName[] = "content_host_zoom_map"; 24 const char kHostZoomMapKeyName[] = "content_host_zoom_map";
26 const char kStreamContextKeyName[] = "content_stream_context";
27 const char kURLDataManagerBackendKeyName[] = "url_data_manager_backend"; 25 const char kURLDataManagerBackendKeyName[] = "url_data_manager_backend";
28 26
29 class NonOwningZoomData : public base::SupportsUserData::Data { 27 class NonOwningZoomData : public base::SupportsUserData::Data {
30 public: 28 public:
31 explicit NonOwningZoomData(HostZoomMap* hzm) : host_zoom_map_(hzm) {} 29 explicit NonOwningZoomData(HostZoomMap* hzm) : host_zoom_map_(hzm) {}
32 HostZoomMap* host_zoom_map() { return host_zoom_map_; } 30 HostZoomMap* host_zoom_map() { return host_zoom_map_; }
33 31
34 private: 32 private:
35 HostZoomMap* host_zoom_map_; 33 HostZoomMap* host_zoom_map_;
36 }; 34 };
(...skipping 17 matching lines...) Expand all
54 DetachUserDataThread(); 52 DetachUserDataThread();
55 } 53 }
56 54
57 ChromeBlobStorageContext* GetChromeBlobStorageContextForResourceContext( 55 ChromeBlobStorageContext* GetChromeBlobStorageContextForResourceContext(
58 ResourceContext* resource_context) { 56 ResourceContext* resource_context) {
59 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 57 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
60 return UserDataAdapter<ChromeBlobStorageContext>::Get( 58 return UserDataAdapter<ChromeBlobStorageContext>::Get(
61 resource_context, kBlobStorageContextKeyName); 59 resource_context, kBlobStorageContextKeyName);
62 } 60 }
63 61
64 StreamContext* GetStreamContextForResourceContext(
65 ResourceContext* resource_context) {
66 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
67 return UserDataAdapter<StreamContext>::Get(
68 resource_context, kStreamContextKeyName);
69 }
70
71 HostZoomMap* GetHostZoomMapForResourceContext(ResourceContext* context) { 62 HostZoomMap* GetHostZoomMapForResourceContext(ResourceContext* context) {
72 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 63 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
73 return static_cast<NonOwningZoomData*>( 64 return static_cast<NonOwningZoomData*>(
74 context->GetUserData(kHostZoomMapKeyName))->host_zoom_map(); 65 context->GetUserData(kHostZoomMapKeyName))->host_zoom_map();
75 } 66 }
76 67
77 URLDataManagerBackend* GetURLDataManagerForResourceContext( 68 URLDataManagerBackend* GetURLDataManagerForResourceContext(
78 ResourceContext* context) { 69 ResourceContext* context) {
79 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 70 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
80 if (!context->GetUserData(kURLDataManagerBackendKeyName)) { 71 if (!context->GetUserData(kURLDataManagerBackendKeyName)) {
81 context->SetUserData(kURLDataManagerBackendKeyName, 72 context->SetUserData(kURLDataManagerBackendKeyName,
82 new URLDataManagerBackend()); 73 new URLDataManagerBackend());
83 } 74 }
84 return static_cast<URLDataManagerBackend*>( 75 return static_cast<URLDataManagerBackend*>(
85 context->GetUserData(kURLDataManagerBackendKeyName)); 76 context->GetUserData(kURLDataManagerBackendKeyName));
86 } 77 }
87 78
88 void InitializeResourceContext(BrowserContext* browser_context) { 79 void InitializeResourceContext(BrowserContext* browser_context) {
89 ResourceContext* resource_context = browser_context->GetResourceContext(); 80 ResourceContext* resource_context = browser_context->GetResourceContext();
90 DCHECK(!resource_context->GetUserData(kHostZoomMapKeyName)); 81 DCHECK(!resource_context->GetUserData(kHostZoomMapKeyName));
91 82
92 resource_context->SetUserData( 83 resource_context->SetUserData(
93 kBlobStorageContextKeyName, 84 kBlobStorageContextKeyName,
94 new UserDataAdapter<ChromeBlobStorageContext>( 85 new UserDataAdapter<ChromeBlobStorageContext>(
95 ChromeBlobStorageContext::GetFor(browser_context))); 86 ChromeBlobStorageContext::GetFor(browser_context)));
96 87
97 resource_context->SetUserData(
98 kStreamContextKeyName,
99 new UserDataAdapter<StreamContext>(
100 StreamContext::GetFor(browser_context)));
101
102 // This object is owned by the BrowserContext and not ResourceContext, so 88 // This object is owned by the BrowserContext and not ResourceContext, so
103 // store a non-owning pointer here. 89 // store a non-owning pointer here.
104 resource_context->SetUserData( 90 resource_context->SetUserData(
105 kHostZoomMapKeyName, 91 kHostZoomMapKeyName,
106 new NonOwningZoomData( 92 new NonOwningZoomData(
107 HostZoomMap::GetForBrowserContext(browser_context))); 93 HostZoomMap::GetForBrowserContext(browser_context)));
108 94
109 resource_context->DetachUserDataThread(); 95 resource_context->DetachUserDataThread();
110 } 96 }
111 97
112 } // namespace content 98 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/resource_context_impl.h ('k') | content/browser/storage_partition_impl_map.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698