[Development] Use what you include mapping file

David Redondo qt at david-redondo.de
Tue Oct 14 09:18:32 CEST 2025


Am Montag, 13. Oktober 2025, 19:14 schrieb Scott Bloom:
> As part of a pre-checkin "semi-lint" strategy (along with proper formatting etc), I am investigating the usage of the tool include-what-you-use.
> 
> https://github.com/include-what-you-use/include-what-you-use
> 
> Essentially, it confirms that both every source (and header) file includes every header directly to reduce the possibility of a compile break if a dependent header changes what it includes.
> 
> It also reports when you include something that you don't need, reducing compile time and dependencies.
> 
> It supports mapping files, for when a file is intentionally supposed to be included transitively.  For instance, including <iostream> vs <iosfwd> will not report issues.
> 
> The problem is with Qt, every include is transitive.  You include <QComboBox> not <qcombobox.h> for instance.
> 

We have these pragmas 

➜ /usr/include/x86_64-linux-gnu/qt6/QtWidgets cat QComboBox 
#include "qcombobox.h" // IWYU pragma: export

do these  not help the tool? Why is a separate mapping file needed?

David




More information about the Development mailing list