Reputation: 510
I am working on a c++ project where I am using a lot of #pragma omp
. I use the wonderful clang-format for tidiness but it always deletes the indentation for all preprocessor directives. Is there a way to change that behavior? Or is there another formatting tool that is more recommendable? Or should I avoid using these tools at all?
Upvotes: 48
Views: 17449
Reputation: 52449
By manual inspection of the various Clang-Format Style Options pages, I have determined that as of Clang-format version 9, a 3rd (and best, in my opinion) option came out, called BeforeHash
.
Note: as of the time of this writing, Clang 12 is out. For the latest Clang-format options documentation for whatever version is currently out, see here: https://clang.llvm.org/docs/ClangFormatStyleOptions.html.
In your .clang-format
file, you can therefore specify 3 options, as follows:
IndentPPDirectives: None
Example:
#if FOO
#if BAR
#include <foo>
#endif
#endif
#
)IndentPPDirectives: AfterHash
Example:
#if FOO
# if BAR
# include <foo>
# endif
#endif
#
)IndentPPDirectives: BeforeHash
Example:
#if FOO
#if BAR
#include <foo>
#endif
#endif
clang-format
on Ubuntu...so that you can get access to the version 9 or later feature just above:
See my detailed instructions here. The latest version at this moment is 14.0.0.
clang-format
and git-clang-format
(runnable as git clang-format
)clang-format
-based project here: eRCaGuy_CodeFormatterUpvotes: 8
Reputation: 855
As of version 6.0, the option IndentPPDirectives
can be used. Usage is described in this review.
Using IndentPPDirectives: None
results in:
#if FOO
#if BAR
#include <foo>
#endif
#endif
While IndentPPDirectives: AfterHash
gives:
#if FOO
# if BAR
# include <foo>
# endif
#endif
Edit: see @Gabriel Staples' answer for details on the BeforeHash
option introduced in clang-format
version 9.
Upvotes: 27
Reputation: 582
astyle
(Artistic Style) indents #pragma omp
nicely with the code, out-of-the-box. There doesn't even seem to be an option to change the behavior. Only line continuations aren't indented, as shown in the example—I would prefer line continuations were indented, perhaps 8 spaces, under omp
. Other pragmas are aligned left.
void foo()
{
#pragma omp parallel
#pragma omp master
{
#pragma omp task depend( some_expression ) \
depend( other_expression ) \
priority(1)
{
code();
}
}
#pragma other
code();
}
becomes
void foo()
{
#pragma omp parallel
#pragma omp master
{
#pragma omp task depend( some_expression ) \
depend( other_expression ) \
priority(1)
{
code();
}
}
#pragma other
code();
}
There is an Astyle Visual Studio extension.
Upvotes: 1
Reputation: 101
It's been late but this is the solution you are looking for. It formats the pragma along with the code block. You can use this before they finally support the pragma indentation.
https://github.com/MedicineYeh/p-clang-format
The main concept is replacing the string so that the formatter uses the "correct" rules on these pragmas. The motivative example is as following.
# Replace "#pragma omp" by "//#pragma omp"
sed -i 's/#pragma omp/\/\/#pragma omp/g' ./main.c
# Do format
clang-format ./main.c
# Replace "// *#pragma omp" by "#pragma omp"
sed -i 's/\/\/ *#pragma omp/#pragma omp/g' ./main.c
Upvotes: 5
Reputation: 16204
You might want to just patch it yourself and make a pull request.
It's not that hard, I made a similarly mundane pull request once. The clang-format code is pretty tidy. Clang-format already handles code comments in the way that you want, aligning them to the surrounding code (at least it has an option to enable this) so making a patch to treat certain PP directives the same way should be straightforward.
Alternatively, you can just write the patch yourself and compile clang yourself from source with the extra option, for use in your project. I also did this before I decided to send them the patch.
It seriously took me only a few hours to figure out how to do this, their code is much cleaner than the code of many other open source projects.
Upvotes: 6