mirror of
https://github.com/php/php-src.git
synced 2024-09-23 02:47:26 +00:00
add Phar::unlinkArchive() to allow complete removal of a parsed phar archive from memory and disk
This commit is contained in:
parent
dff93bd359
commit
a180fcc9bc
@ -1279,6 +1279,46 @@ PHP_METHOD(Phar, getSupportedCompression)
|
||||
}
|
||||
/* }}} */
|
||||
|
||||
/* {{{ proto array Phar::unlinkArchive(string archive)
|
||||
* Completely remove a phar archive from memory and disk
|
||||
*/
|
||||
PHP_METHOD(Phar, unlinkArchive)
|
||||
{
|
||||
char *fname, *error;
|
||||
int fname_len;
|
||||
phar_archive_data *phar;
|
||||
|
||||
if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "s", &fname, &fname_len) == FAILURE) {
|
||||
RETURN_FALSE;
|
||||
}
|
||||
|
||||
if (!fname_len) {
|
||||
zend_throw_exception_ex(phar_ce_PharException, 0 TSRMLS_CC, "Unknown phar archive \"\"");
|
||||
return;
|
||||
}
|
||||
|
||||
if (FAILURE == phar_open_filename(fname, fname_len, NULL, 0, REPORT_ERRORS, &phar, &error TSRMLS_CC)) {
|
||||
if (error) {
|
||||
zend_throw_exception_ex(phar_ce_PharException, 0 TSRMLS_CC, "Unknown phar archive \"%s\": %s", fname, error);
|
||||
efree(error);
|
||||
} else {
|
||||
zend_throw_exception_ex(phar_ce_PharException, 0 TSRMLS_CC, "Unknown phar archive \"%s\"", fname);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if (phar->refcount) {
|
||||
zend_throw_exception_ex(phar_ce_PharException, 0 TSRMLS_CC, "phar archive \"%s\" has open file handles or objects. fclose() all file handles, and unset() all objects prior to calling unlinkArchive()", fname);
|
||||
return;
|
||||
}
|
||||
fname = estrndup(phar->fname, phar->fname_len);
|
||||
phar_archive_delref(phar TSRMLS_CC);
|
||||
unlink(fname);
|
||||
efree(fname);
|
||||
RETURN_TRUE;
|
||||
}
|
||||
/* }}} */
|
||||
|
||||
#if HAVE_SPL
|
||||
|
||||
#define PHAR_ARCHIVE_OBJECT() \
|
||||
@ -4297,6 +4337,11 @@ ZEND_BEGIN_ARG_INFO_EX(arginfo_phar_running, 0, 0, 1)
|
||||
ZEND_ARG_INFO(0, retphar)
|
||||
ZEND_END_ARG_INFO();
|
||||
|
||||
static
|
||||
ZEND_BEGIN_ARG_INFO_EX(arginfo_phar_ua, 0, 0, 1)
|
||||
ZEND_ARG_INFO(0, archive)
|
||||
ZEND_END_ARG_INFO();
|
||||
|
||||
#if HAVE_SPL
|
||||
|
||||
static
|
||||
@ -4473,6 +4518,7 @@ zend_function_entry php_archive_methods[] = {
|
||||
PHP_ME(Phar, running, arginfo_phar_running, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC|ZEND_ACC_FINAL)
|
||||
PHP_ME(Phar, mount, arginfo_phar_mount, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC|ZEND_ACC_FINAL)
|
||||
PHP_ME(Phar, mungServer, arginfo_phar_mungServer, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC|ZEND_ACC_FINAL)
|
||||
PHP_ME(Phar, unlinkArchive, arginfo_phar_ua, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC|ZEND_ACC_FINAL)
|
||||
PHP_ME(Phar, webPhar, arginfo_phar_webPhar, ZEND_ACC_PUBLIC|ZEND_ACC_STATIC|ZEND_ACC_FINAL)
|
||||
{NULL, NULL, NULL}
|
||||
};
|
||||
|
@ -35,7 +35,6 @@ copy($fname2, $fname3);
|
||||
$phar = new Phar($fname3);
|
||||
var_dump($phar->isFileFormat(Phar::ZIP));
|
||||
var_dump($phar->getStub());
|
||||
|
||||
?>
|
||||
===DONE===
|
||||
--CLEAN--
|
||||
|
95
ext/phar/tests/phar_unlinkarchive.phpt
Normal file
95
ext/phar/tests/phar_unlinkarchive.phpt
Normal file
@ -0,0 +1,95 @@
|
||||
--TEST--
|
||||
Phar::unlinkArchive()
|
||||
--SKIPIF--
|
||||
<?php if (!extension_loaded("phar")) die("skip"); ?>
|
||||
--INI--
|
||||
phar.require_hash=0
|
||||
phar.readonly=0
|
||||
--FILE--
|
||||
<?php
|
||||
|
||||
try {
|
||||
Phar::unlinkArchive("");
|
||||
} catch (Exception $e) {
|
||||
echo $e->getMessage(),"\n";
|
||||
}
|
||||
|
||||
$fname = dirname(__FILE__) . '/' . basename(__FILE__, '.php') . '.phar';
|
||||
$pdname = dirname(__FILE__) . '/' . basename(__FILE__, '.php') . '.phar.tar';
|
||||
|
||||
try {
|
||||
Phar::unlinkArchive($fname);
|
||||
} catch (Exception $e) {
|
||||
echo $e->getMessage(),"\n";
|
||||
}
|
||||
file_put_contents($pdname, 'blahblah');
|
||||
try {
|
||||
Phar::unlinkArchive($pdname);
|
||||
} catch (Exception $e) {
|
||||
echo $e->getMessage(),"\n";
|
||||
}
|
||||
Phar::unlinkArchive(array());
|
||||
|
||||
$pname = 'phar://' . $fname;
|
||||
$fname2 = dirname(__FILE__) . '/' . basename(__FILE__, '.php') . '.phar.zip';
|
||||
$fname3 = dirname(__FILE__) . '/' . basename(__FILE__, '.php') . '.2.phar.zip';
|
||||
$stub = '<?php echo "first stub\n"; __HALT_COMPILER(); ?>';
|
||||
$file = $stub;
|
||||
|
||||
$files = array();
|
||||
$files['a'] = 'a';
|
||||
$files['b'] = 'b';
|
||||
$files['c'] = 'c';
|
||||
|
||||
include 'files/phar_test.inc';
|
||||
|
||||
$phar = new Phar($fname);
|
||||
var_dump($phar->isFileFormat(Phar::ZIP));
|
||||
var_dump($phar->getStub());
|
||||
try {
|
||||
Phar::unlinkArchive($fname);
|
||||
} catch (Exception $e) {
|
||||
echo $e->getMessage(),"\n";
|
||||
}
|
||||
$phar = $phar->convertToExecutable(Phar::ZIP);
|
||||
var_dump($phar->isFileFormat(Phar::ZIP));
|
||||
var_dump($phar->getStub());
|
||||
|
||||
copy($fname2, $fname3);
|
||||
|
||||
$phar = new Phar($fname3);
|
||||
var_dump($phar->isFileFormat(Phar::ZIP));
|
||||
var_dump($phar->getStub());
|
||||
|
||||
Phar::unlinkArchive($fname);
|
||||
var_dump(file_exists($fname));
|
||||
$phar = new Phar($fname);
|
||||
var_dump(count($phar));
|
||||
?>
|
||||
===DONE===
|
||||
--CLEAN--
|
||||
<?php
|
||||
unlink(dirname(__FILE__) . '/' . basename(__FILE__, '.clean.php') . '.phar.tar');
|
||||
unlink(dirname(__FILE__) . '/' . basename(__FILE__, '.clean.php') . '.phar');
|
||||
unlink(dirname(__FILE__) . '/' . basename(__FILE__, '.clean.php') . '.2.phar.zip');
|
||||
unlink(dirname(__FILE__) . '/' . basename(__FILE__, '.clean.php') . '.phar.zip');
|
||||
__HALT_COMPILER();
|
||||
?>
|
||||
--EXPECTF--
|
||||
Unknown phar archive ""
|
||||
Unknown phar archive "%sphar_unlinkarchive.phar"
|
||||
Unknown phar archive "%sphar_unlinkarchive.phar.tar": internal corruption of phar "%sphar_unlinkarchive.phar.tar" (truncated entry)
|
||||
|
||||
Warning: Phar::unlinkArchive() expects parameter 1 to be string, array given in %sphar_unlinkarchive.php on line %d
|
||||
bool(false)
|
||||
string(48) "<?php echo "first stub\n"; __HALT_COMPILER(); ?>"
|
||||
phar archive "%sphar_unlinkarchive.phar" has open file handles or objects. fclose() all file handles, and unset() all objects prior to calling unlinkArchive()
|
||||
bool(true)
|
||||
string(60) "<?php // zip-based phar archive stub file
|
||||
__HALT_COMPILER();"
|
||||
bool(true)
|
||||
string(60) "<?php // zip-based phar archive stub file
|
||||
__HALT_COMPILER();"
|
||||
bool(false)
|
||||
int(0)
|
||||
===DONE===
|
Loading…
Reference in New Issue
Block a user