Qt - pytania o licencję

Qt - pytania o licencję
KR
  • Rejestracja:ponad 16 lat
  • Ostatnio:około 10 lat
  • Postów:10
0

Jak dotąd pisałem soft (z większym lub mniejszym powodzeniem) w VS oraz VB6 korzystając z licencji komercyjnej. Teraz przyszedł czas na naukę C++, najlepiej z wykorzystaniem Qt i Qt Creatora (ze względu na łatwość przenoszenia projektów Win-Lin).
Niestety, pewne aspekty licencyjne są dla mnie nie do końca zrozumiałe:

  1. Biblioteki Qt są dostępne na licencji LGPL (pomijam licencję Developer ze względu na koszt). Jak rozumiem, mogę pisać programy zamknięte jednak muszę wszystkie biblioteki Qt linkować dynamicznie, czy to prawda?
  2. Jeśli odpowiedź na powyższe pytanie jest twierdząca, to w jaki sposób ustawić Qt Creatora (kompiler, linker?) aby domyślnie w ten sposób linkował biblioteki?
  3. Zauważyłem, że wykorzystanie MySQL w Qt jest... trudne (to delikatne sformułowanie) i wymaga kompilacji sterowników. Czy w takim wypadku dołączanie takiego sterownika do programu także narzuca licencję GPL (ze względu na licencję drivera MySQL)?
  4. Jeśli odpowiedź na powyższe również jest twierdząca, to czy ten sam problem dotyczy PostgreSQL'a?

Z góry dziękuję za odpowiedzi :)

kq
Moderator C/C++
  • Rejestracja:prawie 12 lat
  • Ostatnio:około 11 godzin
  • Lokalizacja:Szczecin
1
  1. Tak, jedyny kod jaki musisz udostępnić to Twoje zmiany w samej bibliotece Qt. (np. gdybyś usprawnił klasę QString)
  2. Nie zmieniaj domyślnych ustawień, nie kompiluj Qt statycznie od zera.
  3. Nie jest trudne, sprowadza się do instalacji zależności i wywołania qmake w folderze pluginu. Nie wiem która wersja jest w użyciu w MySQL, jeśli 2 to nie masz czego się obawiać bo plugin to osobna biblioteka. Jeśli 3 to nie wiem.
  4. Nie wiem.

KR
  • Rejestracja:ponad 16 lat
  • Ostatnio:około 10 lat
  • Postów:10
0

Dzięki za odpowiedź, jest bardzo pomocna.
Tak tylko aby się upewnić w 100%. Qt Creator zainstalowany na Linuksie (Ubuntu) domyślnie linkuje biblioteki dynamicznie? Zakładam, że tak.
Ad 3. No właśnie nie do końca tak jest w moim przypadku, przynajmniej na drugim komputerze - z Windows, tam mam osobno poinstalowane konektory MySQL w kilku wersjach, które są mi potrzebne do pracy z VS i niestety to rozwiązanie "gryzie się" z Qt... Mam nadzieję, że po stronie linuksa będzie to śmigać (o ile właśnie nie zrezygnuję z MySQL ze względu na licencję).

kq
Moderator C/C++
  • Rejestracja:prawie 12 lat
  • Ostatnio:około 11 godzin
  • Lokalizacja:Szczecin
1

Przyznam, że MySQL na windowsie nie próbowałem, ale plugin MSSQL wymagał ode mnie włączenia konsoli Qt (zwykły cmd z dodanymi pathami), nawigacji do katalogu z pluginami i qmake, make, make install (o ile dobrze pamiętam). Na ubuntu z MySQL też problemów nie było.

Jeśli VS jest nie do przeskoczenia to może używaj Qt zbudowane o VS? W robocie teraz robimy na Qt dla VS 2010, cały kod klepiemy w QtCreatorze i wszystko działa znakomicie.


MarekR22
Moderator C/C++
  • Rejestracja:około 17 lat
  • Ostatnio:minuta
0

odnośnie 2 jest nieco inaczej niż opisał to @kq.
Zmiany w kodzie Qt możesz robić, ale musisz je publikować, ale wątpię czy będziesz to robił.
Możesz jednak swobodnie skonfigurować Qt, np wywalić cześć featureów by biblioteka była lżejsza, najlepiej wywalić część stylów i zostawić tylko jeden, biblioteki znacznie schudną. Jednak wynikiem końcowym muszą być biblioteki dynamiczne o standardowych nazwach.


Jeśli chcesz pomocy, NIE pisz na priva, ale zadaj dobre pytanie na forum.
kq
Nie bardzo rozumiem w czym uważasz, że się myliłem. O konieczności publikacji swoich zmian w bibliotece pisałem, natomiast rekompilacja z innymi flagami nie zmienia kodu źródłowego, więc nie ma czego udostępniać.
MarekR22
"Nie zmieniaj domyślnych ustawień"
kq
To była odpowiedź do "w jaki sposób ustawić Qt Creatora (kompiler, linker?) aby domyślnie w ten sposób linkował biblioteki?"
KR
  • Rejestracja:ponad 16 lat
  • Ostatnio:około 10 lat
  • Postów:10
0

Niestety, na Ubuntu 13.04 też MySQL nie działa "z marszu"...
Przyznam, że jestem zmęczony próbowaniem.
W moim przypadku (na Ubuntu) instaluje się Qt4 i Qt5, jednakże biblioteki dla MySQL są w Qt4, a domyślne ścieżki wskazują na Qt5. Po ich zmianie dostaję komunikat o niemożliwości odnalezienia mysql.h w moim programie (który tylko próbuje nawiązać połączenie z db).

Co do konfiguracji wszystkiego pod VS, to to rozwiązanie odpada - do Qt skusiła mnie wieloplatformowość z docelowym środowiskiem na Linuksie, a to "se nevrati" z VS...
Muszę jeszcze chyba trochę poczekać, aż pojawi się jednak dobre IDE, w którym będzie WYSIWYG do GUI i wszystko będzie działać z marszu... :/

kq
Możesz korzystać z VS-Qt na windowsie i (jeśli nie używasz nic stricte visualowego, tylko Qt) praktycznie bez żadnych zmian w kodzie odpalić to samo na MinGW lub gcc/clangu na linuksie/macu. VC to tylko kompilator, ale jak jest wymagany to nie ma problemów by go nie używać (pomijając to, że jest słabszy od konkurencji)
MarekR22
Qt Creator ma WYSIWYG do GUI
KR
@MarekR22 Ma, ale właśnie w nim nie mogę się dogryźć z MySQL... A bez tego nie ma dla mnie sensu... @kq "praktycznie" jest tutaj słowem kluczowym... Nie ufam VS, wiem, że przenoszenie kodu z jednego kompa z VS do drugiego, też z VS przy bardziej rozbudowanych projektach potrafi przyprawić o ból głowy. Nie wyobrażam sobie takich przenosin pomiędzy różnymi systemami... Jak wygląda (czy w ogóle) skrośna kompilacja pod VS? Ale odbiegamy od tematu :) Generalnie rozumiem, że jak długo nie zmieniam nic wewnątrz bibliotek Qt i MySQL'a, tak długo mogę trzymać źródła zamknięte.
KR
  • Rejestracja:ponad 16 lat
  • Ostatnio:około 10 lat
  • Postów:10
0

A jednak się udało :)

Rozwiązanie pod linuksem było prozaiczne...

Dla potomnych:

  1. Należy zainstalować libmysqlclient-dev
  2. W pliku /usr/include/qt5/QtSql/qsql_mysql.h należy zmienić linijkę:
Kopiuj
#include <mysql.h> 

na linijkę:

Kopiuj
#include </usr/include/mysql/mysql.h>  

Powyższe dotyczy Debiana i pochodnych.

n0name_l
Powinno wystarczy #include &lt;mysql/mysql.h&gt;, /usr/include/ jest standardowo przeszukiwane.
MarekR22
Moderator C/C++
  • Rejestracja:około 17 lat
  • Ostatnio:minuta
2

A nie lepiej dopisać w pliku pro coś takiego:

Kopiuj
unix {
    INCLUDEPATH += /usr/include/mysql
}

Jeśli chcesz pomocy, NIE pisz na priva, ale zadaj dobre pytanie na forum.
KR
  • Rejestracja:ponad 16 lat
  • Ostatnio:około 10 lat
  • Postów:10
0

Pewnie lepiej, ale najpierw znalazłem swoje rozwiązanie ;)

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.