source: trunk/README.OS2@ 525

Last change on this file since 525 was 524, checked in by Dmitry A. Kuminov, 16 years ago

README for GA.

File size: 16.4 KB
RevLine 
[397]1This is Beta 5 of Qt version 4.5.1 for OS/2 and eCS.
[144]2
[397]3This document contains a brief information on the OS/2 version of the Qt
[524]4library. Please read it carefully before starting your work. You may also
5visit the project page at
[144]6
7 http://svn.netlabs.org/qt4/wiki
8
[188]9to get more information and the latest news and also to report bugs.
[144]10
[397]11To get a brief list of OS/2-specific changes from release to release
12please see the CHANGES.OS2 file included in this distribution.
[144]13
[188]14
[397]15
[144]16REQUIREMENTS
17
[397]18In order to compile the Qt library and Qt-based applications, you will need
19the following tools:
[144]20
21 - One of the OS/2 Warp 4, OS/2 Warp 4.5 or eComStation operating systems.
22
[524]23 - InnoTek GCC compiler version 3.3.5 CSD3 or 4.4.2 (recommended).
24 You can download the GCC 4.4.2 compiler using the following link:
[144]25
[524]26 http://download.smedley.info/gcc-4.4.2-os2-20091205.zip
27
28 GCC 4.4.2 requires newer binutils available at:
29
30 http://download.smedley.info/binutils-2.19.1-os2-20090427.zip
31
32 Note that in order to use the above version of GCC, you will also need
33 to install the previous 3.x version (e.g. 3.3.5 CSD3) available at:
34
[144]35 ftp://ftp.netlabs.org/pub/gcc/GCC-3.3.5-csd3.zip
36
[259]37 - Patched OpenWatcom linker which you can download from here:
[144]38
[152]39 ftp://ftp.netlabs.org/pub/gcc/wl-hll-r1.zip
[144]40
[152]41 Note that if you use IBM ILINK (no matter what version), you will
42 not be able to build the debug version of the library due to
43 bugs/limitations of ILINK.
[144]44
[152]45 - GNU Make 3.81beta1 or above (not tested) available at:
[144]46
[152]47 http://unix.os2site.com/pub/binary/make/make-3_81beta1-bin-static.zip
[144]48
[314]49 - LxLite 1.3.3 or above (not tested) if you want Qt DLLs and application
50 executables to be compressed (to save hard disk space and load time). If
51 you have a recent eComStation installation (e.g. 2.0 rc6) you will already
52 have LxLite installed. Otherwise, you may take it from here:
53
54 http://www.os2site.com/sw/util/archiver/lxlt133.zip
55
[397]56
57
58SETTING UP THE ENVIRONMENT
59
[144]60After unpacking the GCC archive, you will have to set up the compiler
[524]61environment by invoking gccenv.cmd from the "bin" subdirectory with the correct
[402]62arguments (type gccenv.cmd -? for help). For the OpenWatcom linker, specify
63WLINK as the second argument.
[144]64
[524]65Please note that setting up the GCC 4.x environment requires some additional
66steps. Please look through the README files contained within the OS/2
67distribution.
68
[259]69You will also need to perform the following steps:
70
[314]71 - Make sure the selected linker, the make utility and LxLite executable are
72 in PATH.
[144]73
[152]74 - Make sure CMD.EXE is your command line processor (the generated makefiles
[258]75 will rely on its 'copy', 'if' and other commands). If you have a Unix shell
76 (SH.EXE) in your environment, you may need to force GNU make to use CMD.EXE
77 by doing 'set MAKESHELL=C:\OS2\CMD.EXE' where C: is your boot drive.
[152]78
[524]79 - Do set LIBRARY_PATH=C:\OS2\DLL;C:\MPTN\DLL where C: is your boot drive.
[144]80
[258]81 - Make sure that there are no traces of any other Watcom or OpenWatcom
82 installation in the environment where you build Qt as it will most likely
83 interfere with the patched OpenWatcom linker we use. This basically means
84 removing all *WATCOM* environment variables and removing references to those
85 Watcom installations from PATH.
86
[524]87 - Add the "bin" subdirectory of the directory where you unpacked the Qt4
88 source tree to PATH and BEGINLIBPATH using its full path, e.g.:
89
90 set PATH=D:\Coding\Qt4\bin;%PATH%
91 set BEGINLIBPATH=D:\Coding\Qt4\bin;%BEGINLIBPATH%
92
[188]93Note that the QTDIR environment variable used by previous Qt versions is not
94used by Qt4 anymore (except two rare cases that do not affect the OS/2 platform
95anyway and are probably leftovers after the migration of the qmake feature
96specifications to Qt4). Therefore, there is no need to set this variable
[259]97explicitly. See also a note below about hard-coded paths to the source tree.
[144]98
[188]99There is also no need to set the QMAKESPEC variable explicitly. If it is absent,
100qmake will use the specification stored in the <Qt4_Home>/mkspecs/default
101directory, which on OS/2 always refers to the "os2-g++" specification, the only
102one supported at the present time.
[144]103
[397]104
105
106COMPILING QT
107
108You should skip this section if you downloaded and installed a binary
[402]109distribution of the Qt library for developers (qt-dev-X_Y_Z.wpi) and proceed
110directly to section USING OFFICIAL BINARY QT PACKAGES below.
[397]111
[144]112When the environment is set up, go to the directory where you unpacked the
113Qt4 source tree and type:
114
115 configure.cmd
116
[259]117This will set up the library (by creating necessary configuration and include
118files and a bunch of Makefiles for variuos components) and build the qmake
119utility.
[144]120
[402]121The next step is to type:
[144]122
[148]123 make
[144]124
[148]125This will compile and link the library. Note that by default both the release
126and the debug version of the library are built (please be patient, it may take
127quite some time depending on your hardware). The release and debug libraries can
128co-exist in the same source tree and may be used in parallel: all the debug DLLs
129get a 'd' letter in their name preceeding the Qt major version number and use
130separate directories for object files.
[144]131
[243]132To save time, you may also build the release and the debug versions of the
133library separately by typing 'make release' or 'make debug' accordingly
134instead of just 'make'.
135
[148]136Once the library is successfully built, you may try to compile the demos
[188]137and examples by visiting the individual example subdirectories in the source
[148]138tree and typing 'qmake' followed by one of 'make', 'make release' or
139'make debug' in that subdirectory.
[144]140
[402]141NOTE:
[144]142
[402]143 This version of Qt for OS/2 includes the Extended system tray plugin for
[314]144 XCenter/eCenter which is necessary to enable Qt support for the special
145 notification area on the XCenter/eCenter panel (called the "system tray")
146 which is used by many long-running applications to display their status.
147 In order to activate this support, you need to install this plugin to your
148 XCenter or eCenter. The plugin is built during the normal Qt build process
149 and can be found in the file \plugins\xcenter\xsystray.dll in the Qt source
150 tree. In order to install the plugin, do the following:
[188]151
[314]152 a. Copy xsystray.dll to <XWorkplace installation folder>\plugins\xcenter\
153 (on eComStation, this will be C:\ecs\system\ewps\plugins\xcenter\ where
154 C: is your boot drive).
[188]155
[314]156 b. Restart WPS.
157
158 c. Add the "Extended system tray" widget to the XCenter/eCenter panel using
159 the XCenter context menu ('Create new widget').
160
161 Note that if you upgrade from the previous version of the plugin then
162 please unlock xsystray.dll in the target folder using the UNLOCK.EXE
163 utility (which you can find in the LxLite package, for example) before
164 performing step a., otherwise the copy operation will fail.
165
[397]166IMPORTANT NOTE:
[314]167
[397]168 Please take into account that the Qt library you build on your own as
169 described above is NOT intended for wide distribution with Qt applications
170 you port or create. Such private Qt builds help you develop Qt applications
171 (because you can easily debug your program and parts of the Qt framework at
172 the source level) but being widely distributed they will create a so-called
173 DLL hell when a program running on a user computer crashes because it picks
174 up a wrong build of the Qt library. This will happen because even a single
175 change to Qt configuration options may make your build binary incompatible
176 with another build. And even if you convince the user to isolate different
177 DLLs (using BEGINLIBPATH and alike) it will create another major problem:
178 two different Qt applications will load two different Qt builds into memory
179 which will double resource usage; having three different builds will
180 tripple it and so on -- what a vaste of system resources!
[314]181
[397]182 In order to nicely solve this problem, netlabs.org provides the official
183 binary builds of the Qt library distributed as WPI packages which are
184 described in the next section.
185
186
187
188USING OFFICIAL BINARY QT PACKAGES
189
190For your convenience, netlabs.org provides the following binary distributions
191of the Qt library (where X_Y_Z is the Qt version number):
192
[402]193 qt-lib-X_Y_Z.wpi - Runtime DLLs and binaries ("lib" package)
194 qt-dev-X_Y_Z.wpi - Development libraries, tools and headers ("dev" package)
[397]195
196These packages are called the official binary packages of the Qt library for
197OS/2. An official binary distribution is the most complete Qt build available
198that enables all Qt library features and includes all standard Qt plugins that
199were implemented for OS/2.
200
201The "lib" package contains the release versions of DLLs (and may contain a few
202helper binaries) necessary to run applications created using the Qt framework.
203This package is usually installed by end users together with the Qt applications
204they want to use.
205
206The "dev" package contains pre-built release versions of import libraries and
207a complete set of C++ include headers of the Qt framework. This package is used
208by developers and porters of Qt applications to build release versions of the
209applications for OS/2 that are binary compatibie with the "lib" package
210described above.
211
212Using the "dev" package requires the same environment as the one necessary for
[524]213building Qt and described in section SETTING UP THE ENVIRONMET above with the
214exception that the "bin" subdirectory of the directory where you installed the
215"dev" package needs to be added to PATH instead of the "bin" subdirectory of
216the Qt4 source tree.
217
218The process of compiling Qt applications using the "dev" package is basically
219the same as with the hand made-build of Qt. Note, however, that if you are
[397]220developing or porting a Qt application, it is still recommended that you build
221the debug version of the Qt library yourself and use it in your daily work since
222it will give you much more feedback than the stripped down release version
223contained in the "dev" package. The "dev" package, as said above, is intended
224for making the final release build of the application for subsequent
225distribution together with the official "lib" package.
226
227Besides the binary "lib" and the "dev" packages, the following official
228non-binary packages exist that you may also find useful:
229
230 qt-examples-src-X_Y_Z.wpi - Demo and example sources ("examples")
231
[524]232The "examples" package contains the source code for all demo and example
233applications shipped with Qt. They serve as a good demonstration of the Qt
234library features and it is recommended to build them if you plan to write your
235own applications. In order to build them, go to the directory where you
236installed the respective package (e.g. D:\Coding\Qt4\examples) and type:
[408]237
238 qmake
239 make
240
241Please note that not all demos and examples will build with the current version
242of Qt4 for OS/2 since not all features have been implemented in the OS/2 version.
243
[397]244NOTE:
245
246 All .DLL and .EXE files of the official binary build contain a DESCRIPTION
247 string with the vendor field set to "netlabs.org" (by contrast, all custom
248 Qt builds will set the vendor field to what the USER environment variable
249 contains or to "anonymous" if USER is not set). Please note that you must
250 NOT set vendor to "netlabs.org" when creating your own builds of the Qt
251 library because it will make it really difficult to identify various
252 distributions and track possible problems with the builds.
253
254
255
[429]256ENVIRONMENT VARIABLES
257
258The Qt library recognizes a number of OS/2-specific environment variables that
259affect its functionality at runtime. The table below lists these variables and
260their meaning:
261
262 QT_PM_NO_SOUND_SHARE If set, Qt will open the audio device in exclusive
263 only one sound may be played on the computer at a
264 time. This mode is recommended for some sound cards
265 when using the Uniaud audio driver as it is known to
266 have problems with simultaneous playback. In current
267 Qt builds, this is the default behavior if neither
268 this nor the QT_PM_SOUND_SHARE variable is set.
269
270 QT_PM_SOUND_SHARE The opposite to the above. If set, Qt will open the
271 audio device in shared mode. This variable is
272 ignored if QT_PM_NO_SOUND_SHARE is set.
273
274 QT_PM_NO_REGISTRY If set, Qt will not use the Open32 registry to store
275 application settings with QSettings. Instead, plain
276 text INI files will be used for both NativeFormat
277 and IniFormat. Due to a number of problems in the
278 Open32 registry implementation (that may easily lead
279 to registry corruption), this is the default
280 behavior if neither this nor the QT_PM_REGISTRY
281 variable is set.
282
283 QT_PM_REGISTRY The opposite to the above. If set, Qt will use the
284 Open32 registry to store application settings.
285
286
287
[144]288CURRENT LIMITATIONS
289
[524]290 1. configure.cmd is not yet capable of generating individual Makefiles for
291 demos and examples, it only generates the main Makefile that builds the
292 library and the necessary tools. Demos and examples can be compiled by
293 hand (as described above).
[144]294
[524]295 2. configure.cmd does not understand any command line options. If you want
296 to customize the build of the Qt library (which is not recommended), you
297 may try to modify configure.cmd itself.
298
299 3. OS/2 bitmap fonts are not yet supported. Use TTF or Type1 (PFB) fonts with
[243]300 Qt.
[144]301
[524]302 4. In order to let Qt correctly detect the regional settings and choose the
[397]303 right language for translating the user interface, the LANG environment
304 variable must be set. The format is
[144]305
[397]306 set LANG=ll_CC
[291]307
[397]308 where <ll> is the language code and <CC> is the country code (refer to
309 wikipedia.org to find correct letters for your langage and country if you
310 do not know them). Note that the optional encoding part of the LANG
311 specification is ignored by Qt for OS/2 since 4.5.1 Beta 5 because it now
312 detects the encoding automatically based on the system OS/2 settings.
[291]313
[524]314 Later, the correct language will be detected from the system settings so
315 that specifying LANG will be not necessary at all.
[291]316
[188]317 5. No qt3support module. This functionality is rarely necessary in mature
318 real life applications and has low priority.
[144]319
[243]320 6. No native PM style, but Qt will use fonts and colors from the current
[320]321 OS/2 theme. Hint: if your default OS/2 font is "WarpSans", install the
322 "Workplace Sans" TTF font from Alex Taylor to get more native look & feel.
323 It is recommended to install version 0.6 of the Normal face and version 0.2
324 of the Bold face which you can find here:
[144]325
[320]326 http://users.socis.ca/~ataylo00/creative/fonts/workplace/
[287]327
[524]328 7. QProcess: when starting PM applications from text-mode applications, the
329 returned PID is a PID of the intermediate cmd.exe process, not the target
330 application.
[145]331
[524]332 8. The followign classes are not available due to their rare usage or low
333 importance on the OS/2 platform: QSharedMemory, QSystemSemaphore,
334 QInputContext, QAccessible. The following macros are defined to indicate
335 this: QT_NO_SYSTEMSEMAPHORE, QT_NO_SHAREDMEMORY,
336 QT_NO_IM, QT_NO_ACCESSIBILITY. Applications normally use them to guard the
337 relevant parts of code so they should still build.
[243]338
[524]339 9. No QAssistant, no printer support (QT_NO_PRINTER and QT_NO_PRINTDIALOG are
340 defined). No IPV6 support in the network module (QT_NO_IPV6 is defined).
[145]341
[524]342 See the project roadmap for more information on the current progress and
343 future plans:
[144]344
[524]345 http://svn.netlabs.org/qt4/roadmap
[144]346
[524]347 Feel free to request new features and report bugs using the project bug
348 tracker abaialble at:
[188]349
[524]350 http://svn.netlabs.org/qt4/report
351
352
353
[144]354CREDITS
355
356Dmitry A. Kuminov (development)
357Silvan Scherrer (management)
358
359netlabs.org (hosting & support)
360
361Nokia Corporation (original Qt library)
362
363We also want to THANK all individuals and organizations who made the donations
364to this project and helped to make it happen. Please visit
365
366 http://qt.netlabs.org/en/site/index.xml
367
368to get the full list of sponsors and to find information on how you can support
369the project.
370
371
372Qt is a trademark of Nokia Corporation and/or its subsidiary(-ies).
373OS/2 and OS/2 Warp are trademarks of the IBM Corporation and/or its subsidiary(-ies).
374eComStation is a trademark of Serenity Systems International and/or its subsidiary(-ies).
375Etc.
Note: See TracBrowser for help on using the repository browser.