Skip to content

Streaming terminal emulator, built on top of React PHP

License

Notifications You must be signed in to change notification settings

clue-labs/reactphp-term

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

4 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

clue/term-react Build Status

Streaming terminal emulator, built on top of React PHP

Note: This project is in early alpha stage! Feel free to report any issues you encounter.

Usage

ControlCodeParser

The ControlCodeParser(ReadableStreamInterface $input) class can be used to parse any control code byte sequences when reading from an input stream and it only returns its plain data stream. It wraps a given ReadableStreamInterface and exposes its plain data through the same interface.

$stdin = new Stream(STDIN, $loop);

$stream = new ControlCodeParser($stdin);

$stream->on('data', function ($chunk) {
    var_dump($chunk);
});

As such, you can be sure the resulting data events never include any control code byte sequences and it can be processed like a normal plain data stream.

React's streams emit chunks of data strings and make no assumption about any byte sequences. These chunks do not necessarily represent complete control code byte sequences, as a sequence may be broken up into multiple chunks. This class reassembles these sequences by buffering incomplete ones.

One of the most common forms of control code sequences is CSI (Control Sequence Introducer). For example, CSI is used to print colored console output, also known as "ANSI color codes" or the more technical term SGR (Select Graphic Rendition). CSI codes also appear on STDIN, for example when the user hits special keys, such as the cursor, HOME, END etc. keys. Each CSI code gets emitted as a csi event with its raw byte sequence:

$stream->on('csi', function ($sequence) {
    if ($sequence === "\x1B[A") {
        echo 'cursor UP pressed';
    } else if ($sequence === "\x1B[B") {
        echo 'cursor DOWN pressed';
    }
});

Install

The recommended way to install this library is through Composer. New to Composer?

This will install the latest supported version:

$ composer require clue/term-react:dev-master

License

MIT

About

Streaming terminal emulator, built on top of React PHP

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 100.0%