OXIESEC PANEL
- Current Dir:
/
/
var
/
www
/
firebase
/
vendor
/
guzzlehttp
/
promises
/
src
Server IP: 139.59.38.164
Upload:
Create Dir:
Name
Size
Modified
Perms
📁
..
-
08/12/2024 10:33:20 AM
rwxr-xr-x
📄
AggregateException.php
397 bytes
08/12/2024 10:33:19 AM
rw-r--r--
📄
CancellationException.php
193 bytes
08/12/2024 10:33:19 AM
rw-r--r--
📄
Coroutine.php
4.41 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
Create.php
2.14 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
Each.php
2.91 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
EachPromise.php
7.84 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
FulfilledPromise.php
2.03 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
Is.php
1.02 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
Promise.php
9.01 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
PromiseInterface.php
2.88 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
PromisorInterface.php
260 bytes
08/12/2024 10:33:19 AM
rw-r--r--
📄
RejectedPromise.php
2.32 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
RejectionException.php
1.24 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
TaskQueue.php
1.96 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
TaskQueueInterface.php
457 bytes
08/12/2024 10:33:19 AM
rw-r--r--
📄
Utils.php
8.78 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
functions.php
10.25 KB
08/12/2024 10:33:19 AM
rw-r--r--
📄
functions_include.php
173 bytes
08/12/2024 10:33:19 AM
rw-r--r--
Editing: Coroutine.php
Close
<?php namespace GuzzleHttp\Promise; use Exception; use Generator; use Throwable; /** * Creates a promise that is resolved using a generator that yields values or * promises (somewhat similar to C#'s async keyword). * * When called, the Coroutine::of method will start an instance of the generator * and returns a promise that is fulfilled with its final yielded value. * * Control is returned back to the generator when the yielded promise settles. * This can lead to less verbose code when doing lots of sequential async calls * with minimal processing in between. * * use GuzzleHttp\Promise; * * function createPromise($value) { * return new Promise\FulfilledPromise($value); * } * * $promise = Promise\Coroutine::of(function () { * $value = (yield createPromise('a')); * try { * $value = (yield createPromise($value . 'b')); * } catch (\Exception $e) { * // The promise was rejected. * } * yield $value . 'c'; * }); * * // Outputs "abc" * $promise->then(function ($v) { echo $v; }); * * @param callable $generatorFn Generator function to wrap into a promise. * * @return Promise * * @link https://github.com/petkaantonov/bluebird/blob/master/API.md#generators inspiration */ final class Coroutine implements PromiseInterface { /** * @var PromiseInterface|null */ private $currentPromise; /** * @var Generator */ private $generator; /** * @var Promise */ private $result; public function __construct(callable $generatorFn) { $this->generator = $generatorFn(); $this->result = new Promise(function () { while (isset($this->currentPromise)) { $this->currentPromise->wait(); } }); try { $this->nextCoroutine($this->generator->current()); } catch (\Exception $exception) { $this->result->reject($exception); } catch (Throwable $throwable) { $this->result->reject($throwable); } } /** * Create a new coroutine. * * @return self */ public static function of(callable $generatorFn) { return new self($generatorFn); } public function then( callable $onFulfilled = null, callable $onRejected = null ) { return $this->result->then($onFulfilled, $onRejected); } public function otherwise(callable $onRejected) { return $this->result->otherwise($onRejected); } public function wait($unwrap = true) { return $this->result->wait($unwrap); } public function getState() { return $this->result->getState(); } public function resolve($value) { $this->result->resolve($value); } public function reject($reason) { $this->result->reject($reason); } public function cancel() { $this->currentPromise->cancel(); $this->result->cancel(); } private function nextCoroutine($yielded) { $this->currentPromise = Create::promiseFor($yielded) ->then([$this, '_handleSuccess'], [$this, '_handleFailure']); } /** * @internal */ public function _handleSuccess($value) { unset($this->currentPromise); try { $next = $this->generator->send($value); if ($this->generator->valid()) { $this->nextCoroutine($next); } else { $this->result->resolve($value); } } catch (Exception $exception) { $this->result->reject($exception); } catch (Throwable $throwable) { $this->result->reject($throwable); } } /** * @internal */ public function _handleFailure($reason) { unset($this->currentPromise); try { $nextYield = $this->generator->throw(Create::exceptionFor($reason)); // The throw was caught, so keep iterating on the coroutine $this->nextCoroutine($nextYield); } catch (Exception $exception) { $this->result->reject($exception); } catch (Throwable $throwable) { $this->result->reject($throwable); } } }