2012-02-27 20:09:35 +01:00
|
|
|
# TTY
|
2010-11-26 04:09:28 +01:00
|
|
|
|
2017-01-23 04:16:21 +01:00
|
|
|
<!--introduced_in=v0.10.0-->
|
|
|
|
|
2016-07-16 00:35:38 +02:00
|
|
|
> Stability: 2 - Stable
|
2012-03-03 00:14:03 +01:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
The `tty` module provides the `tty.ReadStream` and `tty.WriteStream` classes.
|
|
|
|
In most cases, it will not be necessary or possible to use this module directly.
|
|
|
|
However, it can be accessed using:
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
```js
|
|
|
|
const tty = require('tty');
|
|
|
|
```
|
|
|
|
|
2017-12-15 22:50:32 +01:00
|
|
|
When Node.js detects that it is being run with a text terminal ("TTY")
|
|
|
|
attached, [`process.stdin`][] will, by default, be initialized as an instance of
|
|
|
|
`tty.ReadStream` and both [`process.stdout`][] and [`process.stderr`][] will, by
|
2016-05-23 18:28:04 +02:00
|
|
|
default be instances of `tty.WriteStream`. The preferred method of determining
|
|
|
|
whether Node.js is being run within a TTY context is to check that the value of
|
|
|
|
the `process.stdout.isTTY` property is `true`:
|
2011-02-20 22:53:40 +01:00
|
|
|
|
2016-07-09 07:13:09 +02:00
|
|
|
```sh
|
2016-01-17 18:39:07 +01:00
|
|
|
$ node -p -e "Boolean(process.stdout.isTTY)"
|
|
|
|
true
|
|
|
|
$ node -p -e "Boolean(process.stdout.isTTY)" | cat
|
|
|
|
false
|
|
|
|
```
|
2011-02-20 22:53:40 +01:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
In most cases, there should be little to no reason for an application to
|
2017-12-15 22:50:32 +01:00
|
|
|
manually create instances of the `tty.ReadStream` and `tty.WriteStream`
|
|
|
|
classes.
|
2016-05-23 18:28:04 +02:00
|
|
|
|
|
|
|
## Class: tty.ReadStream
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.5.8
|
|
|
|
-->
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2017-12-15 22:50:32 +01:00
|
|
|
The `tty.ReadStream` class is a subclass of [`net.Socket`][] that represents the
|
|
|
|
readable side of a TTY. In normal circumstances [`process.stdin`][] will be the
|
2016-05-23 18:28:04 +02:00
|
|
|
only `tty.ReadStream` instance in a Node.js process and there should be no
|
|
|
|
reason to create additional instances.
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
### readStream.isRaw
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
A `boolean` that is `true` if the TTY is currently configured to operate as a
|
|
|
|
raw device. Defaults to `false`.
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2017-11-06 17:02:03 +01:00
|
|
|
### readStream.isTTY
|
|
|
|
<!-- YAML
|
|
|
|
added: v0.5.8
|
|
|
|
-->
|
|
|
|
|
2017-12-15 22:50:32 +01:00
|
|
|
A `boolean` that is always `true` for `tty.ReadStream` instances.
|
2017-11-06 17:02:03 +01:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
### readStream.setRawMode(mode)
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2018-07-12 19:48:11 +02:00
|
|
|
* `mode` {boolean} If `true`, configures the `tty.ReadStream` to operate as a
|
|
|
|
raw device. If `false`, configures the `tty.ReadStream` to operate in its
|
|
|
|
default mode. The `readStream.isRaw` property will be set to the resulting
|
|
|
|
mode.
|
2018-09-19 20:09:25 +02:00
|
|
|
* Returns: {this} - the read stream instance.
|
2018-07-12 19:48:11 +02:00
|
|
|
|
2016-12-06 17:24:26 +01:00
|
|
|
Allows configuration of `tty.ReadStream` so that it operates as a raw device.
|
|
|
|
|
|
|
|
When in raw mode, input is always available character-by-character, not
|
|
|
|
including modifiers. Additionally, all special processing of characters by the
|
|
|
|
terminal is disabled, including echoing input characters.
|
|
|
|
Note that `CTRL`+`C` will no longer cause a `SIGINT` when in this mode.
|
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
## Class: tty.WriteStream
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.5.8
|
|
|
|
-->
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2018-04-25 04:14:12 +02:00
|
|
|
The `tty.WriteStream` class is a subclass of [`net.Socket`][] that represents
|
|
|
|
the writable side of a TTY. In normal circumstances, [`process.stdout`][] and
|
2017-12-15 22:50:32 +01:00
|
|
|
[`process.stderr`][] will be the only `tty.WriteStream` instances created for a
|
2016-05-23 18:28:04 +02:00
|
|
|
Node.js process and there should be no reason to create additional instances.
|
2012-03-27 00:21:25 +02:00
|
|
|
|
|
|
|
### Event: 'resize'
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
The `'resize'` event is emitted whenever either of the `writeStream.columns`
|
|
|
|
or `writeStream.rows` properties have changed. No arguments are passed to the
|
|
|
|
listener callback when called.
|
2012-03-27 00:21:25 +02:00
|
|
|
|
2016-01-17 18:39:07 +01:00
|
|
|
```js
|
|
|
|
process.stdout.on('resize', () => {
|
|
|
|
console.log('screen size has changed!');
|
|
|
|
console.log(`${process.stdout.columns}x${process.stdout.rows}`);
|
|
|
|
});
|
|
|
|
```
|
2015-08-20 00:37:52 +02:00
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
### writeStream.clearLine(dir)
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
2015-08-20 00:37:52 +02:00
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
* `dir` {number}
|
|
|
|
* `-1` - to the left from cursor
|
|
|
|
* `1` - to the right from cursor
|
|
|
|
* `0` - the entire line
|
2015-11-04 18:33:35 +01:00
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
`writeStream.clearLine()` clears the current line of this `WriteStream` in a
|
|
|
|
direction identified by `dir`.
|
|
|
|
|
|
|
|
### writeStream.clearScreenDown()
|
2017-11-06 17:02:03 +01:00
|
|
|
<!-- YAML
|
2018-09-17 10:44:42 +02:00
|
|
|
added: v0.7.7
|
2017-11-06 17:02:03 +01:00
|
|
|
-->
|
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
`writeStream.clearScreenDown()` clears this `WriteStream` from the current
|
|
|
|
cursor down.
|
2017-11-06 17:02:03 +01:00
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
### writeStream.columns
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
2015-11-04 18:33:35 +01:00
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
A `number` specifying the number of columns the TTY currently has. This property
|
2016-05-23 18:28:04 +02:00
|
|
|
is updated whenever the `'resize'` event is emitted.
|
2015-11-04 18:33:35 +01:00
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
### writeStream.cursorTo(x, y)
|
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
|
|
|
|
|
|
|
* `x` {number}
|
|
|
|
* `y` {number}
|
|
|
|
|
|
|
|
`writeStream.cursorTo()` moves this `WriteStream`'s cursor to the specified
|
|
|
|
position.
|
|
|
|
|
2018-01-16 13:20:13 +01:00
|
|
|
### writeStream.getColorDepth([env])
|
|
|
|
<!-- YAML
|
2018-03-18 14:45:41 +01:00
|
|
|
added: v9.9.0
|
2018-01-16 13:20:13 +01:00
|
|
|
-->
|
|
|
|
|
2018-04-29 19:46:41 +02:00
|
|
|
* `env` {Object} An object containing the environment variables to check.
|
2018-04-02 03:44:32 +02:00
|
|
|
**Default:** `process.env`.
|
2018-01-16 13:20:13 +01:00
|
|
|
* Returns: {number}
|
|
|
|
|
|
|
|
Returns:
|
2018-04-29 19:46:41 +02:00
|
|
|
* `1` for 2,
|
|
|
|
* `4` for 16,
|
|
|
|
* `8` for 256,
|
|
|
|
* `24` for 16,777,216
|
2018-01-16 13:20:13 +01:00
|
|
|
colors supported.
|
|
|
|
|
|
|
|
Use this to determine what colors the terminal supports. Due to the nature of
|
|
|
|
colors in terminals it is possible to either have false positives or false
|
|
|
|
negatives. It depends on process information and the environment variables that
|
|
|
|
may lie about what terminal is used.
|
|
|
|
To enforce a specific behavior without relying on `process.env` it is possible
|
|
|
|
to pass in an object with different settings.
|
|
|
|
|
|
|
|
Use the `NODE_DISABLE_COLORS` environment variable to enforce this function to
|
|
|
|
always return 1.
|
|
|
|
|
2018-09-17 10:44:42 +02:00
|
|
|
### writeStream.getWindowSize()
|
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
|
|
|
* Returns: {number[]}
|
|
|
|
|
|
|
|
`writeStream.getWindowSize()` returns the size of the [TTY](tty.html)
|
|
|
|
corresponding to this `WriteStream`. The array is of the type
|
|
|
|
`[numColumns, numRows]` where `numColumns` and `numRows` represent the number
|
|
|
|
of columns and rows in the corresponding [TTY](tty.html).
|
|
|
|
|
|
|
|
### writeStream.isTTY
|
|
|
|
<!-- YAML
|
|
|
|
added: v0.5.8
|
|
|
|
-->
|
|
|
|
|
|
|
|
A `boolean` that is always `true`.
|
|
|
|
|
|
|
|
### writeStream.moveCursor(dx, dy)
|
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
|
|
|
|
|
|
|
* `dx` {number}
|
|
|
|
* `dy` {number}
|
|
|
|
|
|
|
|
`writeStream.moveCursor()` moves this `WriteStream`'s cursor *relative* to its
|
|
|
|
current position.
|
|
|
|
|
|
|
|
### writeStream.rows
|
|
|
|
<!-- YAML
|
|
|
|
added: v0.7.7
|
|
|
|
-->
|
|
|
|
|
|
|
|
A `number` specifying the number of rows the TTY currently has. This property
|
|
|
|
is updated whenever the `'resize'` event is emitted.
|
|
|
|
|
2015-11-04 18:33:35 +01:00
|
|
|
## tty.isatty(fd)
|
2016-05-16 08:15:46 +02:00
|
|
|
<!-- YAML
|
|
|
|
added: v0.5.8
|
|
|
|
-->
|
2015-11-04 18:33:35 +01:00
|
|
|
|
2016-05-23 18:28:04 +02:00
|
|
|
* `fd` {number} A numeric file descriptor
|
|
|
|
|
|
|
|
The `tty.isatty()` method returns `true` if the given `fd` is associated with
|
2017-09-23 10:40:35 +02:00
|
|
|
a TTY and `false` if it is not, including whenever `fd` is not a non-negative
|
|
|
|
integer.
|
2017-12-15 22:50:32 +01:00
|
|
|
|
|
|
|
[`net.Socket`]: net.html#net_class_net_socket
|
2018-11-27 20:49:21 +01:00
|
|
|
[`process.stderr`]: process.html#process_process_stderr
|
2017-12-15 22:50:32 +01:00
|
|
|
[`process.stdin`]: process.html#process_process_stdin
|
|
|
|
[`process.stdout`]: process.html#process_process_stdout
|