diff options
author | Chris Lattner <sabre@nondot.org> | 2008-09-30 01:00:25 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-09-30 01:00:25 +0000 |
commit | 8b30c412198ed004d999f0047e48f87b95bd3205 (patch) | |
tree | 094c31087de316c43af093e31fec6f96a3cf9cf4 /lib/Basic/Targets.cpp | |
parent | 048dd943fc22a3ee60180d6992d744106c4c100a (diff) |
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
Diffstat (limited to 'lib/Basic/Targets.cpp')
-rw-r--r-- | lib/Basic/Targets.cpp | 28 |
1 files changed, 21 insertions, 7 deletions
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<char> &Defs) { Define(Defs, "__SOLARIS__"); } -static void getDarwinDefines(std::vector<char> &Defs) { +static void getDarwinDefines(std::vector<char> &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<char> &Defs) { @@ -509,7 +523,7 @@ public: DarwinPPCTargetInfo(const std::string& triple) : PPC32TargetInfo(triple) {} virtual void getTargetDefines(std::vector<char> &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<char> &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<char> &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<char> &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<char> &Defines) const { ARMTargetInfo::getTargetDefines(Defines); - getDarwinDefines(Defines); + getDarwinDefines(Defines, getTargetTriple()); } }; } // end anonymous namespace. |