0.1.0 |
|
---|
#136 in #float
17KB
255 lines
A fast and easy console library.
This provides a basic, minimal framework over making a console for applications.
Syntax
command string_argument "string argument with spaces" 33 4.8
Note that 33 and 4.8 are two different types, Integer and Float.
Examples
use brc::prelude::*;
fn main() {
let mut command_table: HashMap<String, Command>= HashMap::new();
command_table.insert("add".to_string(), add);
let console = Console::new(command_table, ">> ");
console.run_repl();
}
fn add(mut args: Arguments) -> Result<(), BrcError> {
let mut sum = 0;
for _ in 0..args.len() {
let arg: i32 = args.pop_arg()?.try_into()?;
sum += arg;
}
println!("{}", sum);
Ok(())
}
Writing functions that work with the Console
Every function that you write to be used in the Console must follow this signature: fn(mut args: brc::lex::Arguments) -> Result<(), brc::error::Error>
.
To use user-inputted arguments in your function, you must continually pop the command arguments from the args parameter, and then convert them into the type you expect.
Example below:
fn echo(mut args: Arguments) -> Result<(), BrcError> {
let first_argument: String = args.pop_arg()?.try_into()?; // Expects a String, as per the type annotation. You can expect a f64, i32 or String.
println!("{}", first_argument);
Ok(())
}
Dependencies
~4–14MB
~125K SLoC