Transition from Qt 4.x to Qt5
- 1 The Transition from Qt 4.x to Qt 5
- 1.1 QtWidgets as a Separate Module
- 1.2 QtWebKitWidgets is also a separate module:
- 1.3 QPrinter Doesn’t Work
- 1.4 toAscii() and fromAscii() Methods are deprecated
- 1.5 QCoreApplication::UnicodeUTF8 is deprecated
- 1.6 QWorkspace is deprecated
- 1.7 QDrag Problems
- 1.8 qFindChildren is deprecated
- 1.9 qVariantValue is deprecated
- 1.10 qVariantCanConvert is deprecated
- 1.11 Qt::escape is deprecated
- 1.12 QDesktopServices::storageLocation deprecated
- 1.13 CONFIG+=qtestlib is deprecated
- 1.14 QWeakPointer quirks
- 1.15 QtConcurrent Library is Missing?
- 1.16 Fixing #include<> Headers
- 1.17 Plugin loading
- 1.18 Deploying to systems without C++11
- 1.19 QTimer is no longer accurate to the millisecond by default
- 1.20 QUrl addQueryItem moved to QUrlQuery
- 1.21 QAbstractItemModel changes
- 1.22 Recommended Reading
The Transition from Qt 4.x to Qt 5
The transition from Qt 4.x to Qt 5 is not expected to be significant. However, the “modularization” of the Qt code base requires some amount of changes to project configuration, such as use of “headers”, and configuration of project build settings (such as changes to the *.pro files).
Qt Creator (master) is compiled using Qt 4 and Qt 5; you can refer to its sources to get an overview of what is required to port an application and keep the sources backwards compatible to Qt 4.
QtWidgets as a Separate Module
example compile time errors
Add this in your *.pro file:
Change all instances of
The code should work now, though sometimes you may require to be more explicit:
QtWebKitWidgets is also a separate module:
example compile time errors
Add this in your *.pro file:
Note: when you have QT += webkitwidgets you don’t need QT += widgets
In addition, replace all instances of
You can try this by porting a WYSISWYG html editor [qt.gitorious.org] from Qt 4 to Qt 5.
QPrinter Doesn’t Work
If your code has the following lines:
add the following to your project file:
Again, sometimes it may not work and you would need to be explicit:
toAscii() and fromAscii() Methods are deprecated
Replace all instances of
For example, given the Qt 4 code
you would change to
QCoreApplication::UnicodeUTF8 is deprecated
This enum type used to define the 8-bit encoding of character string arguments to translate(). This enum is now obsolete and UTF-8 will be used in all cases. So remove all instances of QCoreApplication::UnicodeUTF8. For example:
QWorkspace is deprecated
This class is obsolete and was replaced by the QMdiArea class in Qt 4.3. In Qt 5 QWorkspace has been removed. The new class has a similar API to QWorkspace and porting it only involved changing the names of a few methods, signals, and slots.
Apps that has drop and drag functionality will need some tweaking. A line such as
in Qt 5 will generate the error
To fix this add among the includes:
qFindChildren is deprecated
An error will pop of this fashion:
To solve this you replace qFindChildren with findChildren, for example in
qVariantValue is deprecated
Your compiler will say
This function is equivalent to QVariant::value<T>(value). Therefore if given a QVariant val rewrite the line
This QTime enclosed in the angled brackets lets the compiler know what QVariant will return. However, if the variable is not a QVariable the type enclosed in the angled brackets should not be used(doing so will result in a vague compile time error). So given that m_color is of type QColor you will rewrite
qVariantCanConvert is deprecated
Qt::escape is deprecated
So you would change the following block:
this procedure can be automated by a porting tool [kdab.com] from KDAB.
CONFIG+=qtestlib is deprecated
If you have the above line in your project file the compiler will warn you in the compile window, nonetheless the code will still run as usual:
A code block like
To fix this add to the project file:
QtConcurrent Library is Missing?
In Qt 4, QtConcurrent was part of QtCore, so there was no need to include specific headers. This is no longer the case with Qt 5. If your source code have lines like
You will need to include the header:
and add the following line to your project file:
Fixing #include<> Headers
A Perl script “fixqt4headers.pl” exists in qtbase/bin/. that should be run on source code using Qt that corrects the #include<> directives for Qt components to also consider the module name.
The Q_EXPORT_PLUGIN,Q_EXPORT_PLUGIN2 macros have been deprecated in favor of the new Q_PLUGIN_METADATA macro. The advantage of the new system is that it allows Qt to query the metadata for the plugin without actually dlopen’ing it. This greatly improves performance and reliability of the plugin system.
The new Q_PLUGIN_METADATA macro is included next to the Q_OBJECT macro in the QObject derived class that is returned when loading the plugin. It contains the plugins IID and a filename pointing to a json file containing the metadata for the plugin. The json file is compiled into the plugin and does not need to be installed.
An example on how to change your plugins can be found by looking at the patch that changes the Gif image format plugin, see http://qt.gitorious.org/qt/qtbase/commit/963b4c1647299fd023ddbe7c4a25ac404e303c5d .
Deploying to systems without C++11
When Qt is built from source code on a system with C++11 installed, the Qt libraries/frameworks are linked against the system’s C++11 library (libc++). This means that the Qt libraries/frameworks are not deployable to systems without C++11 installed (such as out-of-the-box Mac OS X 10.6). To be able to deploy to systems that only support the older C++ standard (libstdc++), build Qt from source code with the -no-c++11 configure option.
QTimer is no longer accurate to the millisecond by default
QTimer has now 3 accuracy types, with a new default behaviour:
- The new default type is Qt::CoarseTimer which, to reduce power/CPU consumption, allow 5% difference between requested time and actual one, and even allow the timer to fire before the requested time.
- The former one is Qt::PreciseTimer (to the millisecond, never before the requested time).
- A third one is Qt::VeryCoarseTimer and allow a 1 second difference
QUrl addQueryItem moved to QUrlQuery
If you have:
You will want to change it to
both have changed and are now protected.
See Compatibility Members for QAbstractItemModel [qt.io]
- C++ API Changes [qt.io]
- The porting guide [qt.io]
- Porting Desktop Applications from Qt 4 to Qt 5 [blog.ics.com]
- Porting from Qt 4 to Qt 5 [kdab.com]
- Automated porting from Qt 4 to Qt 5 [kdab.com]