Building Qt 5 from Git: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
(Add "cleanup" tag)
No edit summary
 
(162 intermediate revisions by 64 users not shown)
Line 1: Line 1:
{{Cleanup | reason=Auto-imported from ExpressionEngine.}}
{{LangSwitch}}
 
[[Category:HowTo]]
[[Category:HowTo]]
[[Category:Developing_with_Qt::Qt 5]]
[[Category:Developing with Qt]]


'''English''' [[Building-Qt-5-from-Git-SimplifiedChinese|简体中文]] [[Building-Qt-5-from-Git-Bulgarian|Български]] [[Building-Qt-5-from-Git-French|Français]] [[Building-Qt-5-from-Git-Russian|Русский]]
This article provides hints for checking out and building the Qt 5 repositories. This is primarily for '''developers who want to contribute to the Qt library itself,''' or who want to try the latest unreleased code.


= Building Qt 5 from Git =
If you simply want to build a specific release of Qt from source to use the libraries in your own project, you can download the source code from the [http://download.qt.io/official_releases/qt/ Official Releases] page or the [http://download.qt.io/archive/qt/ Archive]. Alternatively, commercial customers can download the Source Packages via the [https://account.qt.io Qt Account] portal.


== Introduction ==
=== To compile Qt 6, see [[Building Qt 6 from Git]]. ===


This article provides hints for checking out and building the modularized Qt 5 from Git, on '''desktop''' platforms. Please feel free to update this article as things change during development. Raise issues related to the article via: http://forum.qt.io/viewthread/7018
=== To compile Qt Creator, see [[Building Qt Creator from Git]]. ===


If you also want to compile Qt Creator, see "Building Qt Creator from Git":http://wiki.qt.io/Building-Qt-Creator-from-Git.
==System Requirements==


== System Requirements ==
===All desktop platforms===


=== All desktop platforms ===
*Git ('''>= 1.6.x''')
*Perl ('''>=5.14''')
*Python ('''>=2.6.x''')
*A working C++ compiler


* Git ('''>= 1.6.x''')
For more detailed information, see [http://doc.qt.io/qt-5/build-sources.html Building Qt Sources]
* Perl ('''>=5.14''')
* Python ('''>=2.6.x''')
* A working compiler


For more detailed information, see "Building Qt Sources":http://doc.qt.io/qt-5/build-sources.html
====Documentation (optional)====


==== SSL (optional) ====
*Clang ('''>=8.x''')


See "Enabling and Disabling SSL Support":http://doc.qt.io/qt-5.1/qtnetwork/ssl.html#enabling-and-disabling-ssl-support
See [https://doc.qt.io/qt-5/qdoc-guide-clang.html Installing Clang for QDoc]


==== WebKit (optional) ====
====SSL (optional)====


* bison
See [http://doc.qt.io/qt-5/ssl.html#enabling-and-disabling-ssl-support Enabling and Disabling SSL Support]
* flex
* gperf
* "Ruby":http://www.ruby-lang.org/
* "ICU":http://site.icu-project.org/


For Windows, ''bison'', ''flex'' and ''gperf'' are provided with the source code at ''<qt>32\bin''. Get Ruby from http://rubyinstaller.org/. You can download the precompiled ICU packages from icu-project.org (MSVC 2010 only), or "compile your own":http://wiki.qt.io/Compiling-ICU
For Windows, ''bison'', ''flex'' and ''gperf'' are provided with the source code at ''c:\pathToQt\gnuwin32\bin''. Get Ruby from http://rubyinstaller.org/. You can download the precompiled ICU packages from [http://download.qt.io/development_releases/prebuilt/icu/prebuilt/ download.qt.io], or see [[Compiling-ICU]] to compile your own.


=== Linux/X11 ===
===Linux/X11===


==== apt-get build-dep ====
====apt-get build-dep====


Ubuntu/Debian based systems have a convenient way of installing build-depends for any package:
Ubuntu/Debian based systems have a convenient way of installing build-depends for any package:
<code>
 
sudo apt-get build-dep qt5-default
sudo apt-get build-dep qtbase5-dev
</code>


RPM-based distros with yum offer a similar tool called yum-builddep.
RPM-based distros with yum offer a similar tool called yum-builddep.


==== Convenience packages (Ubuntu 11.10 — 12.10 only) ====
'''Note:''' In older Debian-based distros, use <kbd>qt5-default</kbd> in place of <kbd>qtbase5-dev</kbd>. See also [[https://askubuntu.com/questions/1335184/qt5-default-not-in-ubuntu-21-04 1]], [[https://www.mail-archive.com/ubuntu-bugs@lists.ubuntu.com/msg5902890.html 2]].
 
'''Note:''' if you see the following error message while running the commands above on Ubuntu:
 
E: You must put some 'source' URIs in your sources.list
 
Then you will need to enable the "Source code" option in Software and Updates > Ubuntu Software under the "Downloadable from the Internet" section. This setting can also be found by running '''software-properties-gtk'''.
 
'''Note:''' some of the package names given here contain embedded version numbers; it can be constructive to ask your package-manager for a list of available versions, e.g. on Debian <kbd>dpkg -l 'libclang*-dev'</kbd> when the instructions below suggest <kbd>libclang6-dev</kbd> may offer you a more recent version, or the package may have changed name, in which case select a sensible match to what's listed below from the <kbd>dpkg -l</kbd> output to install. These lists tend to go out of date&hellip;


For Ubuntu/Debian, Gabor Loki has provided a custom PPA with the "sedkit-env-webkit":https://launchpad.net/~u-szeged/+archive/sedkit meta package that installs all required dependencies for building Qt/Qt WebKit. You can add the PPA by calling:
====Convenience packages (Ubuntu 11.10 -- 12.10 only)====


<code>
For Ubuntu/Debian, Gabor Loki has provided a custom PPA with the [https://launchpad.net/~u-szeged/+archive/sedkit sedkit-env-webkit] meta package that installs all required dependencies for building Qt/Qt WebKit. You can add the PPA by calling:
sudo apt-add-repository ppa:u-szeged/sedkit &amp;&amp; sudo apt-get update &amp;&amp; sudo apt-get install sedkit-env-qtwebkit
 
</code>
sudo apt-add-repository ppa:u-szeged/sedkit &&\
sudo apt-get update &&\
sudo apt-get install sedkit-env-qtwebkit


For other distros, get the separate components below.
For other distros, get the separate components below.


==== Build essentials ====
====Build essentials====
{| style="border-collapse:collapse" border="1"
|'''Ubuntu and/or Debian:'''
|<code>sudo apt-get install build-essential perl python3 git</code>
|-
|'''Fedora 30'''
|<code>su - -c "dnf install perl-version git gcc-c++ compat-openssl10-devel harfbuzz-devel double-conversion-devel libzstd-devel at-spi2-atk-devel dbus-devel mesa-libGL-devel"</code>
|-
|'''OpenSUSE:'''
|<code>sudo zypper install git-core gcc-c++ make</code>
|}
 
====Libxcb====
 
[http://xcb.freedesktop.org/ Libxcb] is now the default window-system backend for platforms based on X11/Xorg, and you should therefore install libxcb and its accompanying packages. Qt5 should build with whatever libxcb version is available in your distro's packages (but you may optionally wish to use v1.8 or higher to have threaded rendering support). The [http://code.qt.io/cgit/qt/qtbase.git/tree/src/plugins/platforms/xcb/README README] lists the required packages.
 
{| style="border-collapse:collapse" border="1"
|'''Ubuntu/Debian:'''
|<code> sudo apt-get install '^libxcb.*-dev' libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev libxkbcommon-dev libxkbcommon-x11-dev </code>
|-
|'''Fedora 30:'''
|<code>su - -c "dnf install libxcb libxcb-devel xcb-util xcb-util-devel xcb-util-*-devel libX11-devel libXrender-devel libxkbcommon-devel libxkbcommon-x11-devel libXi-devel libdrm-devel libXcursor-devel libXcomposite-devel"</code>
 
|-
|'''OpenSUSE 12+:'''
|<code>sudo zypper in xorg-x11-libxcb-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-renderutil-devel xcb-util-wm-devel xorg-x11-devel libxkbcommon-x11-devel libxkbcommon-devel libXi-devel</code>
|-
|'''ArchLinux/Manjaro:'''
|<code>sudo pacman -S --needed libxcb xcb-proto xcb-util xcb-util-image xcb-util-wm libxi</code>
|-
|'''Chakra Linux:'''
|Install the ArchLinux packages, plus xcb-util-keysyms. It's available from CCR.
|-
|'''Mandriva/ROSA/Unity:'''
|<code>urpmi 'pkgconfig(xcb)' 'pkgconfig(xcb-icccm)' 'pkgconfig(xcb-image)' 'pkgconfig(xcb-renderutil)' 'pkgconfig(xcb-keysyms)' 'pkgconfig(xrender)'</code>
|-
|'''Linux Mint:'''
|<code>apt-get install libx11-xcb-dev libxcb-composite0-dev libxcb-cursor-dev libxcb-damage0-dev libxcb-dpms0-dev libxcb-dri2-0-dev libxcb-dri3-dev libxcb-glx0-dev libxcb-icccm4-dev libxcb-image0-dev libxcb-keysyms1-dev libxcb-present-dev libxcb-randr0-dev libxcb-render-util0-dev libxcb-render0-dev libxcb-shape0-dev libxcb-shm0-dev libxcb-sync-dev libxcb-util-dev libxcb-xfixes0-dev libxcb-xinerama0-dev libxcb-xkb-dev libxcb-xtest0-dev libxcb1-dev</code>
|-
|'''Centos 5/6 '''
|Install missing Qt build dependencies:
yum install libxcb libxcb-devel xcb-util xcb-util-devel
 
Install Red Hat DevTools 1.1 for CentOS-5/6 x86_64, they are required due to outdated GCC shipped with default CentOS:
wget http://people.centos.org/tru/devtools-1.1/devtools-1.1.repo -O /etc/yum.repos.d/devtools-1.1.repo
yum install devtoolset-1.1
 
Initialise your newly installed dev tools:
scl enable devtoolset-1.1 bash
# Test - Expect to see gcc version 4.7.2 ('''not''' gcc version 4.4.7)
gcc -v
 
For more info on preparing the environment on '''CentOS''', see [http://forum.qt.io/topic/30140 this thread].
|-
|'''Centos 7'''
|Update to gcc 7:
yum install centos-release-scl
yum install devtoolset-7-gcc*
scl enable devtoolset-7 bash
 
Install missing Qt build dependencies (Qt 5.13):
yum install libxcb libxcb-devel xcb-util xcb-util-devel mesa-libGL-devel libxkbcommon-devel
|}
 
====OpenGL support====
 
For Qt Quick 2, a graphics driver with native OpenGL 2.0 support is highly recommended.
 
====Accessibility====


===== Ubuntu/Debian: =====
It is recommended to build with accessibility enabled, install <kbd>libatspi2.0-dev</kbd> and <kbd>libdbus-1-dev</kbd> packages.


<code>
====Qt WebKit====
sudo apt-get install build-essential perl python git
 
{| style="border-collapse:collapse" border="1"
|'''Ubuntu/Debian:'''
|<code>sudo apt-get install flex bison gperf libicu-dev libxslt-dev ruby</code>
|-
|'''Fedora 30:'''
|<code>su - -c "dnf install flex bison gperf libicu-devel libxslt-devel ruby"</code>
 
|-
|'''OpenSUSE:'''
|<code>sudo zypper install flex bison gperf libicu-devel ruby</code>
|-
|'''Mandriva/ROSA/Unity:'''
|<code>urpmi gperf</code>
|}
 
====Qt WebEngine====
 
{| style="border-collapse:collapse" border="1"
|'''Ubuntu/Debian:'''
|<code>sudo apt-get install libxcursor-dev libxcomposite-dev libxdamage-dev libxrandr-dev libxtst-dev libxss-dev libdbus-1-dev libevent-dev libfontconfig1-dev libcap-dev libpulse-dev libudev-dev libpci-dev libnss3-dev libasound2-dev libegl1-mesa-dev gperf bison nodejs</code>
|-
|'''Fedora/RHEL:'''
|<code>sudo dnf install freetype-devel fontconfig-devel pciutils-devel nss-devel nspr-devel ninja-build gperf cups-devel pulseaudio-libs-devel libcap-devel alsa-lib-devel bison libXrandr-devel libXcomposite-devel libXcursor-devel libXtst-devel dbus-devel fontconfig-devel alsa-lib-devel rh-nodejs12-nodejs rh-nodejs12-nodejs-devel
</code>
</code>
|-
|'''OpenSUSE:'''
|<code>sudo zypper install alsa-devel dbus-1-devel libXcomposite-devel libXcursor-devel libXrandr-devel libXtst-devel mozilla-nspr-devel mozilla-nss-devel gperf bison nodejs10 nodejs10-devel</code>
|}
====Qt Multimedia====
You'll need at least alsa-lib ('''>= 1.0.15''') and gstreamer ('''>=0.10.24''') with the base-plugins package.
To build multimedia on Windows, FEATURE_wmf has to be enabled and wmf has to be installed.
{| style="border-collapse:collapse" border="1"
|'''Ubuntu/Debian:'''
|<code>sudo apt-get install libasound2-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev libgstreamer-plugins-good1.0-dev libgstreamer-plugins-bad1.0-dev</code>
|-
|'''Fedora 30:'''
|<syntaxhighlight lang="bash">
dnf install pulseaudio-libs-devel alsa-lib-devel gstreamer1-devel gstreamer1-plugins-base-devel wayland-devel
</syntaxhighlight>
|}
===='''QDoc Documentation Generator Tool'''====
{| style="border-collapse:collapse" border="1"
|'''Ubuntu/Debian:'''
|<code>sudo apt install clang libclang-dev</code>
|-
|'''Fedora 30:'''
|<syntaxhighlight>
su -c 'dnf install llvm-devel'
</syntaxhighlight>
|}
===macOS===
Install the latest Xcode from the App Store. Verify that your Xcode install is properly set up for command line use:
xcodebuild -version && xcodebuild -showsdks


===== Fedora:=====
This should give you eg:
<code>
 
su - -c "yum install perl-version"
Xcode 6.2
</code>
Build version 6C131e


===== OpenSUSE: =====
OS X SDKs:
  OS X 10.9                    -sdk macosx10.9
  OS X 10.10                    -sdk macosx10.10


<code>
iOS SDKs:
sudo zypper install git-core gcc-c++ make
  iOS 8.2                      -sdk iphoneos8.2
</code>


==== Libxcb ====
iOS Simulator SDKs:
  Simulator - iOS 8.2          -sdk iphonesimulator8.2


"Libxcb":http://xcb.freedesktop.org/ is now the default window-system backend for platforms based on X11/Xorg, and you should therefore install libxcb and its accompanying packages. Qt5 should build with whatever libxcb version is available in your distro's packages (but you may optionally wish to use v1.8 or higher to have threaded rendering support). "src/plugins/platforms/xcb/README":http://qt.gitorious.org/qt/qtbase/blobs/stable/src/plugins/platforms/xcb/README lists the required packages.
You can verify that the right Xcode is being used by running:


===== Ubuntu/Debian: =====
xcode-select --print-path


<code>
If this points to /Developer you're probably using an older Xcode version. Switch to the latest one by running:
sudo apt-get install "^libxcb.'''" libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev
</code>


=====Fedora up to 16:=====
sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer
<code>
If you have not installed CMake and Ninja, you need to do that
su - -c "yum install libxcb libxcb-devel xcb-util xcb-util-devel"
</code>


=====Fedora 17+ (xcb-util-renderutil is currently available in updates repository until it goes stable):=====
#Launch "MaintenanceTool", and choose "Add or remove components" (click next)
<code>
#under "Qt -> Developer and Design Tools", check "CMake" and "Ninja" (click next, and complete that)
su- -c "yum —enablerepo=updates install libxcb libxcb-devel xcb-util xcb-util-devel xcb-util-'''-devel libX11-devel libXrender-devel libXi-devel"
#in Terminal, ensure you add the folder containing cmake to your $PATH, eg: export PATH=$PATH:/path_to/Qt/Tools/CMake/CMake.app/Contents/bin
</code>


===== OpenSuSE 12.2=====
===Windows===
<code>
sudo zypper in xorg-x11-libxcb-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-renderutil-devel xcb-util-wm-devel xorg-x11-devel libxkbcommon-devel libXi-devel
</code>


===== ArchLinux:=====
====Windows Graphics Drivers====
<code>
sudo pacman -S —needed libxcb xcb-proto xcb-util xcb-util-image xcb-util-wm libxi
</code>


On Chakra Linux, other than packages mentioned for ArchLinux, you need to install package xcb-util-keysyms separately. It's available from CCR.
The full feature set of Qt Quick 2 requires OpenGL 2.1 or higher or OpenGL ES 2.0 to work. Several options are available:


===== Mandriva/ROSA/Unity:=====
#Using the native OpenGL driver for your graphics card (Note: The stock Windows driver only supports OpenGL 1.1, which is insufficient).
<code>
#Using the [http://code.google.com/p/angleproject/ ANGLE-library] to translate OpenGL calls into ''DirectX''. A copy of ANGLE is bundled in Qt 5.
urpmi 'pkgconfig(xcb)' 'pkgconfig(xcb-icccm)' 'pkgconfig(xcb-image)' 'pkgconfig(xcb-renderutil)' 'pkgconfig(xcb-keysyms)' 'pkgconfig(xrender)'
#Using a software rasterizer shipped in the Qt SDK. See [[MesaLlvmpipe]] for instructions on how that is built.
</code>


===== Centos 5/6 =====
Starting with Qt 5.8, many Qt Quick applications can also be run with the built-in software backend (previously known as the Qt Quick 2D Renderer). This is not the same as running through a full OpenGL software rasterizer, and is a lot more lightweight. See [https://doc-snapshots.qt.io/qt5-dev/qtquick-visualcanvas-adaptations.html the documentation] on how to request a specific backend.


Install missing Qt build dependencies:
Qt can be built to dynamically choose the OpenGL implementation (see [http://doc.qt.io/qt-5/windows-requirements.html#dynamically-loading-graphics-drivers Dynamically Loading Graphics Drivers]) by passing the option <tt>-opengl dynamic</tt> to <tt>configure</tt>. To build Qt to always use the native OpenGL driver, pass <tt>-opengl desktop</tt>. To build Qt to always use ANGLE, pass <tt>-opengl es2</tt>.
<code>
yum install libxcb libxcb-devel xcb-util xcb-util-devel
</code>


Install Red Hat DevTools 1.1 for CentOS-5/6 x86_64, they are required due to outdated GCC shipped with default CentOS
====ANGLE dependencies====
<code>
wget http://people.centos.org/tru/devtools-1.1/devtools-1.1.repo -O /etc/yum.repos.d/devtools-1.1.repo
yum install devtoolset-1.1
</code>


You also need to initialise your newly installed dev tools:
*'''MSVC'''
<code>
**Qt < 5.12: Building ANGLE with Windows SDKs prior to Windows Kit 8 requires the [http://msdn.microsoft.com/en-us/directx/default.aspx DirectX SDK] to be installed, and the path to the <tt>d3d_compiler<xx>.dll</tt> to be added to the <tt>PATH</tt> variable.
scl enable devtoolset-1.1 bash
**Qt >= 5.12: Qt needs at least a Windows 10 SDK in order to build ANGLE. No additional manual setup is needed


# Test- Expect to see gcc version 4.7.2 ( * not * gcc version 4.4.7 )
*'''MinGW'''
gcc -v
**Building ANGLE with Windows SDKs prior to Windows Kit 8 requires the [http://msdn.microsoft.com/en-us/directx/default.aspx DirectX SDK] to be installed, and the path to the <tt>d3d_compiler<xx>.dll</tt> to be added to the <tt>PATH</tt> variable.
</code>


For more info on preparing the environment on '''CentOS''', see "this thread":https://forum.qt.io/viewthread/30708/.
Any project that uses run-time shader compilation must have D3DCOMPILER_xx.DLL copied to the local executable path for the project. This DLL is available in this sub-directory of the Windows SDK installation under <tt>%ProgramFiles(x86)%\Windows Kits\<version>\Redist\D3D\<arch></tt> where <arch> is x86 and x64 (see [https://msdn.microsoft.com/en-us/library/windows/desktop/ee663275.aspx]).


====OpenGL support====
====Supported Compilers on Windows====


For Qt Quick 2 a graphics driver with native OpenGL 2.0 support is highly recommended.
*Visual Studio 2019
*Visual Studio 2017 (might need a recent service pack, especially for QtWebEngine)
*MinGW-w64 based compiler with ''g++'' version 7.3 or higher (e.g. [http://sourceforge.net/projects/mingwbuilds/ MinGW-builds], see also [[MinGW-64-bit]]).


====Accessibility====
Notes:


It is recommended to build with accessibility enabled, install '''libatspi 2''' and '''libdbus-1''' development packages.
*Add the compiler to the PATH environment variable. Visual Studio usually ships .bat files named <tt>vcvarsall.bat</tt> or similar that can be called with a command line parameter for choosing the toolchain (/x86, /x64, etc) to set up the environment.
*Windows SDK v6.0A/v7.0A contains the same compiler as Visual Studio 2008/2010.
*Windows SDK 8.0 and later do not include a compiler.
*As of 16.3.2012, if you wish to install both Visual Studio 2010 and the standalone SDK, you need to follow this order (see readme.html provided with the service pack):
*#Install Visual Studio 2010
*#Install Windows SDK 7.1. See also the [[Cannot Install Windows SDK]] page.
*#Install Visual Studio 2010 SP1
*#Install Visual C++ 2010 SP1 Compiler Update for the Windows SDK 7.1


====Qt WebKit====
====Windows Build environment====


=====Ubuntu/Debian:=====
We recommend creating a command prompt that provides the build environment (see the [http://code.qt.io/cgit/qt-creator/qt-creator.git/tree/README.md Qt Creator README] ). In this environment, ''Python'' (e.g. ''[http://www.python.org/download/ Active Python] 2.7'' later) and ''Perl'' (e.g. ''[http://strawberryperl.com/ StrawberryPerl] 5.12'' or later) should be in the ''PATH''.
<code>
[http://rubyinstaller.org/downloads/ Ruby] is required for WebKit.
sudo apt-get install flex bison gperf libicu-dev libxslt-dev ruby
</code>


=====Fedora:=====
'''Hint''': If you installed git with the non-recommended setting to add git's entire Unix environment to PATH, make sure that ''Perl'' is added to the path in front of ''git'', since that ships an incompatible build of perl, which would cause the scripts to fail. Also, MinGW builds of Qt become Msys builds due to the presence of sh.exe; and those who've tried have had more success configuring and building for MinGW in MS's <kbd>cmd.exe</kbd> Command Prompt than in the Git Bash shell.
<code>
su- -c "yum install flex bison gperf libicu-devel libxslt-devel ruby"
</code>


=====OpenSUSE:=====
Multicore building: To speed up building when using ''nmake'', the compiler can be instructed to use all available CPU cores in one of the following ways:
<code>
sudo zypper install flex bison gperf libicu-devel ruby
</code>


=====Mandriva/ROSA/Unity:=====
*Pass the option ''-mp'' to Qt's ''configure''
<code>
*Set the environment variable ''CL'' (specifying Visual Studio compiler options) to ''/MP'' (On the command line: <tt>set CL=/MP</tt>)
urpmi gperf
*Use the tool [[jom]] instead of nmake. (Using jom instead of nmake reduces compile time quite a bit)
</code>


====Qt WebEngine====
====Configuring Visual Studio 2013 on Windows 8, 8.1 & 10====


=====Ubuntu (all):=====
Setting the environment variables to properly build Qt can be done by following the steps below:
<code>
sudo apt-get install libssl-dev libxcursor-dev libxcomposite-dev libxdamage-dev libxrandr-dev libfontconfig1-dev </code>


======Additional dependencies on Ubuntu 14.04:======
*Create a file called qt5vars.bat, paste the following inside it and save it
<code>
sudo apt-get install libcap-dev libbz2-dev libgcrypt11-dev libpci-dev libnss3-dev build-essential libxcursor-dev libxcomposite-dev libxdamage-dev libxrandr-dev libdrm-dev libfontconfig1-dev libxtst-dev libasound2-dev gperf libcups2-dev libpulse-dev libudev-dev libssl-dev flex bison ruby </code>


=====Fedora:=====
'''Hint''': Remember to change <arch> to your desired platform and double-check that the paths are correct for Qt and Visual Studio
<code>
<pre style="word-wrap: break-word;">
sudo yum install "qt5-*"
@echo off


sudo yum install libgcrypt-devel libgcrypt pciutils-devel nss-devel libXtst-devel gperf cups-devel pulseaudio-libs-devel libgudev1-devel systemd-devel libcap-devel alsa-lib-devel flex bison ruby
REM Set up \Microsoft Visual Studio 2015, where <arch> is \c amd64, \c x86, etc.
</code>
CALL "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" <arch>


'''Please note that these libraries need to be installed on other distributions as well, though the package names and the set of libraries that are preinstalled may differ depending on the distribution used.'''
REM Edit this location to point to the source code of Qt
SET _ROOT=C:\qt5


==== Qt Multimedia ====
SET PATH=%_ROOT%\qtbase\bin;%_ROOT%\gnuwin32\bin;%PATH%


You'll need at least alsa-lib ('''>= 1.0.15''') and gstreamer ('''>=0.10.24''', "but <1.0 for now":http://lists.qt.io/pipermail/development/2012-November/007916.html) with the base-plugins package.
REM Uncomment the below line when using a git checkout of the source repository
SET PATH=%_ROOT%\qtrepotools\bin;%PATH%


===== Ubuntu/Debian:
REM Uncomment the below line when building with OpenSSL enabled. If so, make sure the directory points
<code>
REM to the correct location (binaries for OpenSSL).
sudo apt-get install libasound2-dev libgstreamer0.10-dev libgstreamer-plugins-base0.10-dev
REM SET PATH=C:\OpenSSL-Win32\bin;%PATH%
</code> =====


=== OS X ===
REM When compiling with ICU, uncomment the lines below and change <icupath> appropriately:
REM SET INCLUDE=<icupath>\include;%INCLUDE%
REM SET LIB=<icupath>\lib;%LIB%
REM SET PATH=<icupath>\lib;%PATH%


Install the latest Xcode from the App Store. Verify that your Xcode install is properly set up for command line use:
REM Contrary to earlier recommendations, do NOT set QMAKESPEC.
<code>
xcodebuild -version &amp;&amp; xcodebuild -showsdks
</code>


This should give you eg:
SET _ROOT=
<code>
Xcode 4.6.1
Build version 4H512
OS X SDKs:
Mac OS X 10.7 -sdk macosx10.7
OS X 10.8 -sdk macosx10.8


iOS SDKs:
REM Keeps the command line open when this script is run.
iOS 6.1 -sdk iphoneos6.1
cmd /k
</pre>


iOS Simulator SDKs:
Complete the steps below after you have cloned Qt5 from Git
Simulator- iOS 5.0 -sdk iphonesimulator5.0
Simulator- iOS 6.1 -sdk iphonesimulator6.1
</code>


You can verify that the right Xcode is being used by running:
*After having cloned Qt5 from Git (assuming it's at C:\Qt5), move qt5vars.bat to the Qt5 folder
<code>
*Double-click on the script to run it. Once it runs the script, the command prompt will stay open to enter additional commands.
xcode-select —print-path
*Navigate to C:\Qt5 in the command prompt
</code>


If this points to /Developer you're probably using an older Xcode version. Switch to the latest one by running:
The working directory should be c:\Qt5.
<code>
sudo xcode-select —switch /Applications/Xcode.app/Contents/Developer
</code>


=== Windows ===
All the required environment variables are now correctly set up and building Qt5 with nmake should work now.
You have to run qt5vars.bat and use the command prompt every time you build Qt5 with nmake.


==== Windows Graphics Drivers ====
The above steps also work for setting up nmake to build [[jom]].


QML2 requires OpenGL 2.1 or higher or Open GL ES 2.0 to work.


In Windows, two options are available:
====Configuring MinGW on Windows 8, 8.1 & 10====
# Use the "ANGLE-library":http://code.google.com/p/angleproject/ to translate OpenGL calls into ''DirectX'' (default)
The configuration process is similar to above except for a few minor changes in the qt5vars.bat script:
# Use the native OpenGL driver for your graphics card
<pre style="word-wrap: break-word;">
@echo off


A copy of ANGLE is bundled in Qt 5. To use Option 1, you need to install the "DirectX SDK":http://msdn.microsoft.com/en-us/directx/default.aspx (Note: Starting from Windows Kit 8, this is included in the Windows SDK).
REM Edit this location to point to the source code of Qt
SET _ROOT=C:\qt5


To use Option 2, you need to ensure that your graphics card driver supports OpenGL 2.1 or higher (Note: The stock Windows driver only supports OpenGL 1.1, which is insufficient), and pass `-opengl desktop' to configure.exe.
SET PATH=%_ROOT%\qtbase\bin;%_ROOT%\gnuwin32\bin;%PATH%


==== Supported Compilers on Windows ====
REM Uncomment the below line when using a git checkout of the source repository
SET PATH=%_ROOT%\qtrepotools\bin;%PATH%


* Visual Studio 2013
REM Uncomment the below line when building with OpenSSL enabled. If so, make sure the directory points
* Visual Studio 2012
REM to the correct location (binaries for OpenSSL).
* Visual Studio 2010 or Windows SDK v7.0A (upgradable to Windows SDK v7.1)
REM SET PATH=C:\OpenSSL-Win32\bin;%PATH%
* Visual Studio 2008 or Windows SDK v6.0A (upgradable to Windows SDK v6.1)
* MinGW-w64 based compiler with _g+''_ version 4.7 or higher (e.g. "MinGW-builds":http://sourceforge.net/projects/mingwbuilds/, see also [[MinGW-64-bit]]).


Notes:
REM When compiling with ICU, uncomment the lines below and change <icupath> appropriately:
* Windows SDK v6.0A/v7.0A contains the same compiler as Visual Studio 2008/2010.
REM Note that -I <icupath>\include and -L <icupath>\lib need to be passed to
* Windows SDK 8.0 and later do not include a compiler.
REM configure separately (that works for MSVC as well).
* As of 16.3.2012, if you wish to install both Visual Studio 2010 and the standalone SDK, you need to follow this order (see readme.html provided with the service pack):
REM SET PATH=<icupath>\lib;%PATH%
## Install Visual Studio 2010
## Install Windows SDK 7.1. See also [[Cannot_Install_Windows_SDK]] page.
## Install Visual Studio 2010 SP1
## Install Visual C''+ 2010 SP1 Compiler Update for the Windows SDK 7.1


==== Windows Build environment ====
REM Contrary to earlier recommendations, do NOT set QMAKESPEC.


We recommend creating a command prompt that provides the build environment (see the "Qt Creator README":http://qt.gitorious.org/qt-creator/qt-creator/blobs/master/README ). In this environment, ''Python'' (e.g. ''Active Python 2.7'' later) and ''Perl'' (e.g. ''Active State Perl 5.12'' or later) should be in the ''PATH''.
SET _ROOT=
Get Perl from: "http://www.activestate.com/activeperl/downloads":http://www.activestate.com/activeperl/downloads
Get Python from: "http://www.python.org/download/releases/":http://www.python.org/download/releases/
Get Ruby from: "http://www.rubyinstaller.org/downloads/":http://www.rubyinstaller.org/


'''Hint''': Make sure that ''Perl'' is added to the path in front of ''git'' since that ships an outdated version (''Perl'' 5.8), which will cause the scripts to fail.
REM Keeps the command line open when this script is run.
cmd /k
</pre>


Multicore building: To speed up building when using ''nmake'', the compiler can be instructed to use all available CPU cores in one of the following ways:
* Pass the option _-MP_ to Qt's ''configure''
* Set the environment variable ''CL'' (specifying Visual Studio compiler options) to ''/MP'' (On the command line: <code>set CL=/MP</code>)
* Use the tool [[jom]] instead of nmake.


====ICU on Windows====
====ICU on Windows====


Qt 5 can make use of the "ICU":http://site.icu-project.org/ library for UNICODE and Globalization support. This is '''required''' for building Qt WebKit. You can use precompiled versions of ICU with a Visual Studio 2010 dependency from the website, or "compile ICU on your own":Compiling-ICU .
Qt 5 can make use of the [http://site.icu-project.org/ ICU] library for UNICODE and Localization support. This is '''required''' for building Qt WebKit. You can use pre-compiled versions of ICU with a Visual Studio 2010 dependency from the website, get pre-compiled versions for different compilers from [http://download.qt.io/development_releases/prebuilt/icu/prebuilt/ download.qt.io], or [[Compiling ICU|compile ICU on your own]].


At compile time, the absolute paths of ''include'' and ''lib'' folders of the ICU installation must be appended to ''INCLUDE'' and ''LIB'' environment variables after calling the setup script of the Windows SDK.
The absolute paths of ''include'' and ''lib'' folders of the ICU installation must be passed with -I and -L option to Qt's configure. In addition, <tt>uic.exe</tt> needs to find the ICU DLLs during compilation, for which the ''lib'' folder of the ICU installation must be added to the ''PATH'' environment variable.
 
At run-time, the ICU DLLs need to be found. This can be achieved by copying the DLLs to the application folder or adding the ''bin'' folder of the ICU installation to the ''PATH'' environment variable.


At run-time, the ICU DLLs need to be found. This can be achieved by copying the DLLs to the application folder or adding the ''lib'' folder of the ICU installation to the ''PATH'' environment variable.


==Getting the source code==
==Getting the source code==


First clone the top-level Qt 5 git repository:
First, cd into the directory where you want the "qt5" directory to live. Then, clone the top-level Qt 5 git repository:


<code>
$ git clone <nowiki>git://code.qt.io/qt/qt5.git</nowiki>
git clone git://gitorious.org/qt/qt5.git qt5
</code>


or (if you're behind a firewall and want to use the https protocol):
or (if you're behind a firewall and want to use the https protocol):


<code>
$ git clone <nowiki>https://code.qt.io/qt/qt5.git</nowiki>
git clone https://git.gitorious.org/qt/qt5.git qt5
 
</code>
This creates a local branch that tracks "origin/dev".  If you plan to submit changes to Qt, stay on this branch. Otherwise, check out the target branch (see [[Branch Guidelines]]):
 
$ cd qt5
$ git checkout 5.12
 
For commercial-only modules and commercial-only branches of public modules, see [[Getting Commercial Qt Sources]].
===Getting the submodule source code===
 
As described in the [http://code.qt.io/cgit/qt/qt5.git/tree/README.git README.git], initialize the repository using the <tt>init-repository</tt> script, which clones the various sub-modules of Qt 5.
 
Relevant options for <tt>init-repository</tt>:
 
*<tt>--module-subset=default,-qtwebengine</tt> : '''Consider skipping the web module''' (Qt WebEngine) by passing this option. It is quite big and takes a long time to compile (and is often a source of compile errors), so it is recommended to only download it if you intend to use it. You can always re-run init-repository later on to add it.
*<tt>--branch</tt> : Check out the branch tips instead of the SHA1s of the latest successful integration build.
*<tt>--codereview-username <Jira/Gerrit username></tt> : If you plan to contribute to Qt, you may specify your [[Setting_up_Gerrit|codereview username]] (pay attention to capitalization!) so that the git remotes are properly set up. Note that it is recommended to adjust your ssh configuration instead.
 
$ cd qt5
$ perl init-repository
 
In order to build a specific release of Qt, you can checkout the desired tag:
 
$ cd qt5
$ git checkout 5.12.0
$ perl init-repository
 
'''Note:''' <tt>init-repository</tt> is currently unable to initialize tags that are too old. An alternative way to build a specific release or branch of Qt5 (although without linking of the gerrit account for code reviewing) is to use <tt>git submodule update --init</tt> in place of the  <tt>init-repository</tt> script. That translates to:
 
$ git clone <nowiki>https://code.qt.io/qt/qt5.git</nowiki>                     # cloning the repo
$ cd qt5
$ git checkout v5.8.0                                        # checking out the specific release or branch
$ git submodule update --init --recursive                    # updating each submodule to match the supermodule


Then check out the target branch (see [[Branch-Guidelines]]):
More information can be found in [[Get The Source]].


<code>
==Configuring and Building==
cd qt5
git checkout 5.4
</code>


Following the "README.git":http://qt.gitorious.org/qt/qt5/blobs/dev/README.git- file we initialize the repository using the script ''init-repository'' which clones the various sub-modules of Qt 5. Relevant options:
The Qt5 build system should be fairly resilient against any "outside distractions" - it shouldn't matter whether you have other Qt versions in PATH, and QTDIR is entirely ignored. However, make sure that you have no qmake-specific environment variables like QMAKEPATH or QMAKEFEATURES set, and the qmake -query output does not refer to any other Qt versions ($HOME/.config/Qt/QMake.conf should be empty).
* <code>&amp;#45;&amp;#45;no-webkit</code> : Consider skipping qtwebkit by passing this option. This module is quite big, takes a long time to compile and is often a source of compile errors, so it is recommend to only download it if you intend to use it. You can always re-run init-repository later on to add it.
* <code>&amp;#45;&amp;#45;codereview-username <Jira/Gerrit username></code> : If you plan to contribute to Qt, you should specify your [[Gerrit_Introduction | codereview username]] so that the git remotes are properly set up.


<code>
For more configure options, see [http://doc.qt.io/qt-5/configure-options.html Qt Configure Options].
cd qt5
perl init-repository
</code>


== Configuring and building ==
'''Note''': To build qdoc and Qt documentation in future you should set LLVM_INSTALL_DIR environment variable pointing to directory where LLVM is installed (it should be top level directory, the configuration scripts use relative path tracing from this directory). For example, in Linux with LLVM installed in isolated directory (/usr/llvm), at a bash prompt:


The Qt5 build system should be fairly resilient against any "outside distractions" - it shouldn't matter whether you have other Qt versions in PATH, and QTDIR is entirely ignored. However, make sure that you have no qmake-specific environment variables like QMAKEPATH or QMAKEFEATURES set, and the qmake -query output does not refer to any other Qt versions ($HOME/.config/Trolltech/QMake.conf should be empty).
$ export LLVM_INSTALL_DIR=/usr/llvm


Configure the build (from top level dir). Disabling tests and examples will greatly speed up compilation:
A build script called <tt>configure</tt> (or <tt>configure.bat</tt> for Windows) will be in the directory that you git cloned the source code into (<tt>~/qt5</tt> if you followed the directions above). You will want to call that script from a different, parallel-level directory, because (unless you are using a [https://wiki.qt.io/Qt_Autotest_Environment#Shadow_builds Qt Autotest Environment]) you do not want to build Qt in the directory that holds the source code. Instead, you should use a "shadow build," meaning you should not build into the source directory.  


For Linux / OS X:
For Linux / macOS, to install in <tt>~/qt5-build</tt> (an arbitrary name), assuming you are in ~:
<code>
./configure -developer-build -opensource -nomake examples -nomake tests
</code>


For Windows:
$ mkdir qt5-build
<code>
$ cd qt5-build
configure -developer-build -opensource -nomake examples -nomake tests
$ ../qt5/configure -developer-build -opensource -nomake examples -nomake tests
</code>


The <code>-developer-build</code> options export more symbols than in a traditional Qt build in order to allow more classes and functions to be unit tested. It also defaults to a 'debug' build, and installs the binaries in the current directory, avoiding the need for 'make install'. '-opensource' sets the license to be LGPL 2.1. The <code>-nomake examples</code> and <code>-nomake tests</code> parameters make sure examples and tests aren't compiled by default. You can always decide to compile them later by hand.
For Windows, again assuming you are in ~:


* Hint1: On Linux, you should also pass <code>-no-gtkstyle</code>. This is because on a number of systems (at least SUSE and Gentoo) <code>pkg-config —cflags gtk+–2.0</code> actually returns paths that include the system Qt 4.x include directories.
$ mkdir qt5-build
$ cd qt5-build
$ ..\\qt5\configure -developer-build -opensource -nomake examples -nomake tests


* Hint2: You can add <code>-confirm-license</code> to get rid of the question whether you agree to the license.
The <tt>-developer-build</tt> option causes more symbols to be exported in order to allow more classes and functions to be unit tested than in a regular Qt build. It also defaults to a 'debug' build, and installs the binaries in the current directory, avoiding the need for 'make install'. '-opensource' sets the license to be GPL/LGPL. The <tt>-nomake examples</tt> and <tt>-nomake tests</tt> parameters make sure examples and tests aren't compiled by default. You can always decide to compile them later by hand.


* Hint3: On Windows, you might not be able to build if <code>sh.exe</code> is in your ''PATH'' (for example due to a ''git'' or ''msys'' installation). Such an error is indicated by <code>qt5-srcqtbasebinqmake.exe: command not found</code> and alike. In this case, make sure that <code>sh.exe</code> is ''not'' in your path. You will have to re-configure if your installation is already configured.
'''Some Hints'''


Now trigger the build by running:
#You can add <tt>-confirm-license</tt> to get rid of the question whether you agree to the license.
#On Windows, you might not be able to build if <tt>sh.exe</tt> is in your ''PATH'' (for example due to a ''git'' or ''msys'' installation). Such an error is indicated by <tt>qt5-src\qtbase\bin\qmake.exe: command not found</tt> and alike. In this case, make sure that <tt>sh.exe</tt> is ''not'' in your path. You will have to re-configure if your installation is already configured.
#If you are planning to make contributions with git, it is advised to configure and build the source in a separate directory so the binaries are not seen by git. This can be done by navigating to the desired build directory and calling configure/make in that directory. (But shadow builds are discouraged in [https://wiki.qt.io/Qt_Autotest_Environment#Shadow_builds Qt Autotest Environment].)
##''Note:'' If you do a shadow build, follow the instructions above for creating a build directory that is parallel to the source directory. Do '''NOT''' make the build directory a subdirectory of the source tree. The build will probably fail in weird ways if the build directory is not exactly parallel to the source directory.


For Linux / OS X:
Now trigger the build from within the build directory by running:
<code>
make -j4 all
</code>


If you are making an out-of-source developer build and that also includes building the QtWebKit module, the above command will "return an error":https://bugreports.qt.io/browse/QTBUG-35514 about <code>WebCore/RunLoop.h</code> while building QtWebKit. This can be fixed by omitting the ''all'' and simply running:
$ make -j$(nproc)
<code>
make -j4
</code>


For Windows (MSVC), choose one of the following, depending on your setup/environment:
For Windows (MSVC), choose one of the following, depending on your setup/environment:
<code>
 
nmake
$ nmake
jom
 
mingw32-make
or
</code>
 
$ jom
 
or
 
$ mingw32-make


Or only build a specific module, e.g. declarative, and modules it depends on:
Or only build a specific module, e.g. declarative, and modules it depends on:


<code>
$ make module-qtdeclarative
make module-qtdeclarative
</code>


=== Building Qt WebKit ===
===Building Qt WebKit===


==== Windows ====
====Windows====


"WebKit.org":http://trac.webkit.org/wiki/BuildingQtOnWindows has instructions for building WebKit on Windows. "ICU":http://site.icu-project.org/ is required for building.
[http://trac.webkit.org/wiki/BuildingQtOnWindows WebKit.org] has instructions for building WebKit on Windows. [http://site.icu-project.org/ ICU] is required for building.


The tools ''bison'', ''flex'' and ''gperf'' which are required for building are provided for convenience in the folder ''gnuwin32\bin''. If you are using shadow builds, you must add this directory to your <code>PATH</code>, else no special actions need to be done manually in order to use them.
The tools ''bison'', ''flex'' and ''gperf'' which are required for building are provided for convenience in the folder ''gnuwin32\bin''. If you are using shadow builds, you must add this directory to your <tt>PATH</tt>, else no special actions need to be done manually in order to use them.


== Installing (Linux / OS X) ==
==Installing==


* '''Note:''' Installation is only needed if you haven't used the configure options <code>-developer-build</code> or <code>-prefix "%PWD%/qtbase"</code>. Otherwise you can just use Qt from the build directory.
*'''Note:''' Installation is only needed if you haven't used the configure options <tt>-developer-build</tt> or <tt>-prefix "%PWD%/qtbase"</tt>. Otherwise, you can just use Qt from the build directory.


To install, run
To install, run


<code>
$ make install
make install
 
</code>
or
 
$ nmake install
 
or
 
$ jom install
 
or
 
$ mingw32-make install


== Cleaning ==
==Cleaning==


To get a '''really''' clean tree use:
To get a '''really''' clean tree use:


<code>
$ git submodule foreach --recursive "git clean -dfx" && git clean -dfx
git submodule foreach —recursive "git clean -dfx"
</code>


since make confclean no longer works from the top-level of the repo.
since make confclean no longer works from the top-level of the repo.


== Getting updates ==
==Getting updates==


To update both the qt5.git repo as well as the submodules to the list of revisions that are known to work, run
To update both the qt5.git repo as well as the submodules to the list of revisions that are known to work, run
<code>
git pull
perl init-repository -f
</code>


In addition, you should pass the same parameters to init-repository as you did in "Getting the source code".
$ git pull
$ perl init-repository -f
 
In addition, you should pass the same parameters to init-repository as you did in [[Building_Qt_5_from_Git#Getting_the_source_code|Getting the source code]].


Unlike a "normal" git submodule update, this ensures that any changes to the module structure are automatically pulled as well.
Unlike a "normal" git submodule update, this ensures that any changes to the module structure are automatically pulled as well.


If you are planning to do nightly builds, consider using the script ''qt5_tool'' that lives in ''qtrepotools/bin''. It provides options for updating the repository, cleaning and building. For example, <code>qt5_tool -u -c -b</code> can be used to clean, update and build. <code>qt5_tool -p -c- b</code> would be used to pull all modules to the head of their master branches.
If you are planning to do nightly builds, consider using the script ''qt5_tool'' that lives in ''qtrepotools/bin''. It provides options for updating the repository, cleaning and building. For example, <tt>qt5_tool -u -c -b</tt> can be used to clean, update and build. <tt>qt5_tool -p -c -b</tt> would be used to pull all modules to the head of their master branches.


Depending upon what changed in the source since it was last updated you might have to run configure again. To be really sure everything gets built, you can run clean first, then configure and make.
Depending upon what changed in the source since it was last updated you might have to run configure again. The safe thing to do is to always run <tt>config.status -recheck-all</tt> in the build directory after updating.


* '''Hint1:''' The submodule update does a checkout in submodules, potentially hiding any local commits you've done. If the latter happened to you (and you haven't been working with branches anyhow), <code>git reflog</code> is your friend.
*'''Hint1:''' The submodule update does a checkout in submodules, potentially hiding any local commits you've done. If the latter happened to you (and you haven't been working with branches anyhow), <tt>git reflog</tt> is your friend.
* '''Hint2:''' When creating scripts for updates on Windows, note that <code>git clean</code> often fails if some process locks a file or folder.
*'''Hint2:''' When creating scripts for updates on Windows, note that <tt>git clean</tt> often fails if some process locks a file or folder.


== Using latest branches in the submodules ==
==Using latest branches in the submodules==


By default the checkout will not contain the latest stable/dev branches of each individual submodule repository, but a combination of versions that are known to work together. If you want to get the absolute latest stuff you can do so on a per-module basis, e.g.
By default, the checkout will not contain the latest stable/dev branches of each individual submodule repository, but a combination of versions that are known to work together. If you want to get the absolute latest stuff you can do so on a per-module basis, e.g.


<code>
$ cd qtdeclarative
cd qtdeclarative
$ git fetch
git fetch
$ git checkout -b 5.9 origin/5.9
git checkout 5.4 origin/5.4
</code>


or use qt5_tool to update all repositories:
or tell init-repository to check out branches in all repositories:


<code>
$ perl init-repository -f --branch
./qtrepotools/bin/qt5_tool -p
</code>


However, there's a good chance that compilation will fail due to incompatible versions of submodules. You might want to ask other persons actively working on a module how to resolve these incompatibilities.
Some [[Unix shell tricks for developing Qt]] can be useful when you are making or reviewing changes in multiple modules.
 
Some [[unix shell tricks for Qt development|advanced shell tricks]] can be useful when you are making or reviewing changes in multiple modules.


==Issues==
==Issues==
Line 438: Line 547:
You should install the libxcb and it's accompanying packages, see 'System Requirements'.
You should install the libxcb and it's accompanying packages, see 'System Requirements'.


====configure fails with errors like "cannot stat file "====
====configure fails with errors like "cannot stat file ..."====


Your perl version is too old, Qt 5 beta1 needs at least 5.14.
Your perl version is too old, Qt 5 beta1 needs at least 5.14.
====configure fails to enable qdoc on Debian====
Debian allows parallel installs of libclang-<version>-dev in /usr/lib/llvm-<version> so LLVM_INSTALL_DIR should be /usr/lib/llvm-<version> to build qdoc. Not /usr/llvm.


====qmlscene segfaults "Cannot create platform GL context, none of GLX, EGL, DRI2 is enabled" (Linux)====
====qmlscene segfaults "Cannot create platform GL context, none of GLX, EGL, DRI2 is enabled" (Linux)====
Line 446: Line 558:
Try installing the libx11-xcb-dev package:
Try installing the libx11-xcb-dev package:


<code>
$ sudo apt-get install libx11-xcb-dev
sudo apt-get install libx11-xcb-dev
</code>


afterwards you have to re-run configure and force qtbase/src/plugins/platforms/xcb to recompile.
afterwards you have to re-run configure and force qtbase/src/plugins/platforms/xcb to recompile.
Line 458: Line 568:
====on Ubuntu/Debian:====
====on Ubuntu/Debian:====


<code>
$ sudo apt-get install libicu-dev
sudo apt-get install libicu-dev
</code>


====on Fedora:====
====on Fedora:====


<code>
$ su - -c "yum install libicu-devel"
su- -c "yum install libicu-devel"
 
</code>
*You can also compile Qt without Qt WebKit by deleting / renaming the qtwebkit, qtwebkit-examples-and-demos directories.
*The --no-webkit option of configure added, see [https://bugreports.qt.io/browse/QTBUG-20577 QTBUG-20577] issue.


* You can also compile Qt without Qt WebKit by deleting / renaming the qtwebkit, qtwebkit-examples-and-demos directories.
====Qt D-Bus fails to build due to "inconsistent user-defined literal suffixes"====
* The —no-webkit option of configure added, see "QTBUG-20577":https://bugreports.qt.io/browse/QTBUG-20577 issue.


==== Qt D-Bus fails to build due to "inconsistent user-defined literal suffixes" ====
This occurs when you attempt to build Qt 5 with GCC 4.7 while D-Bus < 1.4.20 is present on your system. (For example, the default Fedora 17 installation is prone to this error.) The error message is this:


This occours when you attempt to build Qt 5 with GCC 4.7 while D-Bus < 1.4.20 is present on your system. (For example, the default Fedora 17 installation is prone to this error.) The error message is this:
qdbusinternalfilters.cpp:124:36: error: inconsistent user-defined literal suffixes ‘DBUS_INTROSPECT_1_0_XML_PUBLIC_IDENTIFIER’ and ‘DBUS_INTROSPECT_1_0_XML_SYSTEM_IDENTIFIER’ in string literal


<code>
'''Note:''' The error is in the header files of D-Bus itself, and it has been fixed upstream, see https://bugs.freedesktop.org/show_bug.cgi?id=46147.
qdbusinternalfilters.cpp:124:36: error: inconsistent user-defined literal suffixes ‘DBUS_INTROSPECT_1_0_XML_PUBLIC_IDENTIFIER’ and ‘DBUS_INTROSPECT_1_0_XML_SYSTEM_IDENTIFIER’ in string literal
</code>


Note: The error is in the header files of D-Bus itself, and it has been fixed upstream, see https://bugs.freedesktop.org/show_bug.cgi?id=46147
'''Solution:''' either upgrade to a newer version of D-Bus or edit that one line of the header file manually.
Solution: either upgrade to a newer version of D-Bus or edit that one line of the header file manually.


==== […]::isNull is not defined (from qvariant_p.h) ====
====...::isNull is not defined (from qvariant_p.h)====


C+''11 support is detected while your GCC doesn't properly support it
C++11 support is detected while your GCC doesn't properly support it. Fixed by passing <tt>-no-c11</tt> to the configure options.
Fixed by passing
<code>-no-c11<code>
to the configure options


====cc1: fatal error: .pch/release-shared/QtGui: No such file or directory====
====cc1: fatal error: .pch/release-shared/QtGui: No such file or directory====


Currently unresolved bug with the build of assembly files, see discussion at http://comments.gmane.org/gmane.comp.lib.qt.devel/5933
Currently unresolved bug with the build of assembly files, see discussion at http://comments.gmane.org/gmane.comp.lib.qt.devel/5933<br />
Fixed by passing
Fixed by passing -no-pch to the configure options.
</code>-no-pch</code>
to the configure options


====ld: hidden symbol `void QQmlThread::postMethodToThread<QQmlDataBlob*, QQmlDataBlob*, QQmlDataLoaderThread>(void (QQmlDataLoaderThread::''')(QQmlDataBlob'''), QQmlDataBlob* const&amp;amp;)' isn't defined====
====ld: hidden symbol `void QQmlThread::postMethodToThread<QQmlDataBlob*, QQmlDataBlob*, QQmlDataLoaderThread>(void (QQmlDataLoaderThread::''')(QQmlDataBlob'''), QQmlDataBlob* const&)' isn't defined====


Bug with GCC versions < 4.4.x, see bug report at https://bugzilla.redhat.com/show_bug.cgi?id=493929
Bug with GCC versions < 4.4.x, see bug report at https://bugzilla.redhat.com/show_bug.cgi?id=493929. Fixed by adding <tt>QMAKE_CXXFLAGS_RELEASE *= -fno-inline</tt> in ''qtdeclarative/src/qml/qml.pro''.
Fixed by adding
<code>QMAKE_CXXFLAGS_RELEASE''= -fno-inline</code>
in '''qtdeclarative/src/qml/qml.pro'''


==== Touchscreen (or Wacom tablet) doesn't work ====
====Touchscreen (or Wacom tablet) doesn't work====


Qt depends on having libxi (including development headers), supporting XInput protocol 2.2 or higher, available at build time in order to have multi-touch support. Otherwise configure will fall back to XInput 2.0 which does not support touchscreens. To prove that is the problem, try this:
Qt depends on having libxi (including development headers), supporting XInput protocol 2.2 or higher, available at build time in order to have multi-touch support. Otherwise configure will fall back to XInput 2.0 which does not support touchscreens. To prove that is the problem, try this:


export QT_XCB_DEBUG_XINPUT_DEVICES=1
$ export QT_XCB_DEBUG_XINPUT_DEVICES=1


and try your Qt application again. At startup, Qt will enumerate the input devices available, like this
and try your Qt application again. At startup, Qt will enumerate the input devices available, like this


<code>
XInput version 2.2 is available and Qt supports 2.2 or greater
XInput version 2.2 is available and Qt supports 2.2 or greater
input device … (keyboard, mouse etc.) …
input device … (keyboard, mouse etc.) …
input device Advanced Silicon S.A CoolTouch™ System
input device Advanced Silicon S.A CoolTouch™ System
  has valuator "Abs MT Position X" recognized? true
  has valuator "Abs MT Position X" recognized? true
  has valuator "Abs MT Position Y" recognized? true
  has valuator "Abs MT Position Y" recognized? true
  has touch class with mode 1
  has touch class with mode 1
  it's a touchscreen with type 0 capabilities 0x21 max touch points 10
  it's a touchscreen with type 0 capabilities 0x21 max touch points 10
</code>


If it does not say Qt supports 2.2 or greater, it means the headers weren't available when Qt was built, so the support for touch was not included. If you do have 2.2 or greater but it doesn't say it's a touchscreen at the end, there may be some other problem such that the touchscreen is not recognized, and you may want to write up a bug, after verifying that touch works in other X11 applications.
If it does not say Qt supports 2.2 or greater, it means the headers weren't available when Qt was built, so the support for touch was not included. If you do have 2.2 or greater but it doesn't say it's a touchscreen at the end, there may be some other problem such that the touchscreen is not recognized, and you may want to write up a bug, after verifying that touch works in other X11 applications.


=== Windows ===
===Windows===
 
Note that if you're shadow-building Qt, the source directory and build directory must be on the same drive, nested equally deeply. Also, make sure there are ''no'' old build artifacts in the source directory.


==== Debugging OpenGL issues (Windows) ====
====Debugging OpenGL issues (Windows)====


Set the environment variable <code>QT_QPA_VERBOSE=gl:1</code> and run the application with "DebugView":http://technet.microsoft.com/en-us/sysinternals/bb896647 installed. The log will show the requested vs obtained OpenGL version. If the log tells you that it only has OpenGL 1.1, QML2 will not work. Note that ''qmlscene'' will not report errors about unsupported OpenGL versions.
Set the environment variable <tt>QT_QPA_VERBOSE=gl:1</tt> and run the application with [http://technet.microsoft.com/en-us/sysinternals/bb896647 DebugView] installed. The log will show the requested vs obtained OpenGL version. If the log tells you that it only has OpenGL 1.1, Qt Quick 2 will not work. Note that ''qmlscene'' will not report errors about unsupported OpenGL versions.


== Questions &amp; Comments ==
==Questions and comments==


Please raise questions & comments about this article in the forum: http://qt-project.org/forums/viewthread/7018
Please raise questions & comments about this article in this [http://forum.qt.io/topic/6861/qt5-development-primer forum thread].

Latest revision as of 08:36, 11 January 2024

En Ar Bg De El Es Fa Fi Fr Hi Hu It Ja Kn Ko Ms Nl Pl Pt Ru Sq Th Tr Uk Zh

This article provides hints for checking out and building the Qt 5 repositories. This is primarily for developers who want to contribute to the Qt library itself, or who want to try the latest unreleased code.

If you simply want to build a specific release of Qt from source to use the libraries in your own project, you can download the source code from the Official Releases page or the Archive. Alternatively, commercial customers can download the Source Packages via the Qt Account portal.

To compile Qt 6, see Building Qt 6 from Git.

To compile Qt Creator, see Building Qt Creator from Git.

System Requirements

All desktop platforms

  • Git (>= 1.6.x)
  • Perl (>=5.14)
  • Python (>=2.6.x)
  • A working C++ compiler

For more detailed information, see Building Qt Sources

Documentation (optional)

  • Clang (>=8.x)

See Installing Clang for QDoc

SSL (optional)

See Enabling and Disabling SSL Support

For Windows, bison, flex and gperf are provided with the source code at c:\pathToQt\gnuwin32\bin. Get Ruby from http://rubyinstaller.org/. You can download the precompiled ICU packages from download.qt.io, or see Compiling-ICU to compile your own.

Linux/X11

apt-get build-dep

Ubuntu/Debian based systems have a convenient way of installing build-depends for any package:

sudo apt-get build-dep qtbase5-dev

RPM-based distros with yum offer a similar tool called yum-builddep.

Note: In older Debian-based distros, use qt5-default in place of qtbase5-dev. See also [1], [2].

Note: if you see the following error message while running the commands above on Ubuntu:

E: You must put some 'source' URIs in your sources.list

Then you will need to enable the "Source code" option in Software and Updates > Ubuntu Software under the "Downloadable from the Internet" section. This setting can also be found by running software-properties-gtk.

Note: some of the package names given here contain embedded version numbers; it can be constructive to ask your package-manager for a list of available versions, e.g. on Debian dpkg -l 'libclang*-dev' when the instructions below suggest libclang6-dev may offer you a more recent version, or the package may have changed name, in which case select a sensible match to what's listed below from the dpkg -l output to install. These lists tend to go out of date…

Convenience packages (Ubuntu 11.10 -- 12.10 only)

For Ubuntu/Debian, Gabor Loki has provided a custom PPA with the sedkit-env-webkit meta package that installs all required dependencies for building Qt/Qt WebKit. You can add the PPA by calling:

sudo apt-add-repository ppa:u-szeged/sedkit &&\
sudo apt-get update &&\
sudo apt-get install sedkit-env-qtwebkit

For other distros, get the separate components below.

Build essentials

Ubuntu and/or Debian:
sudo apt-get install build-essential perl python3 git
Fedora 30
su - -c "dnf install perl-version git gcc-c++ compat-openssl10-devel harfbuzz-devel double-conversion-devel libzstd-devel at-spi2-atk-devel dbus-devel mesa-libGL-devel"
OpenSUSE:
sudo zypper install git-core gcc-c++ make

Libxcb

Libxcb is now the default window-system backend for platforms based on X11/Xorg, and you should therefore install libxcb and its accompanying packages. Qt5 should build with whatever libxcb version is available in your distro's packages (but you may optionally wish to use v1.8 or higher to have threaded rendering support). The README lists the required packages.

Ubuntu/Debian:
 sudo apt-get install '^libxcb.*-dev' libx11-xcb-dev libglu1-mesa-dev libxrender-dev libxi-dev libxkbcommon-dev libxkbcommon-x11-dev
Fedora 30:
su - -c "dnf install libxcb libxcb-devel xcb-util xcb-util-devel xcb-util-*-devel libX11-devel libXrender-devel libxkbcommon-devel libxkbcommon-x11-devel libXi-devel libdrm-devel libXcursor-devel libXcomposite-devel"
OpenSUSE 12+:
sudo zypper in xorg-x11-libxcb-devel xcb-util-devel xcb-util-image-devel xcb-util-keysyms-devel xcb-util-renderutil-devel xcb-util-wm-devel xorg-x11-devel libxkbcommon-x11-devel libxkbcommon-devel libXi-devel
ArchLinux/Manjaro:
sudo pacman -S --needed libxcb xcb-proto xcb-util xcb-util-image xcb-util-wm libxi
Chakra Linux: Install the ArchLinux packages, plus xcb-util-keysyms. It's available from CCR.
Mandriva/ROSA/Unity:
urpmi 'pkgconfig(xcb)' 'pkgconfig(xcb-icccm)' 'pkgconfig(xcb-image)' 'pkgconfig(xcb-renderutil)' 'pkgconfig(xcb-keysyms)' 'pkgconfig(xrender)'
Linux Mint:
apt-get install libx11-xcb-dev libxcb-composite0-dev libxcb-cursor-dev libxcb-damage0-dev libxcb-dpms0-dev libxcb-dri2-0-dev libxcb-dri3-dev libxcb-glx0-dev libxcb-icccm4-dev libxcb-image0-dev libxcb-keysyms1-dev libxcb-present-dev libxcb-randr0-dev libxcb-render-util0-dev libxcb-render0-dev libxcb-shape0-dev libxcb-shm0-dev libxcb-sync-dev libxcb-util-dev libxcb-xfixes0-dev libxcb-xinerama0-dev libxcb-xkb-dev libxcb-xtest0-dev libxcb1-dev
Centos 5/6 Install missing Qt build dependencies:
yum install libxcb libxcb-devel xcb-util xcb-util-devel

Install Red Hat DevTools 1.1 for CentOS-5/6 x86_64, they are required due to outdated GCC shipped with default CentOS:

wget http://people.centos.org/tru/devtools-1.1/devtools-1.1.repo -O /etc/yum.repos.d/devtools-1.1.repo
yum install devtoolset-1.1

Initialise your newly installed dev tools:

scl enable devtoolset-1.1 bash
# Test - Expect to see gcc version 4.7.2 (not gcc version 4.4.7)
gcc -v

For more info on preparing the environment on CentOS, see this thread.

Centos 7 Update to gcc 7:
yum install centos-release-scl
yum install devtoolset-7-gcc*
scl enable devtoolset-7 bash

Install missing Qt build dependencies (Qt 5.13):

yum install libxcb libxcb-devel xcb-util xcb-util-devel mesa-libGL-devel libxkbcommon-devel

OpenGL support

For Qt Quick 2, a graphics driver with native OpenGL 2.0 support is highly recommended.

Accessibility

It is recommended to build with accessibility enabled, install libatspi2.0-dev and libdbus-1-dev packages.

Qt WebKit

Ubuntu/Debian:
sudo apt-get install flex bison gperf libicu-dev libxslt-dev ruby
Fedora 30:
su - -c "dnf install flex bison gperf libicu-devel libxslt-devel ruby"
OpenSUSE:
sudo zypper install flex bison gperf libicu-devel ruby
Mandriva/ROSA/Unity:
urpmi gperf

Qt WebEngine

Ubuntu/Debian:
sudo apt-get install libxcursor-dev libxcomposite-dev libxdamage-dev libxrandr-dev libxtst-dev libxss-dev libdbus-1-dev libevent-dev libfontconfig1-dev libcap-dev libpulse-dev libudev-dev libpci-dev libnss3-dev libasound2-dev libegl1-mesa-dev gperf bison nodejs
Fedora/RHEL:
sudo dnf install freetype-devel fontconfig-devel pciutils-devel nss-devel nspr-devel ninja-build gperf cups-devel pulseaudio-libs-devel libcap-devel alsa-lib-devel bison libXrandr-devel libXcomposite-devel libXcursor-devel libXtst-devel dbus-devel fontconfig-devel alsa-lib-devel rh-nodejs12-nodejs rh-nodejs12-nodejs-devel
OpenSUSE:
sudo zypper install alsa-devel dbus-1-devel libXcomposite-devel libXcursor-devel libXrandr-devel libXtst-devel mozilla-nspr-devel mozilla-nss-devel gperf bison nodejs10 nodejs10-devel

Qt Multimedia

You'll need at least alsa-lib (>= 1.0.15) and gstreamer (>=0.10.24) with the base-plugins package.

To build multimedia on Windows, FEATURE_wmf has to be enabled and wmf has to be installed.

Ubuntu/Debian:
sudo apt-get install libasound2-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev libgstreamer-plugins-good1.0-dev libgstreamer-plugins-bad1.0-dev
Fedora 30:
dnf install pulseaudio-libs-devel alsa-lib-devel gstreamer1-devel gstreamer1-plugins-base-devel wayland-devel

QDoc Documentation Generator Tool

Ubuntu/Debian:
sudo apt install clang libclang-dev
Fedora 30:
su -c 'dnf install llvm-devel'

macOS

Install the latest Xcode from the App Store. Verify that your Xcode install is properly set up for command line use:

xcodebuild -version && xcodebuild -showsdks

This should give you eg:

Xcode 6.2
Build version 6C131e
OS X SDKs:
 OS X 10.9                     	-sdk macosx10.9
 OS X 10.10                    	-sdk macosx10.10
iOS SDKs:
 iOS 8.2                       	-sdk iphoneos8.2
iOS Simulator SDKs:
 Simulator - iOS 8.2           	-sdk iphonesimulator8.2

You can verify that the right Xcode is being used by running:

xcode-select --print-path

If this points to /Developer you're probably using an older Xcode version. Switch to the latest one by running:

sudo xcode-select --switch /Applications/Xcode.app/Contents/Developer

If you have not installed CMake and Ninja, you need to do that

  1. Launch "MaintenanceTool", and choose "Add or remove components" (click next)
  2. under "Qt -> Developer and Design Tools", check "CMake" and "Ninja" (click next, and complete that)
  3. in Terminal, ensure you add the folder containing cmake to your $PATH, eg: export PATH=$PATH:/path_to/Qt/Tools/CMake/CMake.app/Contents/bin

Windows

Windows Graphics Drivers

The full feature set of Qt Quick 2 requires OpenGL 2.1 or higher or OpenGL ES 2.0 to work. Several options are available:

  1. Using the native OpenGL driver for your graphics card (Note: The stock Windows driver only supports OpenGL 1.1, which is insufficient).
  2. Using the ANGLE-library to translate OpenGL calls into DirectX. A copy of ANGLE is bundled in Qt 5.
  3. Using a software rasterizer shipped in the Qt SDK. See MesaLlvmpipe for instructions on how that is built.

Starting with Qt 5.8, many Qt Quick applications can also be run with the built-in software backend (previously known as the Qt Quick 2D Renderer). This is not the same as running through a full OpenGL software rasterizer, and is a lot more lightweight. See the documentation on how to request a specific backend.

Qt can be built to dynamically choose the OpenGL implementation (see Dynamically Loading Graphics Drivers) by passing the option -opengl dynamic to configure. To build Qt to always use the native OpenGL driver, pass -opengl desktop. To build Qt to always use ANGLE, pass -opengl es2.

ANGLE dependencies

  • MSVC
    • Qt < 5.12: Building ANGLE with Windows SDKs prior to Windows Kit 8 requires the DirectX SDK to be installed, and the path to the d3d_compiler<xx>.dll to be added to the PATH variable.
    • Qt >= 5.12: Qt needs at least a Windows 10 SDK in order to build ANGLE. No additional manual setup is needed
  • MinGW
    • Building ANGLE with Windows SDKs prior to Windows Kit 8 requires the DirectX SDK to be installed, and the path to the d3d_compiler<xx>.dll to be added to the PATH variable.

Any project that uses run-time shader compilation must have D3DCOMPILER_xx.DLL copied to the local executable path for the project. This DLL is available in this sub-directory of the Windows SDK installation under %ProgramFiles(x86)%\Windows Kits\<version>\Redist\D3D\<arch> where <arch> is x86 and x64 (see [1]).

Supported Compilers on Windows

  • Visual Studio 2019
  • Visual Studio 2017 (might need a recent service pack, especially for QtWebEngine)
  • MinGW-w64 based compiler with g++ version 7.3 or higher (e.g. MinGW-builds, see also MinGW-64-bit).

Notes:

  • Add the compiler to the PATH environment variable. Visual Studio usually ships .bat files named vcvarsall.bat or similar that can be called with a command line parameter for choosing the toolchain (/x86, /x64, etc) to set up the environment.
  • Windows SDK v6.0A/v7.0A contains the same compiler as Visual Studio 2008/2010.
  • Windows SDK 8.0 and later do not include a compiler.
  • As of 16.3.2012, if you wish to install both Visual Studio 2010 and the standalone SDK, you need to follow this order (see readme.html provided with the service pack):
    1. Install Visual Studio 2010
    2. Install Windows SDK 7.1. See also the Cannot Install Windows SDK page.
    3. Install Visual Studio 2010 SP1
    4. Install Visual C++ 2010 SP1 Compiler Update for the Windows SDK 7.1

Windows Build environment

We recommend creating a command prompt that provides the build environment (see the Qt Creator README ). In this environment, Python (e.g. Active Python 2.7 later) and Perl (e.g. StrawberryPerl 5.12 or later) should be in the PATH. Ruby is required for WebKit.

Hint: If you installed git with the non-recommended setting to add git's entire Unix environment to PATH, make sure that Perl is added to the path in front of git, since that ships an incompatible build of perl, which would cause the scripts to fail. Also, MinGW builds of Qt become Msys builds due to the presence of sh.exe; and those who've tried have had more success configuring and building for MinGW in MS's cmd.exe Command Prompt than in the Git Bash shell.

Multicore building: To speed up building when using nmake, the compiler can be instructed to use all available CPU cores in one of the following ways:

  • Pass the option -mp to Qt's configure
  • Set the environment variable CL (specifying Visual Studio compiler options) to /MP (On the command line: set CL=/MP)
  • Use the tool jom instead of nmake. (Using jom instead of nmake reduces compile time quite a bit)

Configuring Visual Studio 2013 on Windows 8, 8.1 & 10

Setting the environment variables to properly build Qt can be done by following the steps below:

  • Create a file called qt5vars.bat, paste the following inside it and save it

Hint: Remember to change <arch> to your desired platform and double-check that the paths are correct for Qt and Visual Studio

@echo off

REM Set up \Microsoft Visual Studio 2015, where <arch> is \c amd64, \c x86, etc.
CALL "C:\Program Files (x86)\Microsoft Visual Studio 14.0\VC\vcvarsall.bat" <arch>

REM Edit this location to point to the source code of Qt
SET _ROOT=C:\qt5

SET PATH=%_ROOT%\qtbase\bin;%_ROOT%\gnuwin32\bin;%PATH%

REM Uncomment the below line when using a git checkout of the source repository
SET PATH=%_ROOT%\qtrepotools\bin;%PATH%

REM Uncomment the below line when building with OpenSSL enabled. If so, make sure the directory points
REM to the correct location (binaries for OpenSSL).
REM SET PATH=C:\OpenSSL-Win32\bin;%PATH%

REM When compiling with ICU, uncomment the lines below and change <icupath> appropriately:
REM SET INCLUDE=<icupath>\include;%INCLUDE%
REM SET LIB=<icupath>\lib;%LIB%
REM SET PATH=<icupath>\lib;%PATH%

REM Contrary to earlier recommendations, do NOT set QMAKESPEC.

SET _ROOT=

REM Keeps the command line open when this script is run.
cmd /k

Complete the steps below after you have cloned Qt5 from Git

  • After having cloned Qt5 from Git (assuming it's at C:\Qt5), move qt5vars.bat to the Qt5 folder
  • Double-click on the script to run it. Once it runs the script, the command prompt will stay open to enter additional commands.
  • Navigate to C:\Qt5 in the command prompt

The working directory should be c:\Qt5.

All the required environment variables are now correctly set up and building Qt5 with nmake should work now. You have to run qt5vars.bat and use the command prompt every time you build Qt5 with nmake.

The above steps also work for setting up nmake to build jom.


Configuring MinGW on Windows 8, 8.1 & 10

The configuration process is similar to above except for a few minor changes in the qt5vars.bat script:

@echo off

REM Edit this location to point to the source code of Qt
SET _ROOT=C:\qt5

SET PATH=%_ROOT%\qtbase\bin;%_ROOT%\gnuwin32\bin;%PATH%

REM Uncomment the below line when using a git checkout of the source repository
SET PATH=%_ROOT%\qtrepotools\bin;%PATH%

REM Uncomment the below line when building with OpenSSL enabled. If so, make sure the directory points
REM to the correct location (binaries for OpenSSL).
REM SET PATH=C:\OpenSSL-Win32\bin;%PATH%

REM When compiling with ICU, uncomment the lines below and change <icupath> appropriately:
REM Note that -I <icupath>\include and -L <icupath>\lib need to be passed to
REM configure separately (that works for MSVC as well).
REM SET PATH=<icupath>\lib;%PATH%

REM Contrary to earlier recommendations, do NOT set QMAKESPEC.

SET _ROOT=

REM Keeps the command line open when this script is run.
cmd /k


ICU on Windows

Qt 5 can make use of the ICU library for UNICODE and Localization support. This is required for building Qt WebKit. You can use pre-compiled versions of ICU with a Visual Studio 2010 dependency from the website, get pre-compiled versions for different compilers from download.qt.io, or compile ICU on your own.

The absolute paths of include and lib folders of the ICU installation must be passed with -I and -L option to Qt's configure. In addition, uic.exe needs to find the ICU DLLs during compilation, for which the lib folder of the ICU installation must be added to the PATH environment variable.

At run-time, the ICU DLLs need to be found. This can be achieved by copying the DLLs to the application folder or adding the lib folder of the ICU installation to the PATH environment variable.

Getting the source code

First, cd into the directory where you want the "qt5" directory to live. Then, clone the top-level Qt 5 git repository:

$ git clone git://code.qt.io/qt/qt5.git

or (if you're behind a firewall and want to use the https protocol):

$ git clone https://code.qt.io/qt/qt5.git

This creates a local branch that tracks "origin/dev". If you plan to submit changes to Qt, stay on this branch. Otherwise, check out the target branch (see Branch Guidelines):

$ cd qt5
$ git checkout 5.12

For commercial-only modules and commercial-only branches of public modules, see Getting Commercial Qt Sources.

Getting the submodule source code

As described in the README.git, initialize the repository using the init-repository script, which clones the various sub-modules of Qt 5.

Relevant options for init-repository:

  • --module-subset=default,-qtwebengine : Consider skipping the web module (Qt WebEngine) by passing this option. It is quite big and takes a long time to compile (and is often a source of compile errors), so it is recommended to only download it if you intend to use it. You can always re-run init-repository later on to add it.
  • --branch : Check out the branch tips instead of the SHA1s of the latest successful integration build.
  • --codereview-username <Jira/Gerrit username> : If you plan to contribute to Qt, you may specify your codereview username (pay attention to capitalization!) so that the git remotes are properly set up. Note that it is recommended to adjust your ssh configuration instead.
$ cd qt5
$ perl init-repository

In order to build a specific release of Qt, you can checkout the desired tag:

$ cd qt5
$ git checkout 5.12.0
$ perl init-repository

Note: init-repository is currently unable to initialize tags that are too old. An alternative way to build a specific release or branch of Qt5 (although without linking of the gerrit account for code reviewing) is to use git submodule update --init in place of the init-repository script. That translates to:

$ git clone https://code.qt.io/qt/qt5.git                     # cloning the repo
$ cd qt5
$ git checkout v5.8.0                                         # checking out the specific release or branch
$ git submodule update --init --recursive                     # updating each submodule to match the supermodule

More information can be found in Get The Source.

Configuring and Building

The Qt5 build system should be fairly resilient against any "outside distractions" - it shouldn't matter whether you have other Qt versions in PATH, and QTDIR is entirely ignored. However, make sure that you have no qmake-specific environment variables like QMAKEPATH or QMAKEFEATURES set, and the qmake -query output does not refer to any other Qt versions ($HOME/.config/Qt/QMake.conf should be empty).

For more configure options, see Qt Configure Options.

Note: To build qdoc and Qt documentation in future you should set LLVM_INSTALL_DIR environment variable pointing to directory where LLVM is installed (it should be top level directory, the configuration scripts use relative path tracing from this directory). For example, in Linux with LLVM installed in isolated directory (/usr/llvm), at a bash prompt:

$ export LLVM_INSTALL_DIR=/usr/llvm

A build script called configure (or configure.bat for Windows) will be in the directory that you git cloned the source code into (~/qt5 if you followed the directions above). You will want to call that script from a different, parallel-level directory, because (unless you are using a Qt Autotest Environment) you do not want to build Qt in the directory that holds the source code. Instead, you should use a "shadow build," meaning you should not build into the source directory.

For Linux / macOS, to install in ~/qt5-build (an arbitrary name), assuming you are in ~:

$ mkdir qt5-build
$ cd qt5-build
$ ../qt5/configure -developer-build -opensource -nomake examples -nomake tests

For Windows, again assuming you are in ~:

$ mkdir qt5-build
$ cd qt5-build
$ ..\\qt5\configure -developer-build -opensource -nomake examples -nomake tests

The -developer-build option causes more symbols to be exported in order to allow more classes and functions to be unit tested than in a regular Qt build. It also defaults to a 'debug' build, and installs the binaries in the current directory, avoiding the need for 'make install'. '-opensource' sets the license to be GPL/LGPL. The -nomake examples and -nomake tests parameters make sure examples and tests aren't compiled by default. You can always decide to compile them later by hand.

Some Hints

  1. You can add -confirm-license to get rid of the question whether you agree to the license.
  2. On Windows, you might not be able to build if sh.exe is in your PATH (for example due to a git or msys installation). Such an error is indicated by qt5-src\qtbase\bin\qmake.exe: command not found and alike. In this case, make sure that sh.exe is not in your path. You will have to re-configure if your installation is already configured.
  3. If you are planning to make contributions with git, it is advised to configure and build the source in a separate directory so the binaries are not seen by git. This can be done by navigating to the desired build directory and calling configure/make in that directory. (But shadow builds are discouraged in Qt Autotest Environment.)
    1. Note: If you do a shadow build, follow the instructions above for creating a build directory that is parallel to the source directory. Do NOT make the build directory a subdirectory of the source tree. The build will probably fail in weird ways if the build directory is not exactly parallel to the source directory.

Now trigger the build from within the build directory by running:

$ make -j$(nproc)

For Windows (MSVC), choose one of the following, depending on your setup/environment:

$ nmake

or

$ jom

or

$ mingw32-make

Or only build a specific module, e.g. declarative, and modules it depends on:

$ make module-qtdeclarative

Building Qt WebKit

Windows

WebKit.org has instructions for building WebKit on Windows. ICU is required for building.

The tools bison, flex and gperf which are required for building are provided for convenience in the folder gnuwin32\bin. If you are using shadow builds, you must add this directory to your PATH, else no special actions need to be done manually in order to use them.

Installing

  • Note: Installation is only needed if you haven't used the configure options -developer-build or -prefix "%PWD%/qtbase". Otherwise, you can just use Qt from the build directory.

To install, run

$ make install

or

$ nmake install

or

$ jom install

or

$ mingw32-make install

Cleaning

To get a really clean tree use:

$ git submodule foreach --recursive "git clean -dfx" && git clean -dfx

since make confclean no longer works from the top-level of the repo.

Getting updates

To update both the qt5.git repo as well as the submodules to the list of revisions that are known to work, run

$ git pull
$ perl init-repository -f

In addition, you should pass the same parameters to init-repository as you did in Getting the source code.

Unlike a "normal" git submodule update, this ensures that any changes to the module structure are automatically pulled as well.

If you are planning to do nightly builds, consider using the script qt5_tool that lives in qtrepotools/bin. It provides options for updating the repository, cleaning and building. For example, qt5_tool -u -c -b can be used to clean, update and build. qt5_tool -p -c -b would be used to pull all modules to the head of their master branches.

Depending upon what changed in the source since it was last updated you might have to run configure again. The safe thing to do is to always run config.status -recheck-all in the build directory after updating.

  • Hint1: The submodule update does a checkout in submodules, potentially hiding any local commits you've done. If the latter happened to you (and you haven't been working with branches anyhow), git reflog is your friend.
  • Hint2: When creating scripts for updates on Windows, note that git clean often fails if some process locks a file or folder.

Using latest branches in the submodules

By default, the checkout will not contain the latest stable/dev branches of each individual submodule repository, but a combination of versions that are known to work together. If you want to get the absolute latest stuff you can do so on a per-module basis, e.g.

$ cd qtdeclarative
$ git fetch
$ git checkout -b 5.9 origin/5.9

or tell init-repository to check out branches in all repositories:

$ perl init-repository -f --branch

Some Unix shell tricks for developing Qt can be useful when you are making or reviewing changes in multiple modules.

Issues

Linux

configure fails with "No QPA platform plugin enabled!" (Linux)

You should install the libxcb and it's accompanying packages, see 'System Requirements'.

configure fails with errors like "cannot stat file ..."

Your perl version is too old, Qt 5 beta1 needs at least 5.14.

configure fails to enable qdoc on Debian

Debian allows parallel installs of libclang-<version>-dev in /usr/lib/llvm-<version> so LLVM_INSTALL_DIR should be /usr/lib/llvm-<version> to build qdoc. Not /usr/llvm.

qmlscene segfaults "Cannot create platform GL context, none of GLX, EGL, DRI2 is enabled" (Linux)

Try installing the libx11-xcb-dev package:

$ sudo apt-get install libx11-xcb-dev

afterwards you have to re-run configure and force qtbase/src/plugins/platforms/xcb to recompile.

WebKit doesn't compile, missing ICU

Currently there is no configure time check for ICU, so install it through the package manager through

on Ubuntu/Debian:

$ sudo apt-get install libicu-dev

on Fedora:

$ su - -c "yum install libicu-devel"
  • You can also compile Qt without Qt WebKit by deleting / renaming the qtwebkit, qtwebkit-examples-and-demos directories.
  • The --no-webkit option of configure added, see QTBUG-20577 issue.

Qt D-Bus fails to build due to "inconsistent user-defined literal suffixes"

This occurs when you attempt to build Qt 5 with GCC 4.7 while D-Bus < 1.4.20 is present on your system. (For example, the default Fedora 17 installation is prone to this error.) The error message is this:

qdbusinternalfilters.cpp:124:36: error: inconsistent user-defined literal suffixes ‘DBUS_INTROSPECT_1_0_XML_PUBLIC_IDENTIFIER’ and ‘DBUS_INTROSPECT_1_0_XML_SYSTEM_IDENTIFIER’ in string literal

Note: The error is in the header files of D-Bus itself, and it has been fixed upstream, see https://bugs.freedesktop.org/show_bug.cgi?id=46147.

Solution: either upgrade to a newer version of D-Bus or edit that one line of the header file manually.

...::isNull is not defined (from qvariant_p.h)

C++11 support is detected while your GCC doesn't properly support it. Fixed by passing -no-c11 to the configure options.

cc1: fatal error: .pch/release-shared/QtGui: No such file or directory

Currently unresolved bug with the build of assembly files, see discussion at http://comments.gmane.org/gmane.comp.lib.qt.devel/5933
Fixed by passing -no-pch to the configure options.

ld: hidden symbol `void QQmlThread::postMethodToThread<QQmlDataBlob*, QQmlDataBlob*, QQmlDataLoaderThread>(void (QQmlDataLoaderThread::)(QQmlDataBlob), QQmlDataBlob* const&)' isn't defined

Bug with GCC versions < 4.4.x, see bug report at https://bugzilla.redhat.com/show_bug.cgi?id=493929. Fixed by adding QMAKE_CXXFLAGS_RELEASE *= -fno-inline in qtdeclarative/src/qml/qml.pro.

Touchscreen (or Wacom tablet) doesn't work

Qt depends on having libxi (including development headers), supporting XInput protocol 2.2 or higher, available at build time in order to have multi-touch support. Otherwise configure will fall back to XInput 2.0 which does not support touchscreens. To prove that is the problem, try this:

$ export QT_XCB_DEBUG_XINPUT_DEVICES=1

and try your Qt application again. At startup, Qt will enumerate the input devices available, like this

XInput version 2.2 is available and Qt supports 2.2 or greater
input device … (keyboard, mouse etc.) …
input device Advanced Silicon S.A CoolTouch™ System
has valuator "Abs MT Position X" recognized? true
has valuator "Abs MT Position Y" recognized? true
has touch class with mode 1
it's a touchscreen with type 0 capabilities 0x21 max touch points 10

If it does not say Qt supports 2.2 or greater, it means the headers weren't available when Qt was built, so the support for touch was not included. If you do have 2.2 or greater but it doesn't say it's a touchscreen at the end, there may be some other problem such that the touchscreen is not recognized, and you may want to write up a bug, after verifying that touch works in other X11 applications.

Windows

Note that if you're shadow-building Qt, the source directory and build directory must be on the same drive, nested equally deeply. Also, make sure there are no old build artifacts in the source directory.

Debugging OpenGL issues (Windows)

Set the environment variable QT_QPA_VERBOSE=gl:1 and run the application with DebugView installed. The log will show the requested vs obtained OpenGL version. If the log tells you that it only has OpenGL 1.1, Qt Quick 2 will not work. Note that qmlscene will not report errors about unsupported OpenGL versions.

Questions and comments

Please raise questions & comments about this article in this forum thread.