N°5122 - Update libs to new PHP requirements

This commit is contained in:
Molkobain
2022-08-08 14:10:26 +02:00
parent 30021d9236
commit 57c36d0e51
585 changed files with 62279 additions and 20427 deletions

View File

@@ -1,26 +1,37 @@
<?php
/**
* @see https://github.com/laminas/laminas-stdlib for the canonical source repository
* @copyright https://github.com/laminas/laminas-stdlib/blob/master/COPYRIGHT.md
* @license https://github.com/laminas/laminas-stdlib/blob/master/LICENSE.md New BSD License
*/
declare(strict_types=1);
namespace Laminas\Stdlib;
use Serializable;
use UnexpectedValueException;
use function array_key_exists;
use function get_class;
use function gettype;
use function is_array;
use function is_object;
use function serialize;
use function sprintf;
use function unserialize;
use const PHP_INT_MAX;
/**
* Serializable version of SplPriorityQueue
*
* Also, provides predictable heap order for datums added with the same priority
* (i.e., they will be emitted in the same order they are enqueued).
*
* @psalm-type InternalPriority = array{0: mixed, 1: int}
* @template TValue
* @template TPriority of InternalPriority
* @extends \SplPriorityQueue<TPriority, TValue>
*/
class SplPriorityQueue extends \SplPriorityQueue implements Serializable
{
/**
* @var int Seed used to ensure queue order for items of the same priority
*/
/** @var int Seed used to ensure queue order for items of the same priority */
protected $serial = PHP_INT_MAX;
/**
@@ -29,8 +40,8 @@ class SplPriorityQueue extends \SplPriorityQueue implements Serializable
* Utilizes {@var $serial} to ensure that values of equal priority are
* emitted in the same order in which they are inserted.
*
* @param mixed $datum
* @param mixed $priority
* @param TValue $datum
* @param TPriority|mixed $priority
* @return void
*/
public function insert($datum, $priority)
@@ -38,6 +49,9 @@ class SplPriorityQueue extends \SplPriorityQueue implements Serializable
if (! is_array($priority)) {
$priority = [$priority, $this->serial--];
}
/** @psalm-var TPriority $priority */
parent::insert($datum, $priority);
}
@@ -46,7 +60,7 @@ class SplPriorityQueue extends \SplPriorityQueue implements Serializable
*
* Array will be priority => data pairs
*
* @return array
* @return list<TValue>
*/
public function toArray()
{
@@ -63,6 +77,16 @@ class SplPriorityQueue extends \SplPriorityQueue implements Serializable
* @return string
*/
public function serialize()
{
return serialize($this->__serialize());
}
/**
* Magic method used for serializing of an instance.
*
* @return array
*/
public function __serialize()
{
$clone = clone $this;
$clone->setExtractFlags(self::EXTR_BOTH);
@@ -71,8 +95,7 @@ class SplPriorityQueue extends \SplPriorityQueue implements Serializable
foreach ($clone as $item) {
$data[] = $item;
}
return serialize($data);
return $data;
}
/**
@@ -82,11 +105,52 @@ class SplPriorityQueue extends \SplPriorityQueue implements Serializable
* @return void
*/
public function unserialize($data)
{
$toUnserialize = unserialize($data);
if (! is_array($toUnserialize)) {
throw new UnexpectedValueException(sprintf(
'Cannot deserialize %s instance; corrupt serialization data',
self::class
));
}
$this->__unserialize($toUnserialize);
}
/**
* Magic method used to rebuild an instance.
*
* @param array $data Data array.
* @return void
*/
public function __unserialize($data)
{
$this->serial = PHP_INT_MAX;
foreach (unserialize($data) as $item) {
$this->serial--;
$this->insert($item['data'], $item['priority']);
foreach ($data as $item) {
if (! is_array($item)) {
throw new UnexpectedValueException(sprintf(
'Cannot deserialize %s instance: corrupt item; expected array, received %s',
self::class,
is_object($item) ? get_class($item) : gettype($item)
));
}
if (! array_key_exists('data', $item)) {
throw new UnexpectedValueException(sprintf(
'Cannot deserialize %s instance: corrupt item; missing "data" element',
self::class
));
}
$priority = 1;
if (array_key_exists('priority', $item)) {
$priority = (int) $item['priority'];
}
/** @psalm-var TValue $item['data'] */
$this->insert($item['data'], $priority);
}
}
}