Backport v4 updates
[m6w6/ext-http] / src / php_http_misc.h
index c45ab1595aeee65c4e0dee3a16a2be9924310d39..b91638e2098f27abb48c1abdd0bc53be3f58541a 100644 (file)
@@ -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); \