Kompilacja w Qt Creator / MinGW

Kompilacja w Qt Creator / MinGW
AN
  • Rejestracja:około 19 lat
  • Ostatnio:około 7 godzin
0

Korzystam z Qt 5.3.0 w systemie Windows i programy kompiluję i uruchamiam w Qt Creator w wersji 3.1.1 pracującym w połączeniu z MinGW w wersji 4.8.2 32bit, który instaluje się razem z Qt Creatorem.

Okazuje się, że po włączeniu kompilacji Release i skompilowaniu, plik EXE nie uruchamia się z ikony, ani tym bardziej po przeniesieniu do innego komputera. Z poziomu Qt Creatora programu bez problemu się uruchamiają.

Załóżmy, że mam goły komputer, instaluję Windows i najnowszą wersję Qt Creator. Co po instalacji muszę ustawić lub zmienić, żeby program kompilował się poprawnie, do katalogu z plikiem EXE zostały skopiowane potrzebne pliki DLL i żebym miał pewność, że program również zadziała po przeniesieniu do innego komputera z systemem Windows bez zainstalowanego Qt ani Qt Creatora?

edytowany 2x, ostatnio: andrzejlisek
kq
Moderator C/C++
  • Rejestracja:prawie 12 lat
  • Ostatnio:dzień
  • Lokalizacja:Szczecin
2

Skopiuj brakujące biblioteki z katalogu %QTDIR%\5.3\mingw482_32\bin (czyli jeśli zainstalowałeś Qt do C:\Qt to będzie to C:\Qt\5.3\mingw482_32\bin). Będziesz też potrzebował odpowiednich pluginów platform z %QTDIR%\5.3\mingw482_32\plugins (i ew. pluginów SQL jeśli używasz SQL). Tak wygląda mój zestaw bibliotek, który dołączam klientom do programów:
user image


AN
  • Rejestracja:około 19 lat
  • Ostatnio:około 7 godzin
0

Z tego, co widzę, obowiązkowo należy dodać katalog "platforms", 6 plików widocznych na screenie, których nazwa nie rozpoczyna się od Qt5 i plik Qt5Core.dll.

Natomiast zestaw pozostałych plików zależy od tego, co się wykorzystuje, czyli Qt5Network.dll w przypadku aplikacji wykorzystującej sieć, Qt5Sql.dll w przypadku używania bazy danych, Qt5Xml.dll, jeżeli korzysta się z narzędzi XML.

Posiadam 3 komputery:

  1. Komputer stacjonarny z Windows XP 32-bit i zainstalowanym Qt 5.3.0, Qt Creator 3.1.1 i MinGW 4.8.2
  2. Maszyna wirtualna zawierająca Windows XP 32-bit bez Qt
  3. Laptop z Windows 7 64-bit z Qt 5.2.1, Qt Creator 3.0.1, MinGW 4.8

Wykonane przeze mnie próby wykazały, że program musi zostać uzupełniony o pliki DLL dokładnie z tego komputera, na którym został skompilowany, wtedy uruchamiał się na wszystkich trzech komputerach.

Czy istnieje możliwość wychwycenia i znalezienia lub określenia w inny sposób, których plików DLL i pluginów z serii Qt5xxx potrzebuje konkretny program?

Czy w systemach Linux i MacOS X również trzeba uzupełniać pliki bibliotek po kompilacji?

Azarien
  • Rejestracja:ponad 21 lat
  • Ostatnio:około 2 godziny
3

program musi zostać uzupełniony o pliki DLL dokładnie z tego komputera, na którym został skompilowany
To nie pochodzenie plików jest ważne, tylko ich wersja ;-) Pliki DLL muszą być w tej samej wersji Qt, z jaką skompilowano program.

Brak DLL-ki w większości przypadków powoduje wyświetlenie konkretnego komunikatu z nazwą tej DLL-ki.
Możesz zacząć od gołego exeka i dodawać mu kolejno to o co się domaga.

Jest też taki program Dependency Walker ale nigdy się nim nie bawiłem.

Lucas Darkstorm
Lucas Darkstorm
Dependency Walker jest spoko, tak samo Process Monitora można użyć do rozpoznania, jakich DLLek pragnie programik.
MarekR22
"być w tej samej wersji Qt, z jaką skompilowano program" to akurat nie jest prawda. Oczywiście jest parę ograniczeń, ale nie są aż tak restrykcyjne.
kq
Na windowsie praktycznie to prawda, bo Qt ostatnio zmienia wersję kompilatora co wydanie. 5.3.1 dostarczone przez Qt zbudowane na mingw gcc 4.8.2 nie chciało współpracować z binarkami zrobionymi pod 5.3.0 z tym samym kompilatorem, o 5.2 z mingw gcc 4.8.0 nie wspominając.
AN
  • Rejestracja:około 19 lat
  • Ostatnio:około 7 godzin
0

Dependency Walker pokazuje dla każdego programu, że brakuje WER.DLL i IESHIMS.DLL. Tych plików nie ma w całym komputerze. Czy u Was też tak jest? Mimo to, programy działają poprawnie.

edytowany 1x, ostatnio: andrzejlisek
BA
  • Rejestracja:ponad 11 lat
  • Ostatnio:ponad 6 lat
  • Postów:36
3

@andrzejlisek

Czy istnieje możliwość wychwycenia i znalezienia lub określenia w inny sposób, których plików DLL i pluginów z serii Qt5xxx potrzebuje konkretny program?

Najprostszą metodą (moim zdaniem) zebrania "do kupy" wszystkich plików dll potrzebnych do użycia danego programu jest użycie
windeployqt twoj_program.exe

A dependency walker u mnie też wskazywał kwiatki, kiedy próbowałem ręcznie dołączać odpowiednie dll.

kq
+10 za windeploy! Nie znałem narzędzia, wygląda ślicznie.
Lucas Darkstorm
Lucas Darkstorm
Też go nie znałem (dopiero w Qt wersji 5.2 się pojawił). Ale jak teraz sprawdziłem na swoim obecnym projekcie, to daje więcej plików niż potrzeba ;p.

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.