Edit File by line

Deprecated: str_replace(): Passing null to parameter #2 ($replace) of type array|string is deprecated in /home/sportsfever/public_html/filemanger/function.php on line 93
/home/sportsfe.../httpdocs/wp-conte.../plugins/wordpres.../vendor_p.../guzzleht.../promises/src
File: Utils.php
<?php
[0] Fix | Delete
[1] Fix | Delete
declare (strict_types=1);
[2] Fix | Delete
namespace YoastSEO_Vendor\GuzzleHttp\Promise;
[3] Fix | Delete
[4] Fix | Delete
final class Utils
[5] Fix | Delete
{
[6] Fix | Delete
/**
[7] Fix | Delete
* Get the global task queue used for promise resolution.
[8] Fix | Delete
*
[9] Fix | Delete
* This task queue MUST be run in an event loop in order for promises to be
[10] Fix | Delete
* settled asynchronously. It will be automatically run when synchronously
[11] Fix | Delete
* waiting on a promise.
[12] Fix | Delete
*
[13] Fix | Delete
* <code>
[14] Fix | Delete
* while ($eventLoop->isRunning()) {
[15] Fix | Delete
* GuzzleHttp\Promise\Utils::queue()->run();
[16] Fix | Delete
* }
[17] Fix | Delete
* </code>
[18] Fix | Delete
*
[19] Fix | Delete
* @param TaskQueueInterface|null $assign Optionally specify a new queue instance.
[20] Fix | Delete
*/
[21] Fix | Delete
public static function queue(\YoastSEO_Vendor\GuzzleHttp\Promise\TaskQueueInterface $assign = null) : \YoastSEO_Vendor\GuzzleHttp\Promise\TaskQueueInterface
[22] Fix | Delete
{
[23] Fix | Delete
static $queue;
[24] Fix | Delete
if ($assign) {
[25] Fix | Delete
$queue = $assign;
[26] Fix | Delete
} elseif (!$queue) {
[27] Fix | Delete
$queue = new \YoastSEO_Vendor\GuzzleHttp\Promise\TaskQueue();
[28] Fix | Delete
}
[29] Fix | Delete
return $queue;
[30] Fix | Delete
}
[31] Fix | Delete
/**
[32] Fix | Delete
* Adds a function to run in the task queue when it is next `run()` and
[33] Fix | Delete
* returns a promise that is fulfilled or rejected with the result.
[34] Fix | Delete
*
[35] Fix | Delete
* @param callable $task Task function to run.
[36] Fix | Delete
*/
[37] Fix | Delete
public static function task(callable $task) : \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface
[38] Fix | Delete
{
[39] Fix | Delete
$queue = self::queue();
[40] Fix | Delete
$promise = new \YoastSEO_Vendor\GuzzleHttp\Promise\Promise([$queue, 'run']);
[41] Fix | Delete
$queue->add(function () use($task, $promise) : void {
[42] Fix | Delete
try {
[43] Fix | Delete
if (\YoastSEO_Vendor\GuzzleHttp\Promise\Is::pending($promise)) {
[44] Fix | Delete
$promise->resolve($task());
[45] Fix | Delete
}
[46] Fix | Delete
} catch (\Throwable $e) {
[47] Fix | Delete
$promise->reject($e);
[48] Fix | Delete
}
[49] Fix | Delete
});
[50] Fix | Delete
return $promise;
[51] Fix | Delete
}
[52] Fix | Delete
/**
[53] Fix | Delete
* Synchronously waits on a promise to resolve and returns an inspection
[54] Fix | Delete
* state array.
[55] Fix | Delete
*
[56] Fix | Delete
* Returns a state associative array containing a "state" key mapping to a
[57] Fix | Delete
* valid promise state. If the state of the promise is "fulfilled", the
[58] Fix | Delete
* array will contain a "value" key mapping to the fulfilled value of the
[59] Fix | Delete
* promise. If the promise is rejected, the array will contain a "reason"
[60] Fix | Delete
* key mapping to the rejection reason of the promise.
[61] Fix | Delete
*
[62] Fix | Delete
* @param PromiseInterface $promise Promise or value.
[63] Fix | Delete
*/
[64] Fix | Delete
public static function inspect(\YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface $promise) : array
[65] Fix | Delete
{
[66] Fix | Delete
try {
[67] Fix | Delete
return ['state' => \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface::FULFILLED, 'value' => $promise->wait()];
[68] Fix | Delete
} catch (\YoastSEO_Vendor\GuzzleHttp\Promise\RejectionException $e) {
[69] Fix | Delete
return ['state' => \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface::REJECTED, 'reason' => $e->getReason()];
[70] Fix | Delete
} catch (\Throwable $e) {
[71] Fix | Delete
return ['state' => \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface::REJECTED, 'reason' => $e];
[72] Fix | Delete
}
[73] Fix | Delete
}
[74] Fix | Delete
/**
[75] Fix | Delete
* Waits on all of the provided promises, but does not unwrap rejected
[76] Fix | Delete
* promises as thrown exception.
[77] Fix | Delete
*
[78] Fix | Delete
* Returns an array of inspection state arrays.
[79] Fix | Delete
*
[80] Fix | Delete
* @see inspect for the inspection state array format.
[81] Fix | Delete
*
[82] Fix | Delete
* @param PromiseInterface[] $promises Traversable of promises to wait upon.
[83] Fix | Delete
*/
[84] Fix | Delete
public static function inspectAll($promises) : array
[85] Fix | Delete
{
[86] Fix | Delete
$results = [];
[87] Fix | Delete
foreach ($promises as $key => $promise) {
[88] Fix | Delete
$results[$key] = self::inspect($promise);
[89] Fix | Delete
}
[90] Fix | Delete
return $results;
[91] Fix | Delete
}
[92] Fix | Delete
/**
[93] Fix | Delete
* Waits on all of the provided promises and returns the fulfilled values.
[94] Fix | Delete
*
[95] Fix | Delete
* Returns an array that contains the value of each promise (in the same
[96] Fix | Delete
* order the promises were provided). An exception is thrown if any of the
[97] Fix | Delete
* promises are rejected.
[98] Fix | Delete
*
[99] Fix | Delete
* @param iterable<PromiseInterface> $promises Iterable of PromiseInterface objects to wait on.
[100] Fix | Delete
*
[101] Fix | Delete
* @throws \Throwable on error
[102] Fix | Delete
*/
[103] Fix | Delete
public static function unwrap($promises) : array
[104] Fix | Delete
{
[105] Fix | Delete
$results = [];
[106] Fix | Delete
foreach ($promises as $key => $promise) {
[107] Fix | Delete
$results[$key] = $promise->wait();
[108] Fix | Delete
}
[109] Fix | Delete
return $results;
[110] Fix | Delete
}
[111] Fix | Delete
/**
[112] Fix | Delete
* Given an array of promises, return a promise that is fulfilled when all
[113] Fix | Delete
* the items in the array are fulfilled.
[114] Fix | Delete
*
[115] Fix | Delete
* The promise's fulfillment value is an array with fulfillment values at
[116] Fix | Delete
* respective positions to the original array. If any promise in the array
[117] Fix | Delete
* rejects, the returned promise is rejected with the rejection reason.
[118] Fix | Delete
*
[119] Fix | Delete
* @param mixed $promises Promises or values.
[120] Fix | Delete
* @param bool $recursive If true, resolves new promises that might have been added to the stack during its own resolution.
[121] Fix | Delete
*/
[122] Fix | Delete
public static function all($promises, bool $recursive = \false) : \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface
[123] Fix | Delete
{
[124] Fix | Delete
$results = [];
[125] Fix | Delete
$promise = \YoastSEO_Vendor\GuzzleHttp\Promise\Each::of($promises, function ($value, $idx) use(&$results) : void {
[126] Fix | Delete
$results[$idx] = $value;
[127] Fix | Delete
}, function ($reason, $idx, \YoastSEO_Vendor\GuzzleHttp\Promise\Promise $aggregate) : void {
[128] Fix | Delete
$aggregate->reject($reason);
[129] Fix | Delete
})->then(function () use(&$results) {
[130] Fix | Delete
\ksort($results);
[131] Fix | Delete
return $results;
[132] Fix | Delete
});
[133] Fix | Delete
if (\true === $recursive) {
[134] Fix | Delete
$promise = $promise->then(function ($results) use($recursive, &$promises) {
[135] Fix | Delete
foreach ($promises as $promise) {
[136] Fix | Delete
if (\YoastSEO_Vendor\GuzzleHttp\Promise\Is::pending($promise)) {
[137] Fix | Delete
return self::all($promises, $recursive);
[138] Fix | Delete
}
[139] Fix | Delete
}
[140] Fix | Delete
return $results;
[141] Fix | Delete
});
[142] Fix | Delete
}
[143] Fix | Delete
return $promise;
[144] Fix | Delete
}
[145] Fix | Delete
/**
[146] Fix | Delete
* Initiate a competitive race between multiple promises or values (values
[147] Fix | Delete
* will become immediately fulfilled promises).
[148] Fix | Delete
*
[149] Fix | Delete
* When count amount of promises have been fulfilled, the returned promise
[150] Fix | Delete
* is fulfilled with an array that contains the fulfillment values of the
[151] Fix | Delete
* winners in order of resolution.
[152] Fix | Delete
*
[153] Fix | Delete
* This promise is rejected with a {@see AggregateException} if the number
[154] Fix | Delete
* of fulfilled promises is less than the desired $count.
[155] Fix | Delete
*
[156] Fix | Delete
* @param int $count Total number of promises.
[157] Fix | Delete
* @param mixed $promises Promises or values.
[158] Fix | Delete
*/
[159] Fix | Delete
public static function some(int $count, $promises) : \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface
[160] Fix | Delete
{
[161] Fix | Delete
$results = [];
[162] Fix | Delete
$rejections = [];
[163] Fix | Delete
return \YoastSEO_Vendor\GuzzleHttp\Promise\Each::of($promises, function ($value, $idx, \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface $p) use(&$results, $count) : void {
[164] Fix | Delete
if (\YoastSEO_Vendor\GuzzleHttp\Promise\Is::settled($p)) {
[165] Fix | Delete
return;
[166] Fix | Delete
}
[167] Fix | Delete
$results[$idx] = $value;
[168] Fix | Delete
if (\count($results) >= $count) {
[169] Fix | Delete
$p->resolve(null);
[170] Fix | Delete
}
[171] Fix | Delete
}, function ($reason) use(&$rejections) : void {
[172] Fix | Delete
$rejections[] = $reason;
[173] Fix | Delete
})->then(function () use(&$results, &$rejections, $count) {
[174] Fix | Delete
if (\count($results) !== $count) {
[175] Fix | Delete
throw new \YoastSEO_Vendor\GuzzleHttp\Promise\AggregateException('Not enough promises to fulfill count', $rejections);
[176] Fix | Delete
}
[177] Fix | Delete
\ksort($results);
[178] Fix | Delete
return \array_values($results);
[179] Fix | Delete
});
[180] Fix | Delete
}
[181] Fix | Delete
/**
[182] Fix | Delete
* Like some(), with 1 as count. However, if the promise fulfills, the
[183] Fix | Delete
* fulfillment value is not an array of 1 but the value directly.
[184] Fix | Delete
*
[185] Fix | Delete
* @param mixed $promises Promises or values.
[186] Fix | Delete
*/
[187] Fix | Delete
public static function any($promises) : \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface
[188] Fix | Delete
{
[189] Fix | Delete
return self::some(1, $promises)->then(function ($values) {
[190] Fix | Delete
return $values[0];
[191] Fix | Delete
});
[192] Fix | Delete
}
[193] Fix | Delete
/**
[194] Fix | Delete
* Returns a promise that is fulfilled when all of the provided promises have
[195] Fix | Delete
* been fulfilled or rejected.
[196] Fix | Delete
*
[197] Fix | Delete
* The returned promise is fulfilled with an array of inspection state arrays.
[198] Fix | Delete
*
[199] Fix | Delete
* @see inspect for the inspection state array format.
[200] Fix | Delete
*
[201] Fix | Delete
* @param mixed $promises Promises or values.
[202] Fix | Delete
*/
[203] Fix | Delete
public static function settle($promises) : \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface
[204] Fix | Delete
{
[205] Fix | Delete
$results = [];
[206] Fix | Delete
return \YoastSEO_Vendor\GuzzleHttp\Promise\Each::of($promises, function ($value, $idx) use(&$results) : void {
[207] Fix | Delete
$results[$idx] = ['state' => \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface::FULFILLED, 'value' => $value];
[208] Fix | Delete
}, function ($reason, $idx) use(&$results) : void {
[209] Fix | Delete
$results[$idx] = ['state' => \YoastSEO_Vendor\GuzzleHttp\Promise\PromiseInterface::REJECTED, 'reason' => $reason];
[210] Fix | Delete
})->then(function () use(&$results) {
[211] Fix | Delete
\ksort($results);
[212] Fix | Delete
return $results;
[213] Fix | Delete
});
[214] Fix | Delete
}
[215] Fix | Delete
}
[216] Fix | Delete
[217] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function