efree(entry);
goto stat_entry;
}
- if (SUCCESS == zend_hash_find(&(phar->virtual_dirs), entry, entry_len, (void **) &data)) {
+ if (zend_hash_exists(&(phar->virtual_dirs), entry, entry_len)) {
efree(entry);
efree(arch);
if (IS_EXISTS_CHECK(type)) {
}
goto stat_entry;
}
- if (SUCCESS == zend_hash_find(&(phar->virtual_dirs), entry + 1, entry_len - 1, (void **) &data)) {
+ if (zend_hash_exists(&(phar->virtual_dirs), entry + 1, entry_len - 1)) {
PHAR_G(cwd) = save;
PHAR_G(cwd_len) = save_len;
efree(entry);
php_url_free(resource);
return SUCCESS;
}
- if (SUCCESS == zend_hash_find(&(phar->virtual_dirs), internal_file, internal_file_len, (void **) &entry)) {
+ if (zend_hash_exists(&(phar->virtual_dirs), internal_file, internal_file_len)) {
phar_dostat(phar, NULL, ssb, 1, phar->alias, phar->alias_len TSRMLS_CC);
php_url_free(resource);
return SUCCESS;
return entry;
}
if (dir) {
- if (SUCCESS == zend_hash_find(&phar->virtual_dirs, path, path_len, (void**)&entry)) {
+ if (zend_hash_exists(&phar->virtual_dirs, path, path_len)) {
/* a file or directory exists in a sub-directory of this path */
entry = (phar_entry_info *) ecalloc(1, sizeof(phar_entry_info));
/* this next line tells PharFileInfo->__destruct() to efree the filename */
*/
static int phar_add_empty(HashTable *ht, char *arKey, uint nKeyLength) /* {{{ */
{
- char *dummy = (char*)1;
+ char **dummy;
+
if (SUCCESS == zend_hash_find(ht, arKey, nKeyLength, (void **)&dummy)) {
- dummy++;
- }
+ (*dummy)++;
+ return SUCCESS;
+ } else {
+ char *dummy = (char*)1;
- return zend_hash_update(ht, arKey, nKeyLength, (char *) &dummy, sizeof(void *), NULL);
+ return zend_hash_add(ht, arKey, nKeyLength, (char *) &dummy, sizeof(void *), NULL);
+ }
}
/* }}} */
void phar_delete_virtual_dirs(phar_archive_data *phar, char *filename, int filename_len TSRMLS_DC) /* {{{ */
{
char *s = filename;
+ char **dummy;
/* we use filename_len - 1 to avoid adding a virtual dir for empty directory entries */
for (; s - filename < filename_len - 1; s++) {
if (*s == '/') {
- char *dummy;
- if (FAILURE == zend_hash_find(&phar->virtual_dirs, filename, s - filename, (void **)&dummy)) {
- continue;
- }
-
- if (!--dummy) {
- zend_hash_del(&phar->virtual_dirs, filename, s - filename);
- } else {
- zend_hash_update(&phar->virtual_dirs, filename, s - filename, &dummy, sizeof(void *), NULL);
+ if (SUCCESS == zend_hash_find(&phar->virtual_dirs, filename, s - filename, (void **)&dummy)) {
+ if (!--(*dummy)) {
+ zend_hash_del(&phar->virtual_dirs, filename, s - filename);
+ }
}
}
}