check if safe_mode is enabled (putenv is not allowed then) and
[squirrelmail.git] / functions / i18n.php
1 <?php
2
3 /**
4 ** i18n.php
5 **
6 ** This file contains variuos functions that are needed to do
7 ** internationalization of SquirrelMail.
8 **
9 ** Internally the output character set is used. Other characters are
10 ** encoded using Unicode entities according to HTML 4.0.
11 **
12 ** $Id$
13 **/
14
15 $i18n_php = true;
16
17 // This array specifies the available languages.
18 $languages["en"]["NAME"] = "English";
19 $languages["en"]["CHARSET"] = "iso-8859-1";
20
21 $languages["ca"]["NAME"] = "Catalan";
22 $languages["ca"]["CHARSET"] = "iso-8859-1";
23
24 $languages["cs_CZ"]["NAME"] = "Czech";
25 $languages["cs_CZ"]["CHARSET"] = "iso-8859-2";
26
27 $languages["da"]["NAME"] = "Danish";
28 $languages["da"]["CHARSET"] = "iso-8859-1";
29
30 $languages["de"]["NAME"] = "Deutsch";
31 $languages["de"]["CHARSET"] = "iso-8859-1";
32
33 $languages["nl"]["NAME"] = "Dutch";
34 $languages["nl"]["CHARSET"] = "iso-8859-1";
35
36 $languages["fr"]["NAME"] = "French";
37 $languages["fr"]["CHARSET"] = "iso-8859-1";
38
39 $languages["fi"]["NAME"] = "Finnish";
40 $languages["fi"]["CHARSET"] = "iso-8859-1";
41
42 $languages["it"]["NAME"] = "Italian";
43 $languages["it"]["CHARSET"] = "iso-8859-1";
44
45 $languages["ko"]["NAME"] = "Korean";
46 $languages["ko"]["CHARSET"] = "euc-KR";
47
48 $languages["no"]["NAME"] = "Norwegian (Bokm&aring;l)";
49 $languages["no"]["CHARSET"] = "iso-8859-1";
50
51 $languages["no_NO_ny"]["NAME"] = "Norwegian (Nynorsk)";
52 $languages["no_NO_ny"]["CHARSET"] = "iso-8859-1";
53
54 $languages["pl"]["NAME"] = "Polish";
55 $languages["pl"]["CHARSET"] = "iso-8859-2";
56
57 $languages["pt_BR"]["NAME"] = "Portuguese (Brazil)";
58 $languages["pt_BR"]["CHARSET"] = "iso-8859-1";
59
60 $languages["ru"]["NAME"] = "Russian KOI8-R";
61 $languages["ru"]["CHARSET"] = "koi8-r";
62
63 $languages["sr"]["NAME"] = "Serbian";
64 $languages["sr"]["CHARSET"] = "iso-8859-2";
65
66 $languages["es"]["NAME"] = "Spanish";
67 $languages["es"]["CHARSET"] = "iso-8859-1";
68
69 $languages["sv"]["NAME"] = "Swedish";
70 $languages["sv"]["CHARSET"] = "iso-8859-1";
71
72 $languages["tw"]["NAME"] = "Taiwan";
73 $languages["tw"]["CHARSET"] = "big5";
74
75
76 // Decodes a string to the internal encoding from the given charset
77 function charset_decode ($charset, $string) {
78 global $debug_mime;
79
80 // All HTML special characters are 7 bit and can be replaced first
81 $string = htmlspecialchars ($string);
82
83 $charset = strtolower($charset);
84
85 if ($debug_mime) $string = $charset.":".$string;
86
87 if (ereg("iso-8859-([[:digit:]]+)", $charset, $res)) {
88 if ($res[1] == "1")
89 return charset_decode_iso_8859_1 ($string);
90 else if ($res[1] == "2")
91 return charset_decode_iso_8859_2 ($string);
92 else if ($res[1] == "7")
93 return charset_decode_iso_8859_7 ($string);
94 else if ($res[1] == "15")
95 return charset_decode_iso_8859_15 ($string);
96 else
97 return charset_decode_iso_8859_default ($string);
98 } else if ($charset == "ns_4551-1") {
99 return charset_decode_ns_4551_1 ($string);
100 } else if ($charset == "koi8-r") {
101 return charset_decode_koi8r ($string);
102 } else
103 return "$string";
104 }
105
106 // iso-8859-1 is the same as Latin 1 and is normally used
107 // in western europe.
108 function charset_decode_iso_8859_1 ($string) {
109 global $default_charset;
110
111 if (strtolower($default_charset) == "iso-8859-1") {
112 return $string;
113 } else {
114 // Only do the slow convert if there are 8-bit characters
115 if (ereg("[\200-\377]", $string)) {
116 $string = str_replace("\201", "&#129;", $string);
117 $string = str_replace("\202", "&#130;", $string);
118 $string = str_replace("\203", "&#131;", $string);
119 $string = str_replace("\204", "&#132;", $string);
120 $string = str_replace("\205", "&#133;", $string);
121 $string = str_replace("\206", "&#134;", $string);
122 $string = str_replace("\207", "&#135;", $string);
123 $string = str_replace("\210", "&#136;", $string);
124 $string = str_replace("\211", "&#137;", $string);
125 $string = str_replace("\212", "&#138;", $string);
126 $string = str_replace("\213", "&#139;", $string);
127 $string = str_replace("\214", "&#140;", $string);
128 $string = str_replace("\215", "&#141;", $string);
129 $string = str_replace("\216", "&#142;", $string);
130 $string = str_replace("\217", "&#143;", $string);
131 $string = str_replace("\220", "&#144;", $string);
132 $string = str_replace("\221", "&#145;", $string);
133 $string = str_replace("\222", "&#146;", $string);
134 $string = str_replace("\223", "&#147;", $string);
135 $string = str_replace("\224", "&#148;", $string);
136 $string = str_replace("\225", "&#149;", $string);
137 $string = str_replace("\226", "&#150;", $string);
138 $string = str_replace("\227", "&#151;", $string);
139 $string = str_replace("\230", "&#152;", $string);
140 $string = str_replace("\231", "&#153;", $string);
141 $string = str_replace("\232", "&#154;", $string);
142 $string = str_replace("\233", "&#155;", $string);
143 $string = str_replace("\234", "&#156;", $string);
144 $string = str_replace("\235", "&#157;", $string);
145 $string = str_replace("\236", "&#158;", $string);
146 $string = str_replace("\237", "&#159;", $string);
147 $string = str_replace("\240", "&#160;", $string);
148 $string = str_replace("\241", "&#161;", $string);
149 $string = str_replace("\242", "&#162;", $string);
150 $string = str_replace("\243", "&#163;", $string);
151 $string = str_replace("\244", "&#164;", $string);
152 $string = str_replace("\245", "&#165;", $string);
153 $string = str_replace("\246", "&#166;", $string);
154 $string = str_replace("\247", "&#167;", $string);
155 $string = str_replace("\250", "&#168;", $string);
156 $string = str_replace("\251", "&#169;", $string);
157 $string = str_replace("\252", "&#170;", $string);
158 $string = str_replace("\253", "&#171;", $string);
159 $string = str_replace("\254", "&#172;", $string);
160 $string = str_replace("\255", "&#173;", $string);
161 $string = str_replace("\256", "&#174;", $string);
162 $string = str_replace("\257", "&#175;", $string);
163 $string = str_replace("\260", "&#176;", $string);
164 $string = str_replace("\261", "&#177;", $string);
165 $string = str_replace("\262", "&#178;", $string);
166 $string = str_replace("\263", "&#179;", $string);
167 $string = str_replace("\264", "&#180;", $string);
168 $string = str_replace("\265", "&#181;", $string);
169 $string = str_replace("\266", "&#182;", $string);
170 $string = str_replace("\267", "&#183;", $string);
171 $string = str_replace("\270", "&#184;", $string);
172 $string = str_replace("\271", "&#185;", $string);
173 $string = str_replace("\272", "&#186;", $string);
174 $string = str_replace("\273", "&#187;", $string);
175 $string = str_replace("\274", "&#188;", $string);
176 $string = str_replace("\275", "&#189;", $string);
177 $string = str_replace("\276", "&#190;", $string);
178 $string = str_replace("\277", "&#191;", $string);
179 $string = str_replace("\300", "&#192;", $string);
180 $string = str_replace("\301", "&#193;", $string);
181 $string = str_replace("\302", "&#194;", $string);
182 $string = str_replace("\303", "&#195;", $string);
183 $string = str_replace("\304", "&#196;", $string);
184 $string = str_replace("\305", "&#197;", $string);
185 $string = str_replace("\306", "&#198;", $string);
186 $string = str_replace("\307", "&#199;", $string);
187 $string = str_replace("\310", "&#200;", $string);
188 $string = str_replace("\311", "&#201;", $string);
189 $string = str_replace("\312", "&#202;", $string);
190 $string = str_replace("\313", "&#203;", $string);
191 $string = str_replace("\314", "&#204;", $string);
192 $string = str_replace("\315", "&#205;", $string);
193 $string = str_replace("\316", "&#206;", $string);
194 $string = str_replace("\317", "&#207;", $string);
195 $string = str_replace("\320", "&#208;", $string);
196 $string = str_replace("\321", "&#209;", $string);
197 $string = str_replace("\322", "&#210;", $string);
198 $string = str_replace("\323", "&#211;", $string);
199 $string = str_replace("\324", "&#212;", $string);
200 $string = str_replace("\325", "&#213;", $string);
201 $string = str_replace("\326", "&#214;", $string);
202 $string = str_replace("\327", "&#215;", $string);
203 $string = str_replace("\330", "&#216;", $string);
204 $string = str_replace("\331", "&#217;", $string);
205 $string = str_replace("\332", "&#218;", $string);
206 $string = str_replace("\333", "&#219;", $string);
207 $string = str_replace("\334", "&#220;", $string);
208 $string = str_replace("\335", "&#221;", $string);
209 $string = str_replace("\336", "&#222;", $string);
210 $string = str_replace("\337", "&#223;", $string);
211 $string = str_replace("\340", "&#224;", $string);
212 $string = str_replace("\341", "&#225;", $string);
213 $string = str_replace("\342", "&#226;", $string);
214 $string = str_replace("\343", "&#227;", $string);
215 $string = str_replace("\344", "&#228;", $string);
216 $string = str_replace("\345", "&#229;", $string);
217 $string = str_replace("\346", "&#230;", $string);
218 $string = str_replace("\347", "&#231;", $string);
219 $string = str_replace("\350", "&#232;", $string);
220 $string = str_replace("\351", "&#233;", $string);
221 $string = str_replace("\352", "&#234;", $string);
222 $string = str_replace("\353", "&#235;", $string);
223 $string = str_replace("\354", "&#236;", $string);
224 $string = str_replace("\355", "&#237;", $string);
225 $string = str_replace("\356", "&#238;", $string);
226 $string = str_replace("\357", "&#239;", $string);
227 $string = str_replace("\360", "&#240;", $string);
228 $string = str_replace("\361", "&#241;", $string);
229 $string = str_replace("\362", "&#242;", $string);
230 $string = str_replace("\363", "&#243;", $string);
231 $string = str_replace("\364", "&#244;", $string);
232 $string = str_replace("\365", "&#245;", $string);
233 $string = str_replace("\366", "&#246;", $string);
234 $string = str_replace("\367", "&#247;", $string);
235 $string = str_replace("\370", "&#248;", $string);
236 $string = str_replace("\371", "&#249;", $string);
237 $string = str_replace("\372", "&#250;", $string);
238 $string = str_replace("\373", "&#251;", $string);
239 $string = str_replace("\374", "&#252;", $string);
240 $string = str_replace("\375", "&#253;", $string);
241 $string = str_replace("\376", "&#254;", $string);
242 $string = str_replace("\377", "&#255;", $string);
243 }
244 }
245
246 return ($string);
247 }
248
249 // iso-8859-2 is used for some eastern European languages
250 function charset_decode_iso_8859_2 ($string) {
251 global $default_charset;
252
253 if (strtolower($default_charset) == "iso-8859-2") {
254 return $string;
255 } else {
256 // Only do the slow convert if there are 8-bit characters
257 if (ereg("[\200-\377]", $string)) {
258 // NO-BREAK SPACE
259 $string = str_replace("\240", "&#160;", $string);
260 // LATIN CAPITAL LETTER A WITH OGONEK
261 $string = str_replace("\241", "&#260;", $string);
262 // BREVE
263 $string = str_replace("\242", "&#728;", $string);
264 // LATIN CAPITAL LETTER L WITH STROKE
265 $string = str_replace("\243", "&#321;", $string);
266 // CURRENCY SIGN
267 $string = str_replace("\244", "&#164;", $string);
268 // LATIN CAPITAL LETTER L WITH CARON
269 $string = str_replace("\245", "&#317;", $string);
270 // LATIN CAPITAL LETTER S WITH ACUTE
271 $string = str_replace("\246", "&#346;", $string);
272 // SECTION SIGN
273 $string = str_replace("\247", "&#167;", $string);
274 // DIAERESIS
275 $string = str_replace("\250", "&#168;", $string);
276 // LATIN CAPITAL LETTER S WITH CARON
277 $string = str_replace("\251", "&#352;", $string);
278 // LATIN CAPITAL LETTER S WITH CEDILLA
279 $string = str_replace("\252", "&#350;", $string);
280 // LATIN CAPITAL LETTER T WITH CARON
281 $string = str_replace("\253", "&#356;", $string);
282 // LATIN CAPITAL LETTER Z WITH ACUTE
283 $string = str_replace("\254", "&#377;", $string);
284 // SOFT HYPHEN
285 $string = str_replace("\255", "&#173;", $string);
286 // LATIN CAPITAL LETTER Z WITH CARON
287 $string = str_replace("\256", "&#381;", $string);
288 // LATIN CAPITAL LETTER Z WITH DOT ABOVE
289 $string = str_replace("\257", "&#379;", $string);
290 // DEGREE SIGN
291 $string = str_replace("\260", "&#176;", $string);
292 // LATIN SMALL LETTER A WITH OGONEK
293 $string = str_replace("\261", "&#261;", $string);
294 // OGONEK
295 $string = str_replace("\262", "&#731;", $string);
296 // LATIN SMALL LETTER L WITH STROKE
297 $string = str_replace("\263", "&#322;", $string);
298 // ACUTE ACCENT
299 $string = str_replace("\264", "&#180;", $string);
300 // LATIN SMALL LETTER L WITH CARON
301 $string = str_replace("\265", "&#318;", $string);
302 // LATIN SMALL LETTER S WITH ACUTE
303 $string = str_replace("\266", "&#347;", $string);
304 // CARON
305 $string = str_replace("\267", "&#711;", $string);
306 // CEDILLA
307 $string = str_replace("\270", "&#184;", $string);
308 // LATIN SMALL LETTER S WITH CARON
309 $string = str_replace("\271", "&#353;", $string);
310 // LATIN SMALL LETTER S WITH CEDILLA
311 $string = str_replace("\272", "&#351;", $string);
312 // LATIN SMALL LETTER T WITH CARON
313 $string = str_replace("\273", "&#357;", $string);
314 // LATIN SMALL LETTER Z WITH ACUTE
315 $string = str_replace("\274", "&#378;", $string);
316 // DOUBLE ACUTE ACCENT
317 $string = str_replace("\275", "&#733;", $string);
318 // LATIN SMALL LETTER Z WITH CARON
319 $string = str_replace("\276", "&#382;", $string);
320 // LATIN SMALL LETTER Z WITH DOT ABOVE
321 $string = str_replace("\277", "&#380;", $string);
322 // LATIN CAPITAL LETTER R WITH ACUTE
323 $string = str_replace("\300", "&#340;", $string);
324 // LATIN CAPITAL LETTER A WITH ACUTE
325 $string = str_replace("\301", "&#193;", $string);
326 // LATIN CAPITAL LETTER A WITH CIRCUMFLEX
327 $string = str_replace("\302", "&#194;", $string);
328 // LATIN CAPITAL LETTER A WITH BREVE
329 $string = str_replace("\303", "&#258;", $string);
330 // LATIN CAPITAL LETTER A WITH DIAERESIS
331 $string = str_replace("\304", "&#196;", $string);
332 // LATIN CAPITAL LETTER L WITH ACUTE
333 $string = str_replace("\305", "&#313;", $string);
334 // LATIN CAPITAL LETTER C WITH ACUTE
335 $string = str_replace("\306", "&#262;", $string);
336 // LATIN CAPITAL LETTER C WITH CEDILLA
337 $string = str_replace("\307", "&#199;", $string);
338 // LATIN CAPITAL LETTER C WITH CARON
339 $string = str_replace("\310", "&#268;", $string);
340 // LATIN CAPITAL LETTER E WITH ACUTE
341 $string = str_replace("\311", "&#201;", $string);
342 // LATIN CAPITAL LETTER E WITH OGONEK
343 $string = str_replace("\312", "&#280;", $string);
344 // LATIN CAPITAL LETTER E WITH DIAERESIS
345 $string = str_replace("\313", "&#203;", $string);
346 // LATIN CAPITAL LETTER E WITH CARON
347 $string = str_replace("\314", "&#282;", $string);
348 // LATIN CAPITAL LETTER I WITH ACUTE
349 $string = str_replace("\315", "&#205;", $string);
350 // LATIN CAPITAL LETTER I WITH CIRCUMFLEX
351 $string = str_replace("\316", "&#206;", $string);
352 // LATIN CAPITAL LETTER D WITH CARON
353 $string = str_replace("\317", "&#270;", $string);
354 // LATIN CAPITAL LETTER D WITH STROKE
355 $string = str_replace("\320", "&#272;", $string);
356 // LATIN CAPITAL LETTER N WITH ACUTE
357 $string = str_replace("\321", "&#323;", $string);
358 // LATIN CAPITAL LETTER N WITH CARON
359 $string = str_replace("\322", "&#327;", $string);
360 // LATIN CAPITAL LETTER O WITH ACUTE
361 $string = str_replace("\323", "&#211;", $string);
362 // LATIN CAPITAL LETTER O WITH CIRCUMFLEX
363 $string = str_replace("\324", "&#212;", $string);
364 // LATIN CAPITAL LETTER O WITH DOUBLE ACUTE
365 $string = str_replace("\325", "&#336;", $string);
366 // LATIN CAPITAL LETTER O WITH DIAERESIS
367 $string = str_replace("\326", "&#214;", $string);
368 // MULTIPLICATION SIGN
369 $string = str_replace("\327", "&#215;", $string);
370 // LATIN CAPITAL LETTER R WITH CARON
371 $string = str_replace("\330", "&#344;", $string);
372 // LATIN CAPITAL LETTER U WITH RING ABOVE
373 $string = str_replace("\331", "&#366;", $string);
374 // LATIN CAPITAL LETTER U WITH ACUTE
375 $string = str_replace("\332", "&#218;", $string);
376 // LATIN CAPITAL LETTER U WITH DOUBLE ACUTE
377 $string = str_replace("\333", "&#368;", $string);
378 // LATIN CAPITAL LETTER U WITH DIAERESIS
379 $string = str_replace("\334", "&#220;", $string);
380 // LATIN CAPITAL LETTER Y WITH ACUTE
381 $string = str_replace("\335", "&#221;", $string);
382 // LATIN CAPITAL LETTER T WITH CEDILLA
383 $string = str_replace("\336", "&#354;", $string);
384 // LATIN SMALL LETTER SHARP S
385 $string = str_replace("\337", "&#223;", $string);
386 // LATIN SMALL LETTER R WITH ACUTE
387 $string = str_replace("\340", "&#341;", $string);
388 // LATIN SMALL LETTER A WITH ACUTE
389 $string = str_replace("\341", "&#225;", $string);
390 // LATIN SMALL LETTER A WITH CIRCUMFLEX
391 $string = str_replace("\342", "&#226;", $string);
392 // LATIN SMALL LETTER A WITH BREVE
393 $string = str_replace("\343", "&#259;", $string);
394 // LATIN SMALL LETTER A WITH DIAERESIS
395 $string = str_replace("\344", "&#228;", $string);
396 // LATIN SMALL LETTER L WITH ACUTE
397 $string = str_replace("\345", "&#314;", $string);
398 // LATIN SMALL LETTER C WITH ACUTE
399 $string = str_replace("\346", "&#263;", $string);
400 // LATIN SMALL LETTER C WITH CEDILLA
401 $string = str_replace("\347", "&#231;", $string);
402 // LATIN SMALL LETTER C WITH CARON
403 $string = str_replace("\350", "&#269;", $string);
404 // LATIN SMALL LETTER E WITH ACUTE
405 $string = str_replace("\351", "&#233;", $string);
406 // LATIN SMALL LETTER E WITH OGONEK
407 $string = str_replace("\352", "&#281;", $string);
408 // LATIN SMALL LETTER E WITH DIAERESIS
409 $string = str_replace("\353", "&#235;", $string);
410 // LATIN SMALL LETTER E WITH CARON
411 $string = str_replace("\354", "&#283;", $string);
412 // LATIN SMALL LETTER I WITH ACUTE
413 $string = str_replace("\355", "&#237;", $string);
414 // LATIN SMALL LETTER I WITH CIRCUMFLEX
415 $string = str_replace("\356", "&#238;", $string);
416 // LATIN SMALL LETTER D WITH CARON
417 $string = str_replace("\357", "&#271;", $string);
418 // LATIN SMALL LETTER D WITH STROKE
419 $string = str_replace("\360", "&#273;", $string);
420 // LATIN SMALL LETTER N WITH ACUTE
421 $string = str_replace("\361", "&#324;", $string);
422 // LATIN SMALL LETTER N WITH CARON
423 $string = str_replace("\362", "&#328;", $string);
424 // LATIN SMALL LETTER O WITH ACUTE
425 $string = str_replace("\363", "&#243;", $string);
426 // LATIN SMALL LETTER O WITH CIRCUMFLEX
427 $string = str_replace("\364", "&#244;", $string);
428 // LATIN SMALL LETTER O WITH DOUBLE ACUTE
429 $string = str_replace("\365", "&#337;", $string);
430 // LATIN SMALL LETTER O WITH DIAERESIS
431 $string = str_replace("\366", "&#246;", $string);
432 // DIVISION SIGN
433 $string = str_replace("\367", "&#247;", $string);
434 // LATIN SMALL LETTER R WITH CARON
435 $string = str_replace("\370", "&#345;", $string);
436 // LATIN SMALL LETTER U WITH RING ABOVE
437 $string = str_replace("\371", "&#367;", $string);
438 // LATIN SMALL LETTER U WITH ACUTE
439 $string = str_replace("\372", "&#250;", $string);
440 // LATIN SMALL LETTER U WITH DOUBLE ACUTE
441 $string = str_replace("\373", "&#369;", $string);
442 // LATIN SMALL LETTER U WITH DIAERESIS
443 $string = str_replace("\374", "&#252;", $string);
444 // LATIN SMALL LETTER Y WITH ACUTE
445 $string = str_replace("\375", "&#253;", $string);
446 // LATIN SMALL LETTER T WITH CEDILLA
447 $string = str_replace("\376", "&#355;", $string);
448 // DOT ABOVE
449 $string = str_replace("\377", "&#729;", $string);
450 }
451 }
452 return $string;
453 }
454
455 // iso-8859-7 is Greek.
456 function charset_decode_iso_8859_7 ($string) {
457 global $default_charset;
458
459 if (strtolower($default_charset) == "iso-8859-7") {
460 return $string;
461 } else {
462 // Only do the slow convert if there are 8-bit characters
463 if (ereg("[\200-\377]", $string)) {
464 // Some diverse characters in the beginning
465 $string = str_replace("\240", "&#160;", $string);
466 $string = str_replace("\241", "&#8216;", $string);
467 $string = str_replace("\242", "&#8217;", $string);
468 $string = str_replace("\243", "&#163;", $string);
469 $string = str_replace("\246", "&#166;", $string);
470 $string = str_replace("\247", "&#167;", $string);
471 $string = str_replace("\250", "&#168;", $string);
472 $string = str_replace("\251", "&#169;", $string);
473 $string = str_replace("\253", "&#171;", $string);
474 $string = str_replace("\254", "&#172;", $string);
475 $string = str_replace("\255", "&#173;", $string);
476 $string = str_replace("\257", "&#8213;", $string);
477 $string = str_replace("\260", "&#176;", $string);
478 $string = str_replace("\261", "&#177;", $string);
479 $string = str_replace("\262", "&#178;", $string);
480 $string = str_replace("\263", "&#179;", $string);
481
482 // Horizontal bar (parentheki pavla)
483 $string = str_replace ("\257", "&#8213;", $string);
484
485 // ISO-8859-7 characters from 11/04 (0xB4) to 11/06 (0xB6)
486 // These are Unicode 900-902
487 while (ereg("([\264-\266])", $string, $res)) {
488 $replace = "&#" . (ord($res[1])+720) . ";";
489 $string = str_replace($res[1], $replace, $string);
490 }
491
492 // 11/07 (0xB7) Middle dot is the same in iso-8859-1
493 $string = str_replace("\267", "&#183;", $string);
494
495 // ISO-8859-7 characters from 11/08 (0xB8) to 11/10 (0xBA)
496 // These are Unicode 900-902
497 while (ereg("([\270-\272])", $string, $res)) {
498 $replace = "&#" . (ord($res[1])+720) . ";";
499 $string = str_replace($res[1], $replace, $string);
500 }
501
502 // 11/11 (0xBB) Right angle quotation mark is the same as in
503 // iso-8859-1
504 $string = str_replace("\273", "&#187;", $string);
505
506 // And now the rest of the charset
507 while (ereg("([\274-\376])", $string, $res)) {
508 $replace = "&#" . (ord($res[1])+720) . ";";
509 $string = str_replace($res[1], $replace, $string);
510 }
511 }
512 }
513
514 return $string;
515 }
516
517 // iso-8859-15 is Latin 9 and has very much the same use as Latin 1
518 // but has the Euro symbol and some characters needed for French.
519 function charset_decode_iso_8859_15 ($string) {
520 // Euro sign
521 $string = str_replace ("\244", "&#8364;", $string);
522 // Latin capital letter S with caron
523 $string = str_replace ("\244", "&#352;", $string);
524 // Latin small letter s with caron
525 $string = str_replace ("\250", "&#353;", $string);
526 // Latin capital letter Z with caron
527 $string = str_replace ("\264", "&#381;", $string);
528 // Latin small letter z with caron
529 $string = str_replace ("\270", "&#382;", $string);
530 // Latin capital ligature OE
531 $string = str_replace ("\274", "&#338;", $string);
532 // Latin small ligature oe
533 $string = str_replace ("\275", "&#339;", $string);
534 // Latin capital letter Y with diaeresis
535 $string = str_replace ("\276", "&#376;", $string);
536
537 return (charset_decode_iso_8859_1($string));
538 }
539
540 // ISO-8859-15 is Cyrillic
541 function charset_decode_iso_8859_5 ($string) {
542 // Convert to KOI8-R, then return this decoded.
543 $string = convert_cyr_string($string, "i", "k");
544 return charset_decode_koi8r($string);
545 }
546
547 // Remove all 8 bit characters from all other ISO-8859 character sets
548 function charset_decode_iso_8859_default ($string) {
549 return (strtr($string, "\240\241\242\243\244\245\246\247".
550 "\250\251\252\253\254\255\256\257".
551 "\260\261\262\263\264\265\266\267".
552 "\270\271\272\273\274\275\276\277".
553 "\300\301\302\303\304\305\306\307".
554 "\310\311\312\313\314\315\316\317".
555 "\320\321\322\323\324\325\326\327".
556 "\330\331\332\333\334\335\336\337".
557 "\340\341\342\343\344\345\346\347".
558 "\350\351\352\353\354\355\356\357".
559 "\360\361\362\363\364\365\366\367".
560 "\370\371\372\373\374\375\376\377",
561 "????????????????????????????????????????".
562 "????????????????????????????????????????".
563 "????????????????????????????????????????".
564 "????????"));
565
566 }
567
568 // This is the same as ISO-646-NO and is used by some
569 // Microsoft programs when sending Norwegian characters
570 function charset_decode_ns_4551_1 ($string) {
571 // These characters are:
572 // Latin capital letter AE
573 // Latin capital letter O with stroke
574 // Latin capital letter A with ring above
575 // and the same as small letters
576 return strtr ($string, "[\\]{|}", "ÆØÅæøå");
577 }
578
579 // KOI8-R is used to encode Russian mail (Cyrrilic). Defined in RFC
580 // 1489.
581 function charset_decode_koi8r ($string) {
582 global $default_charset;
583
584 if ($default_charset == "koi8-r") {
585 return $string;
586 } else {
587 // Convert to Unicode HTML entities.
588 // This code is rather ineffective.
589 $string = str_replace("\200", "&#9472;", $string);
590 $string = str_replace("\201", "&#9474;", $string);
591 $string = str_replace("\202", "&#9484;", $string);
592 $string = str_replace("\203", "&#9488;", $string);
593 $string = str_replace("\204", "&#9492;", $string);
594 $string = str_replace("\205", "&#9496;", $string);
595 $string = str_replace("\206", "&#9500;", $string);
596 $string = str_replace("\207", "&#9508;", $string);
597 $string = str_replace("\210", "&#9516;", $string);
598 $string = str_replace("\211", "&#9524;", $string);
599 $string = str_replace("\212", "&#9532;", $string);
600 $string = str_replace("\213", "&#9600;", $string);
601 $string = str_replace("\214", "&#9604;", $string);
602 $string = str_replace("\215", "&#9608;", $string);
603 $string = str_replace("\216", "&#9612;", $string);
604 $string = str_replace("\217", "&#9616;", $string);
605 $string = str_replace("\220", "&#9617;", $string);
606 $string = str_replace("\221", "&#9618;", $string);
607 $string = str_replace("\222", "&#9619;", $string);
608 $string = str_replace("\223", "&#8992;", $string);
609 $string = str_replace("\224", "&#9632;", $string);
610 $string = str_replace("\225", "&#8729;", $string);
611 $string = str_replace("\226", "&#8730;", $string);
612 $string = str_replace("\227", "&#8776;", $string);
613 $string = str_replace("\230", "&#8804;", $string);
614 $string = str_replace("\231", "&#8805;", $string);
615 $string = str_replace("\232", "&#160;", $string);
616 $string = str_replace("\233", "&#8993;", $string);
617 $string = str_replace("\234", "&#176;", $string);
618 $string = str_replace("\235", "&#178;", $string);
619 $string = str_replace("\236", "&#183;", $string);
620 $string = str_replace("\237", "&#247;", $string);
621 $string = str_replace("\240", "&#9552;", $string);
622 $string = str_replace("\241", "&#9553;", $string);
623 $string = str_replace("\242", "&#9554;", $string);
624 $string = str_replace("\243", "&#1105;", $string);
625 $string = str_replace("\244", "&#9555;", $string);
626 $string = str_replace("\245", "&#9556;", $string);
627 $string = str_replace("\246", "&#9557;", $string);
628 $string = str_replace("\247", "&#9558;", $string);
629 $string = str_replace("\250", "&#9559;", $string);
630 $string = str_replace("\251", "&#9560;", $string);
631 $string = str_replace("\252", "&#9561;", $string);
632 $string = str_replace("\253", "&#9562;", $string);
633 $string = str_replace("\254", "&#9563;", $string);
634 $string = str_replace("\255", "&#9564;", $string);
635 $string = str_replace("\256", "&#9565;", $string);
636 $string = str_replace("\257", "&#9566;", $string);
637 $string = str_replace("\260", "&#9567;", $string);
638 $string = str_replace("\261", "&#9568;", $string);
639 $string = str_replace("\262", "&#9569;", $string);
640 $string = str_replace("\263", "&#1025;", $string);
641 $string = str_replace("\264", "&#9570;", $string);
642 $string = str_replace("\265", "&#9571;", $string);
643 $string = str_replace("\266", "&#9572;", $string);
644 $string = str_replace("\267", "&#9573;", $string);
645 $string = str_replace("\270", "&#9574;", $string);
646 $string = str_replace("\271", "&#9575;", $string);
647 $string = str_replace("\272", "&#9576;", $string);
648 $string = str_replace("\273", "&#9577;", $string);
649 $string = str_replace("\274", "&#9578;", $string);
650 $string = str_replace("\275", "&#9579;", $string);
651 $string = str_replace("\276", "&#9580;", $string);
652 $string = str_replace("\277", "&#169;", $string);
653 $string = str_replace("\300", "&#1102;", $string);
654 $string = str_replace("\301", "&#1072;", $string);
655 $string = str_replace("\302", "&#1073;", $string);
656 $string = str_replace("\303", "&#1094;", $string);
657 $string = str_replace("\304", "&#1076;", $string);
658 $string = str_replace("\305", "&#1077;", $string);
659 $string = str_replace("\306", "&#1092;", $string);
660 $string = str_replace("\307", "&#1075;", $string);
661 $string = str_replace("\310", "&#1093;", $string);
662 $string = str_replace("\311", "&#1080;", $string);
663 $string = str_replace("\312", "&#1081;", $string);
664 $string = str_replace("\313", "&#1082;", $string);
665 $string = str_replace("\314", "&#1083;", $string);
666 $string = str_replace("\315", "&#1084;", $string);
667 $string = str_replace("\316", "&#1085;", $string);
668 $string = str_replace("\317", "&#1086;", $string);
669 $string = str_replace("\320", "&#1087;", $string);
670 $string = str_replace("\321", "&#1103;", $string);
671 $string = str_replace("\322", "&#1088;", $string);
672 $string = str_replace("\323", "&#1089;", $string);
673 $string = str_replace("\324", "&#1090;", $string);
674 $string = str_replace("\325", "&#1091;", $string);
675 $string = str_replace("\326", "&#1078;", $string);
676 $string = str_replace("\327", "&#1074;", $string);
677 $string = str_replace("\330", "&#1100;", $string);
678 $string = str_replace("\331", "&#1099;", $string);
679 $string = str_replace("\332", "&#1079;", $string);
680 $string = str_replace("\333", "&#1096;", $string);
681 $string = str_replace("\334", "&#1101;", $string);
682 $string = str_replace("\335", "&#1097;", $string);
683 $string = str_replace("\336", "&#1095;", $string);
684 $string = str_replace("\337", "&#1098;", $string);
685 $string = str_replace("\340", "&#1070;", $string);
686 $string = str_replace("\341", "&#1040;", $string);
687 $string = str_replace("\342", "&#1041;", $string);
688 $string = str_replace("\343", "&#1062;", $string);
689 $string = str_replace("\344", "&#1044;", $string);
690 $string = str_replace("\345", "&#1045;", $string);
691 $string = str_replace("\346", "&#1060;", $string);
692 $string = str_replace("\347", "&#1043;", $string);
693 $string = str_replace("\350", "&#1061;", $string);
694 $string = str_replace("\351", "&#1048;", $string);
695 $string = str_replace("\352", "&#1049;", $string);
696 $string = str_replace("\353", "&#1050;", $string);
697 $string = str_replace("\354", "&#1051;", $string);
698 $string = str_replace("\355", "&#1052;", $string);
699 $string = str_replace("\356", "&#1053;", $string);
700 $string = str_replace("\357", "&#1054;", $string);
701 $string = str_replace("\360", "&#1055;", $string);
702 $string = str_replace("\361", "&#1071;", $string);
703 $string = str_replace("\362", "&#1056;", $string);
704 $string = str_replace("\363", "&#1057;", $string);
705 $string = str_replace("\364", "&#1058;", $string);
706 $string = str_replace("\365", "&#1059;", $string);
707 $string = str_replace("\366", "&#1046;", $string);
708 $string = str_replace("\367", "&#1042;", $string);
709 $string = str_replace("\370", "&#1068;", $string);
710 $string = str_replace("\371", "&#1067;", $string);
711 $string = str_replace("\372", "&#1047;", $string);
712 $string = str_replace("\373", "&#1064;", $string);
713 $string = str_replace("\374", "&#1069;", $string);
714 $string = str_replace("\375", "&#1065;", $string);
715 $string = str_replace("\376", "&#1063;", $string);
716 $string = str_replace("\377", "&#1066;", $string);
717
718 return $string;
719 }
720 }
721
722
723 global $use_gettext;
724
725 // Detect whether gettext is installed.
726 // If it is, set the flag so we can use it.
727 if (! function_exists("_") ||
728 ! function_exists("bindtextdomain") ||
729 ! function_exists("textdomain"))
730 $use_gettext = false;
731 else
732 $use_gettext = true;
733
734
735 // Avoid warnings/errors
736 if (! function_exists("_")) {
737 function _($str) { return $str; };
738 }
739 if (! function_exists("bindtextdomain")) {
740 function bindtextdomain() { return; }
741 }
742 if (! function_exists("textdomain")) {
743 function textdomain() { return; }
744 }
745
746
747 // Set up the language to be output
748 // if $do_search is true, then scan the browser information
749 // for a possible language that we know
750 function set_up_language($sm_language, $do_search = false)
751 {
752 static $SetupAlready = 0;
753 global $HTTP_ACCEPT_LANGUAGE, $use_gettext, $languages, $squirrelmail_language;
754
755 if ($SetupAlready)
756 return;
757 $SetupAlready = 1;
758
759 if ($do_search && ! $sm_language && isset($HTTP_ACCEPT_LANGUAGE)) {
760 $sm_language = substr($HTTP_ACCEPT_LANGUAGE, 0, 2);
761 }
762
763 if (isset($sm_language) && $use_gettext &&
764 $squirrelmail_language != "" &&
765 $languages[$sm_language]["CHARSET"]) {
766 if (ini_get("safe_mode")==FALSE && getenv("LC_ALL")!=$sm_language) {
767 putenv("LC_ALL=".$sm_language);
768 }
769 setlocale("LC_ALL", $sm_language);
770 bindtextdomain("squirrelmail", "../locale/");
771 textdomain("squirrelmail");
772 header ("Content-Type: text/html; charset=".$languages[$sm_language]["CHARSET"]);
773 }
774 }
775 ?>