moby/vendor/github.com/Azure/go-ansiterm
Akihiro Suda 5a1b06d7fd rerun vndr
* run latest vndr so as to collect more LICENSE files
 * remove unused packages
 * vendor github.com/philhofer/fwd with LICENSE.md (MIT)
 * vendor github.com/bsphere/le_go with LICENSE (MIT)

Signed-off-by: Akihiro Suda <suda.akihiro@lab.ntt.co.jp>
2017-03-08 02:29:34 +00:00
..
winterm project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
constants.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
context.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
csi_entry_state.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
csi_param_state.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
escape_intermediate_state.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
escape_state.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
event_handler.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
ground_state.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
LICENSE project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
osc_string_state.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
parser.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
parser_action_helpers.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
parser_actions.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
README.md rerun vndr 2017-03-08 02:29:34 +00:00
states.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00
utilities.go project: use vndr for vendoring 2016-11-03 15:31:46 -07:00

go-ansiterm

This is a cross platform Ansi Terminal Emulation library. It reads a stream of Ansi characters and produces the appropriate function calls. The results of the function calls are platform dependent.

For example the parser might receive "ESC, [, A" as a stream of three characters. This is the code for Cursor Up (http://www.vt100.net/docs/vt510-rm/CUU). The parser then calls the cursor up function (CUU()) on an event handler. The event handler determines what platform specific work must be done to cause the cursor to move up one position.

The parser (parser.go) is a partial implementation of this state machine (http://vt100.net/emu/vt500_parser.png). There are also two event handler implementations, one for tests (test_event_handler.go) to validate that the expected events are being produced and called, the other is a Windows implementation (winterm/win_event_handler.go).

See parser_test.go for examples exercising the state machine and generating appropriate function calls.