johannes Tue Jul 31 22:47:25 2007 UTC
Modified files: (Branch: PHP_5_2)
/ZendEngine2 zend_builtin_functions.c
/ZendEngine2/tests 017.phpt
Log:
- MFH: Add additional param to get_loaded_extensions() for returning Zend
extensions (Fixes #41278) [DOC]
http://cvs.php.net/viewvc.cgi/ZendEngine2/zend_builtin_functions.c?r1=1.277.2.12.2.19&r2=1.277.2.12.2.20&diff_format=u
Index: ZendEngine2/zend_builtin_functions.c
diff -u ZendEngine2/zend_builtin_functions.c:1.277.2.12.2.19
ZendEngine2/zend_builtin_functions.c:1.277.2.12.2.20
--- ZendEngine2/zend_builtin_functions.c:1.277.2.12.2.19 Tue Jul 24
11:39:55 2007
+++ ZendEngine2/zend_builtin_functions.c Tue Jul 31 22:47:25 2007
@@ -17,7 +17,7 @@
+----------------------------------------------------------------------+
*/
-/* $Id: zend_builtin_functions.c,v 1.277.2.12.2.19 2007/07/24 11:39:55 dmitry
Exp $ */
+/* $Id: zend_builtin_functions.c,v 1.277.2.12.2.20 2007/07/31 22:47:25
johannes Exp $ */
#include "zend.h"
#include "zend_API.h"
@@ -25,6 +25,7 @@
#include "zend_constants.h"
#include "zend_ini.h"
#include "zend_exceptions.h"
+#include "zend_extensions.h"
#undef ZEND_TEST_EXCEPTIONS
@@ -1548,6 +1549,13 @@
return 0;
}
+static int add_zendext_info(zend_extension *ext, void *arg TSRMLS_DC)
+{
+ zval *name_array = (zval *)arg;
+ add_next_index_string(name_array, ext->name, 1);
+ return 0;
+}
+
static int add_constant_info(zend_constant *constant, void *arg TSRMLS_DC)
{
zval *name_array = (zval *)arg;
@@ -1562,16 +1570,34 @@
}
-/* {{{ proto array get_loaded_extensions(void)
+/* {{{ proto array get_loaded_extensions([mixed categorize]) U
Return an array containing names of loaded extensions */
ZEND_FUNCTION(get_loaded_extensions)
{
- if (ZEND_NUM_ARGS() != 0) {
+ int argc = ZEND_NUM_ARGS();
+
+ if (argc != 0 && argc != 1) {
ZEND_WRONG_PARAM_COUNT();
}
array_init(return_value);
- zend_hash_apply_with_argument(&module_registry, (apply_func_arg_t)
add_extension_info, return_value TSRMLS_CC);
+
+ if (argc) {
+ zval *modules;
+ zval *extensions;
+
+ MAKE_STD_ZVAL(modules);
+ array_init(modules);
+ zend_hash_apply_with_argument(&module_registry,
(apply_func_arg_t) add_extension_info, modules TSRMLS_CC);
+ add_assoc_zval_ex(return_value, "PHP Modules", sizeof("PHP
Modules"), modules);
+
+ MAKE_STD_ZVAL(extensions);
+ array_init(extensions);
+ zend_llist_apply_with_argument(&zend_extensions,
(llist_apply_with_arg_func_t) add_zendext_info, extensions TSRMLS_CC);
+ add_assoc_zval_ex(return_value, "Zend Extensions", sizeof("Zend
Extensions"), extensions);
+ } else {
+ zend_hash_apply_with_argument(&module_registry,
(apply_func_arg_t) add_extension_info, return_value TSRMLS_CC);
+ }
}
/* }}} */
http://cvs.php.net/viewvc.cgi/ZendEngine2/tests/017.phpt?r1=1.1.2.2&r2=1.1.2.3&diff_format=u
Index: ZendEngine2/tests/017.phpt
diff -u ZendEngine2/tests/017.phpt:1.1.2.2 ZendEngine2/tests/017.phpt:1.1.2.3
--- ZendEngine2/tests/017.phpt:1.1.2.2 Tue Nov 21 11:11:39 2006
+++ ZendEngine2/tests/017.phpt Tue Jul 31 22:47:25 2007
@@ -10,9 +10,9 @@
fclose($fp);
var_dump(get_resource_type($fp));
-var_dump(get_loaded_extensions(true));
var_dump(gettype(get_loaded_extensions()));
var_dump(count(get_loaded_extensions()));
+var_dump(count(get_loaded_extensions(true)));
define("USER_CONSTANT", "test");
@@ -50,11 +50,9 @@
bool(false)
string(6) "stream"
string(7) "Unknown"
-
-Warning: Wrong parameter count for get_loaded_extensions() in %s on line %d
-NULL
string(5) "array"
int(%d)
+int(2)
Warning: Wrong parameter count for get_defined_constants() in %s on line %d
NULL