Merge pull request #85939 from xedin/rdar-159408715

[Diagnostics] Don't attempt to synthesize arguments when destructurin…
This commit is contained in:
Pavel Yaskevich
2025-12-10 06:49:02 -08:00
committed by GitHub
2 changed files with 7 additions and 1 deletions

View File

@@ -2747,6 +2747,12 @@ static bool fixMissingArguments(ConstraintSystem &cs, ASTNode anchor,
args.pop_back();
for (const auto &elt : tuple->getElements())
args.emplace_back(elt.getType(), elt.getName());
// If unpacking a tuple results in more arguments than parameters
// it would be diagnosed as a general mismatch because it's unclear
// whether it's a problem with missing or extraneous parameters.
if (args.size() > params.size())
return true;
} else if (auto *typeVar = argType->getAs<TypeVariableType>()) {
auto isParam = [](const Expr *expr) {
if (auto *DRE = dyn_cast<DeclRefExpr>(expr)) {

View File

@@ -1,4 +1,4 @@
// {"kind":"typecheck","languageMode":6,"signature":"fixMissingArguments(swift::constraints::ConstraintSystem&, swift::ASTNode, llvm::SmallVectorImpl<swift::AnyFunctionType::Param>&, llvm::ArrayRef<swift::AnyFunctionType::Param>, unsigned int, swift::constraints::ConstraintLocatorBuilder)","signatureAssert":"Assertion failed: (Index < Length && \"Invalid index!\"), function operator[]"}
// RUN: not --crash %target-swift-frontend -typecheck -swift-version 6 %s
// RUN: not %target-swift-frontend -typecheck -swift-version 6 %s
func a((Int, Int, Int)) a > {
b, c in