mirror of
https://github.com/php/php-src.git
synced 2025-01-17 17:23:47 +08:00
Fixed memcmp() check with hash_quick_del (realKeyLength would be 0)
This commit is contained in:
parent
3a9eea4a8d
commit
aab8305c03
@ -622,13 +622,11 @@ ZEND_API int zend_u_hash_del_key_or_index(HashTable *ht, zend_uchar type, zstr a
|
||||
uint nIndex;
|
||||
Bucket *p;
|
||||
void *tmp = NULL;
|
||||
uint realKeyLength = 0;
|
||||
|
||||
IS_CONSISTENT(ht);
|
||||
|
||||
if (flag == HASH_DEL_KEY) {
|
||||
UNICODE_KEY(ht, type, arKey, nKeyLength, tmp);
|
||||
realKeyLength = USTR_BYTES(type, nKeyLength);
|
||||
h = zend_u_inline_hash_func(type, arKey, nKeyLength);
|
||||
}
|
||||
nIndex = h & ht->nTableMask;
|
||||
@ -639,7 +637,7 @@ ZEND_API int zend_u_hash_del_key_or_index(HashTable *ht, zend_uchar type, zstr a
|
||||
&& (p->nKeyLength == nKeyLength)
|
||||
&& ((p->nKeyLength == 0) /* Numeric index (short circuits the memcmp()) */
|
||||
|| ((p->key.type == type)
|
||||
&& !memcmp(p->key.arKey.s, arKey.s, realKeyLength)))) {
|
||||
&& !memcmp(p->key.arKey.s, arKey.s, USTR_BYTES(type, nKeyLength))))) {
|
||||
HANDLE_BLOCK_INTERRUPTIONS();
|
||||
if (p == ht->arBuckets[nIndex]) {
|
||||
ht->arBuckets[nIndex] = p->pNext;
|
||||
|
Loading…
Reference in New Issue
Block a user