fixed cache_paths bug, simplified filename assembly logic

This commit is contained in:
mohrt
2003-06-24 15:45:02 +00:00
parent 2f711dc162
commit 769008b763
3 changed files with 20 additions and 37 deletions

View File

@@ -1165,13 +1165,21 @@ class Smarty
{
static $_cache_info = array();
$this->_cache_paths_file = $this->compile_dir
define('SMARTY_COMPILE_DIR_SEP', $this->use_sub_dirs ? DIRECTORY_SEPARATOR : '^');
$this->_cache_paths_file =
$this->compile_dir
. DIRECTORY_SEPARATOR
. '_smarty_cached_paths'
. DIRECTORY_SEPARATOR
. SMARTY_COMPILE_DIR_SEP
. urlencode($resource_name)
. '.php';
if(!$this->force_compile
&& file_exists($this->_cache_paths_file)) {
include_once($this->_cache_paths_file);
}
$_smarty_old_error_level = $this->debugging ? error_reporting() : error_reporting(error_reporting() & ~E_NOTICE);
if($this->security && !in_array($this->template_dir, $this->secure_dir)) {
@@ -1415,11 +1423,6 @@ class Smarty
if (isset($this->_cache_paths['plugins'][$_cache_paths_key])) {
return $this->_cache_paths['plugins'][$_cache_paths_key];
}
if (!$this->force_compile
&& !isset($this->_cache_paths)
&& file_exists($this->_cache_paths_file)) {
include_once($this->_cache_paths_file);
}
$_params = array('type' => $type, 'name' => $name);
require_once(SMARTY_DIR . 'core' . DIRECTORY_SEPARATOR . 'core.assemble_plugin_filepath.php');
@@ -1685,11 +1688,6 @@ class Smarty
if (isset($this->_cache_paths['auto_file'][$_cache_paths_key])) {
return $this->_cache_paths['auto_file'][$_cache_paths_key];
}
if(!$this->force_compile
&& !isset($this->_cache_paths)
&& file_exists($this->_cache_paths_file)) {
include_once($this->_cache_paths_file);
}
$_params = array('auto_base' => $auto_base, 'auto_source' => $auto_source, 'auto_id' => $auto_id);
require_once(SMARTY_DIR . 'core' . DIRECTORY_SEPARATOR . 'core.assemble_auto_filename.php');

View File

@@ -17,17 +17,6 @@
*/
function smarty_core_assemble_auto_filename($params, &$smarty)
{
static $_dir_sep = null;
static $_dir_sep_enc = null;
if(!isset($_dir_sep)) {
$_dir_sep_enc = urlencode(DIRECTORY_SEPARATOR);
if($smarty->use_sub_dirs) {
$_dir_sep = DIRECTORY_SEPARATOR;
} else {
$_dir_sep = '^';
}
}
if(@is_dir($params['auto_base'])) {
$_return = $params['auto_base'] . DIRECTORY_SEPARATOR;
@@ -43,22 +32,18 @@ function smarty_core_assemble_auto_filename($params, &$smarty)
// make auto_id safe for directory names
$params['auto_id'] = str_replace('%7C','|',(urlencode($params['auto_id'])));
// split into separate directories
$params['auto_id'] = str_replace('|', $_dir_sep, $params['auto_id']);
$_return .= $params['auto_id'] . $_dir_sep;
$params['auto_id'] = str_replace('|', SMARTY_COMPILE_DIR_SEP, $params['auto_id']);
$_return .= $params['auto_id'] . SMARTY_COMPILE_DIR_SEP;
}
if(isset($params['auto_source'])) {
// make source name safe for filename
if($smarty->use_sub_dirs) {
$_filename = urlencode(basename($params['auto_source']));
$_crc32 = crc32($params['auto_source']) . $_dir_sep;
$_crc32 = crc32($params['auto_source']) . SMARTY_COMPILE_DIR_SEP;
// prepend %% to avoid name conflicts with
// with $params['auto_id'] names
$_crc32 = '%%' . substr($_crc32,0,3) . $_dir_sep . '%%' . $_crc32;
$_crc32 = '%%' . substr($_crc32,0,3) . SMARTY_COMPILE_DIR_SEP . '%%' . $_crc32;
$_return .= $_crc32 . $_filename;
} else {
$_return .= str_replace($_dir_sep_enc,'^',urlencode($params['auto_source']));
}
}
return $_return;

View File

@@ -15,7 +15,7 @@
function smarty_core_write_cache_paths_file($params, &$smarty)
{
$_compiled_content = function_exists('var_export') ? var_export($smarty->_cache_paths, true) : "unserialize('" . serialize($smarty->_cache_paths) . "')";
$_compiled_content = '<?php $smarty->_cache_paths = ' . $_compiled_content . '; ?>';
$_compiled_content = '<?php $this->_cache_paths = ' . $_compiled_content . '; ?>';
$_params = array('compile_path' => $smarty->_cache_paths_file, 'compiled_content' => $_compiled_content, 'resource_timestamp' => time());
require_once(SMARTY_DIR . 'core' . DIRECTORY_SEPARATOR . 'core.write_compiled_resource.php');
return smarty_core_write_compiled_resource($_params, $smarty);