aboutsummaryrefslogtreecommitdiffstats
path: root/phpBB/includes/functions_template.php
diff options
context:
space:
mode:
authorMeik Sievertsen <acydburn@phpbb.com>2006-04-17 13:09:50 +0000
committerMeik Sievertsen <acydburn@phpbb.com>2006-04-17 13:09:50 +0000
commita0f8e1323a0fb50e6a4b7449f93b493377eddd2c (patch)
treead60ba619c483e390bf767c70ff7c160e087daf5 /phpBB/includes/functions_template.php
parent8c2f02ca00b41d7aa3282aaacfbf2674a5347a14 (diff)
downloadforums-a0f8e1323a0fb50e6a4b7449f93b493377eddd2c.tar
forums-a0f8e1323a0fb50e6a4b7449f93b493377eddd2c.tar.gz
forums-a0f8e1323a0fb50e6a4b7449f93b493377eddd2c.tar.bz2
forums-a0f8e1323a0fb50e6a4b7449f93b493377eddd2c.tar.xz
forums-a0f8e1323a0fb50e6a4b7449f93b493377eddd2c.zip
- clean up marklist calls (global function)
- added new feature: test out others permissions (admin permissions will not be copied) - changed attachment processing by directly using the template engine - fixed some attachment related bugs - additional tiny fixes git-svn-id: file:///svn/phpbb/trunk@5790 89ea8834-ac86-4346-8a33-228a782c2dd0
Diffstat (limited to 'phpBB/includes/functions_template.php')
-rw-r--r--phpBB/includes/functions_template.php51
1 files changed, 25 insertions, 26 deletions
diff --git a/phpBB/includes/functions_template.php b/phpBB/includes/functions_template.php
index bf70f174d3..ec573d229e 100644
--- a/phpBB/includes/functions_template.php
+++ b/phpBB/includes/functions_template.php
@@ -40,6 +40,10 @@ class template_compile
{
var $template;
+ // Various storage arrays
+ var $block_names = array();
+ var $block_else_level = array();
+
/**
* constuctor
*/
@@ -120,57 +124,54 @@ class template_compile
switch ($blocks[1][$curr_tb])
{
case 'BEGIN':
- $this->template->block_else_level[] = false;
+ $this->block_else_level[] = false;
$compile_blocks[] = '<?php ' . $this->compile_tag_block($blocks[2][$curr_tb]) . ' ?>';
- break;
+ break;
case 'BEGINELSE':
- $this->template->block_else_level[sizeof($this->template->block_else_level) - 1] = true;
+ $this->block_else_level[sizeof($this->block_else_level) - 1] = true;
$compile_blocks[] = '<?php }} else { ?>';
- break;
+ break;
case 'END':
- array_pop($this->template->block_names);
- $compile_blocks[] = '<?php ' . ((array_pop($this->template->block_else_level)) ? '}' : '}}') . ' ?>';
- break;
+ array_pop($this->block_names);
+ $compile_blocks[] = '<?php ' . ((array_pop($this->block_else_level)) ? '}' : '}}') . ' ?>';
+ break;
case 'IF':
$compile_blocks[] = '<?php ' . $this->compile_tag_if($blocks[2][$curr_tb], false) . ' ?>';
- break;
+ break;
case 'ELSE':
$compile_blocks[] = '<?php } else { ?>';
- break;
+ break;
case 'ELSEIF':
$compile_blocks[] = '<?php ' . $this->compile_tag_if($blocks[2][$curr_tb], true) . ' ?>';
- break;
+ break;
case 'ENDIF':
$compile_blocks[] = '<?php } ?>';
- break;
+ break;
case 'DEFINE':
$compile_blocks[] = '<?php ' . $this->compile_tag_define($blocks[2][$curr_tb], true) . ' ?>';
- break;
+ break;
case 'UNDEFINE':
$compile_blocks[] = '<?php ' . $this->compile_tag_define($blocks[2][$curr_tb], false) . ' ?>';
- break;
+ break;
case 'INCLUDE':
- $temp = '';
- list(, $temp) = each($include_blocks);
+ $temp = array_shift($include_blocks);
$compile_blocks[] = '<?php ' . $this->compile_tag_include($temp) . ' ?>';
$this->template->_tpl_include($temp, false);
- break;
+ break;
case 'INCLUDEPHP':
if ($config['tpl_php'])
{
- $temp = '';
- list(, $temp) = each($includephp_blocks);
- $compile_blocks[] = '<?php ' . $this->compile_tag_include_php($temp) . ' ?>';
+ $compile_blocks[] = '<?php ' . $this->compile_tag_include_php(array_shift($includephp_blocks)) . ' ?>';
}
else
{
@@ -181,9 +182,7 @@ class template_compile
case 'PHP':
if ($config['tpl_php'])
{
- $temp = '';
- list(, $temp) = each($php_blocks);
- $compile_blocks[] = '<?php ' . $temp . ' ?>';
+ $compile_blocks[] = '<?php ' . array_shift($php_blocks) . ' ?>';
}
else
{
@@ -306,9 +305,9 @@ class template_compile
}
$tag_template_php = '';
- array_push($this->template->block_names, $tag_args);
+ array_push($this->block_names, $tag_args);
- if (sizeof($this->template->block_names) < 2)
+ if (sizeof($this->block_names) < 2)
{
// Block is not nested.
$tag_template_php = '$_' . $tag_args . "_count = (isset(\$this->_tpldata['$tag_args'])) ? sizeof(\$this->_tpldata['$tag_args']) : 0;";
@@ -321,11 +320,11 @@ class template_compile
if ($no_nesting !== false)
{
// We need to implode $no_nesting times from the end...
- $namespace = implode('.', array_slice($this->template->block_names, -$no_nesting));
+ $namespace = implode('.', array_slice($this->block_names, -$no_nesting));
}
else
{
- $namespace = implode('.', $this->template->block_names);
+ $namespace = implode('.', $this->block_names);
}
// Get a reference to the data array for this block that depends on the