Qt WinAPI - Lesson 001. How to collect all DLL, which used in Qt project?

WinAPI, DLL, DLL Collector, DLLCollector, Qt

Sooner or later before any Qt-developer gets the necessary migration of your application on other computers, and then there is the problem of the availability of libraries on the target computer that are needed to start and run the application. This is especially noticeable when the application can transfer that must be executed under of Windows. If the Linux OS the necessary Qt libraries are present by default, such as with of Ubuntu, is a Windows and they can not be.

But finding and assembling all the necessary libraries can be difficult for a newcomer, and quite tedious task for an experienced programmer. But here, thanks to the good people there is a solution. This utility DLL Collector . This utility allows you to program depending on which was written in the framework, Qt library and automatically copy data to the specified folder.

As the author writes, the utility searches for dependencies in runtime process. Therefore your program must run through this utility. DLL Collector collects information about all loadable plug-ins used by your program, but it should not be forgotten that the plugins are loaded when you first use them in your program functions. Thus, you need to run your program on its functionality to DLL Collector Found all libraries.

How works the DLL Collector

Step one. Setup utility

In this step, you must perform the following steps:

  1. Specift in the name field, the path to the compiled program;
  2. Specify in the field the path to the bin binaries libraries Qt;
  3. Specify in the field the path to the plug-ins plugins Qt;
  4. Specify the path to the folder where you will copy the DLL
  5. Tick add bin to envitonment

Step Two. Running your application

After the setting is made, run your application by clicking the Run button.

Step Three. Updating the list of plug-ins and libraries

Once your application starts, click the Update button. Highlight a list of plug-ins and libraries. Also, work with your application a bit to DLL Collector certainly found all the dependencies and ponazhimayte Update button several times to make sure that all dependencies found.

Step Four. Copying libraries

Once the library is found, press the Copy button, and all libraries will be copied.

Conclusion

Summing up, I can say that the utility is very useful and much easier life.

At the time of this writing, author uploaded a new version of the program, but personally I have it crash. So I still use an older version, you can download here: DLLCollector

You can also research information about the program on the author page.

Also, do not forget to make an installer for your application, and learn how to do this in the next article .

Video

Virtual hosting with 10 percent discount
Virtual hosting with 10 percent discount
EVILEG offers reliable hosting with a 10% discount for virtual hosting and 5% for VPS
Support the author Donate
V

Старой или последней версией пользуетесь? В статье по ссылке есть более старая версия. Она работала лучше, чем последняя версия. К сожалению, не могу проверить работоспособность утилиты, поскольку не имею ни одной установки Windows на данный момент.

Также можете ещё посмотреть в сторону официальной утилиты от Qt. Вот ссылка.
V

Старая не работает с компиляторами msvc , попросту ничерта не находит , новая с ними же выдаёт ошибку при нажатии updаte , обе версии работают  с mingw , однако старая нашла 51 модуль , новая 45. И обе игнорят целый пакет библиотек от MS VS . В общем , подскажите аналогичную программу , может тогда всё нормально станет.

Есть ещё Dependency Walker. Сам не использовал, но часто натыкался на форумах, что его советуют для поиска DLL-ок.

Вероятно по тому что Вы пытаетесь использовать сборщик x32 для сборки Qt x64.
Стоило скачать исходники сборщика и перекомпилить.

Dependency Walker не справляет с этой задачей он не видит плагинов.

Если использовать, то использовать ProcessExplorer которыей в принципе должен отображать то же что и мои сборщик.

Кстати программу я давно обновил, если есть замечания по работе пишите в мой лучше в блог.

Добрый день!

А почему вы не предоставляете сборку программы и для x64?
Я как бы понимаю, что программисту не должно составить труда перекомпилить программу из исходников. Но плюс вашей софтины в том, что она удобна для новичков. А опытный Qt-программист скорее будет использовать windeployqt.
То есть не каждый новичок сразу разберётся с компиляцией сборщика из исходников под необходимую целевую платформу.
Так что, возможно имело бы смысл сделать несколько сборок под последние актуальные версии MSVC.
Или у вас есть некоторые дополнительные аргументы против?

Добрый день!
У меня нет возможности собрать под x32.

Кроме того если человек до сих по не научился нажимать кнопочку "собрать" проект, то ему лучше вообще не заниматься программированием.

И почему только для новичков?
Профи программистами не нужно собирать ддлки в кучу?

Касательно windeployqt:
1. Cобирает не все.
2. Cобирает то что вообще не нужно, порой такое впечатление что он тупо копирует все подряд.
3. Ну и как понимаю он не анализирует зависимости от сторонних библиотек.





Поправка: У меня нет возможности собрать под x64.

Да и я еще планирую поддерживать сборку под Linux.
Но по в связи с внесением изменений она не работает.

К сожалению, ваша программа работает только в рантайме,

  1. Запустить Вашу программу из QtCreator.
  2. Прогнать Вашу программу по всему функционалу , что бы она подгрузила все плагины и qml библиотеки.
Конечно, она позволяет проанализировать все зависимости и взять только необходимое, но при этом нужно запускать программу и прогонять её вручную по функционалу.

Но вы понимаете, что в некоторых случаях и некотором рабочем процессе внедрять подобное не имеет смысла.
Я например работаю над проектом, билд которого разворачивается на пару десятков гигабайт, а сборка билдов для тестирования осуществляется через Service Jenkins в автоматическом режиме. Как бы в крупных проектах многое стараются автоматизировать, поэтому возьмут windeployqt и никого не будет волновать наличие пары десятков лишних библиотек занимающих 50 мб, когда исходный комплект со всеми библиотеками весит 2 Гб.
А сторонние либы идут предкомпилированные в репозитории и собираются через qmake в общий билд.

Прогонять такую софтину по всему функционалу в одних только автоматических тестах составляет несколько часов. А вручную задача непосильная.

В общем со всех сторон есть вполне адекватные доводы, и я согласен с вашими насчёт windeployqt. Но тут уже вопрос компромиса.

А так меня интересовало вообще про x64, но если нет возможности, то тогда вопросов не имею. Спасибо.

Моя программа работает в рантайме ибо нет другого способа узнать все зависимости.

Как что от чего зависит внутри Qt могут знать только разработчики Qt.
Но то что windeployqt работает криво говорит от том что и у них проблемы с пониманием.

Я уже не говорю о той фигне которую они придумали в последних версиях (вшитых хардкор путях).


Как бы в крупных проектах многое стараются автоматизировать, поэтому возьмут windeployqt и никого не будет волновать наличие пары десятков лишних библиотек занимающих 50 мб, когда исходный комплект со всеми библиотеками весит 2 Гб.
Ну с таким успехом можно тупо копирнуть папку QtDIR
И удалить все лишнее.

Получите где-то ~200 MБ это как и будет весь Qt комплект (а не 50M или 2ГБ)






А насколько часто Вы собираете деплой?
Это как бы делается в самом конце так что не должно быть частым.

Деплой делается при каждом коммите, каждой ветви, автоматически, чтобы тестировщики могли проводить тестирование проекта нон-стоп.

На проекте работает 60+ программистов, каждый работает в среднем над одной двумя User Story, плюс каждый багфикс делается в отдельной ветви.
И каждая ветвь билдится. Тестировщик просто скачивает готовый чистый билд со всеми библиотеками.
Под сборку выделен отдельный сервер. Помимо Qt используем Open Cascade, Wt::dbo, Boost и ещё ряд библиотек, так что Qt занимает лишь малую часть. Поэтому на выходе имеем 700 мб.
Так что... примерно 50-60 деплоев в день будет. Если не больше.

Согласен, это морока.
Качать каждый раз по 700M ...

Сомневаюсь что сам набор библиотек так часто меняться по крайней мере касающихся Qt

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

Но ваша софтина замечательна для небольших проектов и при первом деплое, когда вообще непонятно, какой библиотеки не хватает и откуда её брать. Очень удобно.

Если будет время, я сделаю билд под x64 на работе. Я напишу, когда будет готово.

Это вообще лишено смысла, пусть тестировщик держит все либы у себя на компе, и подменяет только исполняемый файл. А деплоить только перед финальным выпуском.

Сам проект состоит примерно из 20-ти подпроектов и все билдится в библиотеки. Запускаемый файл весит 28кб, а собираемые библиотеки, которые были написаны в рамках проекта - остальные 300 мб.
Если бы всё собиралось в один исполняемый файл, то программисты бы очешуели ждать пересборку при каждом изменении кода.

Используем специальный python-скрипт, который склеивает исходники перед сборкой, поэтому полный чистый билд составляет 27 минут, без скрипта 3 часа ))))
Так что просто заменить исполняемый файл не канает

Ну сути это не меняет.

Нет смысла деплоить одно и тоже каждый раз.

Какая-то библиотека может быть изменена в рамках одной единственной ветви из более чем 200 веток, над которыми работают в текщий момент времени.
Предлагаете обучать каждого тестировщика отслеживать, изменилась ли какая-то из библиотек? Бред. Люди имеют свойство забывать и ошибаться. Автоматический скрипт подготовит все необходимые библиотеки и уложит в подготовленный полноценный пакет. Тестировщику нужно лишь знать, откуда скачать.

Библиотека Qt ?

Qt тоже. Там тоже хватает багов, которые мы исправляем.

Про главным образом Qt и шла речь,
Если правятся исходники Qt то согласен для этого случая иначе нельзя.

А при чём тут только один Qt? Ваша же программа собирает и другие зависимые библиотеки. А значит здесь не только Qt, помимо прочего я уже говорил про Wt::dbo, Boost, Open Casecade. Может быть User Story на обновление библиотеки или исправление какого-то бага в этой библиотеки. Зачем заниматься ручной работой и напоминать тестировщику, что если программист что-то исправил, то нужно заменить библиотеку? Есть для этого автоматический скрипт, который просто потратит немного процессорного времени на копирование. Этого гораздо менее накладно, чем нагружать людей лишней ручной работой.

По тому что LibraryCollector заточен конкретно именно под деплой Qt приложений.
Он видит другие зависимости но не делает из сборку
(да и откуда программе знать что нужно для Вашего специфичного проекта)

Пользователь должен сам найти в списке нужные библиотеки и чекнуть их что бы они скопировались(при чем будет тупое копирование в папку исп.файла).

В новой версии LibraryCollector можно добавить свои правила правкой js-скрипта что бы настроить сборку согласно специфике своего проекта и его библиотек.
(Например, если у Вас такая же муторная система плагинами с иерархией папок)



Или Вы хотите сказать что windeployqt видит зависимости от

Wt::dbo, Boost, Open Casecade.
?

Нет, это я не хотел сказать (к сожалению это не так). Говорю о том, что Ваша программа отлично справляется со своей функцией и позволяет также найти недостающие сторонние библиотеки, но это может быть только разовая операция, чтобы разобраться с конкретной проблемой (ну не получается найти конкретную нужную версию (будем считать, что разработчик жёстко не выспался сегодня)), но в рамках автоматизации сборку Qt библиотек лучше положить на windeployqt, если только у вас не поддерживается консольный вариант работы (?), а сторонние бибилотеки держать в рамках репозитория и производить их копирование в итоговый билд. Чтобы просто не нагружать специалистов не нужной работой, а всю сборку просто поставить на поток через автоматизацию.

Но опять же... у вас зависимости ищутся в рантайме. Что также не получится автоматизировать... к сожалению...

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

В таких случаях достаточно проанализировать структуру PE файла (экзешника)
а точнее таблицу импорта (даже не нужно запускать процесс)

Вся проблема в плагинах Qt которые отслеживаются только в процессе и только после прогона по функционалу. Могу конечно предположить что есть библиотеки которые делают так же, но не могу привести примеры.

Консольный вариант можно легко допилить, но смысла мало ибо по любому нужен прогон программы по функционалу.
 

Кстати так советуемый на форумах Dependency Walker скорее всего так и делает- анализирует таблицу импорта - и видит только модули Qt, а плагины и qml пропускает.


Comments

Only authorized users can post comments.
Please, Log in or Sign up
s
May 26, 2019, 2:33 p.m.
simpleunderground

Qt - Test 001. Signals and slots

  • Result:31points,
  • Rating points-10
НД
May 25, 2019, 11:19 p.m.
Николай Демиденко

C++ - Test 002. Constants

  • Result:50points,
  • Rating points-4
Last comments
May 21, 2019, 8:10 p.m.
Дмитрий

Приветствую! Я думаю дойдёт и до этого, но пока изучать его у меня нет желания.
May 20, 2019, 7:20 p.m.
Евгений Легоцкой

Добрый день! Вы не думали разместить репозиторий проекта на GitHub?
P.
May 18, 2019, 2:03 p.m.
PELMYACH .

Спасибо большое! Вскоре буду разбираться!
May 18, 2019, 9:13 a.m.
Евгений Легоцкой

Добрый день! Отнимать значение общего счётчика можно в деструкторе класса кнопки QDynamicButton::~QDynamicButton(){ ResID--;} При этом я бы ещё переустанавливал значения вс...
P.
May 14, 2019, 10:33 p.m.
PELMYACH .

Здравствуйте!А не подскажите, как можно при удалении какой либо кнопки, у щётчика отнять значение?Дабы например четвёртой кнопке соответствовал ID 4, а не 5 скажем
Now discuss on the forum
May 26, 2019, 6:49 a.m.
Михаиллл

Скачал dll от сюда и заработало
May 24, 2019, 6:48 a.m.
Евгений Легоцкой

Если там будут только перечисления внутри namespace, то жа, достаточно будет заголовочного файла
May 24, 2019, 6:28 a.m.
Андрей Янкович

работает любой http сервер, и можно использовать обсалютно любой портпример <RemoteRepositories> <Repository> <Url>http://178.124.160.6:3030/A/B&l...;
May 23, 2019, 10:42 a.m.
Михаиллл

Спасибо, помогло.
May 23, 2019, 6:31 a.m.
Евгений Легоцкой

Для задач и граф-то не нужен. Достаточно будет таблицы в локальной базе данных SQLite, в которой указывается задача, время и т.д. В этом разделе есть примеры по работа с базой д...

For registered users on the site there is a minimum amount of advertising

EVILEG
About
Services
Join us
© EVILEG 2015-2019
Recommend hosting TIMEWEB