summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNikita Popov <nikita.ppv@gmail.com>2017-02-02 18:35:35 +0100
committerNikita Popov <nikita.ppv@gmail.com>2017-02-02 18:35:35 +0100
commit795a4c1bb384a7e0d56705d43e95b9bfcc3265b5 (patch)
treedab5d313002ed8083a3667d1b560476a916e48ff
parentb2a4af7b58d2b06177fb4ea451056a8d9a28fbd0 (diff)
parente81f30ad1d003c5250b1025c963ed0a178d4c51a (diff)
downloadphp-git-795a4c1bb384a7e0d56705d43e95b9bfcc3265b5.tar.gz
Merge branch 'PHP-7.1'
-rw-r--r--Zend/tests/bug73998.phpt19
-rw-r--r--Zend/zend_builtin_functions.c6
-rw-r--r--Zend/zend_hash.h10
3 files changed, 30 insertions, 5 deletions
diff --git a/Zend/tests/bug73998.phpt b/Zend/tests/bug73998.phpt
new file mode 100644
index 0000000000..41813269d1
--- /dev/null
+++ b/Zend/tests/bug73998.phpt
@@ -0,0 +1,19 @@
+--TEST--
+Bug #73998 (array_key_exists fails on arrays created by get_object_vars)
+--DESCRIPTION--
+Properties of objects with numeric names should be accessible
+--FILE--
+<?php
+$a = new stdClass;
+$a->{1234} = "Numeric";
+$a->a1234 = "String";
+
+$properties = get_object_vars($a);
+var_dump(array_key_exists(1234, $properties));
+echo "Value: {$properties[1234]}\n";
+
+?>
+--EXPECT--
+bool(true)
+Value: Numeric
+
diff --git a/Zend/zend_builtin_functions.c b/Zend/zend_builtin_functions.c
index 0f3e321ba3..4ba9dc4189 100644
--- a/Zend/zend_builtin_functions.c
+++ b/Zend/zend_builtin_functions.c
@@ -1284,11 +1284,7 @@ ZEND_FUNCTION(get_object_vars)
*/
zend_hash_str_add_new(Z_ARRVAL_P(return_value), prop_name, prop_len, value);
} else {
- if (ZEND_HANDLE_NUMERIC(key, num_key)) {
- zend_hash_index_add(Z_ARRVAL_P(return_value), num_key, value);
- } else {
- zend_hash_add_new(Z_ARRVAL_P(return_value), key, value);
- }
+ zend_symbtable_add_new(Z_ARRVAL_P(return_value), key, value);
}
} ZEND_HASH_FOREACH_END();
}
diff --git a/Zend/zend_hash.h b/Zend/zend_hash.h
index fa63999c2a..638fbe27fc 100644
--- a/Zend/zend_hash.h
+++ b/Zend/zend_hash.h
@@ -346,6 +346,16 @@ static zend_always_inline int zend_hash_str_exists_ind(const HashTable *ht, cons
Z_TYPE_P(Z_INDIRECT_P(zv)) != IS_UNDEF);
}
+static zend_always_inline zval *zend_symbtable_add_new(HashTable *ht, zend_string *key, zval *pData)
+{
+ zend_ulong idx;
+
+ if (ZEND_HANDLE_NUMERIC(key, idx)) {
+ return zend_hash_index_add_new(ht, idx, pData);
+ } else {
+ return zend_hash_add_new(ht, key, pData);
+ }
+}
static zend_always_inline zval *zend_symtable_update(HashTable *ht, zend_string *key, zval *pData)
{