]> granicus.if.org Git - php/commitdiff
- MFH: Fixed memory leaks in readline_completion_function()
authorFelipe Pena <felipe@php.net>
Thu, 20 Nov 2008 22:26:32 +0000 (22:26 +0000)
committerFelipe Pena <felipe@php.net>
Thu, 20 Nov 2008 22:26:32 +0000 (22:26 +0000)
ext/readline/readline.c
ext/readline/tests/readline_completion_function_001.phpt [new file with mode: 0644]

index 9060a624645eb8b746f0746bc4d4c579b37e443c..3a481dfa4c15e079498ef43735b3fa6b8244b9e6 100644 (file)
@@ -115,8 +115,10 @@ PHP_MINIT_FUNCTION(readline)
 
 PHP_RSHUTDOWN_FUNCTION(readline)
 {
-       if (_readline_completion) 
+       if (_readline_completion) {
+               zval_dtor(_readline_completion);
                FREE_ZVAL(_readline_completion);
+       }
 #if HAVE_RL_CALLBACK_READ_CHAR
        if (_prepped_callback) {
                rl_callback_handler_remove();
@@ -456,9 +458,12 @@ PHP_FUNCTION(readline_completion_function)
                efree(name);
                RETURN_FALSE;
        }
+       efree(name);
 
-       if (_readline_completion)
+       if (_readline_completion) {
+               zval_dtor(_readline_completion);
                FREE_ZVAL(_readline_completion);
+       }
 
        MAKE_STD_ZVAL(_readline_completion);
        *_readline_completion = *arg;
diff --git a/ext/readline/tests/readline_completion_function_001.phpt b/ext/readline/tests/readline_completion_function_001.phpt
new file mode 100644 (file)
index 0000000..828636c
--- /dev/null
@@ -0,0 +1,25 @@
+--TEST--
+readline_completion_function(): Basic test
+--SKIPIF--
+<?php if (!extension_loaded("readline")) die("skip"); ?>
+--FILE--
+<?php
+
+function foo() { }
+
+$data = array(
+       'foo',
+       'strtolower',
+       1,
+       1.1231
+);
+
+foreach ($data as $callback) {
+       readline_completion_function($callback);
+}
+
+?>
+--EXPECTF--
+Warning: readline_completion_function(): 1 is not callable in %s on line %d
+
+Warning: readline_completion_function(): 1.1231 is not callable in %s on line %d