]> granicus.if.org Git - php/commitdiff
- Fixed memory leak when calling the Finfo constructor twice
authorFelipe Pena <felipe@php.net>
Wed, 23 Nov 2011 01:20:49 +0000 (01:20 +0000)
committerFelipe Pena <felipe@php.net>
Wed, 23 Nov 2011 01:20:49 +0000 (01:20 +0000)
ext/fileinfo/fileinfo.c
ext/fileinfo/tests/finfo_open_002.phpt [new file with mode: 0644]

index f173fb5ed61e8cc78717ae82995e32bee6adc081..4f1af35a437d4c433051fc1906c56bd774540b4b 100644 (file)
@@ -289,6 +289,16 @@ PHP_FUNCTION(finfo_open)
        if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|lp", &options, &file, &file_len) == FAILURE) {
                RETURN_FALSE;
        }
+       
+       if (object) {
+               struct finfo_object *finfo_obj = (struct finfo_object*)zend_object_store_get_object(object TSRMLS_CC);
+               
+               if (finfo_obj->ptr) {
+                       magic_close(finfo_obj->ptr->magic);
+                       efree(finfo_obj->ptr);
+                       finfo_obj->ptr = NULL;
+               }
+       }
 
        if (file_len == 0) {
                file = NULL;
diff --git a/ext/fileinfo/tests/finfo_open_002.phpt b/ext/fileinfo/tests/finfo_open_002.phpt
new file mode 100644 (file)
index 0000000..cf4809f
--- /dev/null
@@ -0,0 +1,17 @@
+--TEST--
+FileInfo - Calling the constructor twice
+--SKIPIF--
+<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
+--FILE--
+<?php
+
+$x = new finfo;
+$x->finfo();
+
+echo "done!\n";
+
+?>
+--EXPECTF--
+done!
+
+