X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=include%2Ftemplate_processor.php;h=83f680f0262a43983f11bbaaf2732e95b2ef4808;hb=96342878398e394173ba1a2dd825afbcb19e7199;hp=3f79ed5933925e731e724fdd1468fb5813107226;hpb=bb73c0b9f307accaa284820aaa11852c8481682f;p=friendica.git diff --git a/include/template_processor.php b/include/template_processor.php index 3f79ed5933..83f680f026 100644 --- a/include/template_processor.php +++ b/include/template_processor.php @@ -7,6 +7,7 @@ var $stack = array(); var $nodes = array(); var $done = false; + var $d = false; private function _preg_error(){ switch(preg_last_error()){ @@ -16,7 +17,8 @@ case PREG_BAD_UTF8_ERROR: die('PREG_BAD_UTF8_ERROR'); break; case PREG_BAD_UTF8_OFFSET_ERROR: die('PREG_BAD_UTF8_OFFSET_ERROR'); break; default: - die("Unknown preg error."); + //die("Unknown preg error."); + return; } } @@ -38,10 +40,11 @@ } private function _pop_stack(){ list($this->r, $this->search, $this->replace, $this->nodes) = array_pop($this->stack); + } private function _get_var($name){ - $keys = array_map('trim',explode(".",$name)); + $keys = array_map('trim',explode(".",$name)); $val = $this->r; foreach($keys as $k) { $val = $val[$k]; @@ -57,7 +60,6 @@ * {{ if <$var>!= }}...[{{ else }} ...]{{ endif }} */ private function _replcb_if($args){ - if (strpos($args[2],"==")>0){ list($a,$b) = array_map("trim",explode("==",$args[2])); $a = $this->_get_var($a); @@ -72,7 +74,6 @@ $val = $this->_get_var($args[2]); } list($strue, $sfalse)= preg_split("|{{ *else *}}|", $args[3]); - return ($val?$strue:$sfalse); } @@ -164,8 +165,13 @@ $s = $this->_build_nodes($s); $s = preg_replace_callback('/\|\|([0-9]+)\|\|/', array($this, "_replcb_node"), $s); if ($s==Null) $this->_preg_error(); - $s = str_replace($this->search,$this->replace, $s); + // replace strings recursively (limit to 10 loops) + $os = ""; $count=0; + while($os!=$s && $count<10){ + $os=$s; $count++; + $s = str_replace($this->search,$this->replace, $s); + } return $s; } }