Avoid Re-Compiling Template Libraries with Modules
Learn to avoid re-compiling template libraries with modules.
We'll cover the following...
Header files have been around since the very beginning of the C language. Originally, they were mainly used for text substitution macros and linking external symbols between translation units. With the introduction of templates, C++ leveraged header files to carry actual code. Because templates need to be recompiled for changes in specializations, we've been carrying them around in header files for many years. As the STL continues to grow over the years, these header files have grown as well. The situation has become unwieldy and is no longer scalable for the future.
Header files typically contain a lot more than templates. They often contain configuration macros and other symbols that are required for system purposes, but not useful for the application. As the number of headers grows, the number of opportunities for symbol collisions grows as well. This is even more problematic when we consider the abundance of macros, which are not subject to namespace restrictions nor any form of type safety.
C++20 addresses this problem with modules.
How to do it
We may be used to creating header files like this:
#ifndef BW_MATH#define BW_MATHnamespace bw {template<typename T>T add(T lhs, T rhs) {return lhs + rhs;}}#endif // BW_MATH
This minimalist example illustrates several of the problems that modules address. The BW_ ...