diff options
| author | Christoph M. Becker <cmbecker69@gmx.de> | 2020-03-06 09:10:43 +0100 | 
|---|---|---|
| committer | Christoph M. Becker <cmbecker69@gmx.de> | 2020-03-06 09:11:10 +0100 | 
| commit | b761997de37edf72a6b7f7d458f6503a00c9edb7 (patch) | |
| tree | 39ae07aeae7abaf855dcbdacf268895dd9ac19ff | |
| parent | 04c9c4ae7d8a11c132e8275735dcf457709a0cbd (diff) | |
| parent | b84277297ae18f11055a5731a881a347df8d76b9 (diff) | |
| download | php-git-b761997de37edf72a6b7f7d458f6503a00c9edb7.tar.gz | |
Merge branch 'PHP-7.3' into PHP-7.4
* PHP-7.3:
  Fix #75673: SplStack::unserialize() behavior
| -rw-r--r-- | NEWS | 5 | ||||
| -rw-r--r-- | ext/spl/spl_dllist.c | 6 | ||||
| -rw-r--r-- | ext/spl/tests/bug75673.phpt | 19 | 
3 files changed, 30 insertions, 0 deletions
| @@ -1,6 +1,11 @@  PHP                                                                        NEWS  ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| +?? ??? ????, PHP 7.4.5 + +- Spl: +  . Fixed bug #75673 (SplStack::unserialize() behavior). (cmb) +  ?? ??? ????, PHP 7.4.4  - Core: diff --git a/ext/spl/spl_dllist.c b/ext/spl/spl_dllist.c index 168034906a..a0eb06a97a 100644 --- a/ext/spl/spl_dllist.c +++ b/ext/spl/spl_dllist.c @@ -1185,6 +1185,12 @@ SPL_METHOD(SplDoublyLinkedList, unserialize)  		return;  	} +	while (intern->llist->count > 0) { +		zval tmp; +		spl_ptr_llist_pop(intern->llist, &tmp); +		zval_ptr_dtor(&tmp); +	} +  	s = p = (const unsigned char*)buf;  	PHP_VAR_UNSERIALIZE_INIT(var_hash); diff --git a/ext/spl/tests/bug75673.phpt b/ext/spl/tests/bug75673.phpt new file mode 100644 index 0000000000..76fe3745fb --- /dev/null +++ b/ext/spl/tests/bug75673.phpt @@ -0,0 +1,19 @@ +--TEST-- +Bug #75673 (SplStack::unserialize() behavior) +--FILE-- +<?php +$stack = new SplStack(); +$stack->push("one"); +$stack->push("two"); + +$serialized = $stack->serialize(); +var_dump($stack->count()); +$stack->unserialize($serialized); +var_dump($stack->count()); +$stack->unserialize($serialized); +var_dump($stack->count()); +?> +--EXPECT-- +int(2) +int(2) +int(2) | 
