forked from OSchip/llvm-project
[clang][cli] Store InputKind in FrontendOptions
This patch stores the `InputKind` (parsed mainly from `-x`) to `FrontendOptions`. This is necessary for command line generation. Reviewed By: dexonsmith Differential Revision: https://reviews.llvm.org/D96149
This commit is contained in:
parent
89d9ff8229
commit
521e1733f1
|
@ -374,6 +374,10 @@ public:
|
|||
std::string MTMigrateDir;
|
||||
std::string ARCMTMigrateReportOut;
|
||||
|
||||
/// The input kind, either specified via -x argument or deduced from the input
|
||||
/// file name.
|
||||
InputKind DashX;
|
||||
|
||||
/// The input files and their types.
|
||||
SmallVector<FrontendInputFile, 0> Inputs;
|
||||
|
||||
|
|
|
@ -2153,9 +2153,10 @@ static bool parseTestModuleFileExtensionArg(StringRef Arg,
|
|||
return false;
|
||||
}
|
||||
|
||||
static InputKind ParseFrontendArgs(FrontendOptions &Opts, ArgList &Args,
|
||||
DiagnosticsEngine &Diags,
|
||||
bool &IsHeaderFile) {
|
||||
static bool ParseFrontendArgs(FrontendOptions &Opts, ArgList &Args,
|
||||
DiagnosticsEngine &Diags, bool &IsHeaderFile) {
|
||||
unsigned NumErrorsBefore = Diags.getNumErrors();
|
||||
|
||||
Opts.ProgramAction = frontend::ParseSyntaxOnly;
|
||||
if (const Arg *A = Args.getLastArg(OPT_Action_Group)) {
|
||||
switch (A->getOption().getID()) {
|
||||
|
@ -2424,7 +2425,9 @@ static InputKind ParseFrontendArgs(FrontendOptions &Opts, ArgList &Args,
|
|||
Opts.Inputs.emplace_back(std::move(Inputs[i]), IK, IsSystem);
|
||||
}
|
||||
|
||||
return DashX;
|
||||
Opts.DashX = DashX;
|
||||
|
||||
return Diags.getNumErrors() == NumErrorsBefore;
|
||||
}
|
||||
|
||||
std::string CompilerInvocation::GetResourcesPath(const char *Argv0,
|
||||
|
@ -3968,9 +3971,10 @@ bool CompilerInvocation::CreateFromArgs(CompilerInvocation &Res,
|
|||
}
|
||||
Success &= ParseDiagnosticArgs(Res.getDiagnosticOpts(), Args, &Diags,
|
||||
/*DefaultDiagColor=*/false);
|
||||
Success &= ParseFrontendArgs(Res.getFrontendOpts(), Args, Diags,
|
||||
LangOpts.IsHeaderFile);
|
||||
// FIXME: We shouldn't have to pass the DashX option around here
|
||||
InputKind DashX = ParseFrontendArgs(Res.getFrontendOpts(), Args, Diags,
|
||||
LangOpts.IsHeaderFile);
|
||||
InputKind DashX = Res.getFrontendOpts().DashX;
|
||||
ParseTargetArgs(Res.getTargetOpts(), Args, Diags);
|
||||
llvm::Triple T(Res.getTargetOpts().Triple);
|
||||
ParseHeaderSearchArgs(Res, Res.getHeaderSearchOpts(), Args, Diags,
|
||||
|
|
Loading…
Reference in New Issue