1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
mod commands;
mod config;
mod context;
mod error;
mod fs;
mod history;
mod io;
mod run;
mod tab;
mod ui;
mod util;
use lazy_static::lazy_static;
use std::fs::File;
use std::io::prelude::*;
use std::path::PathBuf;
use std::process;
use structopt::StructOpt;
use crate::config::{
AppConfig, AppKeyMapping, AppMimetypeRegistry, AppTheme, ConfigStructure, JoshutoPreview,
};
use crate::context::AppContext;
use crate::error::{JoshutoError, JoshutoErrorKind};
use crate::run::run;
const PROGRAM_NAME: &str = "joshuto";
const CONFIG_FILE: &str = "joshuto.toml";
const MIMETYPE_FILE: &str = "mimetype.toml";
const KEYMAP_FILE: &str = "keymap.toml";
const THEME_FILE: &str = "theme.toml";
const PREVIEW_FILE: &str = "preview.toml";
lazy_static! {
// dynamically builds the config hierarchy
static ref CONFIG_HIERARCHY: Vec<PathBuf> = {
let mut temp = vec![];
match xdg::BaseDirectories::with_prefix(PROGRAM_NAME) {
Ok(dirs) => temp.push(dirs.get_config_home()),
Err(e) => eprintln!("{}", e),
};
// adds the default config files to the config hierarchy if running through cargo
if cfg!(debug_assertions) {
temp.push(PathBuf::from("./config"));
}
temp
};
static ref THEME_T: AppTheme = AppTheme::get_config(THEME_FILE);
static ref MIMETYPE_T: AppMimetypeRegistry = AppMimetypeRegistry::get_config(MIMETYPE_FILE);
static ref PREVIEW_T: JoshutoPreview = JoshutoPreview::get_config(PREVIEW_FILE);
static ref HOME_DIR: Option<PathBuf> = dirs_next::home_dir();
static ref USERNAME: String = whoami::username();
static ref HOSTNAME: String = whoami::hostname();
}
#[derive(Clone, Debug, StructOpt)]
pub struct Args {
#[structopt(long = "path", parse(from_os_str))]
path: Option<PathBuf>,
#[structopt(short = "v", long = "version")]
version: bool,
#[structopt(long = "lastdir", parse(from_os_str))]
last_dir: Option<PathBuf>,
}
fn run_joshuto(args: Args) -> Result<(), JoshutoError> {
if args.version {
let version = env!("CARGO_PKG_VERSION");
println!("{}", version);
let err = JoshutoError::new(
JoshutoErrorKind::EnvVarNotPresent,
"CARGO_PKG_VERSION variable not found".to_string(),
);
return Err(err);
}
if let Some(p) = args.path.as_ref() {
match std::env::set_current_dir(p.as_path()) {
Ok(_) => {}
Err(e) => {
eprintln!("{}", e);
process::exit(1);
}
}
}
let config = AppConfig::get_config(CONFIG_FILE);
let keymap = AppKeyMapping::get_config(KEYMAP_FILE);
let mut context = AppContext::new(config);
{
let mut backend: ui::TuiBackend = ui::TuiBackend::new()?;
run(&mut backend, &mut context, keymap)?;
}
if let Some(p) = args.last_dir {
let curr_path = std::env::current_dir()?;
let mut file = File::create(p)?;
file.write_all(
curr_path
.into_os_string()
.as_os_str()
.to_string_lossy()
.as_bytes(),
)?;
file.write_all("\n".as_bytes())?;
}
Ok(())
}
fn main() {
let args = Args::from_args();
match run_joshuto(args) {
Ok(_) => {}
Err(e) => {
eprintln!("{}", e.to_string());
process::exit(1);
}
}
}
|