Adding tests for securing private variable inclussion on templates.
[akelos.git] / lib / AkCharset / utf8_mappings / iso_8859_2.php
blob0bcd26db45eeb87eac078d3bc0f2db17453b48e3
1 <?php
3 /**
4 *@file iso_8859_2.php
5 * ISO-8859-2 Mapping and Charset implementation.
7 */
9 //
10 // +----------------------------------------------------------------------+
11 // | Akelos PHP Application Framework |
12 // +----------------------------------------------------------------------+
13 // | Copyright (c) 2002-2005, Akelos Media, S.L. http://www.akelos.org/ |
14 // | Released under the GNU Lesser General Public License |
15 // +----------------------------------------------------------------------+
16 // | You should have received the following files along with this library |
17 // | - COPYRIGHT (Additional copyright notice) |
18 // | - DISCLAIMER (Disclaimer of warranty) |
19 // | - README (Important information regarding this library) |
20 // +----------------------------------------------------------------------+
27 /**
28 * ISO-8859-2 driver for Charset Class
30 * Charset::iso_8859_2 provides functionality to convert
31 * ISO-8859-2 strings, to UTF-8 multibyte format and vice versa.
33 * @author Bermi Ferrer Martinez <bermi@akelos.org>
34 * @copyright Copyright (c) 2002-2005, Akelos Media, S.L. http://www.akelos.org
35 * @license GNU Lesser General Public License <http://www.gnu.org/copyleft/lesser.html>
36 * @link http://www.unicode.org/Public/MAPPINGS/ Original Mapping taken from Unicode.org
37 * @since 0.1
38 * @version $Revision 0.1 $
40 class iso_8859_2 extends AkCharset
44 // ------ CLASS ATTRIBUTES ------ //
48 // ---- Private attributes ---- //
51 /**
52 * ISO-8859-2 to UTF-8 mapping array.
54 * @access private
55 * @var array $_toUtfMap
57 var $_toUtfMap = array(0=>0,1=>1,2=>2,3=>3,4=>4,5=>5,6=>6,7=>7,8=>8,9=>9,10=>10,11=>11,12=>12,13=>13,14=>14,15=>15,16=>16,17=>17,18=>18,19=>19,20=>20,21=>21,22=>22,23=>23,24=>24,25=>25,26=>26,27=>27,28=>28,29=>29,30=>30,31=>31,32=>32,33=>33,34=>34,35=>35,36=>36,37=>37,38=>38,39=>39,40=>40,41=>41,42=>42,43=>43,44=>44,45=>45,46=>46,47=>47,48=>48,49=>49,50=>50,51=>51,52=>52,53=>53,54=>54,55=>55,56=>56,57=>57,58=>58,59=>59,60=>60,61=>61,62=>62,63=>63,64=>64,65=>65,66=>66,67=>67,68=>68,69=>69,70=>70,71=>71,72=>72,73=>73,74=>74,75=>75,76=>76,77=>77,78=>78,79=>79,80=>80,81=>81,82=>82,83=>83,84=>84,85=>85,86=>86,87=>87,88=>88,89=>89,90=>90,91=>91,92=>92,93=>93,94=>94,95=>95,96=>96,97=>97,98=>98,99=>99,100=>100,101=>101,102=>102,103=>103,104=>104,105=>105,106=>106,107=>107,108=>108,109=>109,110=>110,111=>111,112=>112,113=>113,114=>114,115=>115,116=>116,117=>117,118=>118,119=>119,120=>120,121=>121,122=>122,123=>123,124=>124,125=>125,126=>126,127=>127,128=>128,129=>129,130=>130,131=>131,132=>132,133=>133,134=>134,135=>135,136=>136,137=>137,138=>138,139=>139,140=>140,141=>141,142=>142,143=>143,144=>144,145=>145,146=>146,147=>147,148=>148,149=>149,150=>150,151=>151,152=>152,153=>153,154=>154,155=>155,156=>156,157=>157,158=>158,159=>159,160=>160,161=>260,162=>728,163=>321,164=>164,165=>317,166=>346,167=>167,168=>168,169=>352,170=>350,171=>356,172=>377,173=>173,174=>381,175=>379,176=>176,177=>261,178=>731,179=>322,180=>180,181=>318,182=>347,183=>711,184=>184,185=>353,186=>351,187=>357,188=>378,189=>733,190=>382,191=>380,192=>340,193=>193,194=>194,195=>258,196=>196,197=>313,198=>262,199=>199,200=>268,201=>201,202=>280,203=>203,204=>282,205=>205,206=>206,207=>270,208=>272,209=>323,210=>327,211=>211,212=>212,213=>336,214=>214,215=>215,216=>344,217=>366,218=>218,219=>368,220=>220,221=>221,222=>354,223=>223,224=>341,225=>225,226=>226,227=>259,228=>228,229=>314,230=>263,231=>231,232=>269,233=>233,234=>281,235=>235,236=>283,237=>237,238=>238,239=>271,240=>273,241=>324,242=>328,243=>243,244=>244,245=>337,246=>246,247=>247,248=>345,249=>367,250=>250,251=>369,252=>252,253=>253,254=>355,255=>729);
60 /**
61 * UTF-8 to ISO-8859-2 mapping array.
63 * @access private
64 * @var array $_fromUtfMap
66 var $_fromUtfMap = null;
69 // ------------------------------
73 // ------ CLASS METHODS ------ //
76 // ---- Public methods ---- //
79 /**
80 * Encodes given ISO-8859-2 string into UFT-8
82 * @access public
83 * @see UtfDecode
84 * @param string $string ISO-8859-2 string
85 * @return string UTF-8 string data
87 function _Utf8StringEncode($string)
89 return parent::_Utf8StringEncode($string, $this->_toUtfMap);
91 }// -- end of &Utf8StringEncode -- //
93 /**
94 * Decodes given UFT-8 string into ISO-8859-2
96 * @access public
97 * @see UtfEncode
98 * @param string $string UTF-8 string
99 * @return string ISO-8859-2 string data
101 function _Utf8StringDecode($string)
103 $this->_LoadInverseMap();
104 return parent::_Utf8StringDecode($string, $this->_fromUtfMap);
105 }// -- end of &Utf8StringDecode -- //
108 // ---- Private methods ---- //
111 * Flips $this->_toUtfMap to $this->_fromUtfMap
113 * @access private
114 * @return null
116 function _LoadInverseMap()
118 static $loaded;
119 if(!isset($loaded)){
120 $loaded = true;
121 $this->_fromUtfMap = array_flip($this->_toUtfMap);
123 }// -- end of _LoadInverseMap -- //