diff options
author | Daniel Dunbar <daniel@zuster.org> | 2009-03-31 17:30:15 +0000 |
---|---|---|
committer | Daniel Dunbar <daniel@zuster.org> | 2009-03-31 17:30:15 +0000 |
commit | 62145779bf0b8bb93b2fd121fec0361d3accfa09 (patch) | |
tree | abedebe70d79ca2908b6ddb81da366b6c85361b2 /lib/System | |
parent | f17684ec1e0a48745c7f5dc5b5192d490f743399 (diff) | |
download | external_llvm-62145779bf0b8bb93b2fd121fec0361d3accfa09.zip external_llvm-62145779bf0b8bb93b2fd121fec0361d3accfa09.tar.gz external_llvm-62145779bf0b8bb93b2fd121fec0361d3accfa09.tar.bz2 |
Add llvm::sys::getHostTriple and remove
llvm::sys::getOS{Name,Version}.
Right now the implementation just derives from LLVM_HOSTTRIPLE (which
is wrong, but it doesn't look like we have a define for the target
triple). Ideally this routine would actually be able to compute the
triple for targets we care about.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@68118 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/System')
-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 1bd6da5..fb319fd 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 4fabc78..18f00f8 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; } |