X-Git-Url: https://jasonwoof.com/gitweb/?p=wfpl.git;a=blobdiff_plain;f=tar.php;h=d5f7021d154a1bf0763f2e3310ad9b9b661674d6;hp=342fc99fc8c7b044aa1dc3fcb3178e65307b19d1;hb=HEAD;hpb=6126e566b80bd1eb4dd3212481fa4b854bdc3549 diff --git a/tar.php b/tar.php index 342fc99..d5f7021 100644 --- a/tar.php +++ b/tar.php @@ -1,22 +1,9 @@ $file_data) { if(substr($filename, -3) == ' ->') { @@ -56,35 +51,35 @@ function make_tar($dirname, $files, $extra = '') { } else { $link = false; } - $filename_fixed = ereg_replace('[^a-zA-Z0-9_.-]', '', $filename); + $filename_fixed = preg_replace('|[^a-z0-9_.-]|i', '', $filename); if($filename != $filename_fixed) { die("Invalid filename for tar archive"); } if($link) { - $target = ereg_replace('[^a-zA-Z0-9_./-]', '', $file_data); + $target = preg_replace('|[^a-z0-9_./-]|i', '', $file_data); system("/bin/ln -s $file_data \"$tmpdir/$dirname/$filename\""); } else { write_file("$tmpdir/$dirname/$filename", $file_data); } } - if(function_exists($extra)) { - $extra("$tmpdir/$dirname"); + if($pre_archive_func && function_exists($pre_archive_func)) { + $pre_archive_func("$tmpdir/$dirname"); } header("Content-type: application/x-gzip"); passthru("tar -C $tmpdir -czf - $dirname/"); - system("/bin/rm -rf '$tmpdir/$dirname'"); + system('/bin/rm -rf ' . escapeshellarg($tmpdir)); } -# like make_tar above, except it includes a copy of code/wfpl +# like make_tar above, except it includes a copy of wfpl function make_wfpl_tar($dirname, $files) { make_tar($dirname, $files, 'add_wfpl_dir'); } function add_wfpl_dir($dir) { mkdir("$dir/code"); - system("rsync -plr --exclude=\".git\" --exclude=\"*.swp\" 'code/wfpl/' '$dir/code/wfpl/'", $return_code); + system("rsync -plr --exclude=\".git\" --exclude=\"*.swp\" 'inc/wfpl/' '$dir/inc/wfpl/'", $return_code); if($return_code != 0) { die("ERROR: while trying to copy wfpl into archive: rsync returned $return_code"); }