1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00

CODING_CONVENTIONS.md: Add IWYU policy

This makes an implicit agreement that code should include the headers
is uses, no more and no less, explicit.

It also recommends using tooling (such as clangd) and adding IWUY
pragma comments to aid those tools in common cases they otherwise would
provide false positives.

Co-authored-by: chrysn <chrysn@fsfe.org>
This commit is contained in:
Marian Buschsieweke 2024-04-14 15:44:24 +02:00 committed by Marian Buschsieweke
parent 3cdc4379b7
commit ffeb46fc42
No known key found for this signature in database
GPG Key ID: 758BD52517F79C41

View File

@ -175,6 +175,24 @@
#endif #endif
``` ```
### Include What You Use (IWYU)
`#include` directives that are not actually needed should be removed to reduce
clutter and improve compilation speed. Similar: Try to add the corresponding
`#include`s for all the functions, macros, types, etc. used and do not rely on
`bar.h` to implicitly include `foo.h`, unless this is documented behavior.
Tools such as [clang's Include Cleaner][clangd-include-cleaner] can help with
that. These tools may show false positives in cases where headers are *expected*
to be included indirectly: E.g. if `foo.h` is the public header that contains
common helpers and implementations, but a per platform `foo_arch.h` is included
from within `foo.h` for platform specific implementations. If in this scenario
only functions provided by `foo_arch.h` are included, the `#include` of `foo.h`
is considered as unused. To avoid this, one should add
[`/* IWYU pragma: export */`](https://github.com/include-what-you-use/include-what-you-use/blob/master/docs/IWYUPragmas.md) after `#include "foo_arch.h"` in `foo.h`.
[clangd-include-cleaner]: https://clangd.llvm.org/design/include-cleaner
## Header Guards ## Header Guards
All files are required to have header guards of the form All files are required to have header guards of the form