From: Chris Lattner Date: Tue, 30 Sep 2008 01:00:25 +0000 (+0000) Subject: The definition of __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ follows X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8b30c412198ed004d999f0047e48f87b95bd3205;p=clang The definition of __ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__ follows the target triple on darwin. For example i386-apple-darwin9 -> 1050 because darwin9 is "10.5". git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@56826 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Basic/Targets.cpp b/lib/Basic/Targets.cpp index 2625da2e4d..c14588889b 100644 --- a/lib/Basic/Targets.cpp +++ b/lib/Basic/Targets.cpp @@ -39,10 +39,24 @@ static void getSolarisDefines(std::vector &Defs) { Define(Defs, "__SOLARIS__"); } -static void getDarwinDefines(std::vector &Defs) { +static void getDarwinDefines(std::vector &Defs, const char *Triple) { Define(Defs, "__APPLE__"); Define(Defs, "__MACH__"); - Define(Defs, "__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__", "1050"); + + // Figure out which "darwin number" the target triple is. "darwin9" -> 10.5. + const char *Darwin = strstr(Triple, "-darwin"); + if (Darwin) { + Darwin += strlen("-darwin"); + if (Darwin[0] >= '1' && Darwin[0] <= '9') { + unsigned DarwinNo = atoi(Darwin); + if (DarwinNo > 4) { + char DarwinStr[] = "10x0"; + // darwin7 -> 1030, darwin8 -> 1040, darwin9 -> 1050, etc. + DarwinStr[2] = '0' + DarwinNo-4; + Define(Defs, "__ENVIRONMENT_MAC_OS_X_VERSION_MIN_REQUIRED__",DarwinStr); + } + } + } } static void getDragonFlyDefines(std::vector &Defs) { @@ -509,7 +523,7 @@ public: DarwinPPCTargetInfo(const std::string& triple) : PPC32TargetInfo(triple) {} virtual void getTargetDefines(std::vector &Defines) const { PPC32TargetInfo::getTargetDefines(Defines); - getDarwinDefines(Defines); + getDarwinDefines(Defines, getTargetTriple()); } virtual bool useNeXTRuntimeAsDefault() const { return true; } @@ -522,7 +536,7 @@ public: DarwinPPC64TargetInfo(const std::string& triple) : PPC64TargetInfo(triple) {} virtual void getTargetDefines(std::vector &Defines) const { PPC64TargetInfo::getTargetDefines(Defines); - getDarwinDefines(Defines); + getDarwinDefines(Defines, getTargetTriple()); } virtual bool useNeXTRuntimeAsDefault() const { return true; } @@ -668,7 +682,7 @@ public: } virtual void getTargetDefines(std::vector &Defines) const { X86_32TargetInfo::getTargetDefines(Defines); - getDarwinDefines(Defines); + getDarwinDefines(Defines, getTargetTriple()); } virtual bool useNeXTRuntimeAsDefault() const { return true; } }; @@ -777,7 +791,7 @@ public: virtual void getTargetDefines(std::vector &Defines) const { X86_64TargetInfo::getTargetDefines(Defines); - getDarwinDefines(Defines); + getDarwinDefines(Defines, getTargetTriple()); } virtual bool useNeXTRuntimeAsDefault() const { return true; } @@ -848,7 +862,7 @@ public: virtual void getTargetDefines(std::vector &Defines) const { ARMTargetInfo::getTargetDefines(Defines); - getDarwinDefines(Defines); + getDarwinDefines(Defines, getTargetTriple()); } }; } // end anonymous namespace.