5a76a3fb03
The printf-style version of QDebug expands to a lot less code than the std::ostream-style version. Of course, you pay in type safety (but compilers warn about it these days), you cannot stream complex Qt types and streaming QStrings is awkward, but in many cases you actually improve on readability. But the main reason is that something that's not supposed to be executed under normal operation has no business bloating executable code size. This is not an attempt at converting all qWarnings() to printf-style, only the low-hanging fruit. In this second part, replace qWarning() << "" << non-QString with qWarning("..%.", non-QString). QString (and QUrl etc) have special escaping handling when streamed into QDebug, so leave those alone. They also seem to expand to less code than the qPrintable() alternative, so there's no reason to replace them. Saves 2KiB, 3.4KiB, ~750b and ~450b in text size in QtCore, Gui, Network and Widgets, resp., on optimized GCC 5.3 AMD64 builds. Change-Id: Iae6823e543544347e628ca1060d6d51e3b04d3f4 Reviewed-by: Kai Koehne <kai.koehne@qt.io> |
||
---|---|---|
.. | ||
animation | ||
arch | ||
codecs | ||
doc | ||
global | ||
io | ||
itemmodels | ||
json | ||
kernel | ||
mimetypes | ||
plugin | ||
statemachine | ||
thread | ||
tools | ||
xml | ||
corelib.pro | ||
eval.pri | ||
Qt5Config.cmake.in | ||
Qt5CoreConfigExtras.cmake.in | ||
Qt5CoreConfigExtrasMkspecDir.cmake.in | ||
Qt5CoreConfigExtrasMkspecDirForInstall.cmake.in | ||
Qt5CoreMacros.cmake | ||
Qt5CTestMacros.cmake | ||
QtCore.dynlist | ||
qtzlib.pro |