В качестве тулчейна использую MinGW. Если собрать приложение на Windows 10 с MinGW, идущим в онлайн-установщике Qt, то всё работает хорошо. Там gcc-11.2.0.
Но ещё у нас на билд-сервере есть тулчейн с MinGW, который я делю с другими разработчиками, там gcc-12.2.0. Если собрать то же самое приложение с этим тулчейном, то при старте приложения, на мгноверние появляется окошко cmd. И то же самое происходит, если кросскомпилировать приложение с помощью MXE (там, судя по всему, используется mingw-w64-v11.0.0)
Таргет добавляется с помощью qt_add_executable. Что я пробовал дополнительно:
set(CMAKE_WIN32_EXECUTABLE TRUE)
set_target_properties(${PROJECT_NAME} PROPERTIES
WIN32_EXECUTABLE TRUE
)
target_compile_options(${PROJECT_NAME} PUBLIC
"-Wl,--subsystem=windows"
"-lmingw32"
"-municode"
"-lwinmm"
"-mwindows"
"-Wl,--subsystem=windows"
)
target_link_options(${PROJECT_NAME} PUBLIC
"-Wl,--subsystem=windows"
"-lmingw32"
"-municode"
"-lwinmm"
"-mwindows"
"-Wl,--subsystem=windows"
)
Ничего из этого ни в каких сочетаниях не исправило проблему. Я начинаю думать, что и саму проблему ищу не там. Может быть, кто-то знает, что это за проблема?
Если проблема в том, сто появляется окно терминала, то я в своё время использовал qt_add_executable(... WIN32 ...) Впрочем, вот нашёл кусочек целиком if ( WIN32 ) set ( ADDEXEC_KEY "WIN32" ) # disabling terminal window else () set ( ADDEXEC_KEY "" ) endif () if ( ${QT_VERSION_MAJOR} GREATER_EQUAL 6 ) qt_add_executable( ${APP_NAME} ${ADDEXEC_KEY} MANUAL_FINALIZATION ${PROJECT_SOURCES} ) qt_create_translation( QM_FILES ${CMAKE_SOURCE_DIR} ${TS_FILES} ) else () add_executable( ${APP_NAME} ${ADDEXEC_KEY} ${PROJECT_SOURCES} ) qt5_create_translation( QM_FILES ${CMAKE_SOURCE_DIR} ${TS_FILES} ) endif () target_link_libraries ( ${APP_NAME} PRIVATE Qt${QT_VERSION_MAJOR}::Core5Compat Qt${QT_VERSION_MAJOR}::Core Qt${QT_VERSION_MAJOR}::Gui Qt${QT_VERSION_MAJOR}::Svg Qt${QT_VERSION_MAJOR}::Multimedia Qt${QT_VERSION_MAJOR}::MultimediaWidgets Qt${QT_VERSION_MAJOR}::PrintSupport Qt${QT_VERSION_MAJOR}::Sql ) if ( QT_VERSION_MAJOR EQUAL 6 ) qt_finalize_executable( ${APP_NAME} ${ADDEXEC_KEY} ) endif ()
set_target_properties(<your target> PROPERTIES WIN32_EXECUTABLE ON MACOSX_BUNDLE ON )
А это при сборке под Windows чем-то отличается от моего варианта? set_target_properties( ${PROJECT_NAME} PROPERTIES WIN32_EXECUTABLE TRUE )
по идее это и должно скрыть конколь
Тогда не работает. И главная проблема в том, что всё зависит именно от тулчейна в моём случае. Консоль действительно скрывается после появления практически мгновенно, но пользователь её всё равно видит. Может, Qt как-то по особому патчит MinGW, поставляемый в онлайн-установщике?
про mingw не подскажу, я бы держался от него подальше, когда есть msvc community edition
Вынужден собирать с ним из-за используемых зависимостей. Или ничего страшного не будет, если сторонние библиотеки (в данном случае, библиотеки от другой команды) собраны им, а приложение с MSVC? Но и возможность кросскомпиляции не хотелось терять)
если другие либы собраны mingw, и пересобрать их нельзя msvc, то тогда придется оставаться в поле mingw
Обсуждают сегодня