isResolved) { $func($this->error, $this->result); } else { $this->whens[] = $func; } } /** * Notify the $func callback when resolution progress events are emitted * * @return void */ public function watch(callable $func) { if (!$this->isResolved) { $this->watchers[] = $func; } } /** * This method is deprecated. New code should use Amp\wait($promise) instead. */ public function wait() { trigger_error( 'Amp\\Promise::wait() is deprecated and scheduled for removal. ' . 'Please update code to use Amp\\wait($promise) instead.', E_USER_DEPRECATED ); $isWaiting = true; $resolvedError = $resolvedResult = null; $this->when(function($error, $result) use (&$isWaiting, &$resolvedError, &$resolvedResult) { $isWaiting = false; $resolvedError = $error; $resolvedResult = $result; }); $reactor = getReactor(); while ($isWaiting) { $reactor->tick(); } if ($resolvedError) { throw $resolvedError; } return $resolvedResult; } /** * Update watchers of resolution progress events * * @param mixed $progress * @throws \LogicException if the promise has already resolved * @return void */ public function update($progress) { if ($this->isResolved) { throw new \LogicException( 'Cannot update resolved promise' ); } foreach ($this->watchers as $watcher) { $watcher($progress); } } /** * Resolve the promised value as a success * * @param mixed $result * @throws \LogicException if the promise has already resolved or the result is the current instance * @return void */ public function succeed($result = null) { if ($this->isResolved) { throw new \LogicException( 'Promise already resolved' ); } elseif ($result === $this) { throw new \LogicException( 'A Promise cannot act as its own resolution result' ); } elseif ($result instanceof Promise) { $result->when(function(\Exception $error = null, $result = null) { if ($error) { $this->fail($error); } else { $this->succeed($result); } }); } else { $this->isResolved = true; $this->result = $result; $error = null; foreach ($this->whens as $when) { $when($error, $result); } $this->whens = $this->watchers = []; } } /** * Resolve the promised value as a failure * * @throws \LogicException if the promise has already resolved * @return void */ public function fail(\Exception $error) { if ($this->isResolved) { throw new \LogicException( 'Promise already resolved' ); } $this->isResolved = true; $this->error = $error; $result = null; foreach ($this->whens as $when) { $when($error, $result); } $this->whens = $this->watchers = []; } }