<?php
echo sqlTemplate("{{o}} {[a]} {{u:BLABLABLA {{a}} }}",array("o"=>"HELLO","a"=>array(1,323,452),"u"=>false));
function sqlTemplate($query,$vars){
$i = 0;$l = strlen($query);
$bigRecord = "";
while($i < $l){
if($query[$i] == '{' && ($query[$i+1] == '{' || $query[$i+1] == '[')){
$i+=2;
$end = false;
$level=0;
$record = $query[$i-1];
while($i < $l){
$record .= $query[$i];
if($query[$i] == '{' && ($query[$i+1] == '{' || $query[$i+1] == '[')) $level++;
if(($query[$i] == ']' || $query[$i] == '}') && $query[$i+1] == '}') $level--;
if($level==-1){
if($record[0] == '['){
$bigRecord .= implode(',',$vars[trim(substr($record,1,-1))]);
}else{
$pos = false;
if($pos = strpos($record, ':') !== false){
$varName = trim(substr($record,1,$pos-1));
die($varName);
if(isset($vars[$varName]) && $vars[$varName]){
$bigRecord .= sqlTemplate(substr($record,$pos+1,-1));
}
}else{
$bigRecord .= $vars[trim(substr($record,1,-1))];
}
}
$i++;
break;
}
$i++;
}
}else{
$bigRecord .= $query[$i];
}
$i++;
}
return $bigRecord;
}
preferences:
42.61 ms | 402 KiB | 5 Q