}
/* }}} */
+static void add_config_entries(HashTable *hash, zval *return_value);
+
/* {{{ add_config_entry
*/
static void add_config_entry(zend_ulong h, zend_string *key, zval *entry, zval *retval)
add_index_str(retval, h, zend_string_copy(Z_STR_P(entry)));
}
} else if (Z_TYPE_P(entry) == IS_ARRAY) {
- zend_ulong h;
- zend_string *key;
- zval *zv, tmp;
-
+ zval tmp;
array_init(&tmp);
- ZEND_HASH_FOREACH_KEY_VAL(Z_ARRVAL_P(entry), h, key, zv)
- add_config_entry(h, key, zv, &tmp);
- ZEND_HASH_FOREACH_END();
+ add_config_entries(Z_ARRVAL_P(entry), &tmp);
zend_hash_update(Z_ARRVAL_P(retval), key, &tmp);
}
}
--- /dev/null
+--TEST--
+Using get_cfg_var() on an array ini value
+--INI--
+ary[a] = 1
+ary[b] = 2
+ary2[1] = a
+ary2[2] = b
+--FILE--
+<?php
+
+var_dump(get_cfg_var('ary'));
+var_dump(get_cfg_var('ary2'));
+
+?>
+--EXPECT--
+array(2) {
+ ["a"]=>
+ string(1) "1"
+ ["b"]=>
+ string(1) "2"
+}
+array(2) {
+ [1]=>
+ string(1) "a"
+ [2]=>
+ string(1) "b"
+}