if (UNEXPECTED(ht->nNumOfElements == 0)) {
if (ht->u.flags & HASH_FLAG_INITIALIZED) {
+ ht->nNumUsed = 0;
HT_HASH_RESET(ht);
}
return SUCCESS;
HT_HASH(ht, p->h | ht->nTableMask) = Z_NEXT(p->val);
}
}
- if (ht->nNumUsed - 1 == idx) {
+ if (HT_IDX_TO_HASH(ht->nNumUsed - 1) == idx) {
do {
ht->nNumUsed--;
} while (ht->nNumUsed > 0 && (Z_TYPE(ht->arData[ht->nNumUsed-1].val) == IS_UNDEF));
}
ht->nNumOfElements--;
- if (ht->nInternalPointer == idx || UNEXPECTED(ht->u.v.nIteratorsCount)) {
- uint32_t new_idx = idx;
+ if (HT_IDX_TO_HASH(ht->nInternalPointer) == idx || UNEXPECTED(ht->u.v.nIteratorsCount)) {
+ uint32_t new_idx;
+ new_idx = idx = HT_HASH_TO_IDX(idx);
while (1) {
new_idx++;
if (new_idx >= ht->nNumUsed) {
if (h < ht->nNumUsed) {
p = ht->arData + h;
if (Z_TYPE(p->val) != IS_UNDEF) {
- _zend_hash_del_el_ex(ht, h, p, NULL);
+ _zend_hash_del_el_ex(ht, HT_IDX_TO_HASH(h), p, NULL);
return SUCCESS;
}
}
((Bucket*)((char*)(data) + (idx)))
# define HT_IDX_TO_HASH(idx) \
((idx) * sizeof(Bucket))
+# define HT_HASH_TO_IDX(idx) \
+ ((idx) / sizeof(Bucket))
#elif SIZEOF_SIZE_T == 8
# define HT_MAX_SIZE 0x80000000
# define HT_HASH_TO_BUCKET_EX(data, idx) \
((data) + (idx))
# define HT_IDX_TO_HASH(idx) \
(idx)
+# define HT_HASH_TO_IDX(idx) \
+ (idx)
#else
# error "Unknown SIZEOF_SIZE_T"
#endif