2020-09-12 13:03:18 +01:00
|
|
|
# Handle OS Signals
|
2020-05-07 00:21:13 +02:00
|
|
|
|
|
|
|
> This program makes use of an unstable Deno feature. Learn more about
|
2020-05-09 09:15:26 -04:00
|
|
|
> [unstable features](../runtime/stability.md).
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-09-12 13:03:18 +01:00
|
|
|
## Concepts
|
|
|
|
|
2020-09-27 10:49:41 -07:00
|
|
|
- Use the `--unstable` flag to access new or unstable features in Deno.
|
2020-09-12 13:03:18 +01:00
|
|
|
- [Deno.signal](https://doc.deno.land/builtin/unstable#Deno.signal) can be used
|
2020-09-27 10:49:41 -07:00
|
|
|
to capture and monitor OS signals.
|
2020-09-12 13:03:18 +01:00
|
|
|
- Use the `dispose()` function of the Deno.signal
|
|
|
|
[SignalStream](https://doc.deno.land/builtin/unstable#Deno.SignalStream) to
|
2020-09-27 10:49:41 -07:00
|
|
|
stop watching the signal.
|
2020-09-12 13:03:18 +01:00
|
|
|
|
|
|
|
## Async iterator example
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-08-15 22:46:36 +09:00
|
|
|
You can use `Deno.signal()` function for handling OS signals:
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-05-14 12:54:57 +09:00
|
|
|
```ts
|
2020-09-12 13:03:18 +01:00
|
|
|
/**
|
|
|
|
* async-iterator-signal.ts
|
|
|
|
*/
|
|
|
|
console.log("Press Ctrl-C to trigger a SIGINT signal");
|
2020-05-07 00:21:13 +02:00
|
|
|
for await (const _ of Deno.signal(Deno.Signal.SIGINT)) {
|
|
|
|
console.log("interrupted!");
|
2020-09-12 13:03:18 +01:00
|
|
|
Deno.exit();
|
2020-05-07 00:21:13 +02:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-09-12 13:03:18 +01:00
|
|
|
Run with:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
deno run --unstable async-iterator-signal.ts
|
|
|
|
```
|
|
|
|
|
|
|
|
## Promise based example
|
|
|
|
|
2020-08-15 22:46:36 +09:00
|
|
|
`Deno.signal()` also works as a promise:
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-05-14 12:54:57 +09:00
|
|
|
```ts
|
2020-09-12 13:03:18 +01:00
|
|
|
/**
|
|
|
|
* promise-signal.ts
|
|
|
|
*/
|
|
|
|
console.log("Press Ctrl-C to trigger a SIGINT signal");
|
2020-05-14 17:18:33 -03:00
|
|
|
await Deno.signal(Deno.Signal.SIGINT);
|
2020-05-07 00:21:13 +02:00
|
|
|
console.log("interrupted!");
|
2020-09-12 13:03:18 +01:00
|
|
|
Deno.exit();
|
2020-05-07 00:21:13 +02:00
|
|
|
```
|
|
|
|
|
2020-09-12 13:03:18 +01:00
|
|
|
Run with:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
deno run --unstable promise-signal.ts
|
|
|
|
```
|
|
|
|
|
|
|
|
## Stop watching signals
|
|
|
|
|
2020-05-07 00:21:13 +02:00
|
|
|
If you want to stop watching the signal, you can use `dispose()` method of the
|
2020-08-15 22:46:36 +09:00
|
|
|
signal object:
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-05-14 12:54:57 +09:00
|
|
|
```ts
|
2020-09-12 13:03:18 +01:00
|
|
|
/**
|
|
|
|
* dispose-signal.ts
|
|
|
|
*/
|
2020-05-07 00:21:13 +02:00
|
|
|
const sig = Deno.signal(Deno.Signal.SIGINT);
|
2020-05-14 12:54:57 +09:00
|
|
|
setTimeout(() => {
|
|
|
|
sig.dispose();
|
2020-09-12 13:03:18 +01:00
|
|
|
console.log("No longer watching SIGINT signal");
|
2020-05-14 12:54:57 +09:00
|
|
|
}, 5000);
|
2020-05-07 00:21:13 +02:00
|
|
|
|
2020-09-12 13:03:18 +01:00
|
|
|
console.log("Watching SIGINT signals");
|
2020-05-07 00:21:13 +02:00
|
|
|
for await (const _ of sig) {
|
|
|
|
console.log("interrupted");
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-09-12 13:03:18 +01:00
|
|
|
Run with:
|
|
|
|
|
|
|
|
```shell
|
|
|
|
deno run --unstable dispose-signal.ts
|
|
|
|
```
|
|
|
|
|
2020-08-15 22:46:36 +09:00
|
|
|
The above for-await loop exits after 5 seconds when `sig.dispose()` is called.
|