mirror of
https://github.com/php/php-src.git
synced 2025-08-16 05:58:45 +02:00
Fixed bug #80121
The issue affected both CurlHandle and CurlMultiHandle. I'll have to double check this for other resource->object conversions as well.
This commit is contained in:
parent
f82414e935
commit
d96219c185
4 changed files with 45 additions and 5 deletions
|
@ -3308,6 +3308,12 @@ static void curl_free_obj(zend_object *object)
|
|||
fprintf(stderr, "DTOR CALLED, ch = %x\n", ch);
|
||||
#endif
|
||||
|
||||
if (!ch->cp) {
|
||||
/* Can happen if constructor throws. */
|
||||
zend_object_std_dtor(&ch->std);
|
||||
return;
|
||||
}
|
||||
|
||||
_php_curl_verify_handlers(ch, 0);
|
||||
|
||||
/*
|
||||
|
@ -3321,12 +3327,10 @@ static void curl_free_obj(zend_object *object)
|
|||
*
|
||||
* Libcurl commit d021f2e8a00 fix this issue and should be part of 7.28.2
|
||||
*/
|
||||
if (ch->cp != NULL) {
|
||||
curl_easy_setopt(ch->cp, CURLOPT_HEADERFUNCTION, curl_write_nothing);
|
||||
curl_easy_setopt(ch->cp, CURLOPT_WRITEFUNCTION, curl_write_nothing);
|
||||
curl_easy_setopt(ch->cp, CURLOPT_HEADERFUNCTION, curl_write_nothing);
|
||||
curl_easy_setopt(ch->cp, CURLOPT_WRITEFUNCTION, curl_write_nothing);
|
||||
|
||||
curl_easy_cleanup(ch->cp);
|
||||
}
|
||||
curl_easy_cleanup(ch->cp);
|
||||
|
||||
/* cURL destructors should be invoked only by last curl handle */
|
||||
if (--(*ch->clone) == 0) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue