check if folder is not empty (may happen for absolute paths). Thanks paul

git-svn-id: file:///svn/phpbb/trunk@8640 89ea8834-ac86-4346-8a33-228a782c2dd0
This commit is contained in:
Meik Sievertsen 2008-06-09 17:46:41 +00:00
parent e199f55ba2
commit 50f5502cc9

View file

@ -177,7 +177,7 @@ class compress_zip extends compress
* Extract archive * Extract archive
*/ */
public function extract($dst) public function extract($dst)
{ {
// Loop the file, looking for files and folders // Loop the file, looking for files and folders
$dd_try = false; $dd_try = false;
rewind($this->fp); rewind($this->fp);
@ -213,6 +213,12 @@ class compress_zip extends compress
// Create and folders and subfolders if they do not exist // Create and folders and subfolders if they do not exist
foreach ($folders as $folder) foreach ($folders as $folder)
{ {
$folder = trim($folder);
if (!$folder)
{
continue;
}
$str = (!empty($str)) ? $str . '/' . $folder : $folder; $str = (!empty($str)) ? $str . '/' . $folder : $folder;
if (!is_dir($str)) if (!is_dir($str))
{ {
@ -236,6 +242,12 @@ class compress_zip extends compress
// Create and folders and subfolders if they do not exist // Create and folders and subfolders if they do not exist
foreach ($folders as $folder) foreach ($folders as $folder)
{ {
$folder = trim($folder);
if (!$folder)
{
continue;
}
$str = (!empty($str)) ? $str . '/' . $folder : $folder; $str = (!empty($str)) ? $str . '/' . $folder : $folder;
if (!is_dir($str)) if (!is_dir($str))
{ {
@ -265,7 +277,7 @@ class compress_zip extends compress
// Not compressed // Not compressed
fwrite($fp, $content); fwrite($fp, $content);
break; break;
case 8: case 8:
// Deflate // Deflate
fwrite($fp, gzinflate($content, $data['uc_size'])); fwrite($fp, gzinflate($content, $data['uc_size']));
@ -276,7 +288,7 @@ class compress_zip extends compress
fwrite($fp, bzdecompress($content)); fwrite($fp, bzdecompress($content));
break; break;
} }
fclose($fp); fclose($fp);
break; break;
@ -286,11 +298,11 @@ class compress_zip extends compress
// This case should simply never happen.. but it does exist.. // This case should simply never happen.. but it does exist..
case "\x50\x4b\x05\x06": case "\x50\x4b\x05\x06":
break 2; break 2;
// 'Packed to Removable Disk', ignore it and look for the next signature... // 'Packed to Removable Disk', ignore it and look for the next signature...
case 'PK00': case 'PK00':
continue 2; continue 2;
// We have encountered a header that is weird. Lets look for better data... // We have encountered a header that is weird. Lets look for better data...
default: default:
if (!$dd_try) if (!$dd_try)
@ -515,6 +527,12 @@ class compress_tar extends compress
// Create and folders and subfolders if they do not exist // Create and folders and subfolders if they do not exist
foreach ($folders as $folder) foreach ($folders as $folder)
{ {
$folder = trim($folder);
if (!$folder)
{
continue;
}
$str = (!empty($str)) ? $str . '/' . $folder : $folder; $str = (!empty($str)) ? $str . '/' . $folder : $folder;
if (!is_dir($str)) if (!is_dir($str))
{ {
@ -536,6 +554,12 @@ class compress_tar extends compress
// Create and folders and subfolders if they do not exist // Create and folders and subfolders if they do not exist
foreach ($folders as $folder) foreach ($folders as $folder)
{ {
$folder = trim($folder);
if (!$folder)
{
continue;
}
$str = (!empty($str)) ? $str . '/' . $folder : $folder; $str = (!empty($str)) ? $str . '/' . $folder : $folder;
if (!is_dir($str)) if (!is_dir($str))
{ {