Начиная с версии 5.14.0 Qt можно перемещать , то есть можно перенести установку Qt в другую директорию, не нарушая функциональность и не загружая плагины.
Что это значит для меня?
Давайте перейдем к роли мастера сборки Qt в проекте Windows. Вы тот, кто знает все настройки аргументов наизусть. Вы знаете, какой винтик оптимизации повернуть, а какую ненужную функцию отключить.
Ваша сборка Qt идеально адаптирована к проекту, и вы предоставляете zip-файл, содержащий установку Qt.
configure -prefix C:/Qt/5.12.6 ...more options... jom jom install zip -r X:\shared_stuff\qt-5.12.6.zip C:\Qt\5.12.6
Затем ваши товарищи по команде извлекают архив в одно и то же место, и все работает отлично.
Теперь, по любой причине, Joe Developer должен распаковать инсталляцию Qt в какой-либо другой drive/directory (директорию).
Qt в этом другой директории не работает. QMake не будет работать должным образом. Плагины не могут быть загружены. Asset’ы Qt не найдены.
Почему все сломалось?
Исторически, конфигурация Qt встраивала директорию установки в исполняемом файле qmake и библиотеку Qt5Core. Логика в QLibraryInfo пытается найти плагины, asset’ы и mkspecs под жестко заданным префиксом, который всегда является тем, что вы передали для настройки с аргументом -prefix.
А в Qt 5.14 перемещение директории установки работает?
О да! Начиная с Qt 5.14.0 префикс установки может автоматически определяться расположением библиотеки Qt5Core или самого исполняемого файла без использования жестко заданных путей.
Этот автоматизм контролируется в то время, когда Qt конфигурируется через
функцию перемещения
.
Эта функция включена по умолчанию для нестатических сборок Qt.
Если вам нужна перемещаемая статическая сборка, включите эту функцию вручную:
onfigure -static -feature-relocatable ...
Предостережение о перемещаемых статических сборках заключается в том, что внутренние переводы Qt не обрабатываются автоматически.
Вам нужно будет развернуть файлы перевода Qt вместе с вашим приложением.
Это отличие от не перемещаемой сборки является причиной того, что
перемещение
отключено по умолчанию для статических сборок.
Если мне это не нравится, могу ли я выключить эту функцию?
Конечно вы можете.
configure -no-feature-relocatable ...
вернет старое поведение.
Например, дистрибутивы Linux не нуждаются в перемещаемом Qt и могут отключить эту функцию.