X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fphp_http_misc.h;h=b91638e2098f27abb48c1abdd0bc53be3f58541a;hb=e3976774f27b4129cbfd7d227aaa7e177f1b735c;hp=99660ea98ada5caf0ddc74105c3e72d0b60a17a7;hpb=e44e3ceb60817cfdd17945a3f6043816e134aa75;p=m6w6%2Fext-http diff --git a/src/php_http_misc.h b/src/php_http_misc.h index 99660ea..b91638e 100644 --- a/src/php_http_misc.h +++ b/src/php_http_misc.h @@ -99,13 +99,46 @@ static inline const char *php_http_locate_bin_eol(const char *bin, size_t len, i #if PHP_DEBUG # undef HASH_OF -# define HASH_OF(p) ((HashTable*)(Z_TYPE_P(p)==IS_ARRAY ? Z_ARRVAL_P(p) : ((Z_TYPE_P(p)==IS_OBJECT ? Z_OBJ_HT_P(p)->get_properties(Z_OBJ_P(p)) : NULL)))) +# if PHP_VERSION_ID >= 70500 +# define HASH_OF(p) ((HashTable*)(Z_TYPE_P(p)==IS_ARRAY ? Z_ARRVAL_P(p) : ((Z_TYPE_P(p)==IS_OBJECT ? Z_OBJ_HT_P(p)->get_properties(Z_OBJ_P(p)) : NULL)))) +# else +# define HASH_OF(p) ((HashTable*)(Z_TYPE_P(p)==IS_ARRAY ? Z_ARRVAL_P(p) : ((Z_TYPE_P(p)==IS_OBJECT ? Z_OBJ_HT_P(p)->get_properties((p)) : NULL)))) +# endif #endif +#ifndef GC_SET_REFCOUNT +# define GC_SET_REFCOUNT(gc, rc) GC_REFCOUNT(gc) = rc +#endif +#ifndef GC_ADDREF +# define GC_ADDREF(gc) ++GC_REFCOUNT(gc) +#endif +#ifndef GC_DELREF +# define GC_DELREF(gc) --GC_REFCOUNT(gc) +#endif + +#ifdef ZEND_HASH_GET_APPLY_COUNT +# define HT_IS_RECURSIVE(ht) (ZEND_HASH_GET_APPLY_COUNT(ht) > 0) +#else +# define HT_IS_RECURSIVE(ht) GC_IS_RECURSIVE(ht) +#endif +#ifdef ZEND_HASH_INC_APPLY_COUNT +# define HT_PROTECT_RECURSION(ht) ZEND_HASH_INC_APPLY_COUNT(ht) +#else +# define HT_PROTECT_RECURSION(ht) GC_PROTECT_RECURSION(ht) +#endif +#ifdef ZEND_HASH_DEC_APPLY_COUNT +# define HT_UNPROTECT_RECURSION(ht) ZEND_HASH_DEC_APPLY_COUNT(ht) +#else +# define HT_UNPROTECT_RECURSION(ht) GC_UNPROTECT_RECURSION(ht) +#endif -#define HT_IS_RECURSIVE(ht) GC_IS_RECURSIVE(ht) -#define HT_PROTECT_RECURSION(ht) GC_PROTECT_RECURSION(ht) -#define HT_UNPROTECT_RECURSION(ht) GC_UNPROTECT_RECURSION(ht) +#if PHP_VERSION_ID >= 70400 +# define PHP_WRITE_PROP_HANDLER_TYPE zval * +# define PHP_WRITE_PROP_HANDLER_RETURN(v) return v +#else +# define PHP_WRITE_PROP_HANDLER_TYPE void +# define PHP_WRITE_PROP_HANDLER_RETURN(v) +#endif static inline void *PHP_HTTP_OBJ(zend_object *zo, zval *zv) { @@ -117,8 +150,16 @@ static inline void *PHP_HTTP_OBJ(zend_object *zo, zval *zv) static inline zend_string *php_http_cs2zs(char *s, size_t l) { - zend_string *str = zend_string_init(s, l, 0); - efree(s); + zend_string *str = erealloc(s, sizeof(*str) + l); + + memmove(str->val, str, l); + str->val[l] = 0; + str->len = l; + str->h = 0; + + GC_SET_REFCOUNT(str, 1); + GC_TYPE_INFO(str) = IS_STRING; + return str; } @@ -139,6 +180,9 @@ static inline ZEND_RESULT_CODE php_http_ini_entry(const char *name_str, size_t n return FAILURE; } +#define Z_ISUSER(zv) (Z_TYPE(zv) <= 10) +#define Z_ISUSER_P(zvp) Z_ISUSER(*(zvp)) + /* return object(values) */ #define ZVAL_OBJECT(z, o, addref) \ ZVAL_OBJ(z, o); \