851285225f
* Add stats command For example atuin stats day yesterday atuin stats day last friday atuin stats day 01/01/21 * Output tables, fix import blanks
51 lines
1.1 KiB
Rust
51 lines
1.1 KiB
Rust
use eyre::Result;
|
|
use structopt::StructOpt;
|
|
use uuid::Uuid;
|
|
|
|
use crate::local::database::Sqlite;
|
|
|
|
mod history;
|
|
mod import;
|
|
mod server;
|
|
mod stats;
|
|
|
|
#[derive(StructOpt)]
|
|
pub enum AtuinCmd {
|
|
#[structopt(
|
|
about="manipulate shell history",
|
|
aliases=&["h", "hi", "his", "hist", "histo", "histor"],
|
|
)]
|
|
History(history::Cmd),
|
|
|
|
#[structopt(about = "import shell history from file")]
|
|
Import(import::Cmd),
|
|
|
|
#[structopt(about = "start an atuin server")]
|
|
Server(server::Cmd),
|
|
|
|
#[structopt(about = "calculate statistics for your history")]
|
|
Stats(stats::Cmd),
|
|
|
|
#[structopt(about = "generates a UUID")]
|
|
Uuid,
|
|
}
|
|
|
|
pub fn uuid_v4() -> String {
|
|
Uuid::new_v4().to_simple().to_string()
|
|
}
|
|
|
|
impl AtuinCmd {
|
|
pub fn run(self, db: &mut Sqlite) -> Result<()> {
|
|
match self {
|
|
Self::History(history) => history.run(db),
|
|
Self::Import(import) => import.run(db),
|
|
Self::Server(server) => server.run(),
|
|
Self::Stats(stats) => stats.run(db),
|
|
|
|
Self::Uuid => {
|
|
println!("{}", uuid_v4());
|
|
Ok(())
|
|
}
|
|
}
|
|
}
|
|
}
|