Index: webkit/glue/webkit_glue.cc |
diff --git a/webkit/glue/webkit_glue.cc b/webkit/glue/webkit_glue.cc |
index 36584d1f4c16a50b96a230d732d4216a6cbc5589..cd14f456aede977fce61b24f9a2e58f50df1c850 100644 |
--- a/webkit/glue/webkit_glue.cc |
+++ b/webkit/glue/webkit_glue.cc |
@@ -13,7 +13,6 @@ |
#include <limits> |
-#include "base/lazy_instance.h" |
#include "base/logging.h" |
#include "base/memory/scoped_ptr.h" |
#include "base/path_service.h" |
@@ -21,7 +20,6 @@ |
#include "base/string_tokenizer.h" |
#include "base/string_util.h" |
#include "base/stringprintf.h" |
-#include "base/synchronization/lock.h" |
#include "base/sys_info.h" |
#include "base/sys_string_conversions.h" |
#include "base/utf_string_conversions.h" |
@@ -53,7 +51,6 @@ |
#endif |
#include "v8/include/v8.h" |
#include "webkit/glue/glue_serialize.h" |
-#include "webkit/glue/user_agent.h" |
using WebKit::WebCanvas; |
using WebKit::WebData; |
@@ -321,135 +318,6 @@ void PlatformFileInfoToWebFileInfo( |
web_file_info->type = WebKit::WebFileInfo::TypeFile; |
} |
-namespace { |
- |
-class UserAgentState { |
- public: |
- UserAgentState(); |
- ~UserAgentState(); |
- |
- void Set(const std::string& user_agent, bool overriding); |
- const std::string& Get(const GURL& url) const; |
- |
- private: |
- mutable std::string user_agent_; |
- // The UA string when we're pretending to be Mac Safari or Win Firefox. |
- mutable std::string user_agent_for_spoofing_hack_; |
- |
- mutable bool user_agent_requested_; |
- bool user_agent_is_overridden_; |
- |
- // This object can be accessed from multiple threads, so use a lock around |
- // accesses to the data members. |
- mutable base::Lock lock_; |
-}; |
- |
-UserAgentState::UserAgentState() |
- : user_agent_requested_(false), |
- user_agent_is_overridden_(false) { |
-} |
- |
-UserAgentState::~UserAgentState() { |
-} |
- |
-void UserAgentState::Set(const std::string& user_agent, bool overriding) { |
- base::AutoLock auto_lock(lock_); |
- if (user_agent == user_agent_) { |
- // We allow the user agent to be set multiple times as long as it |
- // is set to the same value, in order to simplify unit testing |
- // given g_user_agent is a global. |
- return; |
- } |
- DCHECK(!user_agent.empty()); |
- DCHECK(!user_agent_requested_) << "Setting the user agent after someone has " |
- "already requested it can result in unexpected behavior."; |
- user_agent_is_overridden_ = overriding; |
- user_agent_ = user_agent; |
-} |
- |
-bool IsMicrosoftSiteThatNeedsSpoofingForSilverlight(const GURL& url) { |
-#if defined(OS_MACOSX) |
- // The landing page for updating Silverlight gives a confusing experience |
- // in browsers that Silverlight doesn't officially support; spoof as |
- // Safari to reduce the chance that users won't complete updates. |
- // Should be removed if the sniffing is removed: http://crbug.com/88211 |
- if (url.host() == "www.microsoft.com" && |
- StartsWithASCII(url.path(), "/getsilverlight", false)) { |
- return true; |
- } |
-#endif |
- return false; |
-} |
- |
-bool IsYahooSiteThatNeedsSpoofingForSilverlight(const GURL& url) { |
-#if defined(OS_MACOSX) || defined(OS_WIN) |
- // The following Yahoo! JAPAN pages erroneously judge that Silverlight does |
- // not support Chromium. Until the pages are fixed, spoof the UA. |
- // http://crbug.com/104426 |
- if (url.host() == "headlines.yahoo.co.jp" && |
- StartsWithASCII(url.path(), "/videonews/", true)) { |
- return true; |
- } |
-#endif |
-#if defined(OS_MACOSX) |
- if ((url.host() == "downloads.yahoo.co.jp" && |
- StartsWithASCII(url.path(), "/docs/silverlight/", true)) || |
- url.host() == "gyao.yahoo.co.jp") { |
- return true; |
- } |
-#elif defined(OS_WIN) |
- if ((url.host() == "weather.yahoo.co.jp" && |
- StartsWithASCII(url.path(), "/weather/zoomradar/", true)) || |
- url.host() == "promotion.shopping.yahoo.co.jp" || |
- url.host() == "pokemon.kids.yahoo.co.jp") { |
- return true; |
- } |
-#endif |
- return false; |
-} |
- |
-const std::string& UserAgentState::Get(const GURL& url) const { |
- base::AutoLock auto_lock(lock_); |
- user_agent_requested_ = true; |
- |
- DCHECK(!user_agent_.empty()); |
- |
- // Workarounds for sites that use misguided UA sniffing. |
- if (!user_agent_is_overridden_) { |
- if (IsMicrosoftSiteThatNeedsSpoofingForSilverlight(url) || |
- IsYahooSiteThatNeedsSpoofingForSilverlight(url)) { |
- if (user_agent_for_spoofing_hack_.empty()) { |
-#if defined(OS_MACOSX) |
- user_agent_for_spoofing_hack_ = |
- BuildUserAgentFromProduct("Version/5.1.1 Safari/534.51.22"); |
-#elif defined(OS_WIN) |
- // Pretend to be Firefox. Silverlight doesn't support Win Safari. |
- base::StringAppendF( |
- &user_agent_for_spoofing_hack_, |
- "Mozilla/5.0 (%s) Gecko/20100101 Firefox/8.0", |
- webkit_glue::BuildOSCpuInfo().c_str()); |
-#endif |
- } |
- DCHECK(!user_agent_for_spoofing_hack_.empty()); |
- return user_agent_for_spoofing_hack_; |
- } |
- } |
- |
- return user_agent_; |
-} |
- |
-base::LazyInstance<UserAgentState> g_user_agent = LAZY_INSTANCE_INITIALIZER; |
- |
-} // namespace |
- |
-void SetUserAgent(const std::string& user_agent, bool overriding) { |
- g_user_agent.Get().Set(user_agent, overriding); |
-} |
- |
-const std::string& GetUserAgent(const GURL& url) { |
- return g_user_agent.Get().Get(url); |
-} |
- |
void SetForcefullyTerminatePluginProcess(bool value) { |
g_forcefully_terminate_plugin_process = value; |
} |