Qt for Debian README -------------------- 1. Preface This README is intended to give developers and users exact information about how the qt-x11-free package provided by TrollTech AS has been packaged for Debian in case you either want to faciliate it for development of applications and libraries or plugins using the Qt class library. With qt-x11-3.1.1, the Debian packages have been massively restructured to get the most out of theoriginal Qt package and spit the contents up into several packages so that they make the most sensefor several groups of users; developers, application users, translators of Qt-based applications and Debian packagers who are packaging applications developed with Qt.2. 2. General Overview As Qt is a huge package that contains a complete environment for developers, it needs to be split up into several packages that make it easier for everyone else to handle it and not to require unnecessary disk space for end-users. Additionally, Qt can be configured in several ways - and therefore also used in several ways. Qt development usually requires the environment variable QTDIR. As Debian is placing libraries and header files in a quite specific filesystem order, this usually breaks setting a single environment variable to meet the requirements of packages. Therefore, symlinks are used to set up the system to meet both, the Debian filesystem standard and the QTDIR variable. All of Qt (so the QTDIR path) is available in /usr/share/qt3. If you need to set QTDIR, do export QTDIR=/usr/share/qt3 As far as the common build configuration goes, we note explicitely that the Debian package of Qt will in very rare cases break the compilation (most likely the linking) of applications on Debian which use Qt, in particular utilizing styles in an incorrect way by deriving from one of the styles that ship with Qt. In case you are a Debian packager and encounter problems, contact Debian Qt/KDE Maintainers (debian-qt-kde@lists.debian.org). We will tell you why things don't work and what you should communicate on with the programmers of your application that you are packaging. The build configuration generally is intended to provide a Qt version that is as small as possible in terms of the memory size it requires. Therefore, everything inside Qt that can be compiled as plugins has been compiled that way. This includes: - imageformats: jpeg and mng - codecs (for languages like arab, japanese etc provided with Qt) - sql drivers for databases (MySQL, ODBC and PostgreSQL) The only exception is the imageformat png which has been compiled built-in due to the fact that there is literally no program that uses no icons at all and icons are to be used preferrably in png format. The plugins are all located under /usr/lib/qt3/plugins. This is also the install location you should choose as a package maintainer for qt-plugins so the user doesn't have to customize his library path for loading Qt plugins. The only exception is that KDE delivers a set of Qt plugins as well (mainly styles and designer plugins); those are placed in /usr/lib/trinity/plugins. QMotif Extension: As this code is only available in commercial environments (and produces a static library libqmotif.a anyway that those commercial applications have to be linked against in addition to Qt), we left out all header files of the libqt3-headers package that are belonging to this QMotif extension. Oracle Database driver, Sybase & Microsoft SQL Server driver: Those drivers are only available in a commercial version of Qt due to license incompatibilities with the GPL. If you need to faciliate those drivers, please visit http://www.trolltech.com and have a read at http://doc.trolltech.com/3.0/sql-driver.html. 3. Packages (End-User) The Qt built has been split up into several packages that allow for easy installation for all types of users. The End-user usually only requires to have the following packages installed to run an application that links against Qt: Threaded version:libqt3-mt (the library libqt-mt.so.* and libqui.so.* for loading designer-made user interfaces at runtime). Optionally depending on the program's requirements: libqt3-mt-odbc libqt3-mt-mysql libqt3-mt-psql In addition to the libraries, it may make sense to install the program qtconfig to customize the look and behaviorof Qt programs. If you have KDE installed, the KDE control center will take this task automatically in most cases. qtconfig is available in the package qt3-qtconfig. Also, Qt programs can make use of the online-help tool that ships with Qt, the Qt Assistant. The Assistant can be installed with the package qt3-assistant. Qt Configuration files ---------------------- Qt programs most often use QSettings to store their information in configuration files. With Qt 3.2, the new option --sysconfdir has been introduced that allows us to use /etc/qt3 as the system-wide location where qt-program specific global configuration files can go. If you're a programmer that wants to get familiar with that, please look at the examples, documentation and the code in designer or assistant as well as qtconfig. 4. Packages (Package maintainers) In addition to the library, a package maintainer will require an additional set of packages to compile a package that requires Qt. Depending on the version of the qt library, you will require a different set of packages; the most common option should be to make your application link against the multi-threaded version (-mt).Packages necessary for compiling Qt applications from source: libqt3-mt-dev (use libqt3-dev for linking against -lqt, this package only contains the .so files and the header file for libqui.so) libqt3-headers (header files for libqt and libqt-mt) qt3-dev-tools (this package contains the tools uic and moc as well as qmake, required for building Qt applications) If, however, you encounter an older program not to compile with this set read the FAQ at the end of this document. 5. Packages (Developers) In addition to the packages that packagers require, a developer usually will require the Qt API documentationas well as tools like the assistant, linguist or designer. However, you should be fine with installing the API documentation that you can browse with a webbrowser, optionally with the assistant. They are available in /usr/share/doc/qt3-doc/html. For a regular development environment, install qt3-designer and qt3-doc. For faciliating Qt's extended environment to write plugins for the Qt Designer or extend the Designer as well as utilizing the Qt Assistant by calling it from within your program, install qt3-apps-dev, which contains the static libraries and header files required for this functionality. For Embedded Developers, the program qvfb (Qt Virtual Frambuffer) and makeqpf (embedded fonts tool)have been packaged into qt3-dev-tools-embedded. For developers that work on migrating their program from any Qt version prior to Qt 3.x to the Qt 3.x platform you will find additional tools in the qt3-dev-tools-compat. For using the QTranslator class and where to find the qm-file for qt as well as where to place your translations,see the next section. If your program doesn't compile with those settings in case you have started your project with Qt 1.x or 2.x, please read the FAQ section at the end of this document. 5. Packages (Translators) In order to translate a Qt program into any other language, the Qt 3 way to do this is to let the developer create a ts-file containing the strings that the program exposes on the user interface. The tools to create the ts-file and to create the final qm (Q-message binary) file, lupdate and lrelease, are included in qt3-dev-tools.The single translator that only gets provided the ts file and has to return a translated ts file, it is absolutely enough to install qt3-linguist; the package qt3-assistant can be installed to access the online-help for the Qt Linguist itself. In case you're converting an application using Qt prior to Qt 3, you may want to uitilize the qt3-dev-tools-compat which include the necessary tools to convert older qm files to the new ts file standard. Locations of message translations: Qt ships with a set of translations for the strings used inside Qt. Those translations will be installed into /usr/share/qt3/translations (qm files only), which equals $QTDIR/translations respectively qInstallPath() + QString( "/translations" ). The configure option --translationdir has been set to /usr/share/qt3/translations accordingly since it was introduced in Qt 3.2. To correctly enable your program to display the translations to the Qt library and to load the translation of the program itself, we currently suggest to either install your translations along with any other data files into/usr/share/<appname>/, translation files into the subdirectory translations (that is /usr/share/<appname>/translations) The code that your application should use to load the Qt translation will have to look like the following: int main( int argc, char **argv ) { QApplication app( argc, argv ); // translation file for Qt QTranslator qt( 0 ); qt.load( QString( "qt_" ) + QTextCodec::locale(), qInstallPath() + QString( "/translations" ); app.installTranslator( &qt ); // translation file for application strings QTranslator myapp( 0 ); myapp.load( QString( "myapp_" ) + QTextCodec::locale(), "." ); // use a substitue for $prefix/share/appname/translations here app.installTranslator( &myapp ); 6. Frequently Asked Questions Using Qt for Debian as a developer or packager ---------------------------------------------- Q: I want to compile a source package that utilizes qmake to build the Makefiles. What do I need to do to makeit work ? A: qmake requires two environment variables to be set, QTDIR and QMAKESPEC. To make it work, do export QTDIR=/usr/share/qt3 export QMAKESPEC=linux-g++ Then run qmake -o Makefile <projectfile>.pro After that, the Makefile is correctly created to build your application on Debian. As a packager, export thosetwo variables in the rules file before calling qmake. Q: I have an application that when linking gives me symbol referencing errors to Q*Style. Why does my applicationnot link correctly ? A: The author of the program is using the styles that ship with Qt directly instead of using the QStylePlugin interface.If you are the author of the program, change your program to use QStylePlugin. If you are a packager, write to theauthor of the program that he is assuming that the styles shipped with Qt are built-in to the library which is not the case on Debian and that he please should fix this and use QStylePlugin. Q: Where are all the examples and tutorials ? And how do I build them ? A: Qt ships with examples and tutorials; so does the Linguist and Designer. The tutorials and examples are compressed tarballs which you can unpack with tar -zxvf into your home directory. Change into the qt3-examples directory and run the provided ./build-examples script. All Qt examples and tutorials, including those for designer and the linguist, will be compiled. You will notice however, that those examples that inherit from style classes which are not built-in into Qt but configured as a plugin will not compile due to the fact that they can't link to the Qt library. Q: I'm writing a pure Qt application and I want to ship it with a default configuration file. Where does that global configuration file go if I make use of the QSettings class ? A: With qt-3.2.0, Trolltech has introduced a configure option to Qt called --sysconfdir which we intentionally set to /etc/qt3 similar to /etc/trinity for KDE programs. Install your application's system wide configuration file to /etc/qt3. Q: I'm compiling a program and I have a compile error due to a missing include. Why isn't that include not present in the Debian packages anymore ? It compiled with older versions of Debian packages of Qt ! A: This may be due to two reasons: either the package still uses the old includes from Qt 1.x or 2.x that got basically renamed by Trolltech due to the naming convention. The filenames are now all following the scheme ClassName -> classname.h. Therefore, if you are the developer of the affected program, change your sources according to this scheme. Qt ships with qtrename140, a tool to help developers migrate their API to the Qt 3 version, which can help you in the transition upgrade to Qt 3. If you are affected by this as a packager, notify upstream to fix those problems and in the meanwhile use libqt3-compat-headers as a build dependency which includes the compatibility headers that just include the right files from the new API again. Q: I have a question not covered by this FAQ and README file. Who should I turn to ? A: Please turn to Debian Qt/KDE Maintainers (debian-qt-kde@lists.debian.org) for any questions regarding Qt on Debian. -- Ralf Nolden <nolden@kde.org> Sun, 26 Jan 2003 20:39:19 +0100 -- Ralf Nolden <nolden@kde.org> Mon, 1 Sep 2003 19:24:16 +0200 -- Modestas Vainius <modestas@vainius.eu> Fri, 22 Feb 2008 01:40:06 +0200