================ @@ -1118,16 +1121,40 @@ void WhitespaceManager::alignTrailingComments() { } } - // We don't want to align namespace end comments. - const bool DontAlignThisComment = - I > 0 && C.NewlinesBefore == 0 && - Changes[I - 1].Tok->is(TT_NamespaceRBrace); - if (Style.AlignTrailingComments.Kind == FormatStyle::TCAS_Never || - DontAlignThisComment) { + // We don't want to align comments which end a scope, which are here + // identified by most closing braces. + const bool DontAlignThisComment = [&] { + if (I == 0) + return false; + if (C.NewlinesBefore != 0) + return false; + const auto &PrevChange = Changes[I - 1]; + if (PrevChange.Tok->is(tok::r_brace)) + return true; + if (PrevChange.Tok->is(tok::semi)) { + if (auto PrevNonComment = PrevChange.Tok->getPreviousNonComment()) { + if (PrevNonComment->is(tok::r_paren) && + PrevNonComment->MatchingParen && + PrevNonComment->MatchingParen->endsSequence( + tok::l_paren, tok::kw_while, TT_ControlStatementRBrace)) { + return true; + } + return PrevNonComment->isOneOf( + TT_ClassRBrace, TT_ControlStatementRBrace, TT_ElseRBrace, + TT_EnumRBrace, TT_NamespaceRBrace, TT_RecordRBrace, + TT_StructRBrace, TT_UnionRBrace); + } + } + return false; ---------------- owenca wrote:
```suggestion if (I == 0 || C.NewlinesBefore > 0) return false; const auto *Tok = Changes[I - 1].Tok; if (Tok->is(tok::semi)) { Tok = Tok->Previous; if (!Tok) return false; } if (Tok->isNot(tok::r_brace)) return false; while (Tok->Previous && Tok->Previous->is(tok::r_brace)) Tok = Tok->Previous; return Tok->NewlinesBefore > 0; ``` https://github.com/llvm/llvm-project/pull/68743 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits