diff --git a/scalafmt-core/shared/src/main/scala/org/scalafmt/internal/FormatWriter.scala b/scalafmt-core/shared/src/main/scala/org/scalafmt/internal/FormatWriter.scala index f4cdd8b515..6fa02b7a2b 100644 --- a/scalafmt-core/shared/src/main/scala/org/scalafmt/internal/FormatWriter.scala +++ b/scalafmt-core/shared/src/main/scala/org/scalafmt/internal/FormatWriter.scala @@ -162,7 +162,7 @@ class FormatWriter(formatOps: FormatOps) { val ok = tok.meta.leftOwner match { case b: Term.Block => checkApply(b) && RedundantBraces.canRewriteBlockWithParens(b) && - b.parent.exists(_.tokens.last.start == rb.start) + b.parent.exists(tokens.getLast(_) eq tok) case f: Term.FunctionTerm => checkApply(f) && RedundantBraces.canRewriteFuncWithParens(f) case t @ TreeOps.SingleArgInBraces(arg) => diff --git a/scalafmt-core/shared/src/main/scala/org/scalafmt/rewrite/RedundantBraces.scala b/scalafmt-core/shared/src/main/scala/org/scalafmt/rewrite/RedundantBraces.scala index 5d0b275ff0..1acf0716cb 100644 --- a/scalafmt-core/shared/src/main/scala/org/scalafmt/rewrite/RedundantBraces.scala +++ b/scalafmt-core/shared/src/main/scala/org/scalafmt/rewrite/RedundantBraces.scala @@ -27,14 +27,19 @@ object RedundantBraces extends Rewrite with FormatTokensRewrite.RuleFactory { case _ => false } - def canRewriteBlockWithParens(b: Term.Block): Boolean = + def canRewriteBlockWithParens(b: Term.Block)(implicit + ftoks: FormatTokens + ): Boolean = getBlockSingleStat(b).exists(canRewriteStatWithParens) - def canRewriteStatWithParens(t: Stat): Boolean = + def canRewriteStatWithParens(t: Stat)(implicit ftoks: FormatTokens): Boolean = t match { case f: Term.FunctionTerm => canRewriteFuncWithParens(f) case _: Term.Assign => false // disallowed in 2.13 case _: Defn => false + case _: Term.PartialFunction => false + case b @ Term.Block(s :: Nil) if !ftoks.isEnclosedInMatching(b) => + canRewriteStatWithParens(s) case _ => true } diff --git a/scalafmt-tests/src/test/resources/rewrite/RedundantParens.stat b/scalafmt-tests/src/test/resources/rewrite/RedundantParens.stat index 47b44540a2..74ee3f3542 100644 --- a/scalafmt-tests/src/test/resources/rewrite/RedundantParens.stat +++ b/scalafmt-tests/src/test/resources/rewrite/RedundantParens.stat @@ -1404,3 +1404,9 @@ object A { Option(""), ).map(identity) } +<<< func in parens and braces, single line +rewrite.rules = [RedundantBraces, RedundantParens] +=== +foo.mtd({ x => x + 1 }) +>>> +foo.mtd(x => x + 1)