From 529aa19cc74defb64d61ef198f5e9549185dfabb Mon Sep 17 00:00:00 2001 From: Greg Beaver Date: Sat, 21 Jun 2008 06:53:10 +0000 Subject: [PATCH] 82x(./profile2) speedup for buildFrom*() --- ext/phar/phar.phar | Bin 15252 -> 15252 bytes ext/phar/phar_object.c | 57 +++++++++++++++++------------------------ 2 files changed, 23 insertions(+), 34 deletions(-) diff --git a/ext/phar/phar.phar b/ext/phar/phar.phar index 170c4a8860a154cd199c087be054e3974a5a0af0..0da97c8923314eb690ccabeb998cbbc61769637e 100755 GIT binary patch delta 85 zcmbPIKBas^04uZg(wND?tj1uvlhp`J?}O5xSvA0XIW|QQz1fM)%v6Tq^Up(lQi-ko Yeuww}xZcl, fname_len; phar_entry_data *data; php_stream *fp; @@ -1605,7 +1607,13 @@ after_open_fp: if (error) { efree(error); } - contents_len = php_stream_copy_to_stream(fp, data->fp, PHP_STREAM_COPY_ALL); + /* convert to PHAR_UFP */ + php_stream_close(data->internal_file->fp); + data->internal_file->fp_type = PHAR_UFP; + data->internal_file->offset_abs = data->internal_file->offset = php_stream_tell(p_obj->fp); + contents_len = php_stream_copy_to_stream(fp, p_obj->fp, PHP_STREAM_COPY_ALL); + data->internal_file->uncompressed_filesize = data->internal_file->compressed_filesize = + php_stream_tell(p_obj->fp) - data->internal_file->offset; } if (close_fp) { php_stream_close(fp); @@ -1622,15 +1630,6 @@ after_open_fp: data->internal_file->compressed_filesize = data->internal_file->uncompressed_filesize = contents_len; phar_entry_delref(data TSRMLS_CC); - if (++p_obj->count && p_obj->count % 900) { - /* every 900 files, flush so we remove open temp file handles, fixes Bug #45218 */ - phar_flush(p_obj->p->arc.archive, 0, 0, 0, &error TSRMLS_CC); - if (error) { - zend_throw_exception_ex(phar_ce_PharException, 0 TSRMLS_CC, error); - efree(error); - return ZEND_HASH_APPLY_STOP; - } - } return ZEND_HASH_APPLY_KEEP; } /* }}} */ @@ -1647,14 +1646,7 @@ PHP_METHOD(Phar, buildFromDirectory) int dir_len, regex_len = 0; zend_bool apply_reg = 0; zval arg, arg2, *iter, *iteriter, *regexiter = NULL; - struct { - phar_archive_object *p; - zend_class_entry *c; - char *b; - uint l; - zval *ret; - int count; - } pass; + struct _phar_t pass; PHAR_ARCHIVE_OBJECT(); @@ -1731,12 +1723,14 @@ PHP_METHOD(Phar, buildFromDirectory) pass.l = dir_len; pass.count = 0; pass.ret = return_value; + pass.fp = php_stream_fopen_tmpfile(); if (SUCCESS == spl_iterator_apply((apply_reg ? regexiter : iteriter), (spl_iterator_apply_func_t) phar_build, (void *) &pass TSRMLS_CC)) { zval_ptr_dtor(&iteriter); if (apply_reg) { zval_ptr_dtor(®exiter); } + phar_obj->arc.archive->ufp = pass.fp; phar_flush(phar_obj->arc.archive, 0, 0, 0, &error TSRMLS_CC); if (error) { zend_throw_exception_ex(phar_ce_PharException, 0 TSRMLS_CC, error); @@ -1761,14 +1755,7 @@ PHP_METHOD(Phar, buildFromIterator) char *error; uint base_len = 0; char *base = NULL; - struct { - phar_archive_object *p; - zend_class_entry *c; - char *b; - uint l; - zval *ret; - int count; - } pass; + struct _phar_t pass; PHAR_ARCHIVE_OBJECT(); if (PHAR_G(readonly) && !phar_obj->arc.archive->is_data) { @@ -1789,8 +1776,10 @@ PHP_METHOD(Phar, buildFromIterator) pass.l = base_len; pass.ret = return_value; pass.count = 0; + pass.fp = php_stream_fopen_tmpfile(); if (SUCCESS == spl_iterator_apply(obj, (spl_iterator_apply_func_t) phar_build, (void *) &pass TSRMLS_CC)) { + phar_obj->arc.archive->ufp = pass.fp; phar_flush(phar_obj->arc.archive, 0, 0, 0, &error TSRMLS_CC); if (error) { zend_throw_exception_ex(phar_ce_PharException, 0 TSRMLS_CC, error); -- 2.40.0