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

Side by Side Diff: chrome/browser/ui/webui/downloads_ui.cc

Issue 9224002: Make WebUI objects not derive from WebUI. WebUI objects own the controller. This is the ownership... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: sync to head to clear linux_chromeos browsertest failures Created 8 years, 11 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
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 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/browser/ui/webui/downloads_ui.h" 5 #include "chrome/browser/ui/webui/downloads_ui.h"
6 6
7 #include "base/memory/singleton.h" 7 #include "base/memory/singleton.h"
8 #include "base/string_piece.h" 8 #include "base/string_piece.h"
9 #include "base/threading/thread.h" 9 #include "base/threading/thread.h"
10 #include "base/values.h" 10 #include "base/values.h"
11 #include "chrome/browser/defaults.h" 11 #include "chrome/browser/defaults.h"
12 #include "chrome/browser/download/download_service.h" 12 #include "chrome/browser/download/download_service.h"
13 #include "chrome/browser/download/download_service_factory.h" 13 #include "chrome/browser/download/download_service_factory.h"
14 #include "chrome/browser/profiles/profile.h" 14 #include "chrome/browser/profiles/profile.h"
15 #include "chrome/browser/ui/webui/chrome_url_data_manager.h" 15 #include "chrome/browser/ui/webui/chrome_url_data_manager.h"
16 #include "chrome/browser/ui/webui/chrome_web_ui_data_source.h" 16 #include "chrome/browser/ui/webui/chrome_web_ui_data_source.h"
17 #include "chrome/browser/ui/webui/downloads_dom_handler.h" 17 #include "chrome/browser/ui/webui/downloads_dom_handler.h"
18 #include "chrome/common/url_constants.h" 18 #include "chrome/common/url_constants.h"
19 #include "content/browser/webui/web_ui.h"
19 #include "content/public/browser/download_manager.h" 20 #include "content/public/browser/download_manager.h"
20 #include "content/public/browser/web_contents.h" 21 #include "content/public/browser/web_contents.h"
21 #include "grit/browser_resources.h" 22 #include "grit/browser_resources.h"
22 #include "grit/generated_resources.h" 23 #include "grit/generated_resources.h"
23 #include "grit/theme_resources.h" 24 #include "grit/theme_resources.h"
24 #include "grit/theme_resources_standard.h" 25 #include "grit/theme_resources_standard.h"
25 #include "ui/base/resource/resource_bundle.h" 26 #include "ui/base/resource/resource_bundle.h"
26 27
27 using content::DownloadManager; 28 using content::DownloadManager;
28 using content::WebContents; 29 using content::WebContents;
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after
77 } 78 }
78 79
79 } // namespace 80 } // namespace
80 81
81 /////////////////////////////////////////////////////////////////////////////// 82 ///////////////////////////////////////////////////////////////////////////////
82 // 83 //
83 // DownloadsUI 84 // DownloadsUI
84 // 85 //
85 /////////////////////////////////////////////////////////////////////////////// 86 ///////////////////////////////////////////////////////////////////////////////
86 87
87 DownloadsUI::DownloadsUI(WebContents* contents) : WebUI(contents, this) { 88 DownloadsUI::DownloadsUI(WebUI* web_ui) : WebUIController(web_ui) {
88 Profile* profile = Profile::FromBrowserContext(contents->GetBrowserContext()); 89 Profile* profile = Profile::FromBrowserContext(
90 web_ui->web_contents()->GetBrowserContext());
89 DownloadManager* dlm = 91 DownloadManager* dlm =
90 DownloadServiceFactory::GetForProfile(profile)->GetDownloadManager(); 92 DownloadServiceFactory::GetForProfile(profile)->GetDownloadManager();
91 93
92 DownloadsDOMHandler* handler = new DownloadsDOMHandler(dlm); 94 DownloadsDOMHandler* handler = new DownloadsDOMHandler(dlm);
93 AddMessageHandler(handler); 95 web_ui->AddMessageHandler(handler);
94 handler->Init(); 96 handler->Init();
95 97
96 // Set up the chrome://downloads/ source. 98 // Set up the chrome://downloads/ source.
97 profile->GetChromeURLDataManager()->AddDataSource( 99 profile->GetChromeURLDataManager()->AddDataSource(
98 CreateDownloadsUIHTMLSource()); 100 CreateDownloadsUIHTMLSource());
99 } 101 }
100 102
101 // static 103 // static
102 RefCountedMemory* DownloadsUI::GetFaviconResourceBytes() { 104 RefCountedMemory* DownloadsUI::GetFaviconResourceBytes() {
103 return ResourceBundle::GetSharedInstance(). 105 return ResourceBundle::GetSharedInstance().
104 LoadDataResourceBytes(IDR_DOWNLOADS_FAVICON); 106 LoadDataResourceBytes(IDR_DOWNLOADS_FAVICON);
105 } 107 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698