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

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

Issue 12084029: Simplify how TestChromeWebUIControllerFactory is registered now that multiple WebUIControllerFactor… (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: fix MostVisitedWebUITest tests Created 7 years, 10 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) 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 "chrome/browser/ui/webui/chrome_web_ui_controller_factory.h" 5 #include "chrome/browser/ui/webui/chrome_web_ui_controller_factory.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/command_line.h" 8 #include "base/command_line.h"
9 #include "base/location.h" 9 #include "base/location.h"
10 #include "base/message_loop_proxy.h" 10 #include "base/message_loop_proxy.h"
(...skipping 30 matching lines...) Expand all
41 #include "chrome/browser/ui/webui/omnibox/omnibox_ui.h" 41 #include "chrome/browser/ui/webui/omnibox/omnibox_ui.h"
42 #include "chrome/browser/ui/webui/options/options_ui.h" 42 #include "chrome/browser/ui/webui/options/options_ui.h"
43 #include "chrome/browser/ui/webui/performance_monitor/performance_monitor_ui.h" 43 #include "chrome/browser/ui/webui/performance_monitor/performance_monitor_ui.h"
44 #include "chrome/browser/ui/webui/plugins_ui.h" 44 #include "chrome/browser/ui/webui/plugins_ui.h"
45 #include "chrome/browser/ui/webui/predictors/predictors_ui.h" 45 #include "chrome/browser/ui/webui/predictors/predictors_ui.h"
46 #include "chrome/browser/ui/webui/print_preview/print_preview_ui.h" 46 #include "chrome/browser/ui/webui/print_preview/print_preview_ui.h"
47 #include "chrome/browser/ui/webui/profiler_ui.h" 47 #include "chrome/browser/ui/webui/profiler_ui.h"
48 #include "chrome/browser/ui/webui/quota_internals_ui.h" 48 #include "chrome/browser/ui/webui/quota_internals_ui.h"
49 #include "chrome/browser/ui/webui/signin_internals_ui.h" 49 #include "chrome/browser/ui/webui/signin_internals_ui.h"
50 #include "chrome/browser/ui/webui/sync_internals_ui.h" 50 #include "chrome/browser/ui/webui/sync_internals_ui.h"
51 #include "chrome/browser/ui/webui/test_chrome_web_ui_controller_factory.h"
52 #include "chrome/browser/ui/webui/tracing_ui.h" 51 #include "chrome/browser/ui/webui/tracing_ui.h"
53 #include "chrome/browser/ui/webui/user_actions/user_actions_ui.h" 52 #include "chrome/browser/ui/webui/user_actions/user_actions_ui.h"
54 #include "chrome/browser/ui/webui/version_ui.h" 53 #include "chrome/browser/ui/webui/version_ui.h"
55 #include "chrome/common/chrome_switches.h" 54 #include "chrome/common/chrome_switches.h"
56 #include "chrome/common/extensions/extension_constants.h" 55 #include "chrome/common/extensions/extension_constants.h"
57 #include "chrome/common/extensions/feature_switch.h" 56 #include "chrome/common/extensions/feature_switch.h"
58 #include "chrome/common/pref_names.h" 57 #include "chrome/common/pref_names.h"
59 #include "chrome/common/url_constants.h" 58 #include "chrome/common/url_constants.h"
60 #include "content/public/browser/web_contents.h" 59 #include "content/public/browser/web_contents.h"
61 #include "content/public/browser/web_ui.h" 60 #include "content/public/browser/web_ui.h"
(...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after
113 #include "chrome/browser/ui/webui/certificate_viewer_ui.h" 112 #include "chrome/browser/ui/webui/certificate_viewer_ui.h"
114 #endif 113 #endif
115 114
116 using content::WebUI; 115 using content::WebUI;
117 using content::WebUIController; 116 using content::WebUIController;
118 using ui::ExternalWebDialogUI; 117 using ui::ExternalWebDialogUI;
119 using ui::WebDialogUI; 118 using ui::WebDialogUI;
120 119
121 namespace { 120 namespace {
122 121
123 static bool g_use_test_factory = false;
124
125 // A function for creating a new WebUI. The caller owns the return value, which 122 // A function for creating a new WebUI. The caller owns the return value, which
126 // may be NULL (for example, if the URL refers to an non-existent extension). 123 // may be NULL (for example, if the URL refers to an non-existent extension).
127 typedef WebUIController* (*WebUIFactoryFunction)(WebUI* web_ui, 124 typedef WebUIController* (*WebUIFactoryFunction)(WebUI* web_ui,
128 const GURL& url); 125 const GURL& url);
129 126
130 // Template for defining WebUIFactoryFunction. 127 // Template for defining WebUIFactoryFunction.
131 template<class T> 128 template<class T>
132 WebUIController* NewWebUI(WebUI* web_ui, const GURL& url) { 129 WebUIController* NewWebUI(WebUI* web_ui, const GURL& url) {
133 return new T(web_ui); 130 return new T(web_ui);
134 } 131 }
(...skipping 268 matching lines...) Expand 10 before | Expand all | Expand 10 after
403 #endif 400 #endif
404 #if defined(ENABLE_PRINTING) 401 #if defined(ENABLE_PRINTING)
405 if (url.host() == chrome::kChromeUIPrintHost && 402 if (url.host() == chrome::kChromeUIPrintHost &&
406 !profile->GetPrefs()->GetBoolean(prefs::kPrintPreviewDisabled)) 403 !profile->GetPrefs()->GetBoolean(prefs::kPrintPreviewDisabled))
407 return &NewWebUI<PrintPreviewUI>; 404 return &NewWebUI<PrintPreviewUI>;
408 #endif 405 #endif
409 406
410 return NULL; 407 return NULL;
411 } 408 }
412 409
413 // When the test-type switch is set, return a TestType object, which should be a
414 // subclass of Type. The logic is provided here in the traits class, rather than
415 // in GetInstance() so that the choice is made only once, when the Singleton is
416 // first instantiated, rather than every time GetInstance() is called.
417 template<typename Type, typename TestType>
418 struct PossibleTestSingletonTraits : public DefaultSingletonTraits<Type> {
419 static Type* New() {
420 if (g_use_test_factory)
421 return DefaultSingletonTraits<TestType>::New();
422 else
423 return DefaultSingletonTraits<Type>::New();
424 }
425 };
426
427 void RunFaviconCallbackAsync( 410 void RunFaviconCallbackAsync(
428 const FaviconService::FaviconResultsCallback& callback, 411 const FaviconService::FaviconResultsCallback& callback,
429 const std::vector<history::FaviconBitmapResult>* results) { 412 const std::vector<history::FaviconBitmapResult>* results) {
430 base::MessageLoopProxy::current()->PostTask( 413 base::MessageLoopProxy::current()->PostTask(
431 FROM_HERE, 414 FROM_HERE,
432 base::Bind(&FaviconService::FaviconResultsCallbackRunner, 415 base::Bind(&FaviconService::FaviconResultsCallbackRunner,
433 callback, base::Owned(results))); 416 callback, base::Owned(results)));
434 } 417 }
435 418
436 } // namespace 419 } // namespace
(...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after
535 static_cast<int>(gfx::kFaviconSize * scale + 0.5f); 518 static_cast<int>(gfx::kFaviconSize * scale + 0.5f);
536 bitmap_result.pixel_size = gfx::Size(edge_pixel_size, edge_pixel_size); 519 bitmap_result.pixel_size = gfx::Size(edge_pixel_size, edge_pixel_size);
537 } 520 }
538 } 521 }
539 522
540 RunFaviconCallbackAsync(callback, favicon_bitmap_results); 523 RunFaviconCallbackAsync(callback, favicon_bitmap_results);
541 } 524 }
542 525
543 // static 526 // static
544 ChromeWebUIControllerFactory* ChromeWebUIControllerFactory::GetInstance() { 527 ChromeWebUIControllerFactory* ChromeWebUIControllerFactory::GetInstance() {
545 return Singleton< ChromeWebUIControllerFactory, PossibleTestSingletonTraits< 528 return Singleton<ChromeWebUIControllerFactory>::get();
546 ChromeWebUIControllerFactory, TestChromeWebUIControllerFactory> >::get();
547 }
548
549 // static
550 void ChromeWebUIControllerFactory::UseTestFactoryForTesting() {
551 g_use_test_factory = true;
552 } 529 }
553 530
554 ChromeWebUIControllerFactory::ChromeWebUIControllerFactory() { 531 ChromeWebUIControllerFactory::ChromeWebUIControllerFactory() {
555 } 532 }
556 533
557 ChromeWebUIControllerFactory::~ChromeWebUIControllerFactory() { 534 ChromeWebUIControllerFactory::~ChromeWebUIControllerFactory() {
558 } 535 }
559 536
560 base::RefCountedMemory* ChromeWebUIControllerFactory::GetFaviconResourceBytes( 537 base::RefCountedMemory* ChromeWebUIControllerFactory::GetFaviconResourceBytes(
561 const GURL& page_url, ui::ScaleFactor scale_factor) const { 538 const GURL& page_url, ui::ScaleFactor scale_factor) const {
(...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after
602 if (page_url.host() == chrome::kChromeUISettingsFrameHost) 579 if (page_url.host() == chrome::kChromeUISettingsFrameHost)
603 return options::OptionsUI::GetFaviconResourceBytes(scale_factor); 580 return options::OptionsUI::GetFaviconResourceBytes(scale_factor);
604 581
605 // Android doesn't use the plugins pages. 582 // Android doesn't use the plugins pages.
606 if (page_url.host() == chrome::kChromeUIPluginsHost) 583 if (page_url.host() == chrome::kChromeUIPluginsHost)
607 return PluginsUI::GetFaviconResourceBytes(scale_factor); 584 return PluginsUI::GetFaviconResourceBytes(scale_factor);
608 #endif 585 #endif
609 586
610 return NULL; 587 return NULL;
611 } 588 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698