diff options
author | Xinchen Hui <laruence@gmail.com> | 2017-11-02 12:13:35 +0800 |
---|---|---|
committer | Xinchen Hui <laruence@gmail.com> | 2017-11-02 12:13:35 +0800 |
commit | d56a534acc52b0bb7d61ac7c3386ab96e8ca4a97 (patch) | |
tree | 5ea9bf64602faf1abb6ed72dbd78dbd3f1ebc904 /ext | |
parent | 3fa0cee640bd54a500fcaa8aa8293a255d0d3191 (diff) | |
download | php-git-d56a534acc52b0bb7d61ac7c3386ab96e8ca4a97.tar.gz |
RC manipulation cleanup 2
Diffstat (limited to 'ext')
-rw-r--r-- | ext/json/json_parser.tab.c | 11 | ||||
-rw-r--r-- | ext/json/json_parser.tab.h | 6 | ||||
-rw-r--r-- | ext/json/json_parser.y | 5 | ||||
-rw-r--r-- | ext/sockets/conversions.c | 15 | ||||
-rw-r--r-- | ext/sockets/multicast.c | 21 | ||||
-rw-r--r-- | ext/spl/spl_array.c | 5 | ||||
-rw-r--r-- | ext/spl/spl_dllist.c | 4 | ||||
-rw-r--r-- | ext/spl/spl_fixedarray.c | 13 | ||||
-rw-r--r-- | ext/spl/spl_heap.c | 4 | ||||
-rw-r--r-- | ext/spl/spl_iterators.c | 16 | ||||
-rw-r--r-- | ext/wddx/wddx.c | 2 | ||||
-rw-r--r-- | ext/xmlrpc/xmlrpc-epi-php.c | 8 | ||||
-rw-r--r-- | ext/xsl/xsltprocessor.c | 4 |
13 files changed, 37 insertions, 77 deletions
diff --git a/ext/json/json_parser.tab.c b/ext/json/json_parser.tab.c index 5db1842900..2edcc63703 100644 --- a/ext/json/json_parser.tab.c +++ b/ext/json/json_parser.tab.c @@ -139,8 +139,8 @@ int json_yydebug = 1; /* In a future release of Bison, this section will be replaced by #include "json_parser.tab.h". */ -#ifndef YY_PHP_JSON_YY_HOME_DMITRY_PHP_PHP_MASTER_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED -# define YY_PHP_JSON_YY_HOME_DMITRY_PHP_PHP_MASTER_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED +#ifndef YY_PHP_JSON_YY_HOME_HUIXINCHEN_OPENSOURCE_TRUNK_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED +# define YY_PHP_JSON_YY_HOME_HUIXINCHEN_OPENSOURCE_TRUNK_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED /* Debug traces. */ #ifndef YYDEBUG # define YYDEBUG 0 @@ -201,7 +201,7 @@ typedef union YYSTYPE YYSTYPE; int php_json_yyparse (php_json_parser *parser); -#endif /* !YY_PHP_JSON_YY_HOME_DMITRY_PHP_PHP_MASTER_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED */ +#endif /* !YY_PHP_JSON_YY_HOME_HUIXINCHEN_OPENSOURCE_TRUNK_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED */ /* Copy the second part of user declarations. */ @@ -1892,10 +1892,7 @@ static int php_json_parser_object_update(php_json_parser *parser, zval *object, } ZVAL_NEW_STR(&zkey, key); zend_std_write_property(object, &zkey, zvalue, NULL); - - if (Z_REFCOUNTED_P(zvalue)) { - Z_DELREF_P(zvalue); - } + Z_TRY_DELREF_P(zvalue); } zend_string_release(key); diff --git a/ext/json/json_parser.tab.h b/ext/json/json_parser.tab.h index 4349b70406..3f126dc9c7 100644 --- a/ext/json/json_parser.tab.h +++ b/ext/json/json_parser.tab.h @@ -30,8 +30,8 @@ This special exception was added by the Free Software Foundation in version 2.2 of Bison. */ -#ifndef YY_PHP_JSON_YY_HOME_DMITRY_PHP_PHP_MASTER_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED -# define YY_PHP_JSON_YY_HOME_DMITRY_PHP_PHP_MASTER_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED +#ifndef YY_PHP_JSON_YY_HOME_HUIXINCHEN_OPENSOURCE_TRUNK_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED +# define YY_PHP_JSON_YY_HOME_HUIXINCHEN_OPENSOURCE_TRUNK_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED /* Debug traces. */ #ifndef YYDEBUG # define YYDEBUG 0 @@ -92,4 +92,4 @@ typedef union YYSTYPE YYSTYPE; int php_json_yyparse (php_json_parser *parser); -#endif /* !YY_PHP_JSON_YY_HOME_DMITRY_PHP_PHP_MASTER_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED */ +#endif /* !YY_PHP_JSON_YY_HOME_HUIXINCHEN_OPENSOURCE_TRUNK_EXT_JSON_JSON_PARSER_TAB_H_INCLUDED */ diff --git a/ext/json/json_parser.y b/ext/json/json_parser.y index 9b9df983ad..ddac27373b 100644 --- a/ext/json/json_parser.y +++ b/ext/json/json_parser.y @@ -284,10 +284,7 @@ static int php_json_parser_object_update(php_json_parser *parser, zval *object, } ZVAL_NEW_STR(&zkey, key); zend_std_write_property(object, &zkey, zvalue, NULL); - - if (Z_REFCOUNTED_P(zvalue)) { - Z_DELREF_P(zvalue); - } + Z_TRY_DELREF_P(zvalue); } zend_string_release(key); diff --git a/ext/sockets/conversions.c b/ext/sockets/conversions.c index 093b6c5d72..4a1705bcee 100644 --- a/ext/sockets/conversions.c +++ b/ext/sockets/conversions.c @@ -1076,18 +1076,15 @@ static void from_zval_write_iov_array_aux(zval *elem, unsigned i, void **args, s { struct msghdr *msg = args[0]; size_t len; + zend_string *str; - if (Z_REFCOUNTED_P(elem)) { - Z_ADDREF_P(elem); - } - convert_to_string_ex(elem); + str = zval_get_string(elem); - len = Z_STRLEN_P(elem); - msg->msg_iov[i - 1].iov_base = accounted_emalloc(len, ctx); - msg->msg_iov[i - 1].iov_len = len; - memcpy(msg->msg_iov[i - 1].iov_base, Z_STRVAL_P(elem), len); + msg->msg_iov[i - 1].iov_base = accounted_emalloc(ZSTR_LEN(str), ctx); + msg->msg_iov[i - 1].iov_len = ZSTR_LEN(str); + memcpy(msg->msg_iov[i - 1].iov_base, ZSTR_VAL(str), ZSTR_LEN(str)); - zval_ptr_dtor(elem); + zend_string_release(str); } static void from_zval_write_iov_array(const zval *arr, char *msghdr_c, ser_context *ctx) { diff --git a/ext/sockets/multicast.c b/ext/sockets/multicast.c index 24f374c55d..9857be3982 100644 --- a/ext/sockets/multicast.c +++ b/ext/sockets/multicast.c @@ -100,12 +100,9 @@ static int php_get_if_index_from_zval(zval *val, unsigned *out) ret = SUCCESS; } } else { - if (Z_REFCOUNTED_P(val)) { - Z_ADDREF_P(val); - } - convert_to_string_ex(val); - ret = php_string_to_if_index(Z_STRVAL_P(val), out); - zval_ptr_dtor(val); + zend_string *str = zval_get_string(val); + ret = php_string_to_if_index(ZSTR_VAL(str), out); + zend_string_release(str); } return ret; @@ -130,20 +127,18 @@ static int php_get_address_from_array(const HashTable *ht, const char *key, php_socket *sock, php_sockaddr_storage *ss, socklen_t *ss_len) { zval *val; + zend_string *str; if ((val = zend_hash_str_find(ht, key, strlen(key))) == NULL) { php_error_docref(NULL, E_WARNING, "no key \"%s\" passed in optval", key); return FAILURE; } - if (Z_REFCOUNTED_P(val)) { - Z_ADDREF_P(val); - } - convert_to_string_ex(val); - if (!php_set_inet46_addr(ss, ss_len, Z_STRVAL_P(val), sock)) { - zval_ptr_dtor(val); + str = zval_get_string(val); + if (!php_set_inet46_addr(ss, ss_len, ZSTR_VAL(str), sock)) { + zend_string_release(str); return FAILURE; } - zval_ptr_dtor(val); + zend_string_release(str); return SUCCESS; } diff --git a/ext/spl/spl_array.c b/ext/spl/spl_array.c index f1c49f4db4..a9645ec61d 100644 --- a/ext/spl/spl_array.c +++ b/ext/spl/spl_array.c @@ -473,10 +473,7 @@ static void spl_array_write_dimension_ex(int check_inherited, zval *object, zval return; } - if (Z_REFCOUNTED_P(value)) { - Z_ADDREF_P(value); - } - + Z_TRY_ADDREF_P(value); if (!offset) { ht = spl_array_get_hash_table(intern); zend_hash_next_index_insert(ht, value); diff --git a/ext/spl/spl_dllist.c b/ext/spl/spl_dllist.c index fac5007be2..1f594293cd 100644 --- a/ext/spl/spl_dllist.c +++ b/ext/spl/spl_dllist.c @@ -1248,9 +1248,7 @@ SPL_METHOD(SplDoublyLinkedList, add) return; } - if (Z_REFCOUNTED_P(value)) { - Z_ADDREF_P(value); - } + Z_TRY_ADDREF_P(value); if (index == intern->llist->count) { /* If index is the last entry+1 then we do a push because we're not inserting before any entry */ spl_ptr_llist_push(intern->llist, value); diff --git a/ext/spl/spl_fixedarray.c b/ext/spl/spl_fixedarray.c index 46e627102b..20fe02fd74 100644 --- a/ext/spl/spl_fixedarray.c +++ b/ext/spl/spl_fixedarray.c @@ -167,9 +167,7 @@ static HashTable* spl_fixedarray_object_get_properties(zval *obj) /* {{{{ */ for (i = 0; i < intern->array.size; i++) { if (!Z_ISUNDEF(intern->array.elements[i])) { zend_hash_index_update(ht, i, &intern->array.elements[i]); - if (Z_REFCOUNTED(intern->array.elements[i])){ - Z_ADDREF(intern->array.elements[i]); - } + Z_TRY_ADDREF(intern->array.elements[i]); } else { zend_hash_index_update(ht, i, &EG(uninitialized_zval)); } @@ -595,10 +593,7 @@ SPL_METHOD(SplFixedArray, __wakeup) spl_fixedarray_init(&intern->array, size); ZEND_HASH_FOREACH_VAL(intern_ht, data) { - if (Z_REFCOUNTED_P(data)) { - Z_ADDREF_P(data); - } - ZVAL_COPY_VALUE(&intern->array.elements[index], data); + ZVAL_COPY(&intern->array.elements[index], data); index++; } ZEND_HASH_FOREACH_END(); @@ -644,9 +639,7 @@ SPL_METHOD(SplFixedArray, toArray) for (; i < intern->array.size; i++) { if (!Z_ISUNDEF(intern->array.elements[i])) { zend_hash_index_update(Z_ARRVAL_P(return_value), i, &intern->array.elements[i]); - if (Z_REFCOUNTED(intern->array.elements[i])) { - Z_ADDREF(intern->array.elements[i]); - } + Z_TRY_ADDREF(intern->array.elements[i]); } else { zend_hash_index_update(Z_ARRVAL_P(return_value), i, &EG(uninitialized_zval)); } diff --git a/ext/spl/spl_heap.c b/ext/spl/spl_heap.c index db8f8d9779..5fecbfd290 100644 --- a/ext/spl/spl_heap.c +++ b/ext/spl/spl_heap.c @@ -97,9 +97,7 @@ static void spl_ptr_heap_zval_dtor(zval *elem) { /* {{{ */ /* }}} */ static void spl_ptr_heap_zval_ctor(zval *elem) { /* {{{ */ - if (Z_REFCOUNTED_P(elem)) { - Z_ADDREF_P(elem); - } + Z_TRY_ADDREF_P(elem); } /* }}} */ diff --git a/ext/spl/spl_iterators.c b/ext/spl/spl_iterators.c index 41597e5f6b..e9975d0708 100644 --- a/ext/spl/spl_iterators.c +++ b/ext/spl/spl_iterators.c @@ -1579,9 +1579,7 @@ static spl_dual_it_object* spl_dual_it_construct(INTERNAL_FUNCTION_PARAMETERS, z efree(cfi); return NULL; } - if (Z_REFCOUNTED_P(&cfi->fci.function_name)) { - Z_ADDREF(cfi->fci.function_name); - } + Z_TRY_ADDREF(cfi->fci.function_name); cfi->object = cfi->fcc.object; if (cfi->object) GC_ADDREF(cfi->object); intern->u.cbfilter = cfi; @@ -2699,8 +2697,8 @@ static inline void spl_caching_it_next(spl_dual_it_object *intern) use_copy = zend_make_printable_zval(&intern->u.caching.zstr, &expr_copy); if (use_copy) { ZVAL_COPY_VALUE(&intern->u.caching.zstr, &expr_copy); - } else if (Z_REFCOUNTED(intern->u.caching.zstr)) { - Z_ADDREF(intern->u.caching.zstr); + } else { + Z_TRY_ADDREF(intern->u.caching.zstr); } } spl_dual_it_next(intern, 0); @@ -2830,9 +2828,7 @@ SPL_METHOD(CachingIterator, offsetSet) return; } - if (Z_REFCOUNTED_P(value)) { - Z_ADDREF_P(value); - } + Z_TRY_ADDREF_P(value); zend_symtable_update(Z_ARRVAL(intern->u.caching.zcache), key, value); } /* }}} */ @@ -3571,9 +3567,7 @@ static int spl_iterator_to_values_apply(zend_object_iterator *iter, void *puser) if (data == NULL) { return ZEND_HASH_APPLY_STOP; } - if (Z_REFCOUNTED_P(data)) { - Z_ADDREF_P(data); - } + Z_TRY_ADDREF_P(data); add_next_index_zval(return_value, data); return ZEND_HASH_APPLY_KEEP; } diff --git a/ext/wddx/wddx.c b/ext/wddx/wddx.c index 85b3a6438c..3b69d999df 100644 --- a/ext/wddx/wddx.c +++ b/ext/wddx/wddx.c @@ -991,7 +991,7 @@ static void php_wddx_pop_element(void *user_data, const XML_Char *name) zval_ptr_dtor(&ent1->data); } else if (Z_TYPE(ent2->data) == IS_OBJECT) { zend_update_property(Z_OBJCE(ent2->data), &ent2->data, ent1->varname, strlen(ent1->varname), &ent1->data); - if Z_REFCOUNTED(ent1->data) Z_DELREF(ent1->data); + Z_TRY_DELREF(ent1->data); } else { zend_symtable_str_update(target_hash, ent1->varname, strlen(ent1->varname), &ent1->data); } diff --git a/ext/xmlrpc/xmlrpc-epi-php.c b/ext/xmlrpc/xmlrpc-epi-php.c index cb727da38c..2f6bae641d 100644 --- a/ext/xmlrpc/xmlrpc-epi-php.c +++ b/ext/xmlrpc/xmlrpc-epi-php.c @@ -981,9 +981,7 @@ PHP_FUNCTION(xmlrpc_server_register_method) if (XMLRPC_ServerRegisterMethod(server->server_ptr, method_key, php_xmlrpc_callback)) { /* save for later use */ - if (Z_REFCOUNTED_P(method_name)) { - Z_ADDREF_P(method_name); - } + Z_TRY_ADDREF_P(method_name); /* register our php method */ add_zval(&server->method_map, method_key, method_name); @@ -1007,9 +1005,7 @@ PHP_FUNCTION(xmlrpc_server_register_introspection_callback) RETURN_FALSE; } - if (Z_REFCOUNTED_P(method_name)) { - Z_ADDREF_P(method_name); - } + Z_TRY_ADDREF_P(method_name); /* register our php method */ add_zval(&server->introspection_map, NULL, method_name); diff --git a/ext/xsl/xsltprocessor.c b/ext/xsl/xsltprocessor.c index 6fda147b5c..5fe6c61494 100644 --- a/ext/xsl/xsltprocessor.c +++ b/ext/xsl/xsltprocessor.c @@ -764,9 +764,7 @@ PHP_FUNCTION(xsl_xsltprocessor_set_parameter) RETURN_FALSE; } convert_to_string_ex(entry); - if (Z_REFCOUNTED_P(entry)) { - Z_ADDREF_P(entry); - } + Z_TRY_ADDREF_P(entry); zend_hash_update(intern->parameter, string_key, entry); } ZEND_HASH_FOREACH_END(); RETURN_TRUE; |