diff options
| -rw-r--r-- | ext/standard/basic_functions.c | 21 | ||||
| -rw-r--r-- | ext/standard/basic_functions.h | 1 |
2 files changed, 22 insertions, 0 deletions
diff --git a/ext/standard/basic_functions.c b/ext/standard/basic_functions.c index d541627e0e..659187f3a5 100644 --- a/ext/standard/basic_functions.c +++ b/ext/standard/basic_functions.c @@ -382,6 +382,7 @@ function_entry basic_functions[] = { PHP_FE(get_loaded_extensions, NULL) PHP_FE(extension_loaded, NULL) PHP_FE(get_extension_funcs, NULL) + PHP_FE(get_defined_constants, NULL) PHP_FE(parse_ini_file, NULL) @@ -2365,6 +2366,13 @@ static int php_add_extension_info(zend_module_entry *module, void *arg) return 0; } +static int php_add_constant_info(zend_constant *constant, void *arg) +{ + zval *name_array = (zval *)arg; + add_assoc_zval(name_array, constant->name, &(constant->value)); + return 0; +} + /* {{{ proto array get_loaded_extensions(void) Return an array containing names of loaded extensions */ PHP_FUNCTION(get_loaded_extensions) @@ -2378,6 +2386,19 @@ PHP_FUNCTION(get_loaded_extensions) } /* }}} */ +/* {{{ proto array get_defined_constants(void) + Return an array containing the names and values of all defined constants */ +PHP_FUNCTION(get_defined_constants) +{ + ELS_FETCH(); + + if (ZEND_NUM_ARGS() != 0) { + WRONG_PARAM_COUNT; + } + + array_init(return_value); + zend_hash_apply_with_argument(EG(zend_constants), (int (*)(void *, void*)) php_add_constant_info, return_value); +} /* {{{ proto bool extension_loaded(string extension_name) Returns true if the named extension is loaded */ diff --git a/ext/standard/basic_functions.h b/ext/standard/basic_functions.h index 8a3c1e3de6..52c23a25e0 100644 --- a/ext/standard/basic_functions.h +++ b/ext/standard/basic_functions.h @@ -111,6 +111,7 @@ PHP_NAMED_FUNCTION(php_if_crc32); PHP_FUNCTION(get_loaded_extensions); PHP_FUNCTION(extension_loaded); PHP_FUNCTION(get_extension_funcs); +PHP_FUNCTION(get_defined_constants); PHP_FUNCTION(register_tick_function); PHP_FUNCTION(unregister_tick_function); |
