added opendir() error handling

This commit is contained in:
following 2013-04-11 20:38:02 +02:00
parent c594dfa443
commit ffc9b68081
3 changed files with 21 additions and 16 deletions

View File

@ -51,14 +51,17 @@ function smarty_core_rm_auto($params, &$smarty)
$_res = smarty_core_rmdir($_params, $smarty);
} else {
// remove matching file names
$_handle = opendir($params['auto_base']);
$_res = true;
while (false !== ($_filename = readdir($_handle))) {
if($_filename == '.' || $_filename == '..') {
continue;
} elseif (substr($params['auto_base'] . DIRECTORY_SEPARATOR . $_filename, 0, strlen($_tname)) == $_tname) {
$_res &= (bool)$smarty->_unlink($params['auto_base'] . DIRECTORY_SEPARATOR . $_filename, $params['exp_time']);
}
$_res = false;
if ($_handle = opendir($params['auto_base']))
{
$_res = true;
while (false !== ($_filename = readdir($_handle))) {
if($_filename == '.' || $_filename == '..') {
continue;
} elseif (substr($params['auto_base'] . DIRECTORY_SEPARATOR . $_filename, 0, strlen($_tname)) == $_tname) {
$_res &= (bool)$smarty->_unlink($params['auto_base'] . DIRECTORY_SEPARATOR . $_filename, $params['exp_time']);
}
}
}
}
}

View File

@ -164,19 +164,21 @@ if (substr($folder,-1) != '/')
}
$fileList = array();
$handle = opendir($folder);
while (false !== ($file = readdir($handle)))
if ($handle = opendir($folder))
{
if (is_file($file))
while (false !== ($file = readdir($handle)))
{
$file_info = pathinfo($file);
if (isset($extList[strtolower($file_info['extension'])]))
if (is_file($file))
{
$fileList[] = $file;
$file_info = pathinfo($file);
if (isset($extList[strtolower($file_info['extension'])]))
{
$fileList[] = $file;
}
}
}
closedir($handle);
}
closedir($handle);
if (count($fileList) > 0)
{

View File

@ -1093,7 +1093,7 @@ function unlinkrecursiv($path)
$notunlinked = 0;
$hDir = opendir($path);
if ($hDir === FALSE)
if ($hDir === false)
++$notunlinked;
else
{