PDA

View Full Version : [QT4.6] Qt e Windows: Come integrare/linkare nell'eseguibile le librerie runtime?


Wing_Zero
04-03-2010, 02:05
Ciao a tutti,
il problema è semplice: ho sviluppato una applicazione con le librerie QT 4.6.
Su linux nessun problema ne all'atto della compilazione ne all'atto dell'esecuzione (grazie alle librerie dinamiche).

Lo stesso programma su windows,una volta compilato correttamente, per avviarlo devo necessariamente avviarlo dalla linea di comando della shell delle QT , DOPO aver installato l'sdk.

Ora mi chiedo:
1)Possibile che uno per avviare un programmino da 4 mega debba installare l'sdk delle QT?
2) Non ci sono delle "runtime library" da pochi mega per avviare programmi QT?

3) possibile che lo debbo avviare per forza da shell? non è possibile integrare all'interno dell'eseguibile le librerie necessarie?

Vi prego di illuminarmi perchè non uso mai windows per sviluppare, e mi trovo in difficoltà. Possibile che mi debbo portare dietro 300 mega di sdk per avviare uno stupido programma?Alla faccia delle "native application" tanto pubblicizzate -.-

Grazie a chiunque mi vorrà essere d'aiuto
Wing

cionci
04-03-2010, 02:23
Non devi installare l'SDK, ti devi portare dietro solo le DLL necessarie.
Intanto se il programma è 4 Mega significa che è ancora inversione debug. Devi compilarlo in versione Release.
Poi prendi le relative librerie che trovi nella directory bin dell'SDK. Le librerie da allegare all'applicazione sono Qt4Core.dll e quelle che hai selezionato quando hai creato il progetto.
Inoltre all'eseguibile devi anche allegare: mingwm10.dll

Il programma si avvia anche facendoci doppio click sopra.

Non puoi linkare le librerie e il programma in un solo file, o meglio, puoi ma violi la licenza LGPL.

||ElChE||88
04-03-2010, 09:17
Non devi installare l'SDK, ti devi portare dietro solo le DLL necessarie.
Intanto se il programma è 4 Mega significa che è ancora inversione debug. Devi compilarlo in versione Release.
Poi prendi le relative librerie che trovi nella directory bin dell'SDK. Le librerie da allegare all'applicazione sono Qt4Core.dll e quelle che hai selezionato quando hai creato il progetto.
Inoltre all'eseguibile devi anche allegare: mingwm10.dll
e libgcc_s_dw2-1.dll.
Le trovi tutte nella cartella bin della tua installazione di Qt.

Wing_Zero
04-03-2010, 11:22
Non devi installare l'SDK, ti devi portare dietro solo le DLL necessarie.
Intanto se il programma è 4 Mega significa che è ancora inversione debug. Devi compilarlo in versione Release.
Poi prendi le relative librerie che trovi nella directory bin dell'SDK. Le librerie da allegare all'applicazione sono Qt4Core.dll e quelle che hai selezionato quando hai creato il progetto.
Inoltre all'eseguibile devi anche allegare: mingwm10.dll

Il programma si avvia anche facendoci doppio click sopra.

Non puoi linkare le librerie e il programma in un solo file, o meglio, puoi ma violi la licenza LGPL.

grazie mille era proprio quello che cercavo, solo che ora un problema:
Sopo aver copiato nella cartella QtCore4.dll e provato ad avviare il programma mi appare questo messaggio:
"Impossibile trovare il punto di ingresso _Z5qFreePv della procedura nella libreria di collegamento dinamico QtCore4.dll"
A cosa è dovuto???-.-
grazie 1000 per l'aiuto cmq
Wing

cionci
04-03-2010, 11:30
Ci hai copiato anche

mingwm10.dll
libgcc_s_dw2-1.dll
QtGui4.dll ?


Devi aggiungere una libreria per ogni modulo di PHP che hai selezionato al momento della creazione del progetto.
Per vedere quali librerie devi aggiungere oltre a quelle già menzionate, devi aprire il file .pro che trovi nel progetto e nella riga QT.
Ad esempio se è così:

QT += xml

devi aggiungere anche QtXml4.dll

Wing_Zero
04-03-2010, 11:55
Ci hai copiato anche

mingwm10.dll
libgcc_s_dw2-1.dll
QtGui4.dll ?


Devi aggiungere una libreria per ogni modulo di PHP che hai selezionato al momento della creazione del progetto.
Per vedere quali librerie devi aggiungere oltre a quelle già menzionate, devi aprire il file .pro che trovi nel progetto e nella riga QT.
Ad esempio se è così:

QT += xml

devi aggiungere anche QtXml4.dll

Ci ho messo tutto.
ho copiato tutta la cartella bin(dove si trovano le dll) addirittura per provare.
Secondo me è un problema della compilazione: l'ho compilata con le librewrie dinamiche invece la dovevo compilare con le librerie statiche.
Almeno penso, boh.
nn so che dire.

cionci
04-03-2010, 12:05
Secondo me è un problema della compilazione: l'ho compilata con le librewrie dinamiche invece la dovevo compilare con le librerie statiche.
No, non devi compilare con le librerie statiche, violi la licenza.
Non devi copiare la directory bin, devi copiare il contenuto della directory bin. Inoltre le prime due dll sopra si trovano nella directory di mingw.

Wing_Zero
04-03-2010, 12:28
No, non devi compilare con le librerie statiche, violi la licenza.
Non devi copiare la directory bin, devi copiare il contenuto della directory bin. Inoltre le prime due dll sopra si trovano nella directory di mingw.

Nella guarda delle QT c'è la sezione "deployment on windows" e "static linking":

http://doc.trolltech.com/4.6/deployment.html

Cmq ok, siccome lo vorro distribuire via GPL v2 ilprogrammino in questione, allora non devo compilare staticamente, capito.

Quindi secondo te da cosa dipende? se non da quello?
Ho copiato tutte le librerie nella stessa cartella (ovviamente non ho mantenuto la directory bin ma ho copiato solo il contenuto). Ma continua a darmi lo stesso errore.
Se ti va ed hai 1 attimo, ti passo per pm il sorgente e l'eseguibile...(direi che oltretutto è n programmino abbastanza figo: in pratica è un catalogo di film e tu clikkando su un film visualizzi tuttele info di questo, compresa la cover, tramite un query con le API di themoviedb.org. Parsandole poi con un parser xml :P).

sn abbastanza disperato...

Il programma con QtCreator (IDE in cui l'ho sviluppato) o con la console delle QT si avvia e funziona bene!

P.S.:
grazie 1000 per la disponibilità mostratami.
Cmq ti mando in pm il link del programmino, se ci vuoi buttare un occhiata...sennò fa nulla :) Te lo mando cmq tante volte ti fosse utile...un po' di sorgente un piu' nn fa mai male da come la vedo io :)

cionci
04-03-2010, 14:13
QtNetwork4.dll
QtCore4.dll
QtGui4.dll

e le due di mingw.

Basta usare questo programma: http://dependencywalker.com/

Wing_Zero
04-03-2010, 14:40
QtNetwork4.dll
QtCore4.dll
QtGui4.dll

e le due di mingw.

Basta usare questo programma: http://dependencywalker.com/

Come ti ho già detto prima, le ho già copiate quelle librerie, Ma mi da il seguente errore:

"Impossibile trovare il punto di ingresso _Z5qFreePv della procedura nella libreria di collegamento dinamico QtCore4.dll"

Ripeto, sicuramente non dipende dal fatto che mancano le dll, nella cartella: guarda tu stesso, ti ho inviato in pm il link con tutti i file. Nel caso che non ti fosse arrivato : http://www.megaupload.com/?d=ET2POMNY

Penso che dipende dal fatto che lo devo compilare staticamente. E compilandolo staticamente non violo alcuna licensa, in quando viene distribuito in LGPL.

Pero' cmq sia non so come risolvere. Se puoi dare un occhiata ti sarei molto grato!

Ti ringranzio ancora molto per la disponibilità!
Saluti
Gianluigi

cionci
04-03-2010, 15:08
Ti dico di no, non lo devi compilare staticamente. A me il tuo eseguibile funziona senza problemi con quelle DLL.

Wing_Zero
04-03-2010, 15:10
Ti dico di no, non lo devi compilare staticamente. A me il tuo eseguibile funziona senza problemi con quelle DLL.

Cioè a te parte senza problemi? xkè a me no? ??? O_o

cionci
04-03-2010, 15:24
Controlla che non ci sia un "d" in fondo al nome di qualcuna delle dll.

Wing_Zero
04-03-2010, 16:29
Controlla che non ci sia un "d" in fondo al nome di qualcuna delle dll.

Sono nuovo delle QT però nn sono un niubbone totale :)
Le dll non erano la versione debug, che tra l'altro ovviamente pesano un casino.
Il nome era giusto Qtcore4.dll.
Cmq ho risolto. sai quale era l'aarcano?
Che c'erano 2 versione diQTcore4.dll: una in C:\Qt\2010.02.1\bin
ed una in C:\Qt\2010.02.1\qt\bin.

E seppur con lo stesso nome, erano differenti. Una probabilmente era quella usata dall'ide delle qt, un'altra è quella da integrare nelle aplicazioni sviluppate.
Prendendo quella in C:\Qt\2010.02.1\qt\bin. nessun problema :) prima prendevo l'altra.

si puo' chiudere :)

cionci
04-03-2010, 16:32
Ok, ottimo.