Index: clang/lib/Format/TokenAnnotator.cpp =================================================================== --- clang/lib/Format/TokenAnnotator.cpp +++ clang/lib/Format/TokenAnnotator.cpp @@ -145,6 +145,10 @@ Contexts[Contexts.size() - 2].IsExpression && !Line.startsWith(tok::kw_template)) return false; + // If we see a ; then likely this is a for loop and not the template + if (CurrentToken->is(tok::semi)) + return false; + updateParameterCount(Left, CurrentToken); if (Style.Language == FormatStyle::LK_Proto) { if (FormatToken *Previous = CurrentToken->getPreviousNonComment()) { Index: clang/unittests/Format/FormatTest.cpp =================================================================== --- clang/unittests/Format/FormatTest.cpp +++ clang/unittests/Format/FormatTest.cpp @@ -7065,6 +7065,8 @@ verifyFormat("static_assert(is_convertible::value, \"AAA\");"); verifyFormat("Constructor(A... a) : a_(X{std::forward(a)}...) {}"); verifyFormat("< < < < < < < < < < < < < < < < < < < < < < < < < < < < < <"); + + verifyFormat("for ( unsigned i = 0; i < i; ++i, v = v >> 1 )"); } TEST_F(FormatTest, BitshiftOperatorWidth) {