mirror of
https://github.com/danog/amp.git
synced 2024-11-27 04:24:42 +01:00
49 lines
891 B
PHP
49 lines
891 B
PHP
|
<?php
|
||
|
|
||
|
namespace Amp;
|
||
|
|
||
|
/**
|
||
|
* A NullCancellationToken can be used to avoid conditionals to check whether a token has been provided.
|
||
|
*
|
||
|
* Instead of writing
|
||
|
*
|
||
|
* ```php
|
||
|
* if ($token) {
|
||
|
* $token->throwIfRequested();
|
||
|
* }
|
||
|
* ```
|
||
|
*
|
||
|
* potentially multiple times, it allows writing
|
||
|
*
|
||
|
* ```php
|
||
|
* $token = $token ?? new NullCancellationToken;
|
||
|
*
|
||
|
* // ...
|
||
|
*
|
||
|
* $token->throwIfRequested();
|
||
|
* ```
|
||
|
*
|
||
|
* instead.
|
||
|
*/
|
||
|
class NullCancellationToken implements CancellationToken {
|
||
|
/** @inheritdoc */
|
||
|
public function subscribe(callable $callback): string {
|
||
|
return "null-token";
|
||
|
}
|
||
|
|
||
|
/** @inheritdoc */
|
||
|
public function unsubscribe(string $id) {
|
||
|
// nothing to do
|
||
|
}
|
||
|
|
||
|
/** @inheritdoc */
|
||
|
public function isRequested(): bool {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
/** @inheritdoc */
|
||
|
public function throwIfRequested() {
|
||
|
// nothing to do
|
||
|
}
|
||
|
}
|