swiftlang/swift

Invalid fix-it on unused optional binding when multiple conditions

Open

#89.131 aperta il 14 mag 2026

Vedi su GitHub
 (2 commenti) (0 reazioni) (1 assegnatario)Swift (10.719 fork)batch import
compilerdiagnostics qualityfix-itsgood first issuestatementsswift 6.4type checker

Metriche repository

Star
 (69.989 star)
Metriche merge PR
 (Merge medio 7g 6h) (556 PR mergiate in 30 g)

Descrizione

Description

No response

Reproduction

func sync() -> Int? {}
func async() async -> Int? {}
do {
  if let x = sync(), true {} // bad fix-it
  if let x = sync() {}      // good fix-it

  if let x = await async(), true {} // bad fix-it
  if let x = await async() {}     // good fix-it
}
warning: immutable value 'x' was never used; consider replacing with '_' or removing it [#NoUsage]
  if let x = sync(), true {}
     ~~~~^
     _
warning: value 'x' was defined but never used; consider replacing with boolean test [#NoUsage]
  if let x = sync() {}
     ~~~~^~~~
                    != nil
warning: immutable value 'x' was never used; consider replacing with '_' or removing it [#NoUsage]
  if let x = await async(), true {}
     ~~~~^
     _
warning: value 'x' was defined but never used; consider replacing with boolean test [#NoUsage]
  if let x = await async() {}
     ~~~~^~~~
     (                    ) != nil

Expected behavior

Fix-it should match the one we emit when the condition is single.

Environment

f0d8239caeefc8b

Additional information

Please add tests for both if let x = sync(), true and if true, let x = sync().

Guida contributor