X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=src%2Fphp_http_misc.h;h=b91638e2098f27abb48c1abdd0bc53be3f58541a;hb=e3976774f27b4129cbfd7d227aaa7e177f1b735c;hp=c45ab1595aeee65c4e0dee3a16a2be9924310d39;hpb=b9e1564632b6d00d1120ee7c73574759af9e6167;p=m6w6%2Fext-http diff --git a/src/php_http_misc.h b/src/php_http_misc.h index c45ab15..b91638e 100644 --- a/src/php_http_misc.h +++ b/src/php_http_misc.h @@ -99,55 +99,47 @@ 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 -#if PHP_VERSION_ID >= 80100 -# define php_http_mem_stream_open(type, zstr) php_stream_memory_open((type), (zstr)) -#else -# define php_http_mem_stream_open(type, zstr) php_stream_memory_open((type), (zstr)->val, (zstr)->len) -# define ZEND_BEGIN_ARG_WITH_TENTATIVE_RETURN_TYPE_INFO_EX(name, return_reference, required_num_args, type, allow_null) \ - ZEND_BEGIN_ARG_INFO_EX(name, 0, return_reference, required_num_args) -# define ZEND_BEGIN_ARG_WITH_TENTATIVE_RETURN_OBJ_INFO_EX(name, return_reference, required_num_args, type, allow_null) \ - ZEND_BEGIN_ARG_INFO_EX(name, 0, return_reference, required_num_args) +#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 -#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) - -#ifndef convert_to_explicit_type -# define convert_to_explicit_type(pzv, type) \ - do { \ - switch (type) { \ - case IS_NULL: \ - convert_to_null(pzv); \ - break; \ - case IS_LONG: \ - convert_to_long(pzv); \ - break; \ - case IS_DOUBLE: \ - convert_to_double(pzv); \ - break; \ - case _IS_BOOL: \ - convert_to_boolean(pzv); \ - break; \ - case IS_ARRAY: \ - convert_to_array(pzv); \ - break; \ - case IS_OBJECT: \ - convert_to_object(pzv); \ - break; \ - case IS_STRING: \ - convert_to_string(pzv); \ - break; \ - default: \ - assert(0); \ - break; \ - } \ - } while (0); +#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 +#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) { if (!zo) { @@ -158,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; } @@ -180,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); \