Chromium Code Reviews| Index: chrome/browser/ui/webui/chrome_url_data_manager.cc |
| =================================================================== |
| --- chrome/browser/ui/webui/chrome_url_data_manager.cc (revision 176942) |
| +++ chrome/browser/ui/webui/chrome_url_data_manager.cc (working copy) |
| @@ -7,32 +7,19 @@ |
| #include <vector> |
| #include "base/bind.h" |
| -#include "base/i18n/rtl.h" |
| #include "base/lazy_instance.h" |
| #include "base/memory/ref_counted_memory.h" |
| #include "base/memory/scoped_ptr.h" |
| #include "base/message_loop.h" |
| #include "base/string_util.h" |
| #include "base/synchronization/lock.h" |
| -#include "base/values.h" |
| #include "chrome/browser/net/chrome_url_request_context.h" |
| #include "chrome/browser/profiles/profile.h" |
| #include "chrome/browser/ui/webui/chrome_url_data_manager_factory.h" |
| #include "chrome/browser/ui/webui/chrome_url_data_manager_backend.h" |
| #include "content/public/browser/browser_thread.h" |
| -#include "content/public/browser/url_data_source_delegate.h" |
| -#include "grit/platform_locale_settings.h" |
| -#include "ui/base/l10n/l10n_util.h" |
| +#include "content/public/browser/url_data_source.h" |
| -#if defined (TOOLKIT_GTK) |
| -#include "ui/base/resource/resource_bundle.h" |
| -#include "ui/gfx/font.h" |
| -#endif |
| - |
| -#if defined(OS_WIN) |
| -#include "base/win/windows_version.h" |
| -#endif |
| - |
| using content::BrowserThread; |
| static base::LazyInstance<base::Lock>::Leaky |
| @@ -45,7 +32,7 @@ |
| // Invoked on the IO thread to do the actual adding of the DataSource. |
| static void AddDataSourceOnIOThread( |
| const base::Callback<ChromeURLDataManagerBackend*(void)>& backend, |
| - scoped_refptr<URLDataSource> data_source) { |
| + scoped_refptr<URLDataSourceImpl> data_source) { |
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| backend.Run()->AddDataSource(data_source.get()); |
| } |
| @@ -58,7 +45,7 @@ |
| ChromeURLDataManager::~ChromeURLDataManager() { |
| } |
| -void ChromeURLDataManager::AddDataSource(URLDataSource* source) { |
| +void ChromeURLDataManager::AddDataSource(URLDataSourceImpl* source) { |
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| BrowserThread::PostTask( |
| BrowserThread::IO, FROM_HERE, |
| @@ -81,7 +68,8 @@ |
| } |
| // static |
| -void ChromeURLDataManager::DeleteDataSource(const URLDataSource* data_source) { |
| +void ChromeURLDataManager::DeleteDataSource( |
| + const URLDataSourceImpl* data_source) { |
| // Invoked when a DataSource is no longer referenced and needs to be deleted. |
| if (BrowserThread::CurrentlyOn(BrowserThread::UI)) { |
| // We're on the UI thread, delete right away. |
| @@ -110,18 +98,22 @@ |
| // static |
| void ChromeURLDataManager::AddDataSource( |
| Profile* profile, |
| - content::URLDataSourceDelegate* delegate) { |
| - if (!delegate->url_data_source_) { |
| - delegate->url_data_source_ = new URLDataSource( |
| - delegate->GetSource(), delegate); |
| - } |
| + content::URLDataSource* source) { |
| + URLDataSourceImpl* source_impl = |
| + new URLDataSourceImpl(source->GetSource(), source); |
| ChromeURLDataManagerFactory::GetForProfile(profile)->AddDataSource( |
|
Evan Stade
2013/01/15 20:49:34
combine these lines?
jam
2013/01/15 21:09:08
that doesn't fit
Evan Stade
2013/01/15 21:33:43
sorry, what I meant was to inline source_impl
jam
2013/01/15 21:39:47
Done.
|
| - delegate->url_data_source_); |
| + source_impl); |
| } |
| // static |
| +void ChromeURLDataManager::AddDataSourceImpl(Profile* profile, |
| + URLDataSourceImpl* source) { |
| + ChromeURLDataManagerFactory::GetForProfile(profile)->AddDataSource(source); |
| +} |
| + |
| +// static |
| bool ChromeURLDataManager::IsScheduledForDeletion( |
| - const URLDataSource* data_source) { |
| + const URLDataSourceImpl* data_source) { |
| base::AutoLock lock(g_delete_lock.Get()); |
| if (!data_sources_) |
| return false; |
| @@ -129,17 +121,17 @@ |
| data_sources_->end(); |
| } |
| -URLDataSource::URLDataSource(const std::string& source_name, |
| - content::URLDataSourceDelegate* delegate) |
| +URLDataSourceImpl::URLDataSourceImpl(const std::string& source_name, |
| + content::URLDataSource* source) |
| : source_name_(source_name), |
| backend_(NULL), |
| - delegate_(delegate) { |
| + source_(source) { |
| } |
| -URLDataSource::~URLDataSource() { |
| +URLDataSourceImpl::~URLDataSourceImpl() { |
| } |
| -void URLDataSource::SendResponse( |
| +void URLDataSourceImpl::SendResponse( |
| int request_id, |
| base::RefCountedMemory* bytes) { |
| // Take a ref-pointer on entry so byte->Release() will always get called. |
| @@ -160,40 +152,11 @@ |
| } |
| BrowserThread::PostTask( |
| BrowserThread::IO, FROM_HERE, |
| - base::Bind(&URLDataSource::SendResponseOnIOThread, this, request_id, |
| + base::Bind(&URLDataSourceImpl::SendResponseOnIOThread, this, request_id, |
| bytes_ptr)); |
| } |
| -// static |
| -void URLDataSource::SetFontAndTextDirection( |
| - DictionaryValue* localized_strings) { |
| - int web_font_family_id = IDS_WEB_FONT_FAMILY; |
| - int web_font_size_id = IDS_WEB_FONT_SIZE; |
| -#if defined(OS_WIN) |
| - // Vary font settings for Windows XP. |
| - if (base::win::GetVersion() < base::win::VERSION_VISTA) { |
| - web_font_family_id = IDS_WEB_FONT_FAMILY_XP; |
| - web_font_size_id = IDS_WEB_FONT_SIZE_XP; |
| - } |
| -#endif |
| - |
| - std::string font_family = l10n_util::GetStringUTF8(web_font_family_id); |
| - |
| -#if defined(TOOLKIT_GTK) |
| - // Use the system font on Linux/GTK. Keep the hard-coded font families as |
| - // backup in case for some crazy reason this one isn't available. |
| - font_family = ui::ResourceBundle::GetSharedInstance().GetFont( |
| - ui::ResourceBundle::BaseFont).GetFontName() + ", " + font_family; |
| -#endif |
| - |
| - localized_strings->SetString("fontfamily", font_family); |
| - localized_strings->SetString("fontsize", |
| - l10n_util::GetStringUTF8(web_font_size_id)); |
| - localized_strings->SetString("textdirection", |
| - base::i18n::IsRTL() ? "rtl" : "ltr"); |
| -} |
| - |
| -void URLDataSource::SendResponseOnIOThread( |
| +void URLDataSourceImpl::SendResponseOnIOThread( |
| int request_id, |
| scoped_refptr<base::RefCountedMemory> bytes) { |
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |