Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/beryx/text-io

A library for creating interactive console applications in Java
https://github.com/beryx/text-io

console text-based

Last synced: 18 days ago
JSON representation

A library for creating interactive console applications in Java

Awesome Lists containing this project

README

        

[![PRs Welcome](https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square)](http://makeapullrequest.com)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://github.com/beryx/text-io/blob/master/LICENSE)
[![Build Status](https://img.shields.io/travis/beryx/text-io/master.svg?label=Build)](https://travis-ci.org/beryx/text-io)
## Text-IO ##

Text-IO is a library for creating Java console applications.
It can be used in applications that need to read interactive input from the user.

**Features**

- supports reading values with various data types.
- allows masking the input when reading sensitive data.
- allows selecting a value from a list.
- allows to specify constraints on the input values (format patterns, value ranges, length constraints etc.).
- provides different terminal implementations and offers a Service Provider Interface (SPI) for configuring additional text terminals.

By default, Text-IO tries to use text terminals backed by [java.io.Console](http://docs.oracle.com/javase/8/docs/api/java/io/Console.html).
If no console device is present (which may happen, for example, when running the application in your IDE),
a Swing-based terminal is used instead.

*Example*

```
TextIO textIO = TextIoFactory.getTextIO();

String user = textIO.newStringInputReader()
.withDefaultValue("admin")
.read("Username");

String password = textIO.newStringInputReader()
.withMinLength(6)
.withInputMasking(true)
.read("Password");

int age = textIO.newIntInputReader()
.withMinVal(13)
.read("Age");

Month month = textIO.newEnumInputReader(Month.class)
.read("What month were you born in?");

TextTerminal terminal = textIO.getTextTerminal();
terminal.printf("\nUser %s is %d years old, was born in %s and has the password %s.\n",
user, age, month, password);
```

Click on the image below to see the output of the above example in a Swing-based terminal.

You can also use a web-based terminal, which allows you to access your application via a browser, as shown in the image below.

**Useful links**
- [Documentation](http://text-io.beryx.org)
- [javadoc](http://text-io.beryx.org/releases/latest/javadoc)
- [Demos, examples and projects using Text-IO](https://github.com/beryx/text-io/wiki/Demos,-Examples-and-Projects-using-Text-IO)
- [List of all releases](https://github.com/beryx/text-io/blob/gh-pages/releases.md)

Text-IO is available in [Maven Central](http://search.maven.org/#search%7Cga%7C1%7Cg%3A%22org.beryx%22%20AND%20a%3A%22text-io%22) and [JCenter](https://bintray.com/beryx/maven/text-io).