1 2 Welcome! 3 ======== 4 5 This is the OS/2 port of GNU gettext internationalization library. 6 7 8 Compatibility 9 ============= 10 11 The library has been compiled with -Zmt flag, but it doesn't matter as soon 12 as you use the EMX single-threaded runtime fix (emx-strt-fix-0.0.2.zip). 13 14 The library is fully compatible with the previous port of gettext library 15 (0.10.35) which is largely used especialy by XFree86/2 programs. All the 16 old programs that I have with gettext support run fine with the new version 17 of the DLL. 18 19 20 Installation 21 ============ 22 23 If you set the GNULOCALEDIR environment variable to point to your 24 x:/xxx/share/locale directory, it will override any other setting. That is, 25 unpack the binary distribution over /emx, set GNULOCALEDIR=x:/emx/share/locale 26 (where x: is the drive letter of your EMX installation) and that's all. 27 28 If you use the UNIXROOT environment variable, the default catalogue search 29 paths will be like on Unices, e.g. $(UNIXROOT)/usr/lib and 30 $(UNIXROOT)/usr/share/locale. GNULOCALEDIR always overrides this. 31 32 Now if you haven't did it earlier, set the language identifier that you use. 33 This is done by adding a "SET LANG=xxx" environment setting to your CONFIG.SYS, 34 where xxx is the identifier of your language (example: en_UK for English in UK, 35 ru_RU for Russian in Russia. Also you can use names like "russian", "italian" 36 and so on - see the share/locale/locale.alias file). 37 38 This port of gettext supports character set conversions. This means that if 39 your .mo files were written using new gettext guidelines, e.g. they contain a 40 message like this: 41 42 msgid "" 43 msgstr "Content-Type: text/plain; charset=koi8-r\n" 44 45 the messages will be properly converted to your active codepage using OS/2 46 Unicode API. For example, russian message catalog gettext.mo is in the 47 KOI8-R (codepage 878) encoding while OS/2 uses codepage 866. Now when you 48 run any of these tools it detects that the active OS/2 codepage is 866 and 49 performs the translation from CP878 -> CP866 for every message. 50 51 If you want to override the character set used to output messages (for example 52 in XFree86 for Russian the KOI8-R encoding (codepage 878) is used) you can 53 set the output character set by adding a postfix to the LANG environment 54 variable, this way: 55 56 set LANG=ru_RU.KOI8-R 57 58 or (equivalent): 59 60 set LANG=ru_RU.CP878 61 62 or (same effect): 63 64 set LANG=ru_RU.IBM-878 65 66 If the output character set is ommited from the LANG variable, the default 67 codepage is ALWAYS taken from the operating system (e.g. the codepage setting 68 from locale.alias is always ignored, so "russian" stays just for "ru_RU" and 69 not for "ru_RU.ISO-8859-5"); you may want to set it just if you want to 70 override the active OS/2 codepage. 71 72 73 XFree86 setup 74 ============= 75 76 If you use XFree86 and the OS/2 default character set is different from the 77 XFree86 default character set (e.g. for Russain CP866 vs KOI8-R), you can add 78 the following (or similar) statement to your startx.cmd file (after the 79 commands dealing with HOME and X11SHELL): 80 81 call VALUE 'LANG', 'ru_RU.KOI8-R', env 82 83 Otherwise you can get incorrect (wrong codepage) output from programs that 84 previously worked (e.g. GIMP 1.22). This is because earlier versions of gettext 85 didn't support character set translations. 86 87 88 Implementation remarks 89 ====================== 90 91 The codepage conversion code uses OS/2 Unicode API, thus it falls under the 92 limits that OS/2 Unicode API has. For example, OS/2 Unicode API does not 93 support the BIG5 East Asian character set nor ISO-8859-X where X > 9 (at 94 least with Warp4 with fixpack 14 that I have). If someone knows the 95 OS/2 API identifiers for BIG5 or ISO8859-10,... encodings, please tell me! 96 97 Since gettext 0.11 iconv emulation layer supports correctly UTF-8. Also 98 I have added theoretical support for the following East Asian encodings: 99 EUC-JP, EUC-KR, EUC-TW, EUC-CN. However, these encodings are (I believe) 100 supported only on East Asian editions of OS/2. The code pages for them are 101 listed in the \language\codepage\ucstbl.lst file but the codepage files 102 themselves are missing; I believe they are ommited from European OS/2's 103 due to their large size. 104 105 Also I have added "support" for the BIG5 codeset as an alias for IBM-950 106 codepage. However, I'm not very sure about this; in any case OS/2 does not 107 support (as far as I know) anything closer to BIG5. 108 109 110 Additional API 111 ============== 112 113 This package provides additionaly the iconv() API that can be used by 114 developers for doing more feature-full Unix ports. The iconv() API is used 115 to convert text between various codepages. The intl.h header file contains 116 the prototypes and definitions needed for iconv(); if you configure software 117 with autoconf it possibly will find intl.h and set up the software accordingly. 118 119 All these functions are exported from INTL.DLL. The iconv.a import library 120 imports all the iconv* functions from INTL.DLL. So, like on Unix, now you can 121 #include <iconv.h>, then link with -liconv and you will get a fully functional 122 iconv implementation. 123 124 125 Rebuilding the library 126 ====================== 127 128 The library is quite easy to rebuild. Since the OS/2 support is provided now 129 out-of-the-box in gettext, you just have to download and unpack the source 130 archive. Now there are two ways to rebuild the gettext library: 131 132 1. If you're a masochist you can go the clumsy configure/make Unix way. This 133 is not recommended however as I found no way to tell libtool to generate a 134 slightly non-standard DLL which will be backward compatible with gettext 135 0.10.35. The compatibility is achieved by prepending backward.def to the 136 export definition file generated with emximp or somehow else. Thus it is 137 highly recommended you build using the second way, if it is possible. 138 139 2. Go to os2 and just run `make'. If you have all the required tools, 140 it should painlessly compile. Finally, if you want a binary distribution 141 archive, do `make distr'. The weak side of building this way is that makefile 142 is somewhat fragile. This means that if the makefile is left unmodified and 143 a new version of gettext is rolled out, it *may* not work. But every possible 144 attempt was made to ensure that the makefile takes most important build 145 parameters from their autoconf counterparts. 146 147 WARNING: Due to bugs in GNU Make 3.76.1 (at least in its OS/2 port) you can 148 get sometimes (depending on make version and makefile modification :) funny 149 messages like these: 150 151 zip warning: name not matched: emx/src/gettext-0.10.40/support/os2/iconv.h 152 153 or even: 154 155 *** No rule to make target `out/release/intl.a', needed by `all'. Stop. 156 157 Such messages are a bad joke. Ignore it, and re-run make. This is a 158 long-standing bug in GNU make, alas. 159 160 If you want a debug version of library, you can do `make DEBUG=1'. 161 162 If you don't have the LxLite tool installed, do `make LXLITE=0' 163 164 NB: For best results, it is highly recommended that you use at least emxbind.exe 165 and ld.exe from gcc 3.0.2 or later, since they contain a number of fixes that 166 will help you generate a more optimal DLL. 167 168 169 Contributors 170 ============ 171 172 Hung-Chi Chu <hcchu (a] r350.ee.ntu.edu.tw> 173 the original port of gettext (0.10.35) 174 175 Jun SAWATAISHI <jsawa (a] attglobal.net> 176 some more work on it and submitted the patches to GNU team, although 177 they were not completely integrated. 178 179 Andrew Zabolotny <zap (a] cobra.ru> 180 Succeeded to remove almost all OS/2-specific #ifdef's from mainstream 181 source code, wrote the dedicated OS/2 makefile, wrote the iconv wrapper 182 around OS/2 Unicode API, added support for locale translations. 183