atuin/src/main.rs

86 lines
2.1 KiB
Rust
Raw Normal View History

2021-02-14 08:15:26 -07:00
#![warn(clippy::pedantic, clippy::nursery)]
2021-03-10 14:24:08 -07:00
#![allow(clippy::use_self)] // not 100% reliable
2021-02-14 06:28:01 -07:00
use std::path::PathBuf;
use eyre::{eyre, Result};
use fern::colors::{Color, ColoredLevelConfig};
use human_panic::setup_panic;
use structopt::{clap::AppSettings, StructOpt};
#[macro_use]
extern crate log;
2021-03-10 14:24:08 -07:00
#[macro_use]
extern crate serde_derive;
2021-02-14 10:18:02 -07:00
use command::AtuinCmd;
2021-02-14 08:15:26 -07:00
use local::database::Sqlite;
2021-03-10 14:24:08 -07:00
use settings::Settings;
mod api;
2021-02-13 12:37:00 -07:00
mod command;
mod local;
mod server;
2021-03-10 14:24:08 -07:00
mod settings;
mod utils;
2021-02-13 12:37:00 -07:00
#[derive(StructOpt)]
#[structopt(
author = "Ellie Huxtable <e@elm.sh>",
version = "0.5.0",
about = "Magical shell history",
global_settings(&[AppSettings::ColoredHelp, AppSettings::DeriveDisplayOrder])
)]
2021-02-13 05:58:40 -07:00
struct Atuin {
2020-10-05 10:34:28 -06:00
#[structopt(long, parse(from_os_str), help = "db file path")]
db: Option<PathBuf>,
#[structopt(subcommand)]
2021-02-13 05:58:40 -07:00
atuin: AtuinCmd,
}
2021-02-13 05:58:40 -07:00
impl Atuin {
async fn run(self, settings: &Settings) -> Result<()> {
2021-02-14 08:15:26 -07:00
let db_path = if let Some(db_path) = self.db {
let path = db_path
.to_str()
.ok_or_else(|| eyre!("path {:?} was not valid UTF-8", db_path))?;
let path = shellexpand::full(path)?;
PathBuf::from(path.as_ref())
} else {
2021-04-09 05:40:21 -06:00
PathBuf::from(settings.local.db_path.as_str())
};
2021-02-14 08:15:26 -07:00
let mut db = Sqlite::new(db_path)?;
self.atuin.run(&mut db, settings).await
}
}
#[tokio::main]
async fn main() -> Result<()> {
let colors = ColoredLevelConfig::new()
.warn(Color::Yellow)
.error(Color::Red);
fern::Dispatch::new()
.format(move |out, message, record| {
out.finish(format_args!(
"{} [{}] {}",
chrono::Local::now().to_rfc3339(),
colors.color(record.level()),
message
))
})
.level(log::LevelFilter::Info)
.level_for("sqlx", log::LevelFilter::Warn)
.chain(std::io::stdout())
.apply()?;
let settings = Settings::new()?;
setup_panic!();
Atuin::from_args().run(&settings).await
}