| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190 | <?php/*** Smarty Internal Plugin Templatelexer** This is the lexer to break the template source into tokens* @package Smarty* @subpackage Compiler* @author Uwe Tews*//*** Smarty Internal Plugin Templatelexer*/class Smarty_Internal_Templatelexer{    public $data;    public $counter;    public $token;    public $value;    public $node;    public $line;    public $taglineno;    public $state = 1;    private $heredoc_id_stack = Array();    public $smarty_token_names = array (		// Text for parser error messages    				'IDENTITY'	=> '===',    				'NONEIDENTITY'	=> '!==',    				'EQUALS'	=> '==',    				'NOTEQUALS'	=> '!=',    				'GREATEREQUAL' => '(>=,ge)',    				'LESSEQUAL' => '(<=,le)',    				'GREATERTHAN' => '(>,gt)',    				'LESSTHAN' => '(<,lt)',    				'MOD' => '(%,mod)',    				'NOT'			=> '(!,not)',    				'LAND'		=> '(&&,and)',    				'LOR'			=> '(||,or)',    				'LXOR'			=> 'xor',    				'OPENP'		=> '(',    				'CLOSEP'	=> ')',    				'OPENB'		=> '[',    				'CLOSEB'	=> ']',    				'PTR'			=> '->',    				'APTR'		=> '=>',    				'EQUAL'		=> '=',    				'NUMBER'	=> 'number',    				'UNIMATH'	=> '+" , "-',    				'MATH'		=> '*" , "/" , "%',    				'INCDEC'	=> '++" , "--',    				'SPACE'		=> ' ',    				'DOLLAR'	=> '$',    				'SEMICOLON' => ';',    				'COLON'		=> ':',    				'DOUBLECOLON'		=> '::',    				'AT'		=> '@',    				'HATCH'		=> '#',    				'QUOTE'		=> '"',    				'BACKTICK'		=> '`',    				'VERT'		=> '|',    				'DOT'			=> '.',    				'COMMA'		=> '","',    				'ANDSYM'		=> '"&"',    				'QMARK'		=> '"?"',    				'ID'			=> 'identifier',    				'TEXT'		=> 'text',     				'FAKEPHPSTARTTAG'	=> 'Fake PHP start tag',     				'PHPSTARTTAG'	=> 'PHP start tag',     				'PHPENDTAG'	=> 'PHP end tag', 						'LITERALSTART'  => 'Literal start', 						'LITERALEND'    => 'Literal end',    				'LDELSLASH' => 'closing tag',    				'COMMENT' => 'comment',    				'AS' => 'as',    				'TO' => 'to',    				);    function __construct($data,$compiler)    {//        $this->data = preg_replace("/(\r\n|\r|\n)/", "\n", $data);        $this->data = $data;        $this->counter = 0;        $this->line = 1;        $this->smarty = $compiler->smarty;        $this->compiler = $compiler;        $this->ldel = preg_quote($this->smarty->left_delimiter,'/');        $this->ldel_length = strlen($this->smarty->left_delimiter);        $this->rdel = preg_quote($this->smarty->right_delimiter,'/');        $this->smarty_token_names['LDEL'] =	$this->smarty->left_delimiter;        $this->smarty_token_names['RDEL'] =	$this->smarty->right_delimiter;        $this->mbstring_overload = ini_get('mbstring.func_overload') & 2;     }    private $_yy_state = 1;    private $_yy_stack = array();    function yylex()    {        return $this->{'yylex' . $this->_yy_state}();    }    function yypushstate($state)    {        array_push($this->_yy_stack, $this->_yy_state);        $this->_yy_state = $state;    }    function yypopstate()    {        $this->_yy_state = array_pop($this->_yy_stack);    }    function yybegin($state)    {        $this->_yy_state = $state;    }    function yylex1()    {        $tokenMap = array (              1 => 0,              2 => 0,              3 => 1,              5 => 0,              6 => 0,              7 => 0,              8 => 0,              9 => 0,              10 => 0,              11 => 1,              13 => 0,              14 => 0,              15 => 0,              16 => 0,              17 => 0,              18 => 0,              19 => 0,              20 => 0,              21 => 0,              22 => 0,              23 => 0,            );        if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {            return false; // end of input        }        $yy_global_pattern = "/\G(".$this->ldel."[$]smarty\\.block\\.child".$this->rdel.")|\G(\\{\\})|\G(".$this->ldel."\\*([\S\s]*?)\\*".$this->rdel.")|\G(".$this->ldel."strip".$this->rdel.")|\G(".$this->ldel."\\s{1,}strip\\s{1,}".$this->rdel.")|\G(".$this->ldel."\/strip".$this->rdel.")|\G(".$this->ldel."\\s{1,}\/strip\\s{1,}".$this->rdel.")|\G(".$this->ldel."\\s*literal\\s*".$this->rdel.")|\G(".$this->ldel."\\s{1,}\/)|\G(".$this->ldel."\\s*(if|elseif|else if|while)\\s+)|\G(".$this->ldel."\\s*for\\s+)|\G(".$this->ldel."\\s*foreach(?![^\s]))|\G(".$this->ldel."\\s*setfilter\\s+)|\G(".$this->ldel."\\s{1,})|\G(".$this->ldel."\/)|\G(".$this->ldel.")|\G(<\\?(?:php\\w+|=|[a-zA-Z]+)?)|\G(\\?>)|\G(<%)|\G(%>)|\G([\S\s])/iS";        do {            if ($this->mbstring_overload ? preg_match($yy_global_pattern, mb_substr($this->data, $this->counter,2000000000,'latin1'), $yymatches) : preg_match($yy_global_pattern,$this->data, $yymatches, null, $this->counter)) {                $yysubmatches = $yymatches;                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns                if (!count($yymatches)) {                    throw new Exception('Error: lexing failed because a rule matched' .                        ' an empty string.  Input "' . substr($this->data,                        $this->counter, 5) . '... state TEXT');                }                next($yymatches); // skip global match                $this->token = key($yymatches); // token number                if ($tokenMap[$this->token]) {                    // extract sub-patterns for passing to lex function                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,                        $tokenMap[$this->token]);                } else {                    $yysubmatches = array();                }                $this->value = current($yymatches); // token value                $r = $this->{'yy_r1_' . $this->token}($yysubmatches);                if ($r === null) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    // accept this token                    return true;                } elseif ($r === true) {                    // we have changed state                    // process this token in the new state                    return $this->yylex();                } elseif ($r === false) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {                        return false; // end of input                    }                    // skip this token                    continue;                }            } else {                throw new Exception('Unexpected input at line' . $this->line .                    ': ' . $this->data[$this->counter]);            }            break;        } while (true);    } // end function    const TEXT = 1;    function yy_r1_1($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_SMARTYBLOCKCHILD;    }    function yy_r1_2($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_TEXT;    }    function yy_r1_3($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_COMMENT;    }    function yy_r1_5($yy_subpatterns)    {    $this->token = Smarty_Internal_Templateparser::TP_STRIPON;    }    function yy_r1_6($yy_subpatterns)    {  if ($this->smarty->auto_literal) {    $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {    $this->token = Smarty_Internal_Templateparser::TP_STRIPON;  }    }    function yy_r1_7($yy_subpatterns)    {    $this->token = Smarty_Internal_Templateparser::TP_STRIPOFF;    }    function yy_r1_8($yy_subpatterns)    {  if ($this->smarty->auto_literal) {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {    $this->token = Smarty_Internal_Templateparser::TP_STRIPOFF;  }    }    function yy_r1_9($yy_subpatterns)    {   $this->token = Smarty_Internal_Templateparser::TP_LITERALSTART;   $this->yypushstate(self::LITERAL);    }    function yy_r1_10($yy_subpatterns)    {  if ($this->smarty->auto_literal) {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELSLASH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r1_11($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELIF;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r1_13($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELFOR;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r1_14($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELFOREACH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r1_15($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELSETFILTER;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r1_16($yy_subpatterns)    {  if ($this->smarty->auto_literal) {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDEL;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r1_17($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LDELSLASH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;    }    function yy_r1_18($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LDEL;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;    }    function yy_r1_19($yy_subpatterns)    {  if (in_array($this->value, Array('<?', '<?=', '<?php'))) {    $this->token = Smarty_Internal_Templateparser::TP_PHPSTARTTAG;  } elseif ($this->value == '<?xml') {      $this->token = Smarty_Internal_Templateparser::TP_XMLTAG;  } else {    $this->token = Smarty_Internal_Templateparser::TP_FAKEPHPSTARTTAG;    $this->value = substr($this->value, 0, 2);  }     }    function yy_r1_20($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_PHPENDTAG;    }    function yy_r1_21($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ASPSTARTTAG;    }    function yy_r1_22($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ASPENDTAG;    }    function yy_r1_23($yy_subpatterns)    {  if ($this->mbstring_overload) {    $to = mb_strlen($this->data,'latin1');  } else {    $to = strlen($this->data);  }  preg_match("/{$this->ldel}|<\?|\?>|<%|%>/",$this->data,$match,PREG_OFFSET_CAPTURE,$this->counter);  if (isset($match[0][1])) {    $to = $match[0][1];  }  if ($this->mbstring_overload) {    $this->value = mb_substr($this->data,$this->counter,$to-$this->counter,'latin1');  } else {    $this->value = substr($this->data,$this->counter,$to-$this->counter);  }  $this->token = Smarty_Internal_Templateparser::TP_TEXT;    }    function yylex2()    {        $tokenMap = array (              1 => 0,              2 => 0,              3 => 1,              5 => 0,              6 => 0,              7 => 0,              8 => 0,              9 => 0,              10 => 0,              11 => 0,              12 => 0,              13 => 0,              14 => 0,              15 => 0,              16 => 0,              17 => 0,              18 => 0,              19 => 0,              20 => 1,              22 => 1,              24 => 1,              26 => 0,              27 => 0,              28 => 0,              29 => 0,              30 => 0,              31 => 0,              32 => 0,              33 => 0,              34 => 0,              35 => 0,              36 => 0,              37 => 0,              38 => 0,              39 => 0,              40 => 0,              41 => 0,              42 => 0,              43 => 3,              47 => 0,              48 => 0,              49 => 0,              50 => 0,              51 => 0,              52 => 0,              53 => 0,              54 => 0,              55 => 1,              57 => 1,              59 => 0,              60 => 0,              61 => 0,              62 => 0,              63 => 0,              64 => 0,              65 => 0,              66 => 0,              67 => 0,              68 => 0,              69 => 0,              70 => 0,              71 => 0,              72 => 0,              73 => 0,              74 => 0,              75 => 0,              76 => 0,              77 => 0,            );        if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {            return false; // end of input        }        $yy_global_pattern = "/\G('[^'\\\\]*(?:\\\\.[^'\\\\]*)*')|\G(".$this->ldel."\\s{1,}\/)|\G(".$this->ldel."\\s*(if|elseif|else if|while)\\s+)|\G(".$this->ldel."\\s*for\\s+)|\G(".$this->ldel."\\s*foreach(?![^\s]))|\G(".$this->ldel."\\s{1,})|\G(\\s{1,}".$this->rdel.")|\G(".$this->ldel."\/)|\G(".$this->ldel.")|\G(".$this->rdel.")|\G(\\s+is\\s+in\\s+)|\G(\\s+as\\s+)|\G(\\s+to\\s+)|\G(\\s+step\\s+)|\G(\\s+instanceof\\s+)|\G(\\s*===\\s*)|\G(\\s*!==\\s*)|\G(\\s*==\\s*|\\s+eq\\s+)|\G(\\s*!=\\s*|\\s*<>\\s*|\\s+(ne|neq)\\s+)|\G(\\s*>=\\s*|\\s+(ge|gte)\\s+)|\G(\\s*<=\\s*|\\s+(le|lte)\\s+)|\G(\\s*>\\s*|\\s+gt\\s+)|\G(\\s*<\\s*|\\s+lt\\s+)|\G(\\s+mod\\s+)|\G(!\\s*|not\\s+)|\G(\\s*&&\\s*|\\s*and\\s+)|\G(\\s*\\|\\|\\s*|\\s*or\\s+)|\G(\\s*xor\\s+)|\G(\\s+is\\s+odd\\s+by\\s+)|\G(\\s+is\\s+not\\s+odd\\s+by\\s+)|\G(\\s+is\\s+odd)|\G(\\s+is\\s+not\\s+odd)|\G(\\s+is\\s+even\\s+by\\s+)|\G(\\s+is\\s+not\\s+even\\s+by\\s+)|\G(\\s+is\\s+even)|\G(\\s+is\\s+not\\s+even)|\G(\\s+is\\s+div\\s+by\\s+)|\G(\\s+is\\s+not\\s+div\\s+by\\s+)|\G(\\((int(eger)?|bool(ean)?|float|double|real|string|binary|array|object)\\)\\s*)|\G(\\s*\\(\\s*)|\G(\\s*\\))|\G(\\[\\s*)|\G(\\s*\\])|\G(\\s*->\\s*)|\G(\\s*=>\\s*)|\G(\\s*=\\s*)|\G(\\+\\+|--)|\G(\\s*(\\+|-)\\s*)|\G(\\s*(\\*|\/|%)\\s*)|\G(\\$)|\G(\\s*;)|\G(::)|\G(\\s*:\\s*)|\G(@)|\G(#)|\G(\")|\G(`)|\G(\\|)|\G(\\.)|\G(\\s*,\\s*)|\G(\\s*&\\s*)|\G(\\s*\\?\\s*)|\G(0[xX][0-9a-fA-F]+)|\G(\\s+[0-9]*[a-zA-Z_][a-zA-Z0-9_\-:]*\\s?=\\s?)|\G([0-9]*[a-zA-Z_]\\w*)|\G(\\d+)|\G(\\s+)|\G([\S\s])/iS";        do {            if ($this->mbstring_overload ? preg_match($yy_global_pattern, mb_substr($this->data, $this->counter,2000000000,'latin1'), $yymatches) : preg_match($yy_global_pattern,$this->data, $yymatches, null, $this->counter)) {                $yysubmatches = $yymatches;                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns                if (!count($yymatches)) {                    throw new Exception('Error: lexing failed because a rule matched' .                        ' an empty string.  Input "' . substr($this->data,                        $this->counter, 5) . '... state SMARTY');                }                next($yymatches); // skip global match                $this->token = key($yymatches); // token number                if ($tokenMap[$this->token]) {                    // extract sub-patterns for passing to lex function                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,                        $tokenMap[$this->token]);                } else {                    $yysubmatches = array();                }                $this->value = current($yymatches); // token value                $r = $this->{'yy_r2_' . $this->token}($yysubmatches);                if ($r === null) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    // accept this token                    return true;                } elseif ($r === true) {                    // we have changed state                    // process this token in the new state                    return $this->yylex();                } elseif ($r === false) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {                        return false; // end of input                    }                    // skip this token                    continue;                }            } else {                throw new Exception('Unexpected input at line' . $this->line .                    ': ' . $this->data[$this->counter]);            }            break;        } while (true);    } // end function    const SMARTY = 2;    function yy_r2_1($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_SINGLEQUOTESTRING;    }    function yy_r2_2($yy_subpatterns)    {  if ($this->smarty->auto_literal) {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELSLASH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r2_3($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELIF;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r2_5($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELFOR;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r2_6($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELFOREACH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r2_7($yy_subpatterns)    {  if ($this->smarty->auto_literal) {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDEL;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r2_8($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_RDEL;  $this->yypopstate();    }    function yy_r2_9($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LDELSLASH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;    }    function yy_r2_10($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LDEL;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;    }    function yy_r2_11($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_RDEL;     $this->yypopstate();    }    function yy_r2_12($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISIN;    }    function yy_r2_13($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_AS;    }    function yy_r2_14($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_TO;    }    function yy_r2_15($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_STEP;    }    function yy_r2_16($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_INSTANCEOF;    }    function yy_r2_17($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_IDENTITY;    }    function yy_r2_18($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_NONEIDENTITY;    }    function yy_r2_19($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_EQUALS;    }    function yy_r2_20($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_NOTEQUALS;    }    function yy_r2_22($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_GREATEREQUAL;    }    function yy_r2_24($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LESSEQUAL;    }    function yy_r2_26($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_GREATERTHAN;    }    function yy_r2_27($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LESSTHAN;    }    function yy_r2_28($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_MOD;    }    function yy_r2_29($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_NOT;    }    function yy_r2_30($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LAND;    }    function yy_r2_31($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LOR;    }    function yy_r2_32($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LXOR;    }    function yy_r2_33($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISODDBY;    }    function yy_r2_34($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISNOTODDBY;    }    function yy_r2_35($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISODD;    }    function yy_r2_36($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISNOTODD;    }    function yy_r2_37($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISEVENBY;    }    function yy_r2_38($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISNOTEVENBY;    }    function yy_r2_39($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISEVEN;    }    function yy_r2_40($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISNOTEVEN;    }    function yy_r2_41($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISDIVBY;    }    function yy_r2_42($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ISNOTDIVBY;    }    function yy_r2_43($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_TYPECAST;    }    function yy_r2_47($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_OPENP;    }    function yy_r2_48($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_CLOSEP;    }    function yy_r2_49($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_OPENB;    }    function yy_r2_50($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_CLOSEB;    }    function yy_r2_51($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_PTR;    }    function yy_r2_52($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_APTR;    }    function yy_r2_53($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_EQUAL;    }    function yy_r2_54($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_INCDEC;    }    function yy_r2_55($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_UNIMATH;    }    function yy_r2_57($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_MATH;    }    function yy_r2_59($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_DOLLAR;    }    function yy_r2_60($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_SEMICOLON;    }    function yy_r2_61($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_DOUBLECOLON;    }    function yy_r2_62($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_COLON;    }    function yy_r2_63($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_AT;    }    function yy_r2_64($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_HATCH;    }    function yy_r2_65($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_QUOTE;  $this->yypushstate(self::DOUBLEQUOTEDSTRING);    }    function yy_r2_66($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_BACKTICK;  $this->yypopstate();    }    function yy_r2_67($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_VERT;    }    function yy_r2_68($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_DOT;    }    function yy_r2_69($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_COMMA;    }    function yy_r2_70($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ANDSYM;    }    function yy_r2_71($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_QMARK;    }    function yy_r2_72($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_HEX;    }    function yy_r2_73($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ATTR;    }    function yy_r2_74($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ID;    }    function yy_r2_75($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_INTEGER;    }    function yy_r2_76($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_SPACE;    }    function yy_r2_77($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_TEXT;    }    function yylex3()    {        $tokenMap = array (              1 => 0,              2 => 0,              3 => 0,              4 => 0,              5 => 0,              6 => 0,              7 => 0,            );        if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {            return false; // end of input        }        $yy_global_pattern = "/\G(".$this->ldel."\\s*literal\\s*".$this->rdel.")|\G(".$this->ldel."\\s*\/literal\\s*".$this->rdel.")|\G(<\\?(?:php\\w+|=|[a-zA-Z]+)?)|\G(\\?>)|\G(<%)|\G(%>)|\G([\S\s])/iS";        do {            if ($this->mbstring_overload ? preg_match($yy_global_pattern, mb_substr($this->data, $this->counter,2000000000,'latin1'), $yymatches) : preg_match($yy_global_pattern,$this->data, $yymatches, null, $this->counter)) {                $yysubmatches = $yymatches;                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns                if (!count($yymatches)) {                    throw new Exception('Error: lexing failed because a rule matched' .                        ' an empty string.  Input "' . substr($this->data,                        $this->counter, 5) . '... state LITERAL');                }                next($yymatches); // skip global match                $this->token = key($yymatches); // token number                if ($tokenMap[$this->token]) {                    // extract sub-patterns for passing to lex function                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,                        $tokenMap[$this->token]);                } else {                    $yysubmatches = array();                }                $this->value = current($yymatches); // token value                $r = $this->{'yy_r3_' . $this->token}($yysubmatches);                if ($r === null) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    // accept this token                    return true;                } elseif ($r === true) {                    // we have changed state                    // process this token in the new state                    return $this->yylex();                } elseif ($r === false) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {                        return false; // end of input                    }                    // skip this token                    continue;                }            } else {                throw new Exception('Unexpected input at line' . $this->line .                    ': ' . $this->data[$this->counter]);            }            break;        } while (true);    } // end function    const LITERAL = 3;    function yy_r3_1($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LITERALSTART;  $this->yypushstate(self::LITERAL);    }    function yy_r3_2($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LITERALEND;  $this->yypopstate();    }    function yy_r3_3($yy_subpatterns)    {  if (in_array($this->value, Array('<?', '<?=', '<?php'))) {    $this->token = Smarty_Internal_Templateparser::TP_PHPSTARTTAG;   } else {    $this->token = Smarty_Internal_Templateparser::TP_FAKEPHPSTARTTAG;    $this->value = substr($this->value, 0, 2);   }    }    function yy_r3_4($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_PHPENDTAG;    }    function yy_r3_5($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ASPSTARTTAG;    }    function yy_r3_6($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_ASPENDTAG;    }    function yy_r3_7($yy_subpatterns)    {  if ($this->mbstring_overload) {    $to = mb_strlen($this->data,'latin1');  } else {    $to = strlen($this->data);  }  preg_match("/{$this->ldel}\/?literal{$this->rdel}|<\?|<%|\?>|%>/",$this->data,$match,PREG_OFFSET_CAPTURE,$this->counter);  if (isset($match[0][1])) {    $to = $match[0][1];  } else {    $this->compiler->trigger_template_error ("missing or misspelled literal closing tag");  }  if ($this->mbstring_overload) {    $this->value = mb_substr($this->data,$this->counter,$to-$this->counter,'latin1');  } else {    $this->value = substr($this->data,$this->counter,$to-$this->counter);  }  $this->token = Smarty_Internal_Templateparser::TP_LITERAL;    }    function yylex4()    {        $tokenMap = array (              1 => 0,              2 => 1,              4 => 0,              5 => 0,              6 => 0,              7 => 0,              8 => 0,              9 => 0,              10 => 0,              11 => 0,              12 => 0,              13 => 3,              17 => 0,            );        if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {            return false; // end of input        }        $yy_global_pattern = "/\G(".$this->ldel."\\s{1,}\/)|\G(".$this->ldel."\\s*(if|elseif|else if|while)\\s+)|\G(".$this->ldel."\\s*for\\s+)|\G(".$this->ldel."\\s*foreach(?![^\s]))|\G(".$this->ldel."\\s{1,})|\G(".$this->ldel."\/)|\G(".$this->ldel.")|\G(\")|\G(`\\$)|\G(\\$[0-9]*[a-zA-Z_]\\w*)|\G(\\$)|\G(([^\"\\\\]*?)((?:\\\\.[^\"\\\\]*?)*?)(?=(".$this->ldel."|\\$|`\\$|\")))|\G([\S\s])/iS";        do {            if ($this->mbstring_overload ? preg_match($yy_global_pattern, mb_substr($this->data, $this->counter,2000000000,'latin1'), $yymatches) : preg_match($yy_global_pattern,$this->data, $yymatches, null, $this->counter)) {                $yysubmatches = $yymatches;                $yymatches = array_filter($yymatches, 'strlen'); // remove empty sub-patterns                if (!count($yymatches)) {                    throw new Exception('Error: lexing failed because a rule matched' .                        ' an empty string.  Input "' . substr($this->data,                        $this->counter, 5) . '... state DOUBLEQUOTEDSTRING');                }                next($yymatches); // skip global match                $this->token = key($yymatches); // token number                if ($tokenMap[$this->token]) {                    // extract sub-patterns for passing to lex function                    $yysubmatches = array_slice($yysubmatches, $this->token + 1,                        $tokenMap[$this->token]);                } else {                    $yysubmatches = array();                }                $this->value = current($yymatches); // token value                $r = $this->{'yy_r4_' . $this->token}($yysubmatches);                if ($r === null) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    // accept this token                    return true;                } elseif ($r === true) {                    // we have changed state                    // process this token in the new state                    return $this->yylex();                } elseif ($r === false) {                    $this->counter += ($this->mbstring_overload ? mb_strlen($this->value,'latin1'): strlen($this->value));                    $this->line += substr_count($this->value, "\n");                    if ($this->counter >= ($this->mbstring_overload ? mb_strlen($this->data,'latin1'): strlen($this->data))) {                        return false; // end of input                    }                    // skip this token                    continue;                }            } else {                throw new Exception('Unexpected input at line' . $this->line .                    ': ' . $this->data[$this->counter]);            }            break;        } while (true);    } // end function    const DOUBLEQUOTEDSTRING = 4;    function yy_r4_1($yy_subpatterns)    {  if ($this->smarty->auto_literal) {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELSLASH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r4_2($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELIF;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r4_4($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELFOR;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r4_5($yy_subpatterns)    {  if ($this->smarty->auto_literal && trim(substr($this->value,$this->ldel_length,1)) == '') {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDELFOREACH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r4_6($yy_subpatterns)    {  if ($this->smarty->auto_literal) {     $this->token = Smarty_Internal_Templateparser::TP_TEXT;  } else {     $this->token = Smarty_Internal_Templateparser::TP_LDEL;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;  }    }    function yy_r4_7($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LDELSLASH;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;    }    function yy_r4_8($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_LDEL;     $this->yypushstate(self::SMARTY);     $this->taglineno = $this->line;    }    function yy_r4_9($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_QUOTE;  $this->yypopstate();    }    function yy_r4_10($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_BACKTICK;  $this->value = substr($this->value,0,-1);  $this->yypushstate(self::SMARTY);  $this->taglineno = $this->line;    }    function yy_r4_11($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_DOLLARID;    }    function yy_r4_12($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_TEXT;    }    function yy_r4_13($yy_subpatterns)    {  $this->token = Smarty_Internal_Templateparser::TP_TEXT;    }    function yy_r4_17($yy_subpatterns)    {  if ($this->mbstring_overload) {    $to = mb_strlen($this->data,'latin1');  } else {    $to = strlen($this->data);  }  if ($this->mbstring_overload) {    $this->value = mb_substr($this->data,$this->counter,$to-$this->counter,'latin1');  } else {    $this->value = substr($this->data,$this->counter,$to-$this->counter);  }  $this->token = Smarty_Internal_Templateparser::TP_TEXT;    }}?>
 |