diff options
Diffstat (limited to 'lib')
-rw-r--r-- | lib/System/Unix/Host.inc | 34 | ||||
-rw-r--r-- | lib/System/Win32/Host.inc | 20 |
2 files changed, 28 insertions, 26 deletions
diff --git a/lib/System/Unix/Host.inc b/lib/System/Unix/Host.inc index 1bd6da5632..fb319fd09e 100644 --- a/lib/System/Unix/Host.inc +++ b/lib/System/Unix/Host.inc @@ -23,20 +23,36 @@ using namespace llvm; -std::string llvm::sys::getOSName() { +static std::string getOSVersion() { struct utsname info; if (uname(&info)) return ""; - return info.sysname; + return info.release; } -std::string llvm::sys::getOSVersion() { - struct utsname info; - - if (uname(&info)) - return ""; - - return info.release; +std::string sys::getHostTriple() { + // FIXME: Derive more directly instead of relying on the autoconf + // generated variable. + + std::string Triple = LLVM_HOSTTRIPLE; + + // Force i<N>86 to i386. + if (Triple[0] == 'i' && isdigit(Triple[1]) && + Triple[2] == '8' && Triple[3] == '6') + Triple[1] = '3'; + + // On darwin, we want to update the version to match that of the + // host. + std::string::size_type DarwinDashIdx = Triple.find("-darwin"); + if (DarwinDashIdx != std::string::npos) { + Triple.resize(DarwinDashIdx + strlen("-darwin")); + + // Only add the major part of the os version. + std::string Version = getOSVersion(); + Triple += Version.substr(0, Version.find('.')); + } + + return Triple; } diff --git a/lib/System/Win32/Host.inc b/lib/System/Win32/Host.inc index 4fabc78ade..18f00f8bc0 100644 --- a/lib/System/Win32/Host.inc +++ b/lib/System/Win32/Host.inc @@ -17,21 +17,7 @@ using namespace llvm; -std::string sys::getOSName() { - return "Windows"; -} - -std::string sys::getOSVersion() { - OSVERSIONINFO osvi; - - memset(&osvi, 0, sizeof(osvi)); - osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); - - if (!GetVersionEx(&osvi)) - return ""; - - char buf[64]; - sprintf(buf, "%d.%d", (int)osvi.dwMajorVersion, (int)osvi.dwMinorVersion); - - return buf; +std::string sys::getHostTriple() { + // FIXME: Adapt to running version. + return LLVM_HOSTTRIPLE; } |