Search code examples
c++code-formattingclang-format

How can I apply only one clang-format action?


I want to use clang-format to align my comments, but nothing else.

The option for that is: AlignTrailingComments (bool).

But when I run the following:

clang-format-3.6 -i -style='{AlignTrailingComments: true}' <file>

It performs all kinds of other formatting options that I suppose have a default when unspecified.

How can I execute just one clang formatting rule on the codebase?

Having all of these defaults make it difficult to see the full effect that a single formatting option has on the code. I have to parse through the diff of all these other changes and decide if it was the option I specified that actually did it.


I noticed that there is a DisableFormat option, but no matter how I use it, it stops any formatting from happening at all.

clang-format-3.6 -i -style='{AlignTrailingComments: true, DisableFormat: true}'

clang-format-3.6 -i -style='{DisableFormat: true, AlignTrailingComments: true}'

Both cause clang-format to not make any code anywhere.


Solution

  • I think clang format was simply not designed for this. Rules are not things it applies incrementally, the program is instead built around, parsing your entire program and forgetting (most of) the old whitespace, and generating new whitespace based on the rules you select.

    You can see some overview of the architecture here: http://www.llvm.org/devmtg/2013-04/jasper-slides.pdf

    First it runs clang lexer and parser, then it divides groups of tokens into "unwrapped lines" which are "tokens we would like to put together on a single line if there was no column limit". Then a layouter determines the formatting of each unwrapped line based on the various constraints and optimizing for the various penalties.

    So, I don't think "one clang-format action" is actually a thing, the design looks pretty much monolithic to me.