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,20 @@ |
// 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) { |
ChromeURLDataManagerFactory::GetForProfile(profile)->AddDataSource( |
- delegate->url_data_source_); |
+ new URLDataSourceImpl(source->GetSource(), source)); |
} |
// 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 +119,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 +150,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)); |