mirror of https://github.com/microsoft/clang.git
Add __has_feature(modules) to indicate when modules are available (in
any language variant), and restrict __has_feature(objc_modules) to mean that we also have the Objective-C @import syntax. I anticipate __has_feature(cxx_modules) and/or __has_feature(c_modules) for when we nail down the module syntax for C/C++. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@147548 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b7d09c8606
commit
bd507c5ef3
|
@ -617,7 +617,7 @@ static bool HasFeature(const Preprocessor &PP, const IdentifierInfo *II) {
|
|||
LangOpts.ObjCRuntimeHasWeak)
|
||||
.Case("objc_fixed_enum", LangOpts.ObjC2)
|
||||
.Case("objc_instancetype", LangOpts.ObjC2)
|
||||
.Case("objc_modules", LangOpts.Modules)
|
||||
.Case("objc_modules", LangOpts.ObjC2 && LangOpts.Modules)
|
||||
.Case("objc_nonfragile_abi", LangOpts.ObjCNonFragileABI)
|
||||
.Case("objc_weak_class", LangOpts.ObjCNonFragileABI)
|
||||
.Case("ownership_holds", true)
|
||||
|
@ -698,6 +698,7 @@ static bool HasFeature(const Preprocessor &PP, const IdentifierInfo *II) {
|
|||
.Case("is_trivial", LangOpts.CPlusPlus)
|
||||
.Case("is_trivially_copyable", LangOpts.CPlusPlus)
|
||||
.Case("is_union", LangOpts.CPlusPlus)
|
||||
.Case("modules", LangOpts.Modules)
|
||||
.Case("tls", PP.getTargetInfo().isTLSSupported())
|
||||
.Case("underlying_type", LangOpts.CPlusPlus)
|
||||
.Default(false);
|
||||
|
|
|
@ -1,7 +1,12 @@
|
|||
// RUN: %clang_cc1 -E -fmodules %s -o - | FileCheck --check-prefix=CHECK-HAS-OBJC-MODULES %s
|
||||
// RUN: %clang_cc1 -E %s -o - | FileCheck --check-prefix=CHECK-NO-OBJC-MODULES %s
|
||||
// RUN: %clang_cc1 -E -x c -fmodules %s -o - | FileCheck --check-prefix=CHECK-NO-OBJC-MODULES %s
|
||||
|
||||
// RUN: %clang_cc1 -E -fmodules %s -o - | FileCheck --check-prefix=CHECK-HAS-MODULES %s
|
||||
// RUN: %clang_cc1 -E %s -o - | FileCheck --check-prefix=CHECK-NO-MODULES %s
|
||||
// RUN: %clang_cc1 -E -x c -fmodules %s -o - | FileCheck --check-prefix=CHECK-HAS-MODULES %s
|
||||
|
||||
#if __has_feature(objc_modules)
|
||||
#if __has_feature(modules)
|
||||
int has_modules();
|
||||
#else
|
||||
int no_modules();
|
||||
|
@ -9,3 +14,12 @@ int no_modules();
|
|||
|
||||
// CHECK-HAS-MODULES: has_modules
|
||||
// CHECK-NO-MODULES: no_modules
|
||||
|
||||
#if __has_feature(objc_modules)
|
||||
int has_objc_modules();
|
||||
#else
|
||||
int no_objc_modules();
|
||||
#endif
|
||||
|
||||
// CHECK-HAS-OBJC-MODULES: has_objc_modules
|
||||
// CHECK-NO-OBJC-MODULES: no_objc_modules
|
||||
|
|
Loading…
Reference in New Issue