Merging r142349:
authorBill Wendling <isanbard@gmail.com>
Tue, 18 Oct 2011 17:22:17 +0000 (17:22 +0000)
committerBill Wendling <isanbard@gmail.com>
Tue, 18 Oct 2011 17:22:17 +0000 (17:22 +0000)
------------------------------------------------------------------------
r142349 | d0k | 2011-10-18 03:10:08 -0700 (Tue, 18 Oct 2011) | 4 lines

Use llvm::Triple's methods to parse FreeBSD version numbers.

Who could've thought that FreeBSD would ever reach version 10!
Patch from Dimitry Andric.
------------------------------------------------------------------------

git-svn-id: https://llvm.org/svn/llvm-project/cfe/branches/release_30@142366 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Basic/Targets.cpp

index 889518bb2a993b63141d40ccd3de0c07485fe8f6..b89ea0c053268ee4cf6dd8e4267fb8f3c7c765e1 100644 (file)
@@ -247,11 +247,12 @@ protected:
                             MacroBuilder &Builder) const {
     // FreeBSD defines; list based off of gcc output
 
-    // FIXME: Move version number handling to llvm::Triple.
-    StringRef Release = Triple.getOSName().substr(strlen("freebsd"), 1);
+    unsigned Release = Triple.getOSMajorVersion();
+    if (Release == 0U)
+      Release = 8;
 
-    Builder.defineMacro("__FreeBSD__", Release);
-    Builder.defineMacro("__FreeBSD_cc_version", Release + "00001");
+    Builder.defineMacro("__FreeBSD__", Twine(Release));
+    Builder.defineMacro("__FreeBSD_cc_version", Twine(Release * 100000U + 1U));
     Builder.defineMacro("__KPRINTF_ATTRIBUTE__");
     DefineStd(Builder, "unix", Opts);
     Builder.defineMacro("__ELF__");