Newer
Older
use std::io::{self, Write};
use log::{LogRecord, LogLevel, LogLevelFilter, LogMetadata, SetLoggerError};
use rustyline::error::ReadlineError;
use rustyline::{Config, CompletionType, Editor, EditMode};
// On unix platforms you can use ANSI escape sequences
#[cfg(unix)]
static PROMPT: &'static str = "\x1b[1;32m>>\x1b[0m ";
// Windows consoles typically don't support ANSI escape sequences out
// of the box
#[cfg(windows)]
static PROMPT: &'static str = ">> ";
let config = Config::builder()
.history_ignore_space(true)
let mut rl = Editor::with_config(config);
println!("No previous history.");
}
loop {
let readline = rl.readline(PROMPT);
match readline {
Ok(line) => {
println!("Line: {}", line);
Err(ReadlineError::Interrupted) => {
println!("CTRL-C");
Err(ReadlineError::Eof) => {
println!("CTRL-D");
Err(err) => {
println!("Error: {:?}", err);
}
}
rl.save_history("history.txt").unwrap();
struct Logger;
impl log::Log for Logger {
fn enabled(&self, metadata: &LogMetadata) -> bool {
metadata.level() <= LogLevel::Debug
}
fn log(&self, record: &LogRecord) {
if self.enabled(record.metadata()) {
writeln!(io::stderr(), "{} - {}", record.level(), record.args()).unwrap();
}
}
}
fn init_logger() -> Result<(), SetLoggerError> {
log::set_logger(|max_log_level| {