6 releases

0.2.0 Jan 30, 2023
0.1.4 Aug 31, 2022

#525 in Debugging

Download history 106/week @ 2024-07-19 133/week @ 2024-07-26 74/week @ 2024-08-02 101/week @ 2024-08-09 114/week @ 2024-08-16 164/week @ 2024-08-23 191/week @ 2024-08-30 242/week @ 2024-09-06 250/week @ 2024-09-13 318/week @ 2024-09-20 431/week @ 2024-09-27 300/week @ 2024-10-04 209/week @ 2024-10-11 233/week @ 2024-10-18 215/week @ 2024-10-25 73/week @ 2024-11-01

760 downloads per month

MIT license

24KB
316 lines

rustyrepl

The easy Rust Read-Evaluate-Print-Loop (REPL) utility crate

github crates.io docs.rs CI/main

About

rustyrepl is a simple crate to facilitate creation of Read, Evaluate, Print, Loop utilities at the command-line. A unique combination of rustyline and clap to build a simple REPL interface with handy argument parsing.

Purpose

  1. Capturing exits/quits of the REPL interface
  2. Storing and managing REPL history commands as well as an index of said commands for you
  3. Allowing operators to get a help menu at any point, using the full Clap supported help interface (i.e. sub-command help as well)
  4. Processing the commands as incoming

Usage

First, add rustyrepl to your Cargo.toml file

[dependencies]
rustyrepl = "0.2"

Next:

use anyhow::Result;
use clap::{Parser, Subcommand};
use rustyrepl::{Repl, ReplCommandProcessor};
/// The enum of sub-commands supported by the CLI
#[derive(Subcommand, Clone, Debug)]
pub enum Command {
    /// Execute a test command
    Test,
}
/// The general CLI, essentially a wrapper for the sub-commands [Commands]
#[derive(Parser, Clone, Debug)]
pub struct Cli {
    #[clap(subcommand)]
    command: Command,
}
#[derive(Debug)]
pub struct CliProcessor {}
#[async_trait::async_trait]
impl ReplCommandProcessor<Cli> for CliProcessor {
    fn is_quit(&self, command: &str) -> bool {
        matches!(command, "quit" | "exit")
    }
    async fn process_command(&self, command: Cli) -> Result<()> {
        match command.command {
            Command::Test => println!("A wild test appeared!"),
        }
        Ok(())
    }
}
// MAIN //
#[tokio::main]
async fn main() -> Result<()> {
    let processor: Box<dyn ReplCommandProcessor<Cli>> = Box::new(CliProcessor {});
    let mut repl = Repl::<Cli>::new(processor, None, Some(">>".to_string()))?;
    repl.process().await
}

This small program will startup up a REPL with the prompt ">>" which you can interact with

>> help
The general CLI, essentially a wrapper for the sub-commands [Commands]

Usage: repl-interface <COMMAND>

Commands:
  test  Execute a test command
  help  Print this message or the help of the given subcommand(s)

Options:
  -h, --help  Print help

Dependencies

~6.5MB
~121K SLoC