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
use log::info;
use std::fs;
use std::io::Write;
use std::path::PathBuf;
use crate::error::*;
pub const APP_NAME: &str = "llvmenv";
pub const ENTRY_TOML: &str = "entry.toml";
const LLVM_MIRROR: &str = include_str!("llvm-mirror.toml");
pub fn config_dir() -> Result<PathBuf> {
let path = dirs::config_dir()
.ok_or(Error::UnsupportedOS)?
.join(APP_NAME);
if !path.exists() {
fs::create_dir_all(&path).with(&path)?;
}
Ok(path)
}
pub fn cache_dir() -> Result<PathBuf> {
let path = dirs::cache_dir()
.ok_or(Error::UnsupportedOS)?
.join(APP_NAME);
if !path.exists() {
fs::create_dir_all(&path).with(&path)?;
}
Ok(path)
}
pub fn data_dir() -> Result<PathBuf> {
let path = dirs::data_dir().ok_or(Error::UnsupportedOS)?.join(APP_NAME);
if !path.exists() {
fs::create_dir_all(&path).with(&path)?;
}
Ok(path)
}
pub fn init_config() -> Result<()> {
let dir = config_dir()?;
let entry = dir.join(ENTRY_TOML);
if !entry.exists() {
info!("Create default entry setting: {}", entry.display());
let mut f = fs::File::create(&entry).with(&entry)?;
f.write(LLVM_MIRROR.as_bytes()).with(&entry)?;
Ok(())
} else {
Err(Error::ConfigureAlreadyExists { path: entry })
}
}