mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Replaced -disable-copy-prop with multi-var.
Replaced the -disable-copy-propagation flag with -enable-copy-propagation=false where the latter is a new multi-var -enable-copy-propagation= which can take one of three values: - true - requested-passes-only - false
This commit is contained in:
@@ -1463,6 +1463,42 @@ static bool ParseSILArgs(SILOptions &Opts, ArgList &Args,
|
||||
// -Ounchecked might also set removal of runtime asserts (cond_fail).
|
||||
Opts.RemoveRuntimeAsserts |= Args.hasArg(OPT_RemoveRuntimeAsserts);
|
||||
|
||||
Optional<CopyPropagationOption> specifiedCopyPropagationOption;
|
||||
if (Arg *A = Args.getLastArg(OPT_copy_propagation_state_EQ)) {
|
||||
specifiedCopyPropagationOption =
|
||||
llvm::StringSwitch<Optional<CopyPropagationOption>>(A->getValue())
|
||||
.Case("true", CopyPropagationOption::On)
|
||||
.Case("false", CopyPropagationOption::Off)
|
||||
.Case("requested-passes-only",
|
||||
CopyPropagationOption::RequestedPassesOnly)
|
||||
.Default(None);
|
||||
}
|
||||
if (Args.hasArg(OPT_enable_copy_propagation)) {
|
||||
if (specifiedCopyPropagationOption) {
|
||||
if (*specifiedCopyPropagationOption == CopyPropagationOption::Off) {
|
||||
// Error if copy propagation has been set to ::Off via the meta-var form
|
||||
// and enabled via the flag.
|
||||
Diags.diagnose(SourceLoc(), diag::error_invalid_arg_combination,
|
||||
"enable-copy-propagation",
|
||||
"enable-copy-propagation=false");
|
||||
return true;
|
||||
} else if (*specifiedCopyPropagationOption ==
|
||||
CopyPropagationOption::RequestedPassesOnly) {
|
||||
// Error if copy propagation has been set to ::RequestedPassesOnly via
|
||||
// the meta-var form and enabled via the flag.
|
||||
Diags.diagnose(SourceLoc(), diag::error_invalid_arg_combination,
|
||||
"enable-copy-propagation",
|
||||
"enable-copy-propagation=requested-passes-only");
|
||||
return true;
|
||||
}
|
||||
} else {
|
||||
specifiedCopyPropagationOption = CopyPropagationOption::On;
|
||||
}
|
||||
}
|
||||
if (specifiedCopyPropagationOption) {
|
||||
Opts.CopyPropagation = *specifiedCopyPropagationOption;
|
||||
}
|
||||
|
||||
Optional<bool> enableLexicalBorrowScopesFlag;
|
||||
if (Arg *A = Args.getLastArg(OPT_enable_lexical_borrow_scopes)) {
|
||||
enableLexicalBorrowScopesFlag =
|
||||
@@ -1552,24 +1588,6 @@ static bool ParseSILArgs(SILOptions &Opts, ArgList &Args,
|
||||
}
|
||||
}
|
||||
|
||||
if (Args.hasArg(OPT_enable_copy_propagation) &&
|
||||
Args.hasArg(OPT_disable_copy_propagation)) {
|
||||
// Error if copy propagation is enabled and copy propagation is disabled.
|
||||
Diags.diagnose(SourceLoc(), diag::error_invalid_arg_combination,
|
||||
"enable-copy-propagation", "disable-copy-propagation");
|
||||
return true;
|
||||
} else if (Args.hasArg(OPT_enable_copy_propagation) &&
|
||||
!Args.hasArg(OPT_disable_copy_propagation)) {
|
||||
Opts.CopyPropagation = CopyPropagationOption::On;
|
||||
} else if (!Args.hasArg(OPT_enable_copy_propagation) &&
|
||||
Args.hasArg(OPT_disable_copy_propagation)) {
|
||||
Opts.CopyPropagation = CopyPropagationOption::Off;
|
||||
} else /*if (!Args.hasArg(OPT_enable_copy_propagation) &&
|
||||
!Args.hasArg(OPT_disable_copy_propagation))*/
|
||||
{
|
||||
Opts.CopyPropagation = CopyPropagationOption::RequestedPassesOnly;
|
||||
}
|
||||
|
||||
Opts.EnableARCOptimizations &= !Args.hasArg(OPT_disable_arc_opts);
|
||||
Opts.EnableOSSAModules |= Args.hasArg(OPT_enable_ossa_modules);
|
||||
Opts.EnableOSSAOptimizations &= !Args.hasArg(OPT_disable_ossa_opts);
|
||||
|
||||
Reference in New Issue
Block a user