vlazar / term_app

Functional term/console app environment

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Build Status Version License

Term_app

Term_app is a minimal functional term/console app environment for Crystal.

It is closely related to shards Terminfo and Tput:

Terminfo parses terminfo files into instances of Terminfo::Data or custom classes.

Tput uses Terminfo data and additional methods to configure itself for outputting correct terminal sequences.

Term_app uses Tput and implements a completely usable term/console environment. It sets up event handlers, keys and mouse listeners, and everything else needed to provide a minimal working application.

It is implemented natively and does not depend on ncurses or other external library.

Installation

Add the dependency to shard.yml:

dependencies:
  term_app:
    github: crystallabs/term_app
    version: 0.1.1

Usage in a nutshell

Here is a basic example that starts the application, waits for keypresses or pasted data, prints the received content, and then sets the cursor at screen position x = 10, y = 10:

require "term_app"

my = TermApp::Data.new

my.input.on(TermApp::DataEvent) { |e|
  my.tput.print e.data[...e.len]
  my.tput.sety 10
  my.tput.setx 10
}

sleep 10

API documentation

Run crystal docs as usual, then open file docs/index.html.

Also, see examples in the directory examples/.

Testing

Run crystal spec as usual.

Also, see examples in the directory examples/.

Thanks

Other projects

List of interesting or similar projects in no particular order:

About

Functional term/console app environment

License:Other


Languages

Language:Crystal 100.0%