123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163 |
- <?php
- /**
- * decode/iso8859-2.php
- *
- * Copyright (c) 2003-2004 The SquirrelMail Project Team
- * Licensed under the GNU GPL. For full terms see the file COPYING.
- *
- * This file contains iso-8859-2 decoding function that is needed to read
- * iso-8859-2 encoded mails in non-iso-8859-2 locale.
- *
- * Original data taken from:
- * ftp://ftp.unicode.org/Public/MAPPINGS/ISO8859/8859-2.TXT
- *
- * Name: ISO 8859-2:1999 to Unicode
- * Unicode version: 3.0
- * Table version: 1.0
- * Table format: Format A
- * Date: 1999 July 27
- * Authors: Ken Whistler <kenw@sybase.com>
- *
- * Original copyright:
- * Copyright (c) 1999 Unicode, Inc. All Rights reserved.
- *
- * This file is provided as-is by Unicode, Inc. (The Unicode Consortium).
- * No claims are made as to fitness for any particular purpose. No
- * warranties of any kind are expressed or implied. The recipient
- * agrees to determine applicability of information provided. If this
- * file has been provided on optical media by Unicode, Inc., the sole
- * remedy for any claim will be exchange of defective media within 90
- * days of receipt.
- *
- * Unicode, Inc. hereby grants the right to freely use the information
- * supplied in this file in the creation of products supporting the
- * Unicode Standard, and to make copies of this file in any form for
- * internal or external distribution as long as this notice remains
- * attached.
- *
- * @version $Id$
- * @package squirrelmail
- * @subpackage decode
- */
- /**
- * Decode iso8859-2 encoded string
- * @param string $string Encoded string
- * @return string $string Decoded string
- */
- function charset_decode_iso_8859_2 ($string) {
- global $default_charset;
- if (strtolower($default_charset) == 'iso-8859-2')
- return $string;
- /* Only do the slow convert if there are 8-bit characters */
- /* there is no 0x80-0x9F letters in ISO8859-* */
- if ( ! ereg("[\241-\377]", $string) )
- return $string;
- $iso8859_2 = array(
- "\xA0" => ' ',
- "\xA1" => 'Ą',
- "\xA2" => '˘',
- "\xA3" => 'Ł',
- "\xA4" => '¤',
- "\xA5" => 'Ľ',
- "\xA6" => 'Ś',
- "\xA7" => '§',
- "\xA8" => '¨',
- "\xA9" => 'Š',
- "\xAA" => 'Ş',
- "\xAB" => 'Ť',
- "\xAC" => 'Ź',
- "\xAD" => '­',
- "\xAE" => 'Ž',
- "\xAF" => 'Ż',
- "\xB0" => '°',
- "\xB1" => 'ą',
- "\xB2" => '˛',
- "\xB3" => 'ł',
- "\xB4" => '´',
- "\xB5" => 'ľ',
- "\xB6" => 'ś',
- "\xB7" => 'ˇ',
- "\xB8" => '¸',
- "\xB9" => 'š',
- "\xBA" => 'ş',
- "\xBB" => 'ť',
- "\xBC" => 'ź',
- "\xBD" => '˝',
- "\xBE" => 'ž',
- "\xBF" => 'ż',
- "\xC0" => 'Ŕ',
- "\xC1" => 'Á',
- "\xC2" => 'Â',
- "\xC3" => 'Ă',
- "\xC4" => 'Ä',
- "\xC5" => 'Ĺ',
- "\xC6" => 'Ć',
- "\xC7" => 'Ç',
- "\xC8" => 'Č',
- "\xC9" => 'É',
- "\xCA" => 'Ę',
- "\xCB" => 'Ë',
- "\xCC" => 'Ě',
- "\xCD" => 'Í',
- "\xCE" => 'Î',
- "\xCF" => 'Ď',
- "\xD0" => 'Đ',
- "\xD1" => 'Ń',
- "\xD2" => 'Ň',
- "\xD3" => 'Ó',
- "\xD4" => 'Ô',
- "\xD5" => 'Ő',
- "\xD6" => 'Ö',
- "\xD7" => '×',
- "\xD8" => 'Ř',
- "\xD9" => 'Ů',
- "\xDA" => 'Ú',
- "\xDB" => 'Ű',
- "\xDC" => 'Ü',
- "\xDD" => 'Ý',
- "\xDE" => 'Ţ',
- "\xDF" => 'ß',
- "\xE0" => 'ŕ',
- "\xE1" => 'á',
- "\xE2" => 'â',
- "\xE3" => 'ă',
- "\xE4" => 'ä',
- "\xE5" => 'ĺ',
- "\xE6" => 'ć',
- "\xE7" => 'ç',
- "\xE8" => 'č',
- "\xE9" => 'é',
- "\xEA" => 'ę',
- "\xEB" => 'ë',
- "\xEC" => 'ě',
- "\xED" => 'í',
- "\xEE" => 'î',
- "\xEF" => 'ď',
- "\xF0" => 'đ',
- "\xF1" => 'ń',
- "\xF2" => 'ň',
- "\xF3" => 'ó',
- "\xF4" => 'ô',
- "\xF5" => 'ő',
- "\xF6" => 'ö',
- "\xF7" => '÷',
- "\xF8" => 'ř',
- "\xF9" => 'ů',
- "\xFA" => 'ú',
- "\xFB" => 'ű',
- "\xFC" => 'ü',
- "\xFD" => 'ý',
- "\xFE" => 'ţ',
- "\xFF" => '˙'
- );
- $string = str_replace(array_keys($iso8859_2), array_values($iso8859_2), $string);
- return $string;
- }
- ?>
|