4 * cp1251 encoding functions
6 * takes a string of unicode entities and converts it to a cp1251 encoded string
7 * Unsupported characters are replaced with ?.
9 * @copyright © 2004-2009 The SquirrelMail Project Team
10 * @license http://opensource.org/licenses/gpl-license.php GNU Public License
12 * @package squirrelmail
17 * Converts string to cp1251
18 * @param string $string text with numeric unicode entities
19 * @return string cp1251 encoded text
21 function charset_encode_cp1251 ($string) {
22 // don't run encoding function, if there is no encoded characters
23 if (! preg_match("'&#[0-9]+;'",$string) ) return $string;
25 $string=preg_replace("/&#([0-9]+);/e","unicodetocp1251('\\1')",$string);
26 // $string=preg_replace("/&#[xX]([0-9A-F]+);/e","unicodetocp1251(hexdec('\\1'))",$string);
32 * Return cp1251 symbol when unicode character number is provided
34 * This function is used internally by charset_encode_cp1251
35 * function. It might be unavailable to other SquirrelMail functions.
36 * Don't use it or make sure, that functions/encode/cp1251.php is
39 * @param int $var decimal unicode value
40 * @return string cp1251 character
42 function unicodetocp1251($var) {
44 $cp1251chars=array('160' => "\xA0",
172 if (array_key_exists($var,$cp1251chars)) {
173 $ret=$cp1251chars[$var];