| 1 | This is Qt version 4.6.2 for OS/2 and eCS. | 
|---|
| 2 |  | 
|---|
| 3 | This document contains a brief information on the OS/2 version of the Qt | 
|---|
| 4 | library. Please read it carefully before starting your work. You may also | 
|---|
| 5 | visit the project page at | 
|---|
| 6 |  | 
|---|
| 7 | http://svn.netlabs.org/qt4/wiki | 
|---|
| 8 |  | 
|---|
| 9 | to get more information and the latest news and also to report bugs. | 
|---|
| 10 |  | 
|---|
| 11 | To get a brief list of OS/2-specific changes from release to release | 
|---|
| 12 | please see the CHANGES.OS2 file included in this distribution. | 
|---|
| 13 |  | 
|---|
| 14 | Please note that this version is binary incompatible with previous versions of | 
|---|
| 15 | Qt 4 for OS/2! This is not a behavior of the original Qt library (where versions | 
|---|
| 16 | with the same major number are usually binary compatible), but it is due to the | 
|---|
| 17 | fact that we continue to add missing features to the OS/2 version ot Qt and this | 
|---|
| 18 | cannot be done witout breaking the binary compatibility. On practice, this means | 
|---|
| 19 | that you need to recompile your applications with the new version of the Qt | 
|---|
| 20 | library in order to make them work with it. | 
|---|
| 21 |  | 
|---|
| 22 |  | 
|---|
| 23 |  | 
|---|
| 24 | REQUIREMENTS | 
|---|
| 25 |  | 
|---|
| 26 | In order to compile the Qt library and Qt-based applications, you will need | 
|---|
| 27 | the following tools: | 
|---|
| 28 |  | 
|---|
| 29 | - One of the OS/2 Warp 4, OS/2 Warp 4.5 or eComStation operating systems. | 
|---|
| 30 |  | 
|---|
| 31 | - GCC compiler version 4.4.2 for OS/2, patched OpenWatcom linker and | 
|---|
| 32 | GNU Make 3.81beta1 or above. The GCC compiler must be set up to use the | 
|---|
| 33 | OpenWatcom linker for linking. | 
|---|
| 34 |  | 
|---|
| 35 | If you do not have a working GCC environment with the above requirements, it | 
|---|
| 36 | is recommended to download a ready-to-use GCC 4.2.2 distribution from here: | 
|---|
| 37 |  | 
|---|
| 38 | ftp://ftp.netlabs.org/pub/qt4/gcc-4_4_2-complete-20091205.zip | 
|---|
| 39 |  | 
|---|
| 40 | This distribution includes all tools necessary to compile and build the Qt | 
|---|
| 41 | library from the source code. Just follow the installation instructions | 
|---|
| 42 | contained in the README file inside this ZIP archive to set up the GCC | 
|---|
| 43 | environment. | 
|---|
| 44 |  | 
|---|
| 45 | Please note that starting from Qt 4.6.2, support for GCC 3.3.5 and earlier | 
|---|
| 46 | versions of the compiler has been dropped and the Qt library will most | 
|---|
| 47 | likely not build if you use one of these compilers. Later versions prior to | 
|---|
| 48 | GCC 4.4.2 may work but they are not tested and not supported. | 
|---|
| 49 |  | 
|---|
| 50 | There is also a set of optional tools which are necessary to enable the selected | 
|---|
| 51 | features of the Qt library. If these tools are missing, the Qt configuration | 
|---|
| 52 | script (discussed in section "COMPILING QT" below) will automatically disable | 
|---|
| 53 | the corresponding feature: | 
|---|
| 54 |  | 
|---|
| 55 | - LxLite 1.3.3 or above (not tested) to enable the compression of Qt DLLs and | 
|---|
| 56 | application executables (which saves hard disk space and application startup | 
|---|
| 57 | time). If you use a recent version of eComStation (e.g. 2.0 rc6) you will | 
|---|
| 58 | already have LxLite installed. Otherwise, you may take it from here: | 
|---|
| 59 |  | 
|---|
| 60 | http://www.os2site.com/sw/util/archiver/lxlt133.zip | 
|---|
| 61 |  | 
|---|
| 62 | - eCUPS 1.3.11 or later to support printing in Qt. The eCUPS WPI is available | 
|---|
| 63 | from: | 
|---|
| 64 |  | 
|---|
| 65 | ftp://ftp.netlabs.org/incoming/eCUPS003.wpi   or | 
|---|
| 66 | ftp://ftp.netlabs.org/pub/ecups/eCUPS003.wpi | 
|---|
| 67 |  | 
|---|
| 68 | Linking against eCUPS also requires pthread.lib: | 
|---|
| 69 |  | 
|---|
| 70 | http://web.os2power.com/download/lib/pthread-20100217-os2.zip | 
|---|
| 71 |  | 
|---|
| 72 |  | 
|---|
| 73 |  | 
|---|
| 74 | SETTING UP THE ENVIRONMENT | 
|---|
| 75 |  | 
|---|
| 76 | First of all, make sure that your GCC environment is set up and meets the | 
|---|
| 77 | specified requirements. To perform a quick check, you may run the following | 
|---|
| 78 | command: | 
|---|
| 79 |  | 
|---|
| 80 | gcc --version && make --version && wl /version | 
|---|
| 81 |  | 
|---|
| 82 | If the setup is done properly, it will print the versions of the key tools | 
|---|
| 83 | to the console. | 
|---|
| 84 |  | 
|---|
| 85 | The next step is to set up the Qt environment. If you installed the Qt | 
|---|
| 86 | development libraries from the WPI archive (refer to section "USING OFFICIAL | 
|---|
| 87 | BINARY QT ARCHIVES" below for more details about existing WPI archives), you | 
|---|
| 88 | will only need to run the supplied "QtEnv.cmd" script which will do all the | 
|---|
| 89 | setup job for you. The script is located in the directory where you installed | 
|---|
| 90 | the developmnent libraries (or in the WPS folder created by the WPI installer). | 
|---|
| 91 | Execute this script in a command line session to make it ready for building | 
|---|
| 92 | Qt 4 applications (for example, using the "qmake" command follwed by "make" | 
|---|
| 93 | for applications based on qmake project files which most of them are). If you | 
|---|
| 94 | go that way, you may skip the rest of this section and proceed directly to | 
|---|
| 95 | section called "USING OFFICIAL BINARY QT ARCHIVES" or further. | 
|---|
| 96 |  | 
|---|
| 97 | If you use the full source code ZIP distribution of the Qt library or work | 
|---|
| 98 | directly with the Qt SVN tree, you will need to set up the environment yourself | 
|---|
| 99 | by performing the following steps: | 
|---|
| 100 |  | 
|---|
| 101 | - Add the "bin" subdirectory of the directory where you unpacked the Qt4 | 
|---|
| 102 | source tree to PATH and BEGINLIBPATH, like this: | 
|---|
| 103 |  | 
|---|
| 104 | set PATH=D:\Coding\Qt4\bin;%PATH% | 
|---|
| 105 | set BEGINLIBPATH=D:\Coding\Qt4\bin;%BEGINLIBPATH% | 
|---|
| 106 |  | 
|---|
| 107 | - Add the system DLLs to the GCC library path with the following command: | 
|---|
| 108 |  | 
|---|
| 109 | set LIBRARY_PATH=C:\OS2\DLL;C:\MPTN\DLL;%LIBRARY_PATH% | 
|---|
| 110 |  | 
|---|
| 111 | where C: is your boot drive. | 
|---|
| 112 |  | 
|---|
| 113 | - Make sure CMD.EXE is your command line processor (the generated makefiles | 
|---|
| 114 | will rely on its 'copy', 'if' and other commands). If you have a Unix shell | 
|---|
| 115 | (SH.EXE) in your environment, you may need to force GNU make to use CMD.EXE | 
|---|
| 116 | by executing the followingn command: | 
|---|
| 117 |  | 
|---|
| 118 | set MAKESHELL=C:\OS2\CMD.EXE | 
|---|
| 119 |  | 
|---|
| 120 | where C: is your boot drive. | 
|---|
| 121 |  | 
|---|
| 122 | Note that the QTDIR environment variable used in previous Qt versions is not | 
|---|
| 123 | used in Qt4 anymore. Therefore, there is no need to set this variable | 
|---|
| 124 | explicitly. | 
|---|
| 125 |  | 
|---|
| 126 | There is also no need to set the QMAKESPEC variable explicitly. If it is absent, | 
|---|
| 127 | qmake will use the specification stored in the <Qt4_Home>/mkspecs/default | 
|---|
| 128 | directory, which on OS/2 always refers to the "os2-g++" specification, the only | 
|---|
| 129 | one supported at the present time. | 
|---|
| 130 |  | 
|---|
| 131 | NOTE: | 
|---|
| 132 |  | 
|---|
| 133 | It is especially important to make sure that there are no traces of any | 
|---|
| 134 | other Watcom or OpenWatcom installation in the environment where you build | 
|---|
| 135 | Qt as it will interfere with the patched OpenWatcom linker we use. This | 
|---|
| 136 | basically means removing all environment variables containing "WATCOM" in | 
|---|
| 137 | their names and also removing references to all those Watcom installations | 
|---|
| 138 | from PATH. | 
|---|
| 139 |  | 
|---|
| 140 |  | 
|---|
| 141 |  | 
|---|
| 142 | SETTING UP OPTIONAL TOOLS | 
|---|
| 143 |  | 
|---|
| 144 | The following list describes the steps necessary to set up the optional tools | 
|---|
| 145 | that the Qt library depends on: | 
|---|
| 146 |  | 
|---|
| 147 | - Install the eCUPS WPI archive to enable printing support. If this WPI is | 
|---|
| 148 | installed, the Qt build system will pick up all necessary libraries | 
|---|
| 149 | automatically. Otherwise (e.g. if you use a ZIP or build eCUPS yourself), | 
|---|
| 150 | you will need to use the following environment variables to tell it where to | 
|---|
| 151 | look for CUPS: | 
|---|
| 152 |  | 
|---|
| 153 | set CUPS_INCLUDEPATH=X:\Path\to\CUPS\include | 
|---|
| 154 | set CUPS_LIBS=X:\Path\to\CUPS\lib\libcups.a | 
|---|
| 155 |  | 
|---|
| 156 | You will also need to make sure that pthread.lib is placed somewhere in your | 
|---|
| 157 | system library path so that the compiler can find it. | 
|---|
| 158 |  | 
|---|
| 159 |  | 
|---|
| 160 |  | 
|---|
| 161 | COMPILING QT | 
|---|
| 162 |  | 
|---|
| 163 | You should skip this section if you installed the Qt development libraries using | 
|---|
| 164 | the WPI archive (that already contains compiled release versions of the | 
|---|
| 165 | libraries) and proceed directly to the next section. | 
|---|
| 166 |  | 
|---|
| 167 | When the environment is set up, go to the directory where you unpacked the | 
|---|
| 168 | Qt4 source tree and type: | 
|---|
| 169 |  | 
|---|
| 170 | configure.cmd | 
|---|
| 171 |  | 
|---|
| 172 | This will set up the Qt library (by creating necessary configuration and include | 
|---|
| 173 | files and a bunch of Makefiles for variuos components) and build the qmake tool. | 
|---|
| 174 |  | 
|---|
| 175 | The next step is to type: | 
|---|
| 176 |  | 
|---|
| 177 | make | 
|---|
| 178 |  | 
|---|
| 179 | This will compile and link the Qt library. Note that by default both the release | 
|---|
| 180 | and the debug version of the library are built (please be patient, it may take | 
|---|
| 181 | quite some time depending on your hardware). The release and debug libraries can | 
|---|
| 182 | co-exist in the same source tree and may be used in parallel: all the debug DLLs | 
|---|
| 183 | get a 'd' letter in their name preceeding the Qt major version number and use | 
|---|
| 184 | separate directories for object files. | 
|---|
| 185 |  | 
|---|
| 186 | To save time, you may build the release and the debug versions of the Qt library | 
|---|
| 187 | separately by typing 'make release' or 'make debug' accordingly instead of just | 
|---|
| 188 | 'make'. | 
|---|
| 189 |  | 
|---|
| 190 | Once the library is successfully built, you may try to compile the demos and | 
|---|
| 191 | examples by visiting the individual example subdirectories in the source tree | 
|---|
| 192 | and typing 'qmake' followed by one of 'make', 'make release' or 'make debug' | 
|---|
| 193 | in that subdirectory. | 
|---|
| 194 |  | 
|---|
| 195 | NOTE: | 
|---|
| 196 |  | 
|---|
| 197 | This version of Qt for OS/2 includes the Extended system tray plugin for | 
|---|
| 198 | XCenter/eCenter which is necessary to enable Qt support for the special | 
|---|
| 199 | notification area on the XCenter/eCenter panel (called the "system tray") | 
|---|
| 200 | which is used by many long-running applications to display their status. | 
|---|
| 201 | In order to activate this support, you need to install this plugin to your | 
|---|
| 202 | XCenter or eCenter. The plugin is built during the normal Qt build process | 
|---|
| 203 | and can be found in the file \plugins\xcenter\xsystray.dll in the Qt source | 
|---|
| 204 | tree. In order to install the plugin, do the following: | 
|---|
| 205 |  | 
|---|
| 206 | a. Copy xsystray.dll to <XWorkplace installation folder>\plugins\xcenter\ | 
|---|
| 207 | (on eComStation, this will be C:\ecs\system\ewps\plugins\xcenter\ where | 
|---|
| 208 | C: is your boot drive). | 
|---|
| 209 |  | 
|---|
| 210 | b. Restart WPS. | 
|---|
| 211 |  | 
|---|
| 212 | c. Add the "Extended system tray" widget to the XCenter/eCenter panel using | 
|---|
| 213 | the XCenter context menu ('Create new widget'). | 
|---|
| 214 |  | 
|---|
| 215 | Note that if you upgrade from the previous version of the plugin then | 
|---|
| 216 | please unlock xsystray.dll in the target folder using the UNLOCK.EXE | 
|---|
| 217 | utility (which you can find in the LxLite package, for example) before | 
|---|
| 218 | performing step a., otherwise the copy operation will fail. | 
|---|
| 219 |  | 
|---|
| 220 | IMPORTANT NOTE: | 
|---|
| 221 |  | 
|---|
| 222 | Please take into account that the Qt library you build on your own as | 
|---|
| 223 | described above is NOT intended for wide distribution with Qt applications | 
|---|
| 224 | you port or create. Such private Qt builds help you develop Qt applications | 
|---|
| 225 | (because you can easily debug your program and parts of the Qt framework at | 
|---|
| 226 | the source level) but being widely distributed they will create a so-called | 
|---|
| 227 | DLL hell when a program running on a user computer crashes because it picks | 
|---|
| 228 | up a wrong build of the Qt library. This will happen because even a single | 
|---|
| 229 | change to Qt configuration options may make your build binary incompatible | 
|---|
| 230 | with another build. And even if you convince the user to isolate different | 
|---|
| 231 | DLLs (using LIBPATHSTRICT and BEGINLIBPATH) it will create another major | 
|---|
| 232 | problem: two different Qt applications will load two different copies of Qt | 
|---|
| 233 | into memory which will create an unnecessary overhead by doubling the | 
|---|
| 234 | amount of used system resources. | 
|---|
| 235 |  | 
|---|
| 236 | In order to nicely solve this problem, netlabs.org provides the official | 
|---|
| 237 | binary builds of the Qt library distributed as WPI archives which are | 
|---|
| 238 | described in the next section. | 
|---|
| 239 |  | 
|---|
| 240 |  | 
|---|
| 241 |  | 
|---|
| 242 | USING OFFICIAL BINARY QT ARCHIVES | 
|---|
| 243 |  | 
|---|
| 244 | For your convenience, netlabs.org provides the following binary distributions | 
|---|
| 245 | of the Qt library (where X_Y_Z is the Qt version number) distributed as WPI | 
|---|
| 246 | archives: | 
|---|
| 247 |  | 
|---|
| 248 | qt-lib-X_Y_Z.wpi   - Runtime DLLs and binaries ("lib" archive) | 
|---|
| 249 | qt-dev-X_Y_Z.wpi   - Development libraries, tools and headers ("dev" archive) | 
|---|
| 250 |  | 
|---|
| 251 | These archives are called the official binary archives of the Qt library for | 
|---|
| 252 | OS/2. An official binary archive contains the most complete Qt build that | 
|---|
| 253 | enables all features of the Qt library and includes all standard Qt plugins | 
|---|
| 254 | implemented for the OS/2 platform at the time of the release. | 
|---|
| 255 |  | 
|---|
| 256 | The "lib" archive contains the release versions of DLLs (and may contain a few | 
|---|
| 257 | helper binaries) necessary to run applications created using the Qt framework. | 
|---|
| 258 | This package is usually installed by end users together with Qt applications | 
|---|
| 259 | they want to use. | 
|---|
| 260 |  | 
|---|
| 261 | The "dev" archive contains pre-built release versions of import libraries and | 
|---|
| 262 | a complete set of C++ include headers of the Qt framework. This package is used | 
|---|
| 263 | by developers and porters of Qt applications to build release versions of the | 
|---|
| 264 | applications that are binary compatibie with the Qt runtime provided by the | 
|---|
| 265 | official "lib" archive described above. Using the "dev" package requires the | 
|---|
| 266 | same environment as described in section "SETTING UP THE ENVIRONMET" above. | 
|---|
| 267 |  | 
|---|
| 268 | Please note again that the "dev" archive is intended to make a final release | 
|---|
| 269 | build of the Qt application which you do when you decide to ship a new version | 
|---|
| 270 | to the end users -- makes sure that the deployed application will share the same | 
|---|
| 271 | Qt runtime with other Qt applications. However, for daily work it is highly | 
|---|
| 272 | recommended that you build the debug version of the Qt library yourself (using | 
|---|
| 273 | the full source code ZIP archive or directly from SVN) as described in section | 
|---|
| 274 | "COMPILING QT"). | 
|---|
| 275 |  | 
|---|
| 276 | Besides the "lib" and the "dev" archives, the following official archives exist | 
|---|
| 277 | that you may also find useful: | 
|---|
| 278 |  | 
|---|
| 279 | qt-examples-X_Y_Z.wpi  - Demo and example sources ("examples") | 
|---|
| 280 |  | 
|---|
| 281 | The "examples" archive contains the source code and compiled binaries of the | 
|---|
| 282 | demo and example applications shipped with Qt. They serve as a good | 
|---|
| 283 | demonstration of the Qt library features and it is recommended to look at them. | 
|---|
| 284 | The binaries are compiled using the official "lib" archive. Please note that | 
|---|
| 285 | some demos and examples may miss from the arcvhice since not all features have | 
|---|
| 286 | been implemented in the OS/2 version of Qt yet. | 
|---|
| 287 |  | 
|---|
| 288 | NOTE: | 
|---|
| 289 |  | 
|---|
| 290 | All .DLL and .EXE files of the official binary build contain a DESCRIPTION | 
|---|
| 291 | string with the vendor field set to "netlabs.org" (by contrast, all custom | 
|---|
| 292 | Qt builds will set the vendor field to what the USER environment variable | 
|---|
| 293 | contains or to "anonymous" if USER is not set). Please note that you must | 
|---|
| 294 | NOT set vendor to "netlabs.org" when creating your own builds of the Qt | 
|---|
| 295 | library because it will make it difficult to identify various distributions | 
|---|
| 296 | and track possible problems with the builds. | 
|---|
| 297 |  | 
|---|
| 298 |  | 
|---|
| 299 |  | 
|---|
| 300 | QMAKE CONFIG OPTIONS | 
|---|
| 301 |  | 
|---|
| 302 | The following CONFIG options of the qmake tool have a special meaning in OS/2: | 
|---|
| 303 |  | 
|---|
| 304 | windows           Turns on generation of PM (WINDOWAPI) executables. By | 
|---|
| 305 | default, this option is set for release builds that link | 
|---|
| 306 | to the Qt GUI library. | 
|---|
| 307 |  | 
|---|
| 308 | console           Turns on generation of text mode (WINDOWCOMPAT) executables. | 
|---|
| 309 | By default, this option is set when setting the "windows" | 
|---|
| 310 | option is not appropriate (see above). | 
|---|
| 311 |  | 
|---|
| 312 | In addition, qmake recognizes the following OS/2-specific CONFIG options: | 
|---|
| 313 |  | 
|---|
| 314 | map               Turns on generation of the .map files for executables and | 
|---|
| 315 | DLLs. This option is set by default. | 
|---|
| 316 |  | 
|---|
| 317 | exepack           Turns on compression for executables and DLLs. The option is | 
|---|
| 318 | turned on by default for release builds if configure.cmd | 
|---|
| 319 | finds a compression tool (LxLite) in PATH. | 
|---|
| 320 |  | 
|---|
| 321 | highmem           Turns on high memory usage for dynamically allocated memory | 
|---|
| 322 | in DLLs and executables. When this option is set, a special | 
|---|
| 323 | compiler flag (-Zhigh-mem for GCC) is used to enable high | 
|---|
| 324 | memory support in the C library (LIBC). This option is set | 
|---|
| 325 | by default so that all Qt DLLs and Qt applications built | 
|---|
| 326 | with qmake are enabled for high memory. Note that high | 
|---|
| 327 | memory support must be enabled for all LIBC-based DLLs | 
|---|
| 328 | linked to the executable as well as for the executable | 
|---|
| 329 | itself: high memory usage will be disabled if one of them | 
|---|
| 330 | votes against it. | 
|---|
| 331 |  | 
|---|
| 332 | export_all        Cause the linker to export all public symbols in a generated | 
|---|
| 333 | DLL. By default (when this option is absent), only the | 
|---|
| 334 | symbols marked with the __declspec(dllexport) compiler | 
|---|
| 335 | directive in the source files. | 
|---|
| 336 |  | 
|---|
| 337 |  | 
|---|
| 338 |  | 
|---|
| 339 | PRINTING SUPPORT | 
|---|
| 340 |  | 
|---|
| 341 | Starting with version 4.6.2, Qt for OS/2 supports printing through the CUPS | 
|---|
| 342 | framework (provided that this support is enabled when building Qt, see the | 
|---|
| 343 | respective sections in the beginning of this document). The OS/2 implementation | 
|---|
| 344 | of the CUPS framework is provided by the eCUPS package available at | 
|---|
| 345 | http://svn.netlabs.org/ecups/. | 
|---|
| 346 |  | 
|---|
| 347 | The Qt Runtime detects the presence of eCUPS in the system on the fly and talks | 
|---|
| 348 | to the CUPS daemon directly, bypassing the standard OS/2 printing subsystem. | 
|---|
| 349 | This means that in order to print from Qt applications, you don't need to create | 
|---|
| 350 | and configure printer objects using the standard OS/2 system printer setup | 
|---|
| 351 | procedure -- you only need to install eCUPS and configure your printers in | 
|---|
| 352 | there. Please refer to the eCUPS user manual to obtain the detailed instructions | 
|---|
| 353 | on how to configure CUPS printers. | 
|---|
| 354 |  | 
|---|
| 355 |  | 
|---|
| 356 |  | 
|---|
| 357 | ENVIRONMENT VARIABLES | 
|---|
| 358 |  | 
|---|
| 359 | The Qt library recognizes a number of OS/2-specific environment variables that | 
|---|
| 360 | affect its functionality at runtime. The table below lists these variables and | 
|---|
| 361 | their meaning: | 
|---|
| 362 |  | 
|---|
| 363 | QT_PM_NO_DIVE             If set, Qt will not use DIVE (direct interface video | 
|---|
| 364 | extensions) for painting widgets even if DIVE (which | 
|---|
| 365 | provides a much faster painting speed than the | 
|---|
| 366 | regular GPI approach) is available. Currently, this | 
|---|
| 367 | is the default setting if the Panorama video driver | 
|---|
| 368 | is detected because its DIVE implementation contains | 
|---|
| 369 | a number of bugs. | 
|---|
| 370 |  | 
|---|
| 371 | QT_PM_DIVE=<mode>         Enables using DIVE for painting widgets. <mode> is | 
|---|
| 372 | one of: | 
|---|
| 373 |  | 
|---|
| 374 | - FB (direct framebuffer access, which is the | 
|---|
| 375 | fastest mode but causes the curruption of the | 
|---|
| 376 | screen under the software mouse pointer due to | 
|---|
| 377 | the limitation of DIVE). If this mode is not | 
|---|
| 378 | available, BLIT will be used (see below). | 
|---|
| 379 |  | 
|---|
| 380 | - FBSWM (the same FB but hides the mouse pointer | 
|---|
| 381 | before painting which introduces mouse flicker | 
|---|
| 382 | and may be a bit slower than the raw FB). | 
|---|
| 383 |  | 
|---|
| 384 | - BLIT (slower than both FB and FBSWM but prevents | 
|---|
| 385 | screen corruption under the mouse pointer and | 
|---|
| 386 | does not produce a mouse pointer flicker | 
|---|
| 387 | effect). | 
|---|
| 388 |  | 
|---|
| 389 | This variable is ignored if QT_PM_NO_DIVE is set. If | 
|---|
| 390 | neither this nor the QT_PM_NO_DIVE variable is set, | 
|---|
| 391 | the FBSWM mode is used by default (unless the | 
|---|
| 392 | current video driver is Panorama, see above). | 
|---|
| 393 |  | 
|---|
| 394 | QT_PM_NO_SOUND_SHARE      If set, Qt will open the audio device in exclusive | 
|---|
| 395 | only one sound may be played on the computer at a | 
|---|
| 396 | time. This mode is recommended for some sound cards | 
|---|
| 397 | when using the Uniaud audio driver as it is known to | 
|---|
| 398 | have problems with simultaneous playback. In current | 
|---|
| 399 | Qt builds, this is the default behavior if neither | 
|---|
| 400 | this nor the QT_PM_SOUND_SHARE variable is set. | 
|---|
| 401 |  | 
|---|
| 402 | QT_PM_SOUND_SHARE         The opposite to the above. If set, Qt will open the | 
|---|
| 403 | audio device in shared mode. This variable is | 
|---|
| 404 | ignored if QT_PM_NO_SOUND_SHARE is set. | 
|---|
| 405 |  | 
|---|
| 406 | QT_PM_NO_REGISTRY         If set, Qt will not use the Open32 registry to store | 
|---|
| 407 | application settings with QSettings. Instead, plain | 
|---|
| 408 | text INI files will be used for both NativeFormat | 
|---|
| 409 | and IniFormat. Due to a number of problems in the | 
|---|
| 410 | Open32 registry implementation (that may easily lead | 
|---|
| 411 | to registry corruption), this is the default | 
|---|
| 412 | behavior if neither this nor the QT_PM_REGISTRY | 
|---|
| 413 | variable is set. | 
|---|
| 414 |  | 
|---|
| 415 | QT_PM_REGISTRY            The opposite to the above. If set, Qt will use the | 
|---|
| 416 | Open32 registry to store application settings. This | 
|---|
| 417 | variable is ignored if QT_PM_NO_REGISTRY is set. | 
|---|
| 418 |  | 
|---|
| 419 | QT_PM_NO_SYSTEM_LOCALE    If set, Qt will ignore the regional settings from | 
|---|
| 420 | the system locale object found in the Country | 
|---|
| 421 | Palette located in the System Setup folder and will | 
|---|
| 422 | take them from the internal Qt locale database | 
|---|
| 423 | according to the current country and language | 
|---|
| 424 | settings. Due to the fact that this internal Qt | 
|---|
| 425 | database usually has a better representation of the | 
|---|
| 426 | regional settings, this is the default behavior if | 
|---|
| 427 | neither this nor the QT_PM_SYSTEM_LOCALE variable is | 
|---|
| 428 | set. | 
|---|
| 429 |  | 
|---|
| 430 | QT_PM_SYSTEM_LOCALE       The opposite to the above. If set, Qt will use the | 
|---|
| 431 | regional settings as found in the default locale | 
|---|
| 432 | object set the Country Palette.  This variable is | 
|---|
| 433 | ignored if QT_PM_NO_SYSTEM_LOCALE is set. | 
|---|
| 434 |  | 
|---|
| 435 | LANG                      This variable can be used to override the default | 
|---|
| 436 | country and language used in the Qt application both | 
|---|
| 437 | for regional settings and for translations. The | 
|---|
| 438 | format of the value is "ll_CC" where <ll> is the | 
|---|
| 439 | two-letter ISO language code and <CC> is the two- | 
|---|
| 440 | letter ISO country code. Note that if this variable | 
|---|
| 441 | is not set, Qt will derive the language and country | 
|---|
| 442 | from the system country code specified in the | 
|---|
| 443 | COUNTRY statement of CONFIG.SYS. | 
|---|
| 444 |  | 
|---|
| 445 |  | 
|---|
| 446 |  | 
|---|
| 447 | COMMAND LINE OPTIONS | 
|---|
| 448 |  | 
|---|
| 449 | Any Qt executable recognizes a number of command line options that may change | 
|---|
| 450 | the behavior of the Qt application. Here are the most interesting ones: | 
|---|
| 451 |  | 
|---|
| 452 | -style <name>             Changes the default Qt widget style (theme) to a | 
|---|
| 453 | style with the given name. The buiil-in styles which | 
|---|
| 454 | are always available in the official build include: | 
|---|
| 455 | "windows" (currently, the default on OS/2), "motif", | 
|---|
| 456 | "cde", "plastique" and "cleanlooks". Other styles | 
|---|
| 457 | may be also provided by the style plugins. | 
|---|
| 458 |  | 
|---|
| 459 | -graphicssystem <name>    Changes the graphics system used to paint widgets. | 
|---|
| 460 | On OS/2, only two values are supported: "native" | 
|---|
| 461 | (the default one) and "raster". The "native" system | 
|---|
| 462 | uses DIVE (direct interface video extensions) when | 
|---|
| 463 | it is available. If DIVE is not available or if it | 
|---|
| 464 | is disabled (see the QT_PM_NO_DIVE environment | 
|---|
| 465 | variable description for details), the "raster" | 
|---|
| 466 | system will be automatically selected as a fallback. | 
|---|
| 467 |  | 
|---|
| 468 |  | 
|---|
| 469 |  | 
|---|
| 470 | CURRENT LIMITATIONS | 
|---|
| 471 |  | 
|---|
| 472 | 1. configure.cmd is does not build demos and examples by default (to save | 
|---|
| 473 | time). They may be built by hand, as described above. | 
|---|
| 474 |  | 
|---|
| 475 | 2. configure.cmd does not understand any command line options yet. If you want | 
|---|
| 476 | to customize your build of the Qt library (which is normally not | 
|---|
| 477 | recommended and not supported), you may try to modify configure.cmd itself. | 
|---|
| 478 |  | 
|---|
| 479 | 3. OS/2 bitmap fonts are not supported. Use TTF or Type1 (PFB) fonts with Qt. | 
|---|
| 480 |  | 
|---|
| 481 | 4. No native PM style, but Qt will use fonts and colors from the current | 
|---|
| 482 | OS/2 theme. Hint: if your default OS/2 font is "WarpSans", install the | 
|---|
| 483 | "Workplace Sans" TTF font from Alex Taylor to get more native look & feel. | 
|---|
| 484 | It is recommended to install version 0.7 of the Normal face and version 0.3 | 
|---|
| 485 | of the Bold face which you can find here: | 
|---|
| 486 |  | 
|---|
| 487 | http://users.socis.ca/~ataylo00/creative/fonts/workplace/ | 
|---|
| 488 |  | 
|---|
| 489 | 5. QProcess: when starting PM applications from text-mode applications, the | 
|---|
| 490 | returned PID is a PID of the intermediate cmd.exe process, not the target | 
|---|
| 491 | application. | 
|---|
| 492 |  | 
|---|
| 493 | 6. The following classes are not available due to their rare usage or low | 
|---|
| 494 | importance on the OS/2 platform: QSharedMemory, QSystemSemaphore, | 
|---|
| 495 | QInputContext. On the source level, a number of macros is defined to | 
|---|
| 496 | reflect this, respectively: QT_NO_SYSTEMSEMAPHORE, QT_NO_SHAREDMEMORY, | 
|---|
| 497 | QT_NO_IM. Normally, Qt applications use these macros in the form of | 
|---|
| 498 | "#fndef QT_NO_SOMEFEATURE" to isolate the relevant parts of the code that | 
|---|
| 499 | uses these classes so that the application still builds when the | 
|---|
| 500 | corresponding feature is missing. | 
|---|
| 501 |  | 
|---|
| 502 | 7. No qt3support module. This functionality is rarely necessary in mature | 
|---|
| 503 | real life Qt applications and has low priority. In the code, it is | 
|---|
| 504 | reflected by the absense of the QT3_SUPPORT macro. | 
|---|
| 505 |  | 
|---|
| 506 | 8. The following features are missing (either because of the lack of the | 
|---|
| 507 | required support from the system side or because of the rare usage): | 
|---|
| 508 |  | 
|---|
| 509 | - IPV6 support in the network module (QT_NO_IPV6 is defined). | 
|---|
| 510 | - OpenSSL support in the network module (QT_NO_OPENSSL is defined). | 
|---|
| 511 | - phonon module (QT_NO_PHONON is defined). | 
|---|
| 512 | - multimedia module (QT_NO_MULTIMEDIA is defined). | 
|---|
| 513 | - OpenGL module (QT_NO_OPENGL is defined). | 
|---|
| 514 | - declarative module (QT_NO_DECLARATIVE is defined). | 
|---|
| 515 | - tablet support (QT_NO_TABLET is defined). | 
|---|
| 516 |  | 
|---|
| 517 | See the project roadmap for more information on the current progress and | 
|---|
| 518 | future plans: | 
|---|
| 519 |  | 
|---|
| 520 | http://svn.netlabs.org/qt4/roadmap | 
|---|
| 521 |  | 
|---|
| 522 | Feel free to request new features and report bugs using the project bug | 
|---|
| 523 | tracker abaialble at: | 
|---|
| 524 |  | 
|---|
| 525 | http://svn.netlabs.org/qt4/report | 
|---|
| 526 |  | 
|---|
| 527 |  | 
|---|
| 528 |  | 
|---|
| 529 | CREDITS | 
|---|
| 530 |  | 
|---|
| 531 | Dmitry A. Kuminov (development) | 
|---|
| 532 | Silvan Scherrer (management) | 
|---|
| 533 |  | 
|---|
| 534 | netlabs.org (hosting & support) | 
|---|
| 535 |  | 
|---|
| 536 | Nokia Corporation (original Qt library) | 
|---|
| 537 |  | 
|---|
| 538 | We also want to THANK all individuals and organizations who made the donations | 
|---|
| 539 | to this project and helped to make it happen. Please visit | 
|---|
| 540 |  | 
|---|
| 541 | http://qt.netlabs.org/en/site/index.xml | 
|---|
| 542 |  | 
|---|
| 543 | to get the full list of sponsors and to find information on how you can support | 
|---|
| 544 | the project. | 
|---|
| 545 |  | 
|---|
| 546 |  | 
|---|
| 547 | Qt is a trademark of Nokia Corporation and/or its subsidiary(-ies). | 
|---|
| 548 | OS/2 and OS/2 Warp are trademarks of the IBM Corporation and/or its subsidiary(-ies). | 
|---|
| 549 | eComStation is a trademark of Serenity Systems International and/or its subsidiary(-ies). | 
|---|
| 550 | Etc. | 
|---|