forked from OSchip/llvm-project
In the driver, -fmodules enables modules for C/Objective-C but one
also needs -fcxx-modules to enable modules for C++/Objective-C++. llvm-svn: 148393
This commit is contained in:
parent
6255c257e9
commit
226173ae93
|
@ -296,6 +296,7 @@ def fconstexpr_backtrace_limit_EQ : Joined<"-fconstexpr-backtrace-limit=">,
|
|||
Group<f_Group>;
|
||||
def fcreate_profile : Flag<"-fcreate-profile">, Group<f_Group>;
|
||||
def fcxx_exceptions: Flag<"-fcxx-exceptions">, Group<f_Group>;
|
||||
def fcxx_modules : Flag <"-fcxx-modules">, Group<f_Group>, Flags<[NoForward]>;
|
||||
def fdebug_pass_arguments : Flag<"-fdebug-pass-arguments">, Group<f_Group>;
|
||||
def fdebug_pass_structure : Flag<"-fdebug-pass-structure">, Group<f_Group>;
|
||||
def fdiagnostics_fixit_info : Flag<"-fdiagnostics-fixit-info">, Group<f_clang_Group>;
|
||||
|
@ -401,6 +402,7 @@ def fno_color_diagnostics : Flag<"-fno-color-diagnostics">, Group<f_Group>;
|
|||
def fno_common : Flag<"-fno-common">, Group<f_Group>;
|
||||
def fno_constant_cfstrings : Flag<"-fno-constant-cfstrings">, Group<f_Group>;
|
||||
def fno_cxx_exceptions: Flag<"-fno-cxx-exceptions">, Group<f_Group>;
|
||||
def fno_cxx_modules : Flag <"-fno-cxx-modules">, Group<f_Group>, Flags<[NoForward]>;
|
||||
def fno_diagnostics_fixit_info : Flag<"-fno-diagnostics-fixit-info">, Group<f_Group>;
|
||||
def fno_diagnostics_show_name : Flag<"-fno-diagnostics-show-name">, Group<f_Group>;
|
||||
def fno_diagnostics_show_option : Flag<"-fno-diagnostics-show-option">, Group<f_Group>;
|
||||
|
|
|
@ -2029,8 +2029,16 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
|
|||
CmdArgs.push_back("-fblocks-runtime-optional");
|
||||
}
|
||||
|
||||
if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false))
|
||||
CmdArgs.push_back("-fmodules");
|
||||
// -fmodules enables modules (off by default). However, for C++/Objective-C++,
|
||||
// users must also pass -fcxx-modules. The latter flag will disappear once the
|
||||
// modules implementation is solid for C++/Objective-C++ programs as well.
|
||||
if (Args.hasFlag(options::OPT_fmodules, options::OPT_fno_modules, false)) {
|
||||
bool AllowedInCXX = Args.hasFlag(options::OPT_fcxx_modules,
|
||||
options::OPT_fno_cxx_modules,
|
||||
false);
|
||||
if (AllowedInCXX || !types::isCXX(InputType))
|
||||
CmdArgs.push_back("-fmodules");
|
||||
}
|
||||
|
||||
// -faccess-control is default.
|
||||
if (Args.hasFlag(options::OPT_fno_access_control,
|
||||
|
|
|
@ -0,0 +1,6 @@
|
|||
// RUN: %clang -fmodules -### %s 2>&1 | FileCheck -check-prefix=CHECK-NO-MODULES %s
|
||||
// RUN: %clang -fcxx-modules -### %s 2>&1 | FileCheck -check-prefix=CHECK-NO-MODULES %s
|
||||
// CHECK-NO-MODULES-NOT: -fmodules
|
||||
|
||||
// RUN: %clang -fcxx-modules -fmodules -### %s 2>&1 | FileCheck -check-prefix=CHECK-HAS-MODULES %s
|
||||
// CHECK-HAS-MODULES: -fmodules
|
Loading…
Reference in New Issue