182257610Sandi<? 282257610Sandi/** 382257610Sandi * UTF8 helper functions 482257610Sandi * 582257610Sandi * @license GPL 2 (http://www.gnu.org/licenses/gpl.html) 682257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 782257610Sandi */ 882257610Sandi 982257610Sandi/** 1049c713a3Sandi * URL-Encode a filename to allow unicodecharacters 1149c713a3Sandi * 1249c713a3Sandi * Slashes are not encoded 1349c713a3Sandi * 14f59b22f0Sandi * When the second parameter is true the string will 15f59b22f0Sandi * be encoded only if non ASCII characters are detected - 16f59b22f0Sandi * This makes it safe to run it multiple times on the 17f59b22f0Sandi * same string (default is true) 18f59b22f0Sandi * 1949c713a3Sandi * @author Andreas Gohr <andi@splitbrain.org> 20f59b22f0Sandi * @see urlencode 2149c713a3Sandi */ 22f59b22f0Sandifunction utf8_encodeFN($file,$safe=true){ 23f59b22f0Sandi if($safe && preg_match('#^[a-zA-Z0-9/_\-.%]+$#',$file)){ 24f59b22f0Sandi return $file; 25f59b22f0Sandi } 26f59b22f0Sandi $file = urlencode($file); 2749c713a3Sandi $file = str_replace('%2F','/',$file); 2849c713a3Sandi return $file; 2949c713a3Sandi} 3049c713a3Sandi 3149c713a3Sandi/** 3249c713a3Sandi * URL-Decode a filename 3349c713a3Sandi * 34f59b22f0Sandi * This is just a wrapper around urldecode 35f59b22f0Sandi * 3649c713a3Sandi * @author Andreas Gohr <andi@splitbrain.org> 37f59b22f0Sandi * @see urldecode 3849c713a3Sandi */ 3949c713a3Sandifunction utf8_decodeFN($file){ 40f59b22f0Sandi $file = urldecode($file); 4149c713a3Sandi return $file; 4249c713a3Sandi} 4349c713a3Sandi 44f29bd553Sandi/** 45*44f669e9Sandi * Checks if a string contains 7bit ASCII only 46*44f669e9Sandi * 47*44f669e9Sandi * @author Andreas Gohr <andi@splitbrain.org> 48*44f669e9Sandi */ 49*44f669e9Sandifunction utf8_isASCII($str){ 50*44f669e9Sandi for($i=0; $i<strlen($str); $i++){ 51*44f669e9Sandi if(ord($str{$i}) >127) return false; 52*44f669e9Sandi } 53*44f669e9Sandi return true; 54*44f669e9Sandi} 55*44f669e9Sandi 56*44f669e9Sandi/** 57f29bd553Sandi * Tries to detect if a string is in Unicode encoding 58f29bd553Sandi * 59f29bd553Sandi * @author <bmorel@ssi.fr> 60f29bd553Sandi * @link http://www.php.net/manual/en/function.utf8-encode.php 61f29bd553Sandi */ 62f29bd553Sandifunction utf8_check($Str) { 63f29bd553Sandi for ($i=0; $i<strlen($Str); $i++) { 64f29bd553Sandi if (ord($Str[$i]) < 0x80) continue; # 0bbbbbbb 65f29bd553Sandi elseif ((ord($Str[$i]) & 0xE0) == 0xC0) $n=1; # 110bbbbb 66f29bd553Sandi elseif ((ord($Str[$i]) & 0xF0) == 0xE0) $n=2; # 1110bbbb 67f29bd553Sandi elseif ((ord($Str[$i]) & 0xF8) == 0xF0) $n=3; # 11110bbb 68f29bd553Sandi elseif ((ord($Str[$i]) & 0xFC) == 0xF8) $n=4; # 111110bb 69f29bd553Sandi elseif ((ord($Str[$i]) & 0xFE) == 0xFC) $n=5; # 1111110b 70f29bd553Sandi else return false; # Does not match any model 71f29bd553Sandi for ($j=0; $j<$n; $j++) { # n bytes matching 10bbbbbb follow ? 72f29bd553Sandi if ((++$i == strlen($Str)) || ((ord($Str[$i]) & 0xC0) != 0x80)) 73f29bd553Sandi return false; 74f29bd553Sandi } 75f29bd553Sandi } 76f29bd553Sandi return true; 77f29bd553Sandi} 7849c713a3Sandi 792f954959Sandi/** 802f954959Sandi * This is a unicode aware replacement for strlen() 812f954959Sandi * 822f954959Sandi * Uses mb_string extension if available 832f954959Sandi * 842f954959Sandi * @author Andreas Gohr <andi@splitbrain.org> 852f954959Sandi * @see strlen() 862f954959Sandi */ 872f954959Sandifunction utf8_strlen($string){ 882f954959Sandi if(!defined('UTF8_NOMBSTRING') && function_exists('mb_strlen')) 892f954959Sandi return mb_strlen($string,'utf-8'); 902f954959Sandi 912f954959Sandi $uni = utf8_to_unicode($string); 922f954959Sandi return count($uni); 932f954959Sandi} 942f954959Sandi 957077c942Sandi/** 967077c942Sandi * This is a unicode aware replacement for substr() 977077c942Sandi * 987077c942Sandi * Uses mb_string extension if available 997077c942Sandi * 1007077c942Sandi * @author Andreas Gohr <andi@splitbrain.org> 1017077c942Sandi * @see substr() 1027077c942Sandi */ 1037077c942Sandifunction utf8_substr($str, $start, $length=null){ 1047077c942Sandi if(!defined('UTF8_NOMBSTRING') && function_exists('mb_substr')) 1057077c942Sandi return mb_substr($str,$start,$length,'utf-8'); 1067077c942Sandi 1077077c942Sandi $uni = utf8_to_unicode($str); 1087077c942Sandi return unicode_to_utf8(array_slice($uni,$start,$length)); 1097077c942Sandi} 1102f954959Sandi 11149c713a3Sandi/** 11282257610Sandi * This is a unicode aware replacement for strtolower() 11382257610Sandi * 11482257610Sandi * Uses mb_string extension if available 11582257610Sandi * 11682257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 11782257610Sandi * @see strtolower() 11882257610Sandi * @see utf8_strtoupper() 11982257610Sandi */ 12082257610Sandifunction utf8_strtolower($string){ 12182257610Sandi if(!defined('UTF8_NOMBSTRING') && function_exists('mb_strtolower')) 12282257610Sandi return mb_strtolower($string,'utf-8'); 12382257610Sandi 12482257610Sandi global $UTF8_UPPER_TO_LOWER; 12582257610Sandi $uni = utf8_to_unicode($string); 12682257610Sandi for ($i=0; $i < count($uni); $i++){ 12782257610Sandi if($UTF8_UPPER_TO_LOWER[$uni[$i]]){ 12882257610Sandi $uni[$i] = $UTF8_UPPER_TO_LOWER[$uni[$i]]; 12982257610Sandi } 13082257610Sandi } 13182257610Sandi return unicode_to_utf8($uni); 13282257610Sandi} 13382257610Sandi 13482257610Sandi/** 13582257610Sandi * This is a unicode aware replacement for strtoupper() 13682257610Sandi * 13782257610Sandi * Uses mb_string extension if available 13882257610Sandi * 13982257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 14082257610Sandi * @see strtoupper() 14182257610Sandi * @see utf8_strtoupper() 14282257610Sandi */ 14382257610Sandifunction utf8_strtoupper($string){ 14482257610Sandi if(!defined('UTF8_NOMBSTRING') && function_exists('mb_strtolower')) 14582257610Sandi return mb_strtolower($string,'utf-8'); 14682257610Sandi 14782257610Sandi global $UTF8_LOWER_TO_UPPER; 14882257610Sandi $uni = utf8_to_unicode($string); 14982257610Sandi for ($i=0; $i < count($uni); $i++){ 15082257610Sandi if($UTF8_LOWER_TO_UPPER[$uni[$i]]){ 15182257610Sandi $uni[$i] = $UTF8_LOWER_TO_UPPER[$uni[$i]]; 15282257610Sandi } 15382257610Sandi } 15482257610Sandi return unicode_to_utf8($uni); 15582257610Sandi} 15682257610Sandi 15782257610Sandi/** 15882257610Sandi * Replace accented UTF-8 characters by unaccented ASCII-7 equivalents 15982257610Sandi * 16082257610Sandi * Use the optional parameter to just deaccent lower ($case = -1) or upper ($case = 1) 16182257610Sandi * letters. Default is to deaccent both cases ($case = 0) 16282257610Sandi * 16382257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 16482257610Sandi */ 16582257610Sandifunction utf8_deaccent($string,$case=0){ 16682257610Sandi if($case <= 0){ 16782257610Sandi global $UTF8_LOWER_ACCENTS; 16882257610Sandi $string = str_replace(array_keys($UTF8_LOWER_ACCENTS),array_values($UTF8_LOWER_ACCENTS),$string); 16982257610Sandi } 17082257610Sandi if($case >= 0){ 17182257610Sandi global $UTF8_UPPER_ACCENTS; 17282257610Sandi $string = str_replace(array_keys($UTF8_UPPER_ACCENTS),array_values($UTF8_UPPER_ACCENTS),$string); 17382257610Sandi } 17482257610Sandi return $string; 17582257610Sandi} 17682257610Sandi 17782257610Sandi/** 1782f954959Sandi * This is an Unicode aware replacement for strpos 1792f954959Sandi * 1802f954959Sandi * Uses mb_string extension if available 1812f954959Sandi * 1822f954959Sandi * @author Scott Michael Reynen <scott@randomchaos.com> 1832f954959Sandi * @author Andreas Gohr <andi@splitbrain.org> 1842f954959Sandi * @link http://www.randomchaos.com/document.php?source=php_and_unicode 1852f954959Sandi * @see strpos() 1862f954959Sandi */ 1872f954959Sandifunction utf8_strpos($haystack, $needle,$offset=0) { 1882f954959Sandi if(!defined('UTF8_NOMBSTRING') && function_exists('mb_strpos')) 1892f954959Sandi return mb_strpos($haystack,$needle,$offset,'utf-8'); 1902f954959Sandi 1912f954959Sandi $haystack = utf8_to_unicode($haystack); 1922f954959Sandi $needle = utf8_to_unicode($needle); 1932f954959Sandi $position = $offset; 1942f954959Sandi $found = false; 1952f954959Sandi 1962f954959Sandi while( (! $found ) && ( $position < count( $haystack ) ) ) { 1972f954959Sandi if ( $needle[0] == $haystack[$position] ) { 1982f954959Sandi for ($i = 1; $i < count( $needle ); $i++ ) { 1992f954959Sandi if ( $needle[$i] != $haystack[ $position + $i ] ) break; 2002f954959Sandi } 2012f954959Sandi if ( $i == count( $needle ) ) { 2022f954959Sandi $found = true; 2032f954959Sandi $position--; 2042f954959Sandi } 2052f954959Sandi } 2062f954959Sandi $position++; 2072f954959Sandi } 2082f954959Sandi return ( $found == true ) ? $position : false; 2092f954959Sandi} 2102f954959Sandi 2112f954959Sandi/** 21282257610Sandi * This function will any UTF-8 encoded text and return it as 21382257610Sandi * a list of Unicode values: 21482257610Sandi * 21582257610Sandi * @author Scott Michael Reynen <scott@randomchaos.com> 21682257610Sandi * @link http://www.randomchaos.com/document.php?source=php_and_unicode 21782257610Sandi * @see unicode_to_utf8() 21882257610Sandi */ 21982257610Sandifunction utf8_to_unicode( $str ) { 22082257610Sandi $unicode = array(); 22182257610Sandi $values = array(); 22282257610Sandi $lookingFor = 1; 22382257610Sandi 22482257610Sandi for ($i = 0; $i < strlen( $str ); $i++ ) { 22582257610Sandi $thisValue = ord( $str[ $i ] ); 22682257610Sandi if ( $thisValue < 128 ) $unicode[] = $thisValue; 22782257610Sandi else { 22882257610Sandi if ( count( $values ) == 0 ) $lookingFor = ( $thisValue < 224 ) ? 2 : 3; 22982257610Sandi $values[] = $thisValue; 23082257610Sandi if ( count( $values ) == $lookingFor ) { 23182257610Sandi $number = ( $lookingFor == 3 ) ? 23282257610Sandi ( ( $values[0] % 16 ) * 4096 ) + ( ( $values[1] % 64 ) * 64 ) + ( $values[2] % 64 ): 23382257610Sandi ( ( $values[0] % 32 ) * 64 ) + ( $values[1] % 64 ); 23482257610Sandi $unicode[] = $number; 23582257610Sandi $values = array(); 23682257610Sandi $lookingFor = 1; 23782257610Sandi } 23882257610Sandi } 23982257610Sandi } 24082257610Sandi return $unicode; 24182257610Sandi} 24282257610Sandi 24382257610Sandi/** 24482257610Sandi * This function will convert a Unicode array back to its UTF-8 representation 24582257610Sandi * 24682257610Sandi * @author Scott Michael Reynen <scott@randomchaos.com> 24782257610Sandi * @link http://www.randomchaos.com/document.php?source=php_and_unicode 24882257610Sandi * @see utf8_to_unicode() 24982257610Sandi */ 25082257610Sandifunction unicode_to_utf8( $str ) { 25182257610Sandi $utf8 = ''; 25282257610Sandi foreach( $str as $unicode ) { 25382257610Sandi if ( $unicode < 128 ) { 25482257610Sandi $utf8.= chr( $unicode ); 25582257610Sandi } elseif ( $unicode < 2048 ) { 25682257610Sandi $utf8.= chr( 192 + ( ( $unicode - ( $unicode % 64 ) ) / 64 ) ); 25782257610Sandi $utf8.= chr( 128 + ( $unicode % 64 ) ); 25882257610Sandi } else { 25982257610Sandi $utf8.= chr( 224 + ( ( $unicode - ( $unicode % 4096 ) ) / 4096 ) ); 26082257610Sandi $utf8.= chr( 128 + ( ( ( $unicode % 4096 ) - ( $unicode % 64 ) ) / 64 ) ); 26182257610Sandi $utf8.= chr( 128 + ( $unicode % 64 ) ); 26282257610Sandi } 26382257610Sandi } 26482257610Sandi return $utf8; 26582257610Sandi} 26682257610Sandi 26782257610Sandi/** 26882257610Sandi * UTF-8 Case lookup table 26982257610Sandi * 27082257610Sandi * This lookuptable defines the upper case letters to their correspponding 27182257610Sandi * lower case letter in UTF-8 27282257610Sandi * 27382257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 27482257610Sandi */ 27582257610Sandi$UTF8_LOWER_TO_UPPER = array( 27682257610Sandi 0x0061=>0x0041, 0x03C6=>0x03A6, 0x0163=>0x0162, 0x00E5=>0x00C5, 0x0062=>0x0042, 27782257610Sandi 0x013A=>0x0139, 0x00E1=>0x00C1, 0x0142=>0x0141, 0x03CD=>0x038E, 0x0101=>0x0100, 27882257610Sandi 0x0491=>0x0490, 0x03B4=>0x0394, 0x015B=>0x015A, 0x0064=>0x0044, 0x03B3=>0x0393, 27982257610Sandi 0x00F4=>0x00D4, 0x044A=>0x042A, 0x0439=>0x0419, 0x0113=>0x0112, 0x043C=>0x041C, 28082257610Sandi 0x015F=>0x015E, 0x0144=>0x0143, 0x00EE=>0x00CE, 0x045E=>0x040E, 0x044F=>0x042F, 28182257610Sandi 0x03BA=>0x039A, 0x0155=>0x0154, 0x0069=>0x0049, 0x0073=>0x0053, 0x1E1F=>0x1E1E, 28282257610Sandi 0x0135=>0x0134, 0x0447=>0x0427, 0x03C0=>0x03A0, 0x0438=>0x0418, 0x00F3=>0x00D3, 28382257610Sandi 0x0440=>0x0420, 0x0454=>0x0404, 0x0435=>0x0415, 0x0449=>0x0429, 0x014B=>0x014A, 28482257610Sandi 0x0431=>0x0411, 0x0459=>0x0409, 0x1E03=>0x1E02, 0x00F6=>0x00D6, 0x00F9=>0x00D9, 28582257610Sandi 0x006E=>0x004E, 0x0451=>0x0401, 0x03C4=>0x03A4, 0x0443=>0x0423, 0x015D=>0x015C, 28682257610Sandi 0x0453=>0x0403, 0x03C8=>0x03A8, 0x0159=>0x0158, 0x0067=>0x0047, 0x00E4=>0x00C4, 28782257610Sandi 0x03AC=>0x0386, 0x03AE=>0x0389, 0x0167=>0x0166, 0x03BE=>0x039E, 0x0165=>0x0164, 28882257610Sandi 0x0117=>0x0116, 0x0109=>0x0108, 0x0076=>0x0056, 0x00FE=>0x00DE, 0x0157=>0x0156, 28982257610Sandi 0x00FA=>0x00DA, 0x1E61=>0x1E60, 0x1E83=>0x1E82, 0x00E2=>0x00C2, 0x0119=>0x0118, 29082257610Sandi 0x0146=>0x0145, 0x0070=>0x0050, 0x0151=>0x0150, 0x044E=>0x042E, 0x0129=>0x0128, 29182257610Sandi 0x03C7=>0x03A7, 0x013E=>0x013D, 0x0442=>0x0422, 0x007A=>0x005A, 0x0448=>0x0428, 29282257610Sandi 0x03C1=>0x03A1, 0x1E81=>0x1E80, 0x016D=>0x016C, 0x00F5=>0x00D5, 0x0075=>0x0055, 29382257610Sandi 0x0177=>0x0176, 0x00FC=>0x00DC, 0x1E57=>0x1E56, 0x03C3=>0x03A3, 0x043A=>0x041A, 29482257610Sandi 0x006D=>0x004D, 0x016B=>0x016A, 0x0171=>0x0170, 0x0444=>0x0424, 0x00EC=>0x00CC, 29582257610Sandi 0x0169=>0x0168, 0x03BF=>0x039F, 0x006B=>0x004B, 0x00F2=>0x00D2, 0x00E0=>0x00C0, 29682257610Sandi 0x0434=>0x0414, 0x03C9=>0x03A9, 0x1E6B=>0x1E6A, 0x00E3=>0x00C3, 0x044D=>0x042D, 29782257610Sandi 0x0436=>0x0416, 0x01A1=>0x01A0, 0x010D=>0x010C, 0x011D=>0x011C, 0x00F0=>0x00D0, 29882257610Sandi 0x013C=>0x013B, 0x045F=>0x040F, 0x045A=>0x040A, 0x00E8=>0x00C8, 0x03C5=>0x03A5, 29982257610Sandi 0x0066=>0x0046, 0x00FD=>0x00DD, 0x0063=>0x0043, 0x021B=>0x021A, 0x00EA=>0x00CA, 30082257610Sandi 0x03B9=>0x0399, 0x017A=>0x0179, 0x00EF=>0x00CF, 0x01B0=>0x01AF, 0x0065=>0x0045, 30182257610Sandi 0x03BB=>0x039B, 0x03B8=>0x0398, 0x03BC=>0x039C, 0x045C=>0x040C, 0x043F=>0x041F, 30282257610Sandi 0x044C=>0x042C, 0x00FE=>0x00DE, 0x00F0=>0x00D0, 0x1EF3=>0x1EF2, 0x0068=>0x0048, 30382257610Sandi 0x00EB=>0x00CB, 0x0111=>0x0110, 0x0433=>0x0413, 0x012F=>0x012E, 0x00E6=>0x00C6, 30482257610Sandi 0x0078=>0x0058, 0x0161=>0x0160, 0x016F=>0x016E, 0x03B1=>0x0391, 0x0457=>0x0407, 30582257610Sandi 0x0173=>0x0172, 0x00FF=>0x0178, 0x006F=>0x004F, 0x043B=>0x041B, 0x03B5=>0x0395, 30682257610Sandi 0x0445=>0x0425, 0x0121=>0x0120, 0x017E=>0x017D, 0x017C=>0x017B, 0x03B6=>0x0396, 30782257610Sandi 0x03B2=>0x0392, 0x03AD=>0x0388, 0x1E85=>0x1E84, 0x0175=>0x0174, 0x0071=>0x0051, 30882257610Sandi 0x0437=>0x0417, 0x1E0B=>0x1E0A, 0x0148=>0x0147, 0x0105=>0x0104, 0x0458=>0x0408, 30982257610Sandi 0x014D=>0x014C, 0x00ED=>0x00CD, 0x0079=>0x0059, 0x010B=>0x010A, 0x03CE=>0x038F, 31082257610Sandi 0x0072=>0x0052, 0x0430=>0x0410, 0x0455=>0x0405, 0x0452=>0x0402, 0x0127=>0x0126, 31182257610Sandi 0x0137=>0x0136, 0x012B=>0x012A, 0x03AF=>0x038A, 0x044B=>0x042B, 0x006C=>0x004C, 31282257610Sandi 0x03B7=>0x0397, 0x0125=>0x0124, 0x0219=>0x0218, 0x00FB=>0x00DB, 0x011F=>0x011E, 31382257610Sandi 0x043E=>0x041E, 0x1E41=>0x1E40, 0x03BD=>0x039D, 0x0107=>0x0106, 0x03CB=>0x03AB, 31482257610Sandi 0x0446=>0x0426, 0x00FE=>0x00DE, 0x00E7=>0x00C7, 0x03CA=>0x03AA, 0x0441=>0x0421, 31582257610Sandi 0x0432=>0x0412, 0x010F=>0x010E, 0x00F8=>0x00D8, 0x0077=>0x0057, 0x011B=>0x011A, 31682257610Sandi 0x0074=>0x0054, 0x006A=>0x004A, 0x045B=>0x040B, 0x0456=>0x0406, 0x0103=>0x0102, 31782257610Sandi 0x03BB=>0x039B, 0x00F1=>0x00D1, 0x043D=>0x041D, 0x03CC=>0x038C, 0x00E9=>0x00C9, 31882257610Sandi 0x00F0=>0x00D0, 0x0457=>0x0407, 0x0123=>0x0122, 31982257610Sandi); 32082257610Sandi 32182257610Sandi/** 32282257610Sandi * UTF-8 Case lookup table 32382257610Sandi * 32482257610Sandi * This lookuptable defines the lower case letters to their correspponding 32582257610Sandi * upper case letter in UTF-8 (it does so by flipping $UTF8_LOWER_TO_UPPER) 32682257610Sandi * 32782257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 32882257610Sandi */ 32982257610Sandi$UTF8_UPPER_TO_LOWER = @array_flip($UTF8_LOWER_TO_UPPER); 33082257610Sandi 33182257610Sandi/** 33282257610Sandi * UTF-8 lookup table for lower case accented letters 33382257610Sandi * 33482257610Sandi * This lookuptable defines replacements for accented characters from the ASCII-7 33582257610Sandi * range. This are lower case letters only. 33682257610Sandi * 33782257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 33882257610Sandi * @see utf8_deaccent() 33982257610Sandi */ 34082257610Sandi$UTF8_LOWER_ACCENTS = array( 34182257610Sandi 'à' => 'a', 'ô' => 'o', 'ď' => 'd', 'ḟ' => 'f', 'ë' => 'e', 'š' => 's', 'ơ' => 'o', 34282257610Sandi 'ß' => 'ss', 'ă' => 'a', 'ř' => 'r', 'ț' => 't', 'ň' => 'n', 'ā' => 'a', 'ķ' => 'k', 34382257610Sandi 'ŝ' => 's', 'ỳ' => 'y', 'ņ' => 'n', 'ĺ' => 'l', 'ħ' => 'h', 'ṗ' => 'p', 'ó' => 'o', 34482257610Sandi 'ú' => 'u', 'ě' => 'e', 'é' => 'e', 'ç' => 'c', 'ẁ' => 'w', 'ċ' => 'c', 'õ' => 'o', 34582257610Sandi 'ṡ' => 's', 'ø' => 'o', 'ģ' => 'g', 'ŧ' => 't', 'ș' => 's', 'ė' => 'e', 'ĉ' => 'c', 34682257610Sandi 'ś' => 's', 'î' => 'i', 'ű' => 'u', 'ć' => 'c', 'ę' => 'e', 'ŵ' => 'w', 'ṫ' => 't', 34782257610Sandi 'ū' => 'u', 'č' => 'c', 'ö' => 'oe', 'è' => 'e', 'ŷ' => 'y', 'ą' => 'a', 'ł' => 'l', 34882257610Sandi 'ų' => 'u', 'ů' => 'u', 'ş' => 's', 'ğ' => 'g', 'ļ' => 'l', 'ƒ' => 'f', 'ž' => 'z', 34982257610Sandi 'ẃ' => 'w', 'ḃ' => 'b', 'å' => 'a', 'ì' => 'i', 'ï' => 'i', 'ḋ' => 'd', 'ť' => 't', 35082257610Sandi 'ŗ' => 'r', 'ä' => 'ae', 'í' => 'i', 'ŕ' => 'r', 'ê' => 'e', 'ü' => 'ue', 'ò' => 'o', 35182257610Sandi 'ē' => 'e', 'ñ' => 'n', 'ń' => 'n', 'ĥ' => 'h', 'ĝ' => 'g', 'đ' => 'd', 'ĵ' => 'j', 35282257610Sandi 'ÿ' => 'y', 'ũ' => 'u', 'ŭ' => 'u', 'ư' => 'u', 'ţ' => 't', 'ý' => 'y', 'ő' => 'o', 35382257610Sandi 'â' => 'a', 'ľ' => 'l', 'ẅ' => 'w', 'ż' => 'z', 'ī' => 'i', 'ã' => 'a', 'ġ' => 'g', 35482257610Sandi 'ṁ' => 'm', 'ō' => 'o', 'ĩ' => 'i', 'ù' => 'u', 'į' => 'i', 'ź' => 'z', 'á' => 'a', 3550c59b0cfSandi 'û' => 'u', 'þ' => 'th', 'ð' => 'dh', 'æ' => 'ae', 'µ' => 'u', 35682257610Sandi); 35782257610Sandi 35882257610Sandi/** 35982257610Sandi * UTF-8 lookup table for upper case accented letters 36082257610Sandi * 36182257610Sandi * This lookuptable defines replacements for accented characters from the ASCII-7 36282257610Sandi * range. This are upper case letters only. 36382257610Sandi * 36482257610Sandi * @author Andreas Gohr <andi@splitbrain.org> 36582257610Sandi * @see utf8_deaccent() 36682257610Sandi */ 36782257610Sandi$UTF8_UPPER_ACCENTS = array( 36882257610Sandi 'à' => 'A', 'ô' => 'O', 'ď' => 'D', 'ḟ' => 'F', 'ë' => 'E', 'š' => 'S', 'ơ' => 'O', 36982257610Sandi 'ß' => 'Ss', 'ă' => 'A', 'ř' => 'R', 'ț' => 'T', 'ň' => 'N', 'ā' => 'A', 'ķ' => 'K', 37082257610Sandi 'ŝ' => 'S', 'ỳ' => 'Y', 'ņ' => 'N', 'ĺ' => 'L', 'ħ' => 'H', 'ṗ' => 'P', 'ó' => 'O', 37182257610Sandi 'ú' => 'U', 'ě' => 'E', 'é' => 'E', 'ç' => 'C', 'ẁ' => 'W', 'ċ' => 'C', 'õ' => 'O', 37282257610Sandi 'ṡ' => 'S', 'ø' => 'O', 'ģ' => 'G', 'ŧ' => 'T', 'ș' => 'S', 'ė' => 'E', 'ĉ' => 'C', 37382257610Sandi 'ś' => 'S', 'î' => 'I', 'ű' => 'U', 'ć' => 'C', 'ę' => 'E', 'ŵ' => 'W', 'ṫ' => 'T', 37482257610Sandi 'ū' => 'U', 'č' => 'C', 'ö' => 'Oe', 'è' => 'E', 'ŷ' => 'Y', 'ą' => 'A', 'ł' => 'L', 37582257610Sandi 'ų' => 'U', 'ů' => 'U', 'ş' => 'S', 'ğ' => 'G', 'ļ' => 'L', 'ƒ' => 'F', 'ž' => 'Z', 37682257610Sandi 'ẃ' => 'W', 'ḃ' => 'B', 'å' => 'A', 'ì' => 'I', 'ï' => 'I', 'ḋ' => 'D', 'ť' => 'T', 37782257610Sandi 'ŗ' => 'R', 'ä' => 'Ae', 'í' => 'I', 'ŕ' => 'R', 'ê' => 'E', 'ü' => 'Ue', 'ò' => 'O', 37882257610Sandi 'ē' => 'E', 'ñ' => 'N', 'ń' => 'N', 'ĥ' => 'H', 'ĝ' => 'G', 'đ' => 'D', 'ĵ' => 'J', 37982257610Sandi 'ÿ' => 'Y', 'ũ' => 'U', 'ŭ' => 'U', 'ư' => 'U', 'ţ' => 'T', 'ý' => 'Y', 'ő' => 'O', 38082257610Sandi 'â' => 'A', 'ľ' => 'L', 'ẅ' => 'W', 'ż' => 'Z', 'ī' => 'I', 'ã' => 'A', 'ġ' => 'G', 38182257610Sandi 'ṁ' => 'M', 'ō' => 'O', 'ĩ' => 'I', 'ù' => 'U', 'į' => 'I', 'ź' => 'Z', 'á' => 'A', 3820c59b0cfSandi 'û' => 'U', 'Þ' => 'th', 'Ð' => 'dh', 'Æ' => 'ae', 38382257610Sandi); 38482257610Sandi 38582257610Sandi?> 386