| 1 | <?php |
| 2 | |
| 3 | /** |
| 4 | * decode/cp1250.php |
| 5 | * |
| 6 | * This file contains cp1250 decoding function that is needed to read |
| 7 | * cp1250 encoded mails in non-cp1250 locale. |
| 8 | * |
| 9 | * Original data taken from: |
| 10 | * ftp://ftp.unicode.org/Public/MAPPINGS/VENDORS/MICSFT/WINDOWS/CP1250.TXT |
| 11 | * |
| 12 | * Name: cp1250 to Unicode table |
| 13 | * Unicode version: 2.0 |
| 14 | * Table version: 2.01 |
| 15 | * Table format: Format A |
| 16 | * Date: 04/15/98 |
| 17 | * Contact: cpxlate@microsoft.com |
| 18 | * |
| 19 | * @copyright 2003-2019 The SquirrelMail Project Team |
| 20 | * @license http://opensource.org/licenses/gpl-license.php GNU Public License |
| 21 | * @version $Id$ |
| 22 | * @package squirrelmail |
| 23 | * @subpackage decode |
| 24 | */ |
| 25 | |
| 26 | /** |
| 27 | * Decode a cp1250 string |
| 28 | * @param string $string Encoded string |
| 29 | * @return string $string Decoded string |
| 30 | */ |
| 31 | function charset_decode_cp1250 ($string) { |
| 32 | // don't do decoding when there are no 8bit symbols |
| 33 | if (! sq_is8bit($string,'windows-1250')) |
| 34 | return $string; |
| 35 | |
| 36 | $cp1250 = array( |
| 37 | "\x80" => '€', |
| 38 | "\x81" => '�', |
| 39 | "\x82" => '‚', |
| 40 | "\x83" => '�', |
| 41 | "\x84" => '„', |
| 42 | "\x85" => '…', |
| 43 | "\x86" => '†', |
| 44 | "\x87" => '‡', |
| 45 | "\x88" => '�', |
| 46 | "\x89" => '‰', |
| 47 | "\x8A" => 'Š', |
| 48 | "\x8B" => '‹', |
| 49 | "\x8C" => 'Ś', |
| 50 | "\x8D" => 'Ť', |
| 51 | "\x8E" => 'Ž', |
| 52 | "\x8F" => 'Ź', |
| 53 | "\x90" => '�', |
| 54 | "\x91" => '‘', |
| 55 | "\x92" => '’', |
| 56 | "\x93" => '“', |
| 57 | "\x94" => '”', |
| 58 | "\x95" => '•', |
| 59 | "\x96" => '–', |
| 60 | "\x97" => '—', |
| 61 | "\x98" => '�', |
| 62 | "\x99" => '™', |
| 63 | "\x9A" => 'š', |
| 64 | "\x9B" => '›', |
| 65 | "\x9C" => 'ś', |
| 66 | "\x9D" => 'ť', |
| 67 | "\x9E" => 'ž', |
| 68 | "\x9F" => 'ź', |
| 69 | "\xA0" => ' ', |
| 70 | "\xA1" => 'ˇ', |
| 71 | "\xA2" => '˘', |
| 72 | "\xA3" => 'Ł', |
| 73 | "\xA4" => '¤', |
| 74 | "\xA5" => 'Ą', |
| 75 | "\xA6" => '¦', |
| 76 | "\xA7" => '§', |
| 77 | "\xA8" => '¨', |
| 78 | "\xA9" => '©', |
| 79 | "\xAA" => 'Ş', |
| 80 | "\xAB" => '«', |
| 81 | "\xAC" => '¬', |
| 82 | "\xAD" => '­', |
| 83 | "\xAE" => '®', |
| 84 | "\xAF" => 'Ż', |
| 85 | "\xB0" => '°', |
| 86 | "\xB1" => '±', |
| 87 | "\xB2" => '˛', |
| 88 | "\xB3" => 'ł', |
| 89 | "\xB4" => '´', |
| 90 | "\xB5" => 'µ', |
| 91 | "\xB6" => '¶', |
| 92 | "\xB7" => '·', |
| 93 | "\xB8" => '¸', |
| 94 | "\xB9" => 'ą', |
| 95 | "\xBA" => 'ş', |
| 96 | "\xBB" => '»', |
| 97 | "\xBC" => 'Ľ', |
| 98 | "\xBD" => '˝', |
| 99 | "\xBE" => 'ľ', |
| 100 | "\xBF" => 'ż', |
| 101 | "\xC0" => 'Ŕ', |
| 102 | "\xC1" => 'Á', |
| 103 | "\xC2" => 'Â', |
| 104 | "\xC3" => 'Ă', |
| 105 | "\xC4" => 'Ä', |
| 106 | "\xC5" => 'Ĺ', |
| 107 | "\xC6" => 'Ć', |
| 108 | "\xC7" => 'Ç', |
| 109 | "\xC8" => 'Č', |
| 110 | "\xC9" => 'É', |
| 111 | "\xCA" => 'Ę', |
| 112 | "\xCB" => 'Ë', |
| 113 | "\xCC" => 'Ě', |
| 114 | "\xCD" => 'Í', |
| 115 | "\xCE" => 'Î', |
| 116 | "\xCF" => 'Ď', |
| 117 | "\xD0" => 'Đ', |
| 118 | "\xD1" => 'Ń', |
| 119 | "\xD2" => 'Ň', |
| 120 | "\xD3" => 'Ó', |
| 121 | "\xD4" => 'Ô', |
| 122 | "\xD5" => 'Ő', |
| 123 | "\xD6" => 'Ö', |
| 124 | "\xD7" => '×', |
| 125 | "\xD8" => 'Ř', |
| 126 | "\xD9" => 'Ů', |
| 127 | "\xDA" => 'Ú', |
| 128 | "\xDB" => 'Ű', |
| 129 | "\xDC" => 'Ü', |
| 130 | "\xDD" => 'Ý', |
| 131 | "\xDE" => 'Ţ', |
| 132 | "\xDF" => 'ß', |
| 133 | "\xE0" => 'ŕ', |
| 134 | "\xE1" => 'á', |
| 135 | "\xE2" => 'â', |
| 136 | "\xE3" => 'ă', |
| 137 | "\xE4" => 'ä', |
| 138 | "\xE5" => 'ĺ', |
| 139 | "\xE6" => 'ć', |
| 140 | "\xE7" => 'ç', |
| 141 | "\xE8" => 'č', |
| 142 | "\xE9" => 'é', |
| 143 | "\xEA" => 'ę', |
| 144 | "\xEB" => 'ë', |
| 145 | "\xEC" => 'ě', |
| 146 | "\xED" => 'í', |
| 147 | "\xEE" => 'î', |
| 148 | "\xEF" => 'ď', |
| 149 | "\xF0" => 'đ', |
| 150 | "\xF1" => 'ń', |
| 151 | "\xF2" => 'ň', |
| 152 | "\xF3" => 'ó', |
| 153 | "\xF4" => 'ô', |
| 154 | "\xF5" => 'ő', |
| 155 | "\xF6" => 'ö', |
| 156 | "\xF7" => '÷', |
| 157 | "\xF8" => 'ř', |
| 158 | "\xF9" => 'ů', |
| 159 | "\xFA" => 'ú', |
| 160 | "\xFB" => 'ű', |
| 161 | "\xFC" => 'ü', |
| 162 | "\xFD" => 'ý', |
| 163 | "\xFE" => 'ţ', |
| 164 | "\xFF" => '˙' |
| 165 | ); |
| 166 | |
| 167 | $string = str_replace(array_keys($cp1250), array_values($cp1250), $string); |
| 168 | |
| 169 | return $string; |
| 170 | } |