1
0
mirror of https://github.com/danog/amp.git synced 2024-12-03 18:07:57 +01:00
amp/lib/TimeoutCancellationToken.php

74 lines
1.7 KiB
PHP
Raw Normal View History

2017-06-13 19:41:47 +02:00
<?php
namespace Amp;
2021-03-26 22:34:32 +01:00
use Revolt\EventLoop\Loop;
2017-06-13 19:41:47 +02:00
/**
* A TimeoutCancellationToken automatically requests cancellation after the timeout has elapsed.
*/
2018-06-18 20:00:01 +02:00
final class TimeoutCancellationToken implements CancellationToken
{
private string $watcher;
2017-06-13 19:41:47 +02:00
private CancellationToken $token;
2017-06-13 19:41:47 +02:00
/**
* @param int $timeout Milliseconds until cancellation is requested.
* @param string $message Message for TimeoutException. Default is "Operation timed out".
2017-06-13 19:41:47 +02:00
*/
public function __construct(int $timeout, string $message = "Operation timed out")
2018-06-18 20:00:01 +02:00
{
2017-06-13 19:41:47 +02:00
$source = new CancellationTokenSource;
$this->token = $source->getToken();
$trace = \debug_backtrace(\DEBUG_BACKTRACE_IGNORE_ARGS);
2020-10-02 20:55:46 +02:00
$this->watcher = Loop::delay($timeout, static function () use ($source, $message, $trace): void {
$trace = Internal\formatStacktrace($trace);
$source->cancel(new TimeoutException("$message\r\nTimeoutCancellationToken was created here:\r\n$trace"));
2017-06-13 19:41:47 +02:00
});
2017-06-13 19:41:47 +02:00
Loop::unreference($this->watcher);
}
/**
* Cancels the delay watcher.
*/
2018-06-18 20:00:01 +02:00
public function __destruct()
{
2017-06-13 19:41:47 +02:00
Loop::cancel($this->watcher);
}
/**
* {@inheritdoc}
*/
2018-06-18 20:00:01 +02:00
public function subscribe(callable $callback): string
{
2017-06-13 19:41:47 +02:00
return $this->token->subscribe($callback);
}
/**
* {@inheritdoc}
*/
public function unsubscribe(string $id): void
2018-06-18 20:00:01 +02:00
{
2017-06-13 19:41:47 +02:00
$this->token->unsubscribe($id);
}
/**
* {@inheritdoc}
*/
2018-06-18 20:00:01 +02:00
public function isRequested(): bool
{
2017-06-13 19:41:47 +02:00
return $this->token->isRequested();
}
/**
* {@inheritdoc}
*/
public function throwIfRequested(): void
2018-06-18 20:00:01 +02:00
{
2017-06-13 19:41:47 +02:00
$this->token->throwIfRequested();
}
}