]> granicus.if.org Git - php/commitdiff
make built-in SplFileInfo->isWriteable() work for PharFileInfo as well, by ensuring...
authorGreg Beaver <cellog@php.net>
Thu, 10 Apr 2008 03:12:08 +0000 (03:12 +0000)
committerGreg Beaver <cellog@php.net>
Thu, 10 Apr 2008 03:12:08 +0000 (03:12 +0000)
ext/phar/phar.c
ext/phar/tests/phar_oo_iswriteable.phpt [new file with mode: 0644]

index 806a6cfc922f806d7b130485bfc7c3caa94f4b45..0694f04a77b21513dd2953d178ce84645645652a 100644 (file)
 
 ZEND_DECLARE_MODULE_GLOBALS(phar)
 
+/**
+ * set's phar->is_writeable based on the current INI value
+ */
+static int phar_set_writeable_bit(void *pDest, void *argument TSRMLS_DC) /* {{{ */
+{
+       zend_bool keep = *(zend_bool *)argument;
+       phar_archive_data *phar = *(phar_archive_data **)pDest;
+
+       if (!phar->is_data) {
+               phar->is_writeable = !keep;
+       }
+       return ZEND_HASH_APPLY_KEEP;
+}
+/* }}} */
+
 /* if the original value is 0 (disabled), then allow setting/unsetting at will
    otherwise, only allow 1 (enabled), and error on disabling */
 ZEND_INI_MH(phar_ini_modify_handler) /* {{{ */
@@ -63,7 +78,10 @@ ZEND_INI_MH(phar_ini_modify_handler) /* {{{ */
        }
 
        if (entry->name_length == 14) {
-               PHAR_G(readonly) = ini; 
+               PHAR_G(readonly) = ini;
+               if (PHAR_GLOBALS->request_init && PHAR_GLOBALS->phar_fname_map.arBuckets) {
+                       zend_hash_apply_with_argument(&(PHAR_GLOBALS->phar_fname_map), phar_set_writeable_bit, (void *)&ini TSRMLS_CC);
+               }
        } else {
                PHAR_G(require_hash) = ini;
        } 
diff --git a/ext/phar/tests/phar_oo_iswriteable.phpt b/ext/phar/tests/phar_oo_iswriteable.phpt
new file mode 100644 (file)
index 0000000..9957cea
--- /dev/null
@@ -0,0 +1,53 @@
+--TEST--
+Phar::isWriteable
+--SKIPIF--
+<?php if (!extension_loaded("phar")) die("skip"); ?>
+--INI--
+phar.readonly=0
+phar.require_hash=0
+--FILE--
+<?php
+$fname = dirname(__FILE__) . '/' . basename(__FILE__, '.php') . '.1.phar.php';
+$pname = 'phar://hio';
+$file = '<?php include "' . $pname . '/a.php"; __HALT_COMPILER(); ?>';
+
+$files = array();
+$files['a.php']   = '<?php echo "This is a\n"; include "'.$pname.'/b.php"; ?>';
+$files['dir/'] = '';
+$hasdir = 1;
+include 'files/phar_test.inc';
+$a = new Phar($fname);
+var_dump($a['a.php']->isWritable());
+var_dump($a['a.php']->isReadable());
+$a['a.php']->chmod(000);
+var_dump($a['a.php']->isWritable());
+var_dump($a['a.php']->isReadable());
+$a['a.php']->chmod(0666);
+var_dump($a['a.php']->isWritable());
+var_dump($a['a.php']->isReadable());
+ini_set('phar.readonly',1);
+clearstatcache();
+var_dump($a['a.php']->isWritable());
+var_dump($a['a.php']->isReadable());
+ini_set('phar.readonly',0);
+clearstatcache();
+var_dump($a['a.php']->isWritable());
+var_dump($a['a.php']->isReadable());
+?>
+===DONE===
+--CLEAN--
+<?php 
+unlink(dirname(__FILE__) . '/' . basename(__FILE__, '.clean.php') . '.1.phar.php');
+?>
+--EXPECT--
+bool(true)
+bool(true)
+bool(false)
+bool(false)
+bool(true)
+bool(true)
+bool(false)
+bool(true)
+bool(true)
+bool(true)
+===DONE===