X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=template.php;h=3c0e1e068806fde5a8ed57ad4093cfb39ce74f9b;hb=38773f50c9e89f547d2e190d2ae64a5fc39a038d;hp=239630cc8905af0a65e8c41563164626095362e0;hpb=5c65188ef82c668befd6dc5802af051706b0b05b;p=wfpl.git diff --git a/template.php b/template.php index 239630c..3c0e1e0 100644 --- a/template.php +++ b/template.php @@ -33,18 +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/basics.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(); } @@ -53,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]; @@ -63,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; } @@ -92,10 +109,19 @@ class tem { # this limits sub_template names to 50 chars 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); @@ -111,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 @@ -191,12 +219,15 @@ 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;