- bugfix on changes of 05/02/2010

This commit is contained in:
Uwe.Tews
2010-02-07 22:21:37 +00:00
parent d19fbb19d9
commit 7bfa54f067

View File

@@ -220,6 +220,8 @@ class Smarty extends Smarty_Internal_Data {
public $_dir_perms = 0771;
// smarty object reference
public $smarty = null;
// block data at template inheritance
public $block_data = array();
// generate deprecated function call notices?
public $deprecation_notices = true;
@@ -428,6 +430,13 @@ class Smarty extends Smarty_Internal_Data {
}
}
/**
* Disable security
*/
public function disableSecurity() {
$this->security = true;
}
/**
* Set template directory
*
@@ -449,13 +458,6 @@ class Smarty extends Smarty_Internal_Data {
return;
}
/**
* Enable Caching
*/
public function enableCaching() {
$this->caching = SMARTY_CACHING_LIFETIME_CURRENT;
return;
}
/**
* Check if a template resource exists
@@ -463,8 +465,7 @@ class Smarty extends Smarty_Internal_Data {
* @param string $resource_name template name
* @return boolean status
*/
function templateExists($resource_name)
{
function templateExists($resource_name) {
// create template object
$tpl = new $this->template_class($resource_name, $this);
// check if it does exists
@@ -526,8 +527,7 @@ class Smarty extends Smarty_Internal_Data {
* @param string $name filter name
* @return bool
*/
function loadFilter($type, $name)
{
function loadFilter($type, $name) {
$_plugin = "smarty_{$type}filter_{$name}";
$_filter_name = $_plugin;
if ($this->loadPlugin($_plugin)) {
@@ -568,16 +568,15 @@ class Smarty extends Smarty_Internal_Data {
*
* @param callback $function_name
*/
public function _get_filter_name($function_name)
{
if (is_array($function_name)) {
$_class_name = (is_object($function_name[0]) ?
get_class($function_name[0]) : $function_name[0]);
return $_class_name . '_' . $function_name[1];
}
else {
return $function_name;
}
public function _get_filter_name($function_name) {
if (is_array($function_name)) {
$_class_name = (is_object($function_name[0]) ?
get_class($function_name[0]) : $function_name[0]);
return $_class_name . '_' . $function_name[1];
}
else {
return $function_name;
}
}
/**
@@ -587,8 +586,7 @@ class Smarty extends Smarty_Internal_Data {
* @param string $ |array $ plugins folder
* @return
*/
function addPluginsDir($plugins_dir)
{
function addPluginsDir($plugins_dir) {
$this->plugins_dir = array_merge((array)$this->plugins_dir, (array)$plugins_dir);
$this->plugins_dir = array_unique($this->plugins_dir);
return;
@@ -601,15 +599,16 @@ class Smarty extends Smarty_Internal_Data {
* @param string $varname variable name or null
* @return string variable value or or array of variables
*/
function getGlobal($varname = null)
{
function getGlobal($varname = null) {
if (isset($varname)) {
if (isset($this->global_tpl_vars[$varname])) {
return $this->global_tpl_vars[$varname]->value;
} else {
}
else {
return '';
}
} else {
}
else {
$_result = array();
foreach ($this->global_tpl_vars AS $key => $var) {
$_result[$key] = $var->value;
@@ -624,13 +623,12 @@ class Smarty extends Smarty_Internal_Data {
* @param string $name object name
* @return object
*/
function getRegisteredObject($name)
{
function getRegisteredObject($name) {
if (!isset($this->registered_objects[$name]))
throw new Exception("'$name' is not a registered object");
throw new Exception("'$name' is not a registered object");
if (!is_object($this->registered_objects[$name][0]))
throw new Exception("registered '$name' is not an object");
throw new Exception("registered '$name' is not an object");
return $this->registered_objects[$name][0];
}
@@ -640,8 +638,7 @@ class Smarty extends Smarty_Internal_Data {
*
* @return string
*/
function getDebugTemplate()
{
function getDebugTemplate() {
return $this->debug_tpl;
}
@@ -651,8 +648,7 @@ class Smarty extends Smarty_Internal_Data {
* @param string $tpl_name
* @return bool
*/
function setDebugTemplate($tpl_name)
{
function setDebugTemplate($tpl_name) {
return $this->debug_tpl = $tpl_name;
}
@@ -662,8 +658,8 @@ class Smarty extends Smarty_Internal_Data {
* @param string $name property name
*/
public function __get($name) {
if(in_array($name,array('register','unregister','utility','cache'))) {
$class = "Smarty_Internal_".ucfirst($name);
if(in_array($name, array('register', 'unregister', 'utility', 'cache'))) {
$class = "Smarty_Internal_" . ucfirst($name);
return new $class($this);
}
return false;
@@ -680,34 +676,32 @@ class Smarty extends Smarty_Internal_Data {
public function __call($name, $args) {
static $camel_func;
if(!isset($camel_func))
$camel_func = create_function('$c', 'return "_" . strtolower($c[1]);');
$camel_func = create_function('$c', 'return "_" . strtolower($c[1]);');
// PHP4 call to constructor?
if (strtolower($name) == 'smarty') {
throw new Exception('Please use parent::__construct() to call parent constuctor');
return false;
}
// see if this is a set/get for a property
$first3 = strtolower(substr($name,0,3));
if(in_array($first3,array('set','get')) && substr($name,3,1) !== '_') {
// try to keep case correct for future PHP 6.0 case-sensitive class methods
// lcfirst() not available < PHP 5.3.0, so improvise
$property_name = strtolower(substr($name,3,1)).substr($name,4);
// convert camel case to underscored name
$property_name = preg_replace_callback('/([A-Z])/', $camel_func, $property_name);
if(!property_exists($this,$property_name)) {
throw new Exception("property '$property_name' does not exist.");
return false;
}
if($first3 == 'get')
return $this->$property_name;
else
return $this->$property_name = $args[0];
$first3 = strtolower(substr($name, 0, 3));
if(in_array($first3, array('set', 'get')) && substr($name, 3, 1) !== '_') {
// try to keep case correct for future PHP 6.0 case-sensitive class methods
// lcfirst() not available < PHP 5.3.0, so improvise
$property_name = strtolower(substr($name, 3, 1)) . substr($name, 4);
// convert camel case to underscored name
$property_name = preg_replace_callback('/([A-Z])/', $camel_func, $property_name);
if(!property_exists($this, $property_name)) {
throw new Exception("property '$property_name' does not exist.");
return false;
}
if($first3 == 'get')
return $this->$property_name;
else
return $this->$property_name = $args[0];
}
// Smarty Backward Compatible wrapper
if(!isset($this->wrapper)) {
$this->wrapper = new Smarty_Internal_Wrapper($this);
$this->wrapper = new Smarty_Internal_Wrapper($this);
}
return $this->wrapper->convert($name, $args);