Russian Qt Forum

Qt => Общие вопросы => Тема начата: coder-ex от Декабрь 10, 2016, 09:56



Название: Компоновка программы
Отправлено: coder-ex от Декабрь 10, 2016, 09:56
Подскажите как правильно скомпоновать программу на Qt в Linux. Есть следующие модули программы:
1. главное окно с системой меню
2. независимое окно для выполнения загрузки БД и ее обработки
3. независимое окно для расчета данных (на сонове БД)
Как правильно скомпилировать все три модуля, при условии что в них используется механизм сигналов и слотов Qt и вызываются они из модуля 1:
1. все три модуля независимыми исполняемыми файлами
2. модуль 1 исполняемым файлом, модули 2 и 3 плагинами Qt
3. модуль 1 исполняемым файлом, модули 2 и 3 статическими библиотеками
4. модуль 1 исполняемым файлом, модули 2 и 3 динамическими Qt
Читал, что есть проблема с механизмом сигналов и слотов если компоновать компоновать в динамические библиотеки. Подскажите нормальное рабочее решение.


Название: Re: Компоновка программы
Отправлено: Old от Декабрь 10, 2016, 10:25
Читал, что есть проблема с механизмом сигналов и слотов если компоновать компоновать в динамические библиотеки. Подскажите нормальное рабочее решение.
Если это было бы так, то плагинов в Qt не было бы, а они есть. :)
А QtCreator из одних только динамических библиотек и состоит. Посмотрите на него.


Название: Re: Компоновка программы
Отправлено: qate от Декабрь 10, 2016, 12:01
все модули в одной программе
загрузка и обработка БД возможно в другом потоке, в зависимости от обработки, а может все в одном


Название: Re: Компоновка программы
Отправлено: coder-ex от Декабрь 10, 2016, 12:30
в одной программе сделать нет проблем, но т.к. модули могут быть модернизированы, не хотелось бы их привязывать к основному коду программ и при их модернизации собирать всю программу по новой


Название: Re: Компоновка программы
Отправлено: qate от Декабрь 10, 2016, 16:42
если по задаче необходимо разнести модули, то имеет смысл делать отдельными программами
так например сделана запись дисков - морда k3b и консольная программа cdrecord раздельно


Название: Re: Компоновка программы
Отправлено: Bepec от Декабрь 10, 2016, 17:14
При сборке одним компилятором и одной версией библиотек проблем никаких не будет.
При изменении компилятора или версии библиотек у вас возникнет большой БУМ в программе и она сдохнет :D


Название: Re: Компоновка программы
Отправлено: Old от Декабрь 10, 2016, 18:38
или версии библиотек у вас возникнет большой БУМ в программе и она сдохнет :D
Не придумывайте. Qt прилагает огромные усилия для обеспечения бинарной совместимости, поэтому никакого бума не будет. Все будет работать в штатном режиме.


Название: Re: Компоновка программы
Отправлено: Racheengel от Декабрь 10, 2016, 19:03
Все будет работать в штатном режиме.

Я бы даже согласился, если бы не имел опыт в обратном....
Еще худший вариант - когда БУМ происходит не сразу, а где-то через недельку "стабильной" работы.


Название: Re: Компоновка программы
Отправлено: Old от Декабрь 10, 2016, 19:11
Я бы даже согласился, если бы не имел опыт в обратном....
Еще худший вариант - когда БУМ происходит не сразу, а где-то через недельку "стабильной" работы.
В Qt всего несколько раз ломали бинарную совместимость, если вы попали на этот случай... Ну что ж бывает.
У меня Qt регулярно обновляется без пересборки программ ее использующих и проблем нет.


Название: Re: Компоновка программы
Отправлено: Bepec от Декабрь 10, 2016, 19:14
т.е. вы хотите сказать, что плагин на Qt 5.0 будет работать с приложением на Qt 5.6?
А плагин собранный mingw доблестно скомпонуется с приложением, собранным на MSVC?
Эх, если бы так работало...


Название: Re: Компоновка программы
Отправлено: Old от Декабрь 10, 2016, 19:36
т.е. вы хотите сказать, что плагин на Qt 5.0 будет работать с приложением на Qt 5.6?
Плагин собранный с Qt5.0 будет спокойно работать с программой собранной с Qt5.6

А плагин собранный mingw доблестно скомпонуется с приложением, собранным на MSVC?
Нет. Проблемы манглинга имен остается, но это больше проблема msvc, чем gcc.
Насколько мне известно под linux разработчики компиляторов договорились про ABI и библиотека собранная одним компилятором спокойно может использоваться программой собранной другим компилятором. А ТС спрашивает именно про linux.