X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=template.php;h=3c0e1e068806fde5a8ed57ad4093cfb39ce74f9b;hb=38773f50c9e89f547d2e190d2ae64a5fc39a038d;hp=c56e7436236b4f305565ccc9caccde0525768888;hpb=3bec0ef771d741361c6c4c4c1ff069398f6e37a0;p=wfpl.git diff --git a/template.php b/template.php index c56e743..3c0e1e0 100644 --- a/template.php +++ b/template.php @@ -33,17 +33,22 @@ # tem_output('filename.html') to output the page. A more complex example # including the use of sub-templates can be found in tem_test.php +# FIXME: sub-sub templates need to be cleared when the sub template containing +# them is run + require_once('code/wfpl/encode.php'); +require_once('code/wfpl/misc.php'); # to get read_whole_file() class tem { var $keyval; # an array containing key/value pairs - var $filename; # template filename (sometimes unset) + var $filename; # template filename (sometimes not set) var $template; # contents of template var $sub_templates; # tag-name/template-string pairs + var $sub_subs; # key: sub-template name value: array of names of the sub-templates of this one # initialize variables function tem() { - $this->keyval = array('' => '~'); + $this->keyval = array('' => '~'); # so that ~~ in the template creates a single ~ $this->sub_templates = array(); } @@ -52,6 +57,11 @@ class tem { $this->keyval[$key] = $value; } + # clear a value. Functionally equivalent to set($key, '') but cleaner and more efficient + function clear($key) { + unset($this->keyval[$key]); + } + # grab a value you stuck in earlier with set() function get($key) { return $this->keyval[$key]; @@ -62,10 +72,17 @@ class tem { # this can be used. function sub($sub_template_name) { $this->keyval[$sub_template_name] .= template_run($this->sub_templates[$sub_template_name], $this->keyval); + + # after running a sub-template, clear its sub-templates + if(isset($this->sub_subs[$sub_template_name])) { + foreach($this->sub_subs[$sub_template_name] as $sub_sub) { + $this->clear($sub_sub); + } + } } # this is used by tem::load() and should be otherwise useless - function _load(&$in, &$out) { + function _load(&$in, &$out, &$parents, &$parent) { while($in) { # scan for one of: 1) the begining of a sub-template 2) the end of this one 3) the end of the file $n = strpos($in, '', substr($in, 0, 12)) == 0) { $in = substr($in, 12); + $parent = array_pop($parents); return; } $matches = array(); # this limits sub_template names to 50 chars - if(ereg('', substr($in, 0, 65), $matches)) { + if(ereg('^', substr($in, 0, 65), $matches)) { list($start_tag, $tag_name) = $matches; + + # keep track of the tree + if(!isset($this->sub_subs[$parent])) { + $this->sub_subs[$parent] = array(); + } + array_push($this->sub_subs[$parent], $tag_name); + array_push($parents, $parent); + $parent = $tag_name; + $out .= '~' . $tag_name . '~'; $in = substr($in, strlen($start_tag)); $this->sub_templates[$tag_name] = ''; - $this->_load($in, $this->sub_templates[$tag_name]); + $this->_load($in, $this->sub_templates[$tag_name], $parents, $parent); } else { # it's not a start tag or end tag, so let's pass it through: $out .= substr($in, 0, 5); @@ -109,7 +137,9 @@ class tem { $this->filename = $filename; $tmp = read_whole_file($filename); $this->template = ''; - $this->_load($tmp, $this->template); + $parents = array('top_level_subs' => array()); + $parent = 'top_level_subs'; + $this->_load($tmp, $this->template, $parents, $parent); } # Run the template. Pass a filename, or a string, unless you've already @@ -184,27 +214,20 @@ function tem_output($filename = false) { -function read_whole_file($name) { - $fd = fopen($name, 'r'); - if($fd === false) { - die("Failed to read file: '$name'"); - } - $temp = fread($fd, filesize($name)); - fclose($fd); - return $temp; -} - # this is used in template_run() and should be of no other use function template_filler($matches) { list($tag, $enc) = explode('.', $matches[1], 2); $value = $GLOBALS['wfpl_template_keyval'][$tag]; if($enc) { - $enc = "enc_$enc"; - if(function_exists($enc)) { - $value = $enc($value); - } else { - print "ERROR: encoder function '$enc' not found.
\n"; - exit(1); + $encs = explode('.', $enc); + foreach($encs as $enc) { + $enc = "enc_$enc"; + if(function_exists($enc)) { + $value = $enc($value); + } else { + print "ERROR: encoder function '$enc' not found.
\n"; + exit(1); + } } } return $value;