#user-input #console #ui #tui #terminal

interactor

A library for simple (usually command-line) user interaction

4 releases

0.1.3 Oct 1, 2022
0.1.2 Aug 5, 2022
0.1.1 Feb 1, 2016
0.1.0 Nov 12, 2015

#658 in Command-line interface

Download history 69/week @ 2023-11-30 109/week @ 2023-12-07 134/week @ 2023-12-14 119/week @ 2023-12-21 88/week @ 2023-12-28 99/week @ 2024-01-04 118/week @ 2024-01-11 105/week @ 2024-01-18 67/week @ 2024-01-25 81/week @ 2024-02-01 113/week @ 2024-02-08 164/week @ 2024-02-15 141/week @ 2024-02-22 130/week @ 2024-02-29 151/week @ 2024-03-07 116/week @ 2024-03-14

545 downloads per month
Used in 48 crates (2 directly)

Unlicense

10KB
156 lines

crates.io API Docs unlicense

interactor

A Rust library for simple (usually command-line) user interaction.

  • Reading input from the console with a callback for each byte (e.g. for displaying colorhash256 for a password)
  • Selecting an item from a list using an external menu program (usually a fuzzy finder) or a built-in simple menu
  • Selecting a file using the "item from a list" thing above

Menu program?

A program that accepts a newline-separated list of items on stdin, presents a UI to the user (directly on /dev/tty if it's a CLI; can also be a GUI), and outputs the selected item on stdout.

You should let the users of your application pick their own favorite tool as a config option.
I propose the $MENU environment variable, like $EDITOR, as a place to look for user preference.

Usage

extern crate interactor;

use std::io::Write;
use interactor::*;

fn main() {
    let read_result = read_from_tty(|buf, b, tty| {
        tty.write(&format!("({:?} | {})\n", buf, b).into_bytes());
    }, false, false).unwrap();
    println!("Read: {}", String::from_utf8(read_result).unwrap());

    let chosen_ext = pick_from_list(default_menu_cmd().as_mut(), &["first", "second"], "Selection: ").unwrap();
    println!("Congratulations, you chose '{}'!!", chosen_ext);
}

License

This is free and unencumbered software released into the public domain.
For more information, please refer to the UNLICENSE file or unlicense.org.

Dependencies

~120KB