Package Exports
- node-pty
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (node-pty) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
node-pty
forkpty(3)
bindings for node.js. This allows you to fork processes with pseudoterminal file descriptors. It returns a terminal object which allows reads and writes.
This is useful for:
- Writing a terminal emulator (eg. via xterm.js).
- Getting certain programs to think you're a terminal, such as when you need a program to send you control sequences.
node-pty
supports Linux, macOS and Windows. Windows support is possible by utilizing the winpty library.
Real-world Uses
node-pty
powers many different terminal emulators, including:
- Microsoft Visual Studio Code
- Hyper
- Upterm
- Script Runner for Atom.
- Theia
- FreeMAN file manager
- atom-xterm - Atom plugin for providing terminals inside your Atom workspace.
Do you use node-pty in your application as well? Please open a Pull Request to include it here. We would love to have it in our list.
Example Usage
var os = require('os');
var pty = require('node-pty');
var shell = os.platform() === 'win32' ? 'powershell.exe' : 'bash';
var ptyProcess = pty.spawn(shell, [], {
name: 'xterm-color',
cols: 80,
rows: 30,
cwd: process.env.HOME,
env: process.env
});
ptyProcess.on('data', function(data) {
console.log(data);
});
ptyProcess.write('ls\r');
ptyProcess.resize(100, 40);
ptyProcess.write('ls\r');
Building
# Install dependencies and build C++
npm install
# Compile TypeScript -> JavaScript
npm run tsc
Dependencies on Windows
npm install
requires some tools to be present in the system like Python and C++ compiler. Windows users can easily install them by running the following command in PowerShell as administrator. For more information see https://github.com/felixrieseberg/windows-build-tools:
npm install --global --production windows-build-tools
The Windows SDK is also needed which can be downloaded here. Only the "Desktop C++ Apps" components are needed to be installed.
Debugging
On Windows, you can show the winpty agent console window by adding the environment variable WINPTY_SHOW_CONSOLE=1
to the pty's environment. See https://github.com/rprichard/winpty#debugging-winpty for more information.
Troubleshooting
Powershell gives error 8009001d
Internal Windows PowerShell error. Loading managed Windows PowerShell failed with error 8009001d.
This happens when PowerShell is launched with no SystemRoot
environment variable present.
pty.js
This project is forked from chjj/pty.js with the primary goals being to provide better support for later Node.JS versions and Windows.
License
Copyright (c) 2012-2015, Christopher Jeffrey (MIT License).
Copyright (c) 2016, Daniel Imms (MIT License).