// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "webkit/glue/user_agent.h" #if defined(OS_POSIX) && !defined(OS_MACOSX) #include #endif #include "base/lazy_instance.h" #include "base/string_util.h" #include "base/stringprintf.h" #include "base/sys_info.h" #if defined(OS_WIN) #include "base/win/windows_version.h" #endif // Generated #include "webkit_version.h" // NOLINT #if defined(OS_ANDROID) namespace { base::LazyInstance::Leaky g_os_info = LAZY_INSTANCE_INITIALIZER; } // namespace #endif namespace webkit_glue { std::string GetWebKitVersion() { return base::StringPrintf("%d.%d (%s)", WEBKIT_VERSION_MAJOR, WEBKIT_VERSION_MINOR, WEBKIT_SVN_REVISION); } std::string GetWebKitRevision() { return WEBKIT_SVN_REVISION; } std::string BuildOSCpuInfo() { std::string os_cpu; #if defined(OS_WIN) || defined(OS_MACOSX) || defined(OS_CHROMEOS) int32 os_major_version = 0; int32 os_minor_version = 0; int32 os_bugfix_version = 0; base::SysInfo::OperatingSystemVersionNumbers(&os_major_version, &os_minor_version, &os_bugfix_version); #endif #if defined(OS_POSIX) && !defined(OS_MACOSX) && !defined(OS_ANDROID) // Should work on any Posix system. struct utsname unixinfo; uname(&unixinfo); std::string cputype; // special case for biarch systems if (strcmp(unixinfo.machine, "x86_64") == 0 && sizeof(void*) == sizeof(int32)) { // NOLINT cputype.assign("i686 (x86_64)"); } else { cputype.assign(unixinfo.machine); } #endif #if defined(OS_WIN) std::string architecture_token; base::win::OSInfo* os_info = base::win::OSInfo::GetInstance(); if (os_info->wow64_status() == base::win::OSInfo::WOW64_ENABLED) { architecture_token = "; WOW64"; } else { base::win::OSInfo::WindowsArchitecture windows_architecture = os_info->architecture(); if (windows_architecture == base::win::OSInfo::X64_ARCHITECTURE) architecture_token = "; Win64; x64"; else if (windows_architecture == base::win::OSInfo::IA64_ARCHITECTURE) architecture_token = "; Win64; IA64"; } #endif base::StringAppendF( &os_cpu, #if defined(OS_WIN) "Windows NT %d.%d%s", os_major_version, os_minor_version, architecture_token.c_str() #elif defined(OS_MACOSX) "Intel Mac OS X %d_%d_%d", os_major_version, os_minor_version, os_bugfix_version #elif defined(OS_CHROMEOS) "CrOS " "%s %d.%d.%d", cputype.c_str(), // e.g. i686 os_major_version, os_minor_version, os_bugfix_version #elif defined(OS_ANDROID) "Android %s", g_os_info.Get().c_str() #else "%s %s", unixinfo.sysname, // e.g. Linux cputype.c_str() // e.g. i686 #endif ); // NOLINT return os_cpu; } int GetWebKitMajorVersion() { return WEBKIT_VERSION_MAJOR; } int GetWebKitMinorVersion() { return WEBKIT_VERSION_MINOR; } std::string BuildUserAgentFromProduct(const std::string& product) { const char kUserAgentPlatform[] = #if defined(OS_WIN) ""; #elif defined(OS_MACOSX) "Macintosh; "; #elif defined(USE_X11) "X11; "; // strange, but that's what Firefox uses #elif defined(OS_ANDROID) "Linux; "; #else "Unknown; "; #endif std::string user_agent; // This is done to expose our product name in a manner that is maximally // compatible with Safari, we hope!! // Derived from Safari's UA string. base::StringAppendF( &user_agent, "Mozilla/5.0 (%s%s) AppleWebKit/%d.%d" " (KHTML, like Gecko) %s Safari/%d.%d", kUserAgentPlatform, webkit_glue::BuildOSCpuInfo().c_str(), WEBKIT_VERSION_MAJOR, WEBKIT_VERSION_MINOR, product.c_str(), WEBKIT_VERSION_MAJOR, WEBKIT_VERSION_MINOR); return user_agent; } #if defined(OS_ANDROID) void SetUserAgentOSInfo(const std::string& os_info) { g_os_info.Get() = os_info; } #endif } // namespace webkit_glue