Компиляция qt из исходников компилятором из состава CodeBlocks. Параллельная компиляция Qt в Windows

Доброго времени суток дорогой читатель и подписчик моего проекта, в данной статье мы с вами по шагам разберем как правильно установить QT creator под 32х и 64х разрядную систему под разные версии компилятора и отладчика от разных фирм производителей. В данной статье мы разберем как правильно установить компилятор MinGW с отладчиком(дебагером) под 32х разрядную систем и MSVS компилятор с дебагером под 64х разрядную систему. К данной статье также будет прилагаться видео в котором я показываю как все это можно установить. В видео соблюден немного неправильный порядок установки так как изначально для тестов планировалось установить только 32х разрядную версию компилятора с дебагером. Итак начнем.

Первое в чем вам необходимо убедиться, это то что у вас уже установлена Visual Studio с компилятором С++ 2013 или 2015 года. Только после этого вы можете переходить к следующим пунктам которые указаны ниже.

  1. Установка SDK для Windows.

Для того чтобы вам начать инсталляцию под 2 разных компилятора с отладчиком(дебагером). Вам изначально потребуется установить пакет SDK под вашу версию ОС Windows для Visual Studio. В моем случае это пакет SDK под Windows 8.1 который с легкостью можно найти в интернете по первым позициям поиска на запрос скачать пакет SDK для (указывает версию вашей ОС Windows). Поиск к примеру можно делать в гугл поисковике. Пример в виде скриншота прикреплен ниже.

Для перехода в гугл поиск нажмите на картинку и скачайте подходящую версию для вашей ОС Windows. В моем случае поиск идет для Windows 8.1

После того когда вы определились с конкретной версией вашего пакета SDK и скачали установщик. Запустите его установку и проинсталлируйте как показано на картинках ниже. В моем случае я установил полный пакет SDK с расчетом на будущее и так как мне память компьютера позволяет, сразу хочу предупредить что для QT будет использоваться только отладчик(дебаггер) из данного пакета. То есть вы можете просто убрать все галочки при инсталляции оставив только одну напротив дебаггера.

Запуск инсталлятора SDK для Windows 8.1

Окно выбора между просто скачиванием и скачиванием и автоматической инсталляцией. В данном случае мы выбираем инсталляцию пакета SDK и нажимаем next.

Подтверждение лицензионного соглашения данного пакета SDK

Здесь необходимо выбрать какой комплект вы хотите проинсталлировать под вашу ОС. Для QT достаточно одного отладчика(дебаггера). После того как вы определились с вашим минимальным комплектом SDK смело нажимайте кнопку install . После нажатии кнопки инсталляции вам останется только немного подождать и завершить инсталляцию SDK. После этого можно переходить к следующему пункту - это установка QT Creator под разные архитектуры.

2. Установка QT Creator + компиляторы с отладчиком

Для того чтобы установить QT Creator под разные компиляторы, вам понадобится скачать онлайн установщик QT с официального сайта. Скачать можно . После того как вы скачаете файл QT, вам его необходимо запустить и следовать дальнейшей инструкции.

Окно приветствия онлайн установщика QT, здесь мы просто нажимаем кнопку далее.

Чуть ниже вы видите окно регистрации в проекте QT. Здесь вы можете либо оставить все поля пустыми нажав клавишу skip тем самым пропустив процесс регистрации, либо заполнить поля авторизации если у вас уже есть аккаунт QT, либо можете создать новый. На данном этапе я просто нажал кнопку skip для продолжения установки без регистрации в QT.

В следующем окне у нас просто просят подтверждения на установку QT. Здесь просто нажимаем далее и ждем пока QT загрузит необходимые файлы для инсталляции.

Окно подтверждения установки QT Creator. Здесь просто нажимаем далее.

После того как QT подгрузил все необходимые метаданные, QT нас просит выбрать каталог куда вы хотите проинсталлировать сам QT Creator. ВАЖНО: QT НЕ ДРУЖИТ С РУССКИМИ БУКВАМИ В ПУТИ, ДАБЫ ИЗБЕЖАТЬ ОШИБОК ПРИ ИНСТАЛЛЯЦИИ И В РАБОТЕ С ПРОЕКТАМИ, ВЫБИРАЙТЕ ПУТЬ УСТАНОВКИ БЕЗ СОДЕРЖАНИЯ РУССКИХ СИМВОЛОВ В ПУТИ УСТАНОВКИ! В моем случае я QT установил корневую папку диска C://qt.

Выбор папки куда вы хотите проинсталлировать QT. После того как вы выбрали куда будете инсталлировать QT, вам необходимо нажать далее.

В следующем окне установщика вам будет предложено выбрать несколько различных версий QT и компиляторов под эти версии, при установке я выбирал самые последние версии 5.9 beta 3, 5.8 и 5.3. От всех остальных версий я отказался. Также при установке у меня автоматически QT определила что необходимо проинсталлировать QT с компилятором MSVC под 64 разрядную систему, чтобы была возможность компиляции и под 32 разрядную архитектуру, я дополнительно установил компилятор MinGW в каждой из предложенных мне ранее версий, все остальное я оставил так как мне предлагал установщик QT.

Окно выбора необходимых компонентов инсталляции. После того как вы определились с необходимым набором компонентов для QT смело нажимаем далее.

После этого у вас откроется окно с подтверждением что вы согласны с лицензионным соглашением.

Окно подтверждения лицензионного соглашения, делаем все как на скриншоте.

Далее у вас будет окно выбора папки в меню пуск в которой будут храниться все ваши ярлыки от QT. Если вы устанавливаете QT первый раз, то вам необходимо оставить настройки по умолчанию и нажать кнопку далее.

Окно выбора папки в меню пуск. При первой установке QT оставляем все по умолчанию.

Далее QT запросит у вас последнее подтверждение на инсталляцию. Прежде чем вы нажмете кнопку установить я настоятельно рекомендую убедиться что у вас на жестком диске места больше того которое QT запрашивает для установки хотя бы процентов на 10%. Это необходимо для стабильной работы QT во время создания различных программ в дальнейшем. Также необходимо убедиться в том что у вас сейчас есть стабильное подключение к интернету и у вас хватает интернет трафика для скачивания всех необходимых файлов для дальнейшей инсталляции. После нажатия кнопки установить, у вас начнется загрузка и инсталляция QT.

Последнее окно подтверждения установки, после которого у вас начнется загрузка необходимых компонентов с интернета и их инсталляция. Все что вам останется сделать — это подождать и в конце после установки закрыть окно после сообщения об успешной установке QT creator.

3. Установка плагина для Visual Studio 2015

Для того чтобы начать установку плагина, необходимо перейти на сайт QT и прокрутить страницу до того места, который вы видите на скриншоте ниже.

Установка QT плагина для Visual Studio. Здесь вам необходимо выбрать перед скачиванием плагин подходящий под вашу QT и вашу версию Visual Studio из тех которые выделены красной рамкой. После выбора необходимого плагина скачайте его и запустите на установку.

После того как вы запустили установщик, вам необходимо убедиться в том что он увидил вашу студию, как в примере на скриншоте ниже. Данный плагин нужен для возможности производить отладку как в QT так и Visual Studio.

Установщик плагина для Visual Studio. Убедились что наш плагин увидел нашу студию. После этого нажимаем на кнопку установить плагин.

После нажатия на кнопку инсталляции немного ожидаем.

Процесс установки плагина для Visual Studio.

После того как плагин проинсталлируется у вас появится окно об окончании успешной установки.

Окно завершения установки, зеленая галочка показывает об окончании успешной установки плагина для следующей версии студии. Здесь нужно нажать закрыть.

4. Проверка успешной установки компиляторов и отладчиков для QT

Для того чтобы убедиться в том что компилятор и отладчик установился корректно, вам необходимо пройти по следующему пути в QT. Инструменты —> Параметры —> Сборка и запуск —> Комплекты. У вас не должно быть ни одного красного и желтого восклицательного знака. Это будет говорить об успешной инсталляции QT + компиляторов с отладчиком.

Если у вас все так же как на скриншоте, то все комплекты успешно проинталировались и определились автоматически.

5. Проверка успешной установки плагина в Visual Studio

При успешной установке плагина у вас в студии должно появиться дополнительное меню от QT как показано на скриншоте ниже.

Пример успешной установки плагина от QT.

Настройка Qt Creator

На вкладке Сборка и запуск > Основное указываем каталог проектов, например, /home/login/Qt/qt-proj (этот каталог надо заблаговременно создать). На вкладке Текстовый редактор > Поведение назначаем Кодировкам файлов > По умолчанию значение UTF-8 .

Настройка инструментов

Qt 5 .

Выбираем вкладку Сборка и запуск > Компиляторы

Имя: Система GDB в /usr/bin/gdb
Путь: /usr/bin/gdb
Тип: GDB
ABI: x86-linux-generic-elf-unknown
Версия: 7.7.1

/home/login/Qt/Qt5/5.5/gcc/bin/qmake . В названии профиля прописываем, например, Qt 5.5.1 GCC 32bit .

На вкладке Сборка и запуск > Основное указываем каталог проектов, например, C:\Qt\qt-proj (этот каталог надо заблаговременно создать). На вкладке Текстовый редактор > Поведение назначаем Кодировкам файлов > По умолчанию значение windows-1251 / CP1251 .

Настройка инструментов

Предполагается, что у Вас уже установлена библиотека Qt 5 с MinGW и собран отладчик GDB .

Выбираем вкладку Сборка и запуск > Компиляторы , нажимаем кнопку Добавить > MinGW и указываем путь к компилятору C:\Qt\Qt5.5.1\Tools\mingw492_32\bin\g++.exe . В названии прописываем, например, MinGW 4.9.2 (x86 32bit) .

На вкладке Отладчики (здесь же) нажимаем кнопку Добавить и в свойствах нового отладчика указываем

Имя: GDB 7.10
Путь: C:\Qt\qtcreator-gdb-7.10\gdb-i686-pc-mingw32.exe

Далее выбираем вкладку Qt Versions , нажимаем кнопку Добавить ... и указываем путь к установленной заранее библиотеке Qt C:\Qt\Qt5.5.1\5.5\mingw492_32\bin\qmake.exe . В названии профиля прописываем, например, Qt 5.5.1 MinGW 4.9.2 .
Теперь можно создать связку инструментов. Выбираем вкладку Комплекты , нажимаем кнопку Добавить и в свойствах новой связки указываем

Qt 5 и MSVC 2010

Предполагается, что у Вас уже установлена библиотека Qt 5 с MSVC 2010 и инструментарий Windows SDK for Windows 7 .

Выбираем вкладку Сборка и запуск > Компиляторы и убеждаемся, что среди обнаруженных имеется компилятор, обладающий свойствами

На вкладке Отладчики (здесь же) убеждаемся, что среди обнаруженных имеется отладчик, в свойствах которого прописано

Далее выбираем вкладку Qt Versions , нажимаем кнопку Добавить ... и указываем путь к установленной заранее библиотеке Qt D:\Qt\Qt5.5.1-vs\5.5\msvc2010\bin\qmake.exe . В названии профиля прописываем, например, Qt 5.5.1 MSVC 2010 .
Теперь можно создать связку инструментов. Выбираем вкладку Комплекты , нажимаем кнопку Добавить и в свойствах новой связки указываем

Закрываем окно Параметры , нажав кнопку OK .

За информацией о платформах, на которых в настоящее время Qt можно запустить, а за дополнительной информацией о статусе каждой платформы - к странице Поддерживаемые платформы .

Если у вас есть что добавить в этот список или для какой-либо платформы или на страницу конкретного компилятора, пожалуйста передайте это через Форму отчета об ошибке или через Общественное хранилище Qt .

Поддерживаемые возможности

Не все используемые для сборки Qt компиляторы способны скомпилировать все модули. Следующая таблица показывает поддержку компиляторов для пяти модулей, которые не доступны одновременно для всех платформ и компиляторов.

Компилятор Свойства
Concurrent XmlPatterns WebKit CLucene Phonon
g++ 3.3 X X X
g++ 3.4 и выше X X X X X
SunCC 5.5 X X
aCC series 3 X X
aCC series 6 X X X X X
xlC 6 X X
Intel CC 10 X X X X X
MSVC 2003 X X X X
MSVC 2005 и выше X X X X X

GCC

GCC под Windows (MinGW)

Мы тестировали Qt с этим компилятором на Windows XP. Минимальная поддерживаемая версия MinGW:

  • GCC 3.4.2
  • MinGW runtime 3.7
  • win32api 3.2
  • binutils 2.15.91
  • mingw32-make 3.80.0-3

Замечание: Для пользователей бинарного пакета MinGW: Этот пакет теперь основан на MinGW 4.4. Установщик более не предлагает вам скачать MinGW, но наоборот предлагает использовать версию MinGW, которая уже установлена на вашей машине. Вы только сообщите установщику в каком каталоге установлен MinGW. Если вы еще не установили MinGW 4.4, вы можете скачать архив.zip с нашего ftp-сервера . Этот архив предоставит исправления для MinGW и поддержку отсутствующих API, За подробностями обращайтесь к каталогу _patches в архиве.

Замечание: Установка MinGW необходима только для сборки бинарного пакета вместо запуска предварительно скомпилированных бинарных файлов, которые находятся в пакете.

GCC 4.0.0

Выпущенный пакет компилятора содержит несколько ошибок, которые приводят к ошибкам компиляции. Мы рекомендуем использовать gcc 4.0.1 или старше, или использовать свежий срез CVS ветки gcc 4.0. Версия gcc 4.0.0, которая идет вместе с Mac OS X 10.4 "Tiger", работает с Qt для Mac OS X.

HP-UX

Платформа hpux-g++ тестировалась с gcc 3.4.3.

Solaris

Пожалуйста, используйте GCC 3.4.2 или более свежую.

Mac OS X

Пожалуйста, используйте последний GCC 3.3 от Apple или свежие версии GCC 3. gcc 3.3, который поставляется вместе с Xcode 1.5, генерирует код с дефектом. Используйте исправление GCC 3.3 от ноября 2004, доступное в Apple .

GCC 3.4.6 (Debian 3.4.6-5) на AMD64 (x86_64)

При создании релиз-сборки этот компилятор компилирует с ошибкой некоторые части Qt. Имеется несколько методов обхода:

  1. Используйте отладочную сборку.
  2. Для каждой встретившейся ошибки компиляции перекомплируйте файл без опции -O2.
  3. Добавьте -fno-gcse в QMAKE_CXXFLAGS_RELEASE .

HP ANSI C++ (aCC)

Платформы hpux-acc-32 и hpux-acc-64 тестировались с aCC A.03.57. Платформы hpuxi-acc-32 и hpuxi-acc-64 тестировались с aCC A.06.10.

Intel C++ Compiler

Qt поддерживает компилятор Intel C++ и для Windows и для Linux. Однако, имеется несколько проблем под Linux (смотрите следующий раздел).

Intel C++ Compiler для Linux

В настоящее время Nokia тестирует следующие компиляторы:

  • Intel(R) C++ Compiler для приложений, запускаемых на IA-32, версия 10.1 Build 20080602 Package ID: l_cc_p_10.1.017
  • Intel(R) C++ Compiler для приложений, запускаемых на Intel(R) 64, версия 10.1 Build 20080602 Package ID: l_cc_p_10.1.017

В настоящее время мы не тестируем компилятор IA-64 (Itanium).

Известные проблемы с Intel C++ Compiler для Linux

  • Поддержка предварительно скомпилированных заголовков не работает в версии 10.0.025 и более старых. Для этих компиляторов вы должны сконфигурировать Qt с опцией -no-pch. Поддержка предварительно скомпилированных заголовков работает в версии 10.0.026 и более поздних.
  • В версии 10.0.026 для Intel 64 известна ошибка компиляции qmake при создании релиз-сборки. Пока конфигурируйте Qt с опцией -debug. Версия 10.1.008 и более поздние могут компилировать qmake в режиме релиза.
  • Для версий с 10.1.008 по 10.1.015 для IA-32 и Intel 64 известен фатальный сбой с сообщением "(0): internal error: 0_47021" при компиляции QtXmlPatterns , QtWebKit и Designer в режиме релиза. Версия 10.1.017 компилирует эти модули в режиме релиза правильно.

Intel C++ Compiler (Windows, Altix)

Qt 4 был успешно протестирован с:

  • Windows - Intel(R) C++ Compiler для 32-битных приложений, Version 9.1.040.
  • Altix - Intel(R) C++ Itanium(R) Compiler для приложений базирующихся на Itanium(R) версия 8.1 Build 20050406 Package ID: l_cc_pc_8.1.030

В настоящее время тестируются компилятор Intel только для 32-битных версий Windows.

MIPSpro (IRIX)

Qt 4.4.x требуется MIPSpro версии 7.4.2m.

Обратите внимание на то, что MIPSpro версии 7.4.4m в настоящее время не поддерживается, так как в ней имеется несколько проблем, которые еще не исправлены. Мы рекомендуем использовать для разработки Qt версию 7.4.2m. Однако, пожалуйста обратите внимание на неподдерживаемый статус этой платформы.

Forte Developer / Sun Studio (Solaris)

Sun Studio

Qt тестировалась с использованием Sun Studio 12 (Sun CC 5.9). Перейдите на страницу Sun Studio Patches на веб-сайте Sun, чтобы скачать последние исправления для вашего компилятора Sun.

Пожалуйста, обратите внимание на то, что Qt 4.6 требовательна в своих требованиях к STL и что стандартная реализация STL, используемая Sun CC, не удовлетворяет этим требованиям. Это не влияет на бинарную совместимость и вы можете продолжать использовать STL в вашем коде, но функции Qt совместимости с STL будут блокированы.

Sun CC поставляется со вторичной реализацией STL (называется stlport4), которая соответствует стандартам и может быть использована Qt. Вы можете разрешить это передав опцию -library=stlport4 компилятору. Обратите внимание на то, что это не скажется на бинарной совместимости Qt, но может повредить другим библиотекам и программам, использующим STL.

Sun WorkShop 5.0

Sun WorkShop 5.0 не поддерживается с Qt 4.

Visual Studio (Windows)

Вы делали большую часть разработки под Windows на Windows XP, используя Microsoft Visual Studio .NET 2005 и Visual Studio 2008 (как 32-, так и 64-битные версии).

Qt работает с Visual Studio 2005 Standard Edition, Professional Edition и Team System Edition.

Мы также тестировали Qt 4 на Windows XP с Visual Studio .NET и Visual Studio 2003.

Для того, чтобы использовать Qt с Visual Studio 2005/2008 Express Edition вам необходимо скачать и установить Platform SDK. Из-за ограничений в Express Edition мы не смогли установить Qt Visual Studio Integration. Вам нужно использовать наши инструменты командной строки для сборки приложений Qt с помощью этой редакции.

Visual C++ Linker не понимает имена файлов с пробелами (такие как C:\Program files\Qt\), поэтому переместите её в другое место, или явно установите путь; например:

QTDIR=C:\Progra~1\Qt

Если вы встретите странные проблемы с использованием специальных флагов, модифицирующих выравнивание структуры и членов объединения (таких как /Zp2), тогда вам нужно также перекомпилировать Qt с флагами, установленными для приложения.

Если вы используете Visual Studio .NET (2002) Standard Edition, вы должны использовать предоставляемые бинарные пакеты Qt, а не пакеты исходного кода. Так как Standard Edition не оптимизирует компилируемый код, ваша скомпилированная версия Qt будет выполняться квазиоптимально с усреднением по скорости.

IBM xlC (AIX)

Утилита makeC++SharedLib должна быть в вашей переменной PATH и соответствовать сборке разделяемых библиотек. Из Красной книги IBM C and C++ Application Development on AIX :

  • "Второй шаг - используйте команду makeC++SharedLib для создания разделяемого объекта. Команда имеет много необязательных аргументов, но в простейшей форме может использована как изложено ниже:" /usr/vacpp/bin/makeC++SharedLib -o shr1.o cplussource1.o
  • "Полный путь к команде не рекомендуется; однако, чтобы обойти это добавьте каталог, в котором находится ваша переменная окружения PATH. Команда находится в /usr/vacpp/bin directory вместе с VisualAge C++ Professional for AIX, Version 5 compiler."

VisualAge C++ для AIX, версия 6.0

GCCE (Symbian)

GCCE нельзя использовать для компиляции библиотек Qt для платформы Symbian, но GCCE поддерживается при компиляции приложений Qt для платформы Symbian.

В данной статье я описываю свой опыт компиляции библиотеки Qt версии 4.8.5 из исходников с помощью компилятора MinGW, идущего в составе среды программирования CodeBlocks версии 10.05 на машине с операционной системой Windows XP.

Так как для движка нужен нормальный редактор карт и объектов, то я задумался о выборе GUI библиотеки. Вполне логично, что ввиду повсеместного расхваливания qt, я не мог не попробовать ее в деле. Скачал книжки, инсталлировал версию "qt-win-opensource-4.8.4-mingw". У меня CodeBlocks версии 10.05. Создал в CodeBlock класс главного окна и модуль с main - короче, простейшее приложение с главным окном. Надо сказать, что меня ждало разочарование - компиляция и сборка qt-приложений представляет собой не банальное нажатие пункта "Build", а ряд предварительных настроек и действий, да и вообще производится в командной строке. После пары дней геморроя я скомпилировал этот небольшой проект с главным окном. Но для этого мне пришлось собрать qt из исходников. Дело в том, что ошибки никак не хотели устраняться и я где-то прочитал, что якобы версия mingw на компьютере разработчика может конфликтовать с установленным qt из-за того, что установленный qt был собран на другой версии mingw. Что ж, решил собрать.
Скачал исходники "qt-everywhere-opensource-src-4.8.5.zip". Хотя сейчас уже есть пятая версия, я решил взять предпоследнюю на тот момент. На диске "E" (это тот, что обычно D у большинства) создал папку "Qt". Положил архив туда. Распаковал его.
Делал я все на Windows XP. Так как компилятор MinGW идет в составе среды программирования CodeBlocks, я использовал его, то есть я не устанавливал его отдельно.

Установил переменные среды:
Мой компьютер-> Свойства:

Дополнительно:

Переменные среды:

Сначала добавляете путь к папке bin компилятора MinGW (у меня E:\Program Files\CodeBlocks\MinGW\bin)
Нужно выделить переменную "Path", нажать кнопку "Изменить":

Внимание! Нужно не заменять то, что там уже есть, а именно добавить , иначе что-то на вашем компе может перестать нормально работать. Появится окошко.
Пойти в конец строки поля ввода с именем "Значение переменной". Если там не стоит в конце ";" (без кавычек), то поставьте точку с запятой и вставьте путь к папке "bin" у MinGW.
У меня вот так (я показал многоточием то, что у меня уже есть путь к другим папкам)...;E:\Program Files\CodeBlocks\MinGW\bin;
То есть пути в "Path" разделяются точками с запятой. Жмете ок.
Создаете следующие переменные:

Имя переменной: MinGWDIR Значение переменной: путь к папке MinGW (у меня E:\Program Files\CodeBlocks\MinGW)
Имя переменной: QMAKESPEC Значение переменной: win32-g++
Имя переменной: QTDIR Значение переменной: путь к распакованным исходникам qt (у меня E:\Qt\qt-everywhere-opensource-src-4.8.5)

QMAKESPEC должен содержать имя профиля сборки. Для выбранного компилятора MinGW, у Qt есть два профиля: "win32-g++" - для версий компилятора GCC ниже 4.6, и "win32-g++-4.6" - для версий компилятора GCC 4.6 (он задействован в последних версиях MinGW).

Конфигурация библиотеки Qt. Запускаем командную строку и переходим в ней в папку с исходниками Qt (у меня E:\Qt\qt-everywhere-opensource-src-4.8.5). Нужно запустить конфигуратор с опциями. Я использую LGPL - версию, поэтому выбрал опцию -opensource. Так же мне не нужны демо и примеры -nomake demos -nomake examples. Мне нужны версии debug и release. Вообщем, я набил (лучше вручную, а то при вставке может запуститья не со всеми опциями, а только с теми, которые поместились в первой строке) следующее:

configure.exe -debug-and-release -qt-libpng -qt-libjpeg -opensource
-no-qt3support -qt-zlib -qt-libmng -qt-libtiff
-nomake demos -nomake examples


Конфигуратор спросит вас, дав 4 варианта. Нужно согласиться использовать LGPL (я к сожалению не помню их названия, но там понятно).
После этого конфигуратор создаст ключевой файл qmake.exe и makefile"ы модулей библиотеки Qt. После завершения этого процесса появится сообщение:

Qt is now configured for building. Just run mingw32-make.
To reconfigure, run mingw32-make confclean and configure.

Осталось запустить компиляцию. Для этого вбейте в командной строке следующее:

Компиляция qt идет очень долго. У меня этот процесс занял 10 часов. Я начал в 11.00. В комп в последний раз заглядывал в 18.20 - процесс еще шел. Утром мне пришлось перезагрузить комп, так как комп не реагировал на нажатия кнопок мыши и клавиш клавиатуры. Через поиск я нашел, что самый последний созданный файл библиотеки был создан в 21.02.
После я решил проверить собранную библиотеку Qt. Прописал в переменных среды путь к папке "bin" у Qt (у меня E:\Qt\qt-everywhere-opensource-src-4.8.5\bin). Это нужно для запуска qmake.
Итак, я проверяю созданный в CodeBlocks пример приложения Qt с главным окном.
В командной строке я перешел в папку проекта с главным окном. Набил

Qt создала файл проекта с расширением.pro. Далее набил просто без параметров. Qt создал makefile" ы проекта. Осталось скомпилировать проект - для этого я набил в командной строке
Все. В папке Debug я увидел долгожданный экзешник, над названием которого ввиду трепки нервов с Qt я не стал долго думать:

Показать

Параллельная компиляция Qt-проектов под Windows с использованием QtCreator - зверь загадочный и очень привередливый. В этой небольшой статье я расскажу, как же все-таки его приручить. Параллельная компиляция может быть выполнена достаточно просто в теории, на практике дела обстоят не совсем гладко, чему в подтверждение бесконечное число тем на форумах, где предлагаются всевозможные решения. Ни одно из них, к сожалению, нам не помогло.


В теории для случая MinGW достаточно указать параметр –j[число процессов компиляции] у команды сборки make, которая в QtSDK MinGW представлена mingw32-make. Например, получается команда mingw32-make.exe –j10.

Рекомендуемое число процессов компиляции составляет число процессоров+1. Если параметр не задается, то считается, что j=1. Если указать слишком большое число также ничего страшного не случится. Make запустит ровно столько, сколько дает прирост производительности.

Для удобства можно воспользоваться переменной окружения %NUMBER_OF_PROCESSORS%, которая показывает число процессоров в системе. Получается команда вида

Mingw32-make.exe –j%NUMBER_OF_PROCESSORS%

Однако, не все так просто. Qmake создает три make-файла. Общий Makefile, который по определенным define’ам выбирает из Makefile.Debug и Makefile.Release в зависимости от сборки релиза или дебага. Дело в том, что параметр –j не наследуемый . И когда в QtCreator вызывается make, то он вызывается для Makefile. А вот до Makefile.Debug или Makefile.Release уже не добирается.

Для того чтобы это исправить придется написать команду в явном виде . Например,

Mingw32-make.exe –j9 –f Makefile.Debug.

Не очень удобно, но прирост скорости сборки это сильно компенсирует. Для примера, пересборка нашего проекта на core-i7-2630 без распараллеливания осуществляется за 12 минут, с флагом –j9 сборка занимает менее двух минут. Прирост производительности в шесть раз заставляет задуматься.

Но даже после указания таких флагов сборки у нас на двух машинах это стало работать, а на двух нет. На форумах пишут, что дело может быть в версии Qt, в кривости mingw, в особенностях работы qmake, версии ОС. Однако, конфигурации наших машин таковы, что методом исключения можно сделать вывод о непричастности версий QtSDK, QtCreator, Windows или разрядности системы ко всему этому.

Решение оказывается очень простым, но в тоже время не таким очевидным. Нужно добавить абcолютный путь к mingw32-make в переменную окружения PATH. На всякий случай, лучше поставить точку с запятой после пути. И после этого чудесным образом начинает работать параллельная компиляция, а программистам не придется по 10 минут отвлекаться каждый раз при добавлении какого-нибудь Q_OBJECT к проекту и его пересборке.

Все эти флаги компиляции могут быть заданы в QtCreator на вкладке Проекты в параметрах make.

Надеюсь, статья окажется полезным и решит вопросы многих у кого до этого не работала параллельная сборка в QtCreator.

UPD (из комментариев) : Что касается Linux/MacOS пользователей, им повезло гораздо больше - достаточно только ключа -jX.

Также если вы используете компилятор MSVC, то проблем быть не должно.

В случае QtCreator нужно добавить запись
QMAKE_CXXFLAGS_RELEASE += -MP[число процессов]
в.pro файл проекта и установление переменной окружения как я описал.

В случае Visual Studio свойствах VS проекта: «Properties»=>«Configuration Properties»=>«C/C++»=>«Command Line». А в поле «Additional options» дописать -MP[число процессов]. Спасибо IGHOR

Также при использовании компилятора MSVC помочь может jom.

Постоянную часть флагов можно вынести в отдельную переменную окружения MAKEFLAGS. Make сам возьмет оттуда установленные флаги. К примеру MAKEFLAGS=-j10. А в параметрах make остается только не забыть указать файл для сборки. Например, -f Makefile.Debug. Если вы все время собираете одну версию, то можно вынести все флаги целиков в MAKEFLAGS и забыть про настройку будущих проектов.

Спасибо всем за дополнения.