forked from OSchip/llvm-project
[clang][cli] Generate and round-trip Target options
This patch implements generation of remaining target options and tests it by performing parse-generate-parse round trip. Reviewed By: dexonsmith Differential Revision: https://reviews.llvm.org/D96158
This commit is contained in:
parent
cb933632bc
commit
b89af18d9e
|
@ -246,7 +246,7 @@ class DiagnosticOpts<string base>
|
||||||
class LangOpts<string base>
|
class LangOpts<string base>
|
||||||
: KeyPathAndMacro<"LangOpts->", base, "LANG_"> {}
|
: KeyPathAndMacro<"LangOpts->", base, "LANG_"> {}
|
||||||
class TargetOpts<string base>
|
class TargetOpts<string base>
|
||||||
: KeyPathAndMacro<"TargetOpts->", base> {}
|
: KeyPathAndMacro<"TargetOpts->", base, "TARGET_"> {}
|
||||||
class FrontendOpts<string base>
|
class FrontendOpts<string base>
|
||||||
: KeyPathAndMacro<"FrontendOpts.", base, "FRONTEND_"> {}
|
: KeyPathAndMacro<"FrontendOpts.", base, "FRONTEND_"> {}
|
||||||
class PreprocessorOutputOpts<string base>
|
class PreprocessorOutputOpts<string base>
|
||||||
|
|
|
@ -4179,8 +4179,44 @@ static bool ParsePreprocessorOutputArgs(CompilerInvocation &Res,
|
||||||
Res, Args, Diags, "PreprocessorOutputOptions");
|
Res, Args, Diags, "PreprocessorOutputOptions");
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ParseTargetArgs(TargetOptions &Opts, ArgList &Args,
|
static void GenerateTargetArgs(const TargetOptions &Opts,
|
||||||
DiagnosticsEngine &Diags) {
|
SmallVectorImpl<const char *> &Args,
|
||||||
|
CompilerInvocation::StringAllocator SA) {
|
||||||
|
const TargetOptions *TargetOpts = &Opts;
|
||||||
|
#define TARGET_OPTION_WITH_MARSHALLING( \
|
||||||
|
PREFIX_TYPE, NAME, ID, KIND, GROUP, ALIAS, ALIASARGS, FLAGS, PARAM, \
|
||||||
|
HELPTEXT, METAVAR, VALUES, SPELLING, SHOULD_PARSE, ALWAYS_EMIT, KEYPATH, \
|
||||||
|
DEFAULT_VALUE, IMPLIED_CHECK, IMPLIED_VALUE, NORMALIZER, DENORMALIZER, \
|
||||||
|
MERGER, EXTRACTOR, TABLE_INDEX) \
|
||||||
|
GENERATE_OPTION_WITH_MARSHALLING( \
|
||||||
|
Args, SA, KIND, FLAGS, SPELLING, ALWAYS_EMIT, KEYPATH, DEFAULT_VALUE, \
|
||||||
|
IMPLIED_CHECK, IMPLIED_VALUE, DENORMALIZER, EXTRACTOR, TABLE_INDEX)
|
||||||
|
#include "clang/Driver/Options.inc"
|
||||||
|
#undef TARGET_OPTION_WITH_MARSHALLING
|
||||||
|
|
||||||
|
if (!Opts.SDKVersion.empty())
|
||||||
|
GenerateArg(Args, OPT_target_sdk_version_EQ, Opts.SDKVersion.getAsString(),
|
||||||
|
SA);
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool ParseTargetArgsImpl(TargetOptions &Opts, ArgList &Args,
|
||||||
|
DiagnosticsEngine &Diags) {
|
||||||
|
TargetOptions *TargetOpts = &Opts;
|
||||||
|
unsigned NumErrorsBefore = Diags.getNumErrors();
|
||||||
|
bool Success = true;
|
||||||
|
|
||||||
|
#define TARGET_OPTION_WITH_MARSHALLING( \
|
||||||
|
PREFIX_TYPE, NAME, ID, KIND, GROUP, ALIAS, ALIASARGS, FLAGS, PARAM, \
|
||||||
|
HELPTEXT, METAVAR, VALUES, SPELLING, SHOULD_PARSE, ALWAYS_EMIT, KEYPATH, \
|
||||||
|
DEFAULT_VALUE, IMPLIED_CHECK, IMPLIED_VALUE, NORMALIZER, DENORMALIZER, \
|
||||||
|
MERGER, EXTRACTOR, TABLE_INDEX) \
|
||||||
|
PARSE_OPTION_WITH_MARSHALLING(Args, Diags, Success, ID, FLAGS, PARAM, \
|
||||||
|
SHOULD_PARSE, KEYPATH, DEFAULT_VALUE, \
|
||||||
|
IMPLIED_CHECK, IMPLIED_VALUE, NORMALIZER, \
|
||||||
|
MERGER, TABLE_INDEX)
|
||||||
|
#include "clang/Driver/Options.inc"
|
||||||
|
#undef TARGET_OPTION_WITH_MARSHALLING
|
||||||
|
|
||||||
if (Arg *A = Args.getLastArg(options::OPT_target_sdk_version_EQ)) {
|
if (Arg *A = Args.getLastArg(options::OPT_target_sdk_version_EQ)) {
|
||||||
llvm::VersionTuple Version;
|
llvm::VersionTuple Version;
|
||||||
if (Version.tryParse(A->getValue()))
|
if (Version.tryParse(A->getValue()))
|
||||||
|
@ -4189,6 +4225,27 @@ static void ParseTargetArgs(TargetOptions &Opts, ArgList &Args,
|
||||||
else
|
else
|
||||||
Opts.SDKVersion = Version;
|
Opts.SDKVersion = Version;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return Success && Diags.getNumErrors() == NumErrorsBefore;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool ParseTargetArgs(CompilerInvocation &Res, TargetOptions &Opts,
|
||||||
|
ArgList &Args, DiagnosticsEngine &Diags) {
|
||||||
|
auto DummyOpts = std::make_shared<TargetOptions>();
|
||||||
|
|
||||||
|
return RoundTrip(
|
||||||
|
[](CompilerInvocation &Res, ArgList &Args,
|
||||||
|
DiagnosticsEngine &Diags) {
|
||||||
|
return ParseTargetArgsImpl(Res.getTargetOpts(), Args, Diags);
|
||||||
|
},
|
||||||
|
[](CompilerInvocation &Res, SmallVectorImpl<const char *> &GeneratedArgs,
|
||||||
|
CompilerInvocation::StringAllocator SA) {
|
||||||
|
GenerateTargetArgs(Res.getTargetOpts(), GeneratedArgs, SA);
|
||||||
|
},
|
||||||
|
[&DummyOpts](CompilerInvocation &Res) {
|
||||||
|
Res.TargetOpts.swap(DummyOpts);
|
||||||
|
},
|
||||||
|
Res, Args, Diags, "TargetArgs");
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CompilerInvocation::CreateFromArgs(CompilerInvocation &Res,
|
bool CompilerInvocation::CreateFromArgs(CompilerInvocation &Res,
|
||||||
|
@ -4239,7 +4296,7 @@ bool CompilerInvocation::CreateFromArgs(CompilerInvocation &Res,
|
||||||
LangOpts.IsHeaderFile);
|
LangOpts.IsHeaderFile);
|
||||||
// FIXME: We shouldn't have to pass the DashX option around here
|
// FIXME: We shouldn't have to pass the DashX option around here
|
||||||
InputKind DashX = Res.getFrontendOpts().DashX;
|
InputKind DashX = Res.getFrontendOpts().DashX;
|
||||||
ParseTargetArgs(Res.getTargetOpts(), Args, Diags);
|
ParseTargetArgs(Res, Res.getTargetOpts(), Args, Diags);
|
||||||
llvm::Triple T(Res.getTargetOpts().Triple);
|
llvm::Triple T(Res.getTargetOpts().Triple);
|
||||||
ParseHeaderSearchArgs(Res, Res.getHeaderSearchOpts(), Args, Diags,
|
ParseHeaderSearchArgs(Res, Res.getHeaderSearchOpts(), Args, Diags,
|
||||||
Res.getFileSystemOpts().WorkingDir);
|
Res.getFileSystemOpts().WorkingDir);
|
||||||
|
@ -4456,6 +4513,7 @@ void CompilerInvocation::generateCC1CommandLine(
|
||||||
|
|
||||||
GenerateAnalyzerArgs(*AnalyzerOpts, Args, SA);
|
GenerateAnalyzerArgs(*AnalyzerOpts, Args, SA);
|
||||||
GenerateFrontendArgs(FrontendOpts, Args, SA, LangOpts->IsHeaderFile);
|
GenerateFrontendArgs(FrontendOpts, Args, SA, LangOpts->IsHeaderFile);
|
||||||
|
GenerateTargetArgs(*TargetOpts, Args, SA);
|
||||||
GenerateHeaderSearchArgs(*HeaderSearchOpts, Args, SA);
|
GenerateHeaderSearchArgs(*HeaderSearchOpts, Args, SA);
|
||||||
GenerateLangArgs(*LangOpts, Args, SA, T);
|
GenerateLangArgs(*LangOpts, Args, SA, T);
|
||||||
GenerateCodeGenArgs(CodeGenOpts, Args, SA, T, FrontendOpts.OutputFile,
|
GenerateCodeGenArgs(CodeGenOpts, Args, SA, T, FrontendOpts.OutputFile,
|
||||||
|
|
Loading…
Reference in New Issue