2013-08-05 16:05:08 -04:00
|
|
|
<?php
|
|
|
|
|
2014-09-22 22:38:32 -04:00
|
|
|
namespace Amp;
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
interface Reactor {
|
|
|
|
/**
|
|
|
|
* Start the event reactor and assume program flow control
|
2014-06-11 12:21:46 -04:00
|
|
|
*
|
2015-03-19 11:14:21 -04:00
|
|
|
* @param callable $onStart An optional callback to invoke upon event loop start
|
|
|
|
* @return void
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2014-08-02 02:10:31 -04:00
|
|
|
public function run(callable $onStart = null);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Execute a single event loop iteration
|
2014-11-26 13:42:36 -05:00
|
|
|
*
|
2015-03-19 11:14:21 -04:00
|
|
|
* @param bool $noWait Should tick return immediately if no watchers are ready to trigger?
|
|
|
|
* @return void
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function tick($noWait = false);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Stop the event reactor
|
2015-03-19 11:14:21 -04:00
|
|
|
*
|
|
|
|
* @return void
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2014-02-23 16:26:28 -05:00
|
|
|
public function stop();
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Schedule a callback for immediate invocation in the next event loop iteration
|
|
|
|
*
|
2015-04-03 11:56:16 -04:00
|
|
|
* @param callable $callback A callback to invoke in the next iteration of the event loop
|
|
|
|
* @param array $options Watcher options
|
2015-03-19 11:14:21 -04:00
|
|
|
* @return string Returns unique (to the process) string watcher ID
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function immediately(callable $callback, array $options = []);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Schedule a callback to execute once
|
|
|
|
*
|
2015-04-03 11:56:16 -04:00
|
|
|
* @param callable $callback A callback to invoke after the specified millisecond delay
|
|
|
|
* @param int $msDelay the number of milliseconds to wait before invoking $callback
|
|
|
|
* @param array $options Watcher options
|
2015-03-19 11:14:21 -04:00
|
|
|
* @return string Returns unique (to the process) string watcher ID
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function once(callable $callback, $msDelay, array $options = []);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Schedule a recurring callback to execute every $interval seconds until cancelled
|
|
|
|
*
|
2015-04-03 11:56:16 -04:00
|
|
|
* @param callable $callback A callback to invoke at the $msDelay interval until cancelled
|
|
|
|
* @param int $msInterval The interval at which to repeat $callback invocations
|
|
|
|
* @param array $options Watcher options
|
2015-03-19 11:14:21 -04:00
|
|
|
* @return string Returns unique (to the process) string watcher ID
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function repeat(callable $callback, $msInterval, array $options = []);
|
2013-11-27 11:56:29 -05:00
|
|
|
|
2013-08-05 16:05:08 -04:00
|
|
|
/**
|
2014-08-06 21:29:08 -04:00
|
|
|
* Watch a stream resource for readable data and trigger the callback when actionable
|
2013-08-05 16:05:08 -04:00
|
|
|
*
|
2015-03-19 11:14:21 -04:00
|
|
|
* @param resource $stream The stream resource to watch for readability
|
2015-04-03 11:56:16 -04:00
|
|
|
* @param callable $callback A callback to invoke when the stream reports as readable
|
|
|
|
* @param array $options Watcher options
|
2015-03-19 11:14:21 -04:00
|
|
|
* @return string Returns unique (to the process) string watcher ID
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function onReadable($stream, callable $callback, array $options = []);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Watch a stream resource to become writable and trigger the callback when actionable
|
|
|
|
*
|
2015-03-19 11:14:21 -04:00
|
|
|
* @param resource $stream The stream resource to watch for writability
|
2015-04-03 11:56:16 -04:00
|
|
|
* @param callable $callback A callback to invoke when the stream reports as writable
|
|
|
|
* @param array $options Watcher options
|
2015-03-19 11:14:21 -04:00
|
|
|
* @return string Returns unique (to the process) string watcher ID
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function onWritable($stream, callable $callback, array $options = []);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
2015-07-29 01:15:43 -04:00
|
|
|
/**
|
|
|
|
* React to process control signals
|
|
|
|
*
|
|
|
|
* @param int $signo The signal number for which to watch
|
|
|
|
* @param callable $func A callback to invoke when the specified signal is received
|
|
|
|
* @param array $options Watcher options
|
|
|
|
* @return string Returns unique (to the process) string watcher ID
|
|
|
|
*/
|
|
|
|
public function onSignal($signo, callable $func, array $options = []);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* An optional "last-chance" exception handler for errors resulting during callback invocation
|
|
|
|
*
|
|
|
|
* If an application throws inside the event loop and no onError callback is specified the
|
|
|
|
* exception bubbles up and the event loop is stopped. This is undesirable in long-running
|
|
|
|
* applications (like servers) where stopping the event loop for an application error is
|
|
|
|
* problematic. Amp applications can instead specify the onError callback to handle uncaught
|
|
|
|
* exceptions without stopping the event loop.
|
|
|
|
*
|
|
|
|
* Additionally, generator callbacks which are auto-resolved by the event reactor may fail.
|
|
|
|
* Coroutine resolution failures are treated like uncaught exceptions and stop the event reactor
|
|
|
|
* if no onError callback is specified to handle these situations.
|
|
|
|
*
|
|
|
|
* onError callback functions are passed a single parameter: the uncaught exception.
|
|
|
|
*
|
|
|
|
* @param callable $callback A callback to invoke when an exception occurs inside the event loop
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
public function onError(callable $callback);
|
|
|
|
|
2013-08-05 16:05:08 -04:00
|
|
|
/**
|
|
|
|
* Cancel an existing timer/stream watcher
|
|
|
|
*
|
2015-03-19 11:14:21 -04:00
|
|
|
* @param string $watcherId The watcher ID to be canceled
|
|
|
|
* @return void
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function cancel($watcherId);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Temporarily disable (but don't cancel) an existing timer/stream watcher
|
|
|
|
*
|
2015-03-19 11:14:21 -04:00
|
|
|
* @param string $watcherId The watcher ID to be disabled
|
|
|
|
* @return void
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function disable($watcherId);
|
2013-08-05 16:05:08 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Enable a disabled timer/stream watcher
|
|
|
|
*
|
2015-03-19 11:14:21 -04:00
|
|
|
* @param string $watcherId The watcher ID to be enabled
|
|
|
|
* @return void
|
2013-08-05 16:05:08 -04:00
|
|
|
*/
|
2015-04-30 13:41:14 -04:00
|
|
|
public function enable($watcherId);
|
2014-12-01 18:08:49 -05:00
|
|
|
|
|
|
|
/**
|
2015-07-29 01:15:43 -04:00
|
|
|
* Retrieve an associative array of information about the event reactor
|
2014-12-01 18:08:49 -05:00
|
|
|
*
|
2015-07-29 01:15:43 -04:00
|
|
|
* The returned array MUST contain the following data describing the reactor's
|
|
|
|
* currently registered watchers:
|
2015-03-19 11:14:21 -04:00
|
|
|
*
|
2015-07-29 01:15:43 -04:00
|
|
|
* [
|
|
|
|
* "immediately" => ["enabled" => int, "disabled" => int],
|
|
|
|
* "once" => ["enabled" => int, "disabled" => int],
|
|
|
|
* "repeat" => ["enabled" => int, "disabled" => int],
|
|
|
|
* "on_readable" => ["enabled" => int, "disabled" => int],
|
|
|
|
* "on_writable" => ["enabled" => int, "disabled" => int],
|
|
|
|
* "on_signal" => ["enabled" => int, "disabled" => int],
|
2015-07-31 01:21:21 -04:00
|
|
|
* "keep_alive" => int,
|
2015-07-29 01:15:43 -04:00
|
|
|
* ];
|
2015-04-03 12:52:17 -04:00
|
|
|
*
|
2015-07-29 01:15:43 -04:00
|
|
|
* Implementations may optionally add more information in the return array but
|
|
|
|
* at minimum the above key=>value format MUST always be provided.
|
2014-12-01 18:08:49 -05:00
|
|
|
*
|
2015-07-29 01:15:43 -04:00
|
|
|
* @return array
|
2014-12-01 18:08:49 -05:00
|
|
|
*/
|
2015-07-29 01:15:43 -04:00
|
|
|
public function info();
|
2013-08-05 16:05:08 -04:00
|
|
|
}
|