static const Bucket *uninitialized_bucket = NULL;
-static inline void zend_hash_bucket_update(
- const HashTable *ht, Bucket *p, void *pData, uint nDataSize, void **pDest ZEND_FILE_LINE_DC
-) {
- ZEND_ASSERT(p->pData != pData);
- HANDLE_BLOCK_INTERRUPTIONS();
- if (ht->pDestructor) {
- ht->pDestructor(p->pData);
- }
- UPDATE_DATA(ht, p, pData, nDataSize);
- HANDLE_UNBLOCK_INTERRUPTIONS();
- if (pDest) {
- *pDest = p->pData;
- }
-}
-
static zend_always_inline void i_zend_hash_bucket_delete(HashTable *ht, Bucket *p)
{
#ifdef ZEND_SIGNALS
p = ht->arBuckets[nIndex];
while (p != NULL) {
if (p->arKey == arKey ||
- ((p->h == h) && (p->nKeyLength == nKeyLength)
- && !memcmp(p->arKey, arKey, nKeyLength))
- ) {
- if (flag & HASH_ADD) {
- return FAILURE;
- }
- zend_hash_bucket_update(ht, p, pData, nDataSize, pDest ZEND_FILE_LINE_RELAY_CC);
- return SUCCESS;
+ ((p->h == h) && (p->nKeyLength == nKeyLength) && !memcmp(p->arKey, arKey, nKeyLength))) {
+ if (flag & HASH_ADD) {
+ return FAILURE;
+ }
+ ZEND_ASSERT(p->pData != pData);
+ HANDLE_BLOCK_INTERRUPTIONS();
+ if (ht->pDestructor) {
+ ht->pDestructor(p->pData);
+ }
+ UPDATE_DATA(ht, p, pData, nDataSize);
+ if (pDest) {
+ *pDest = p->pData;
+ }
+ HANDLE_UNBLOCK_INTERRUPTIONS();
+ return SUCCESS;
}
p = p->pNext;
}
p = ht->arBuckets[nIndex];
while (p != NULL) {
if (p->arKey == arKey ||
- ((p->h == h) && (p->nKeyLength == nKeyLength)
- && !memcmp(p->arKey, arKey, nKeyLength))
- ) {
- if (flag & HASH_ADD) {
- return FAILURE;
- }
- zend_hash_bucket_update(ht, p, pData, nDataSize, pDest ZEND_FILE_LINE_RELAY_CC);
- return SUCCESS;
+ ((p->h == h) && (p->nKeyLength == nKeyLength) && !memcmp(p->arKey, arKey, nKeyLength))) {
+ if (flag & HASH_ADD) {
+ return FAILURE;
+ }
+ ZEND_ASSERT(p->pData != pData);
+ HANDLE_BLOCK_INTERRUPTIONS();
+ if (ht->pDestructor) {
+ ht->pDestructor(p->pData);
+ }
+ UPDATE_DATA(ht, p, pData, nDataSize);
+ if (pDest) {
+ *pDest = p->pData;
+ }
+ HANDLE_UNBLOCK_INTERRUPTIONS();
+ return SUCCESS;
}
p = p->pNext;
}
if (flag & HASH_NEXT_INSERT || flag & HASH_ADD) {
return FAILURE;
}
- zend_hash_bucket_update(ht, p, pData, nDataSize, pDest ZEND_FILE_LINE_RELAY_CC);
+ ZEND_ASSERT(p->pData != pData);
+ HANDLE_BLOCK_INTERRUPTIONS();
+ if (ht->pDestructor) {
+ ht->pDestructor(p->pData);
+ }
+ UPDATE_DATA(ht, p, pData, nDataSize);
+ HANDLE_UNBLOCK_INTERRUPTIONS();
+ if (pDest) {
+ *pDest = p->pData;
+ }
return SUCCESS;
}
p = p->pNext;