summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorfxqnlr <[email protected]>2023-04-30 19:20:29 +0200
committerfxqnlr <[email protected]>2023-04-30 19:20:29 +0200
commit06f933dac333d58b2cc3ae7ab0c285e5015a0257 (patch)
tree95ce75ba97abc9747ffb514d2e0122824d60beb4
parent2b180daf1e2687436046b853c59e0abe12c50f57 (diff)
downloadmodlist-06f933dac333d58b2cc3ae7ab0c285e5015a0257.tar
modlist-06f933dac333d58b2cc3ae7ab0c285e5015a0257.tar.gz
modlist-06f933dac333d58b2cc3ae7ab0c285e5015a0257.zip
fixed config directories, moved to own folder
-rw-r--r--src/config.rs15
1 files changed, 10 insertions, 5 deletions
diff --git a/src/config.rs b/src/config.rs
index 61db1c7..9064548 100644
--- a/src/config.rs
+++ b/src/config.rs
@@ -26,7 +26,8 @@ impl Cfg {
26 Some(p) => String::from(p), 26 Some(p) => String::from(p),
27 None => dirs::config_dir() 27 None => dirs::config_dir()
28 .unwrap() 28 .unwrap()
29 .join("modlist.toml") 29 .join("modlist")
30 .join("config.toml")
30 .to_string_lossy() 31 .to_string_lossy()
31 .to_string(), 32 .to_string(),
32 }; 33 };
@@ -50,7 +51,6 @@ impl Cfg {
50 create_cache(&config.cache)?; 51 create_cache(&config.cache)?;
51 }; 52 };
52 //Check database 53 //Check database
53 //TODO check file
54 let datafile = format!("{}/data.db", config.data); 54 let datafile = format!("{}/data.db", config.data);
55 match File::open(&datafile) { 55 match File::open(&datafile) {
56 Ok(..) => (), 56 Ok(..) => (),
@@ -64,14 +64,19 @@ fn create_config(path: &str) -> MLE<()> {
64 print!("No config file found, create default"); 64 print!("No config file found, create default");
65 //Force flush of stdout, else print! doesn't print instantly 65 //Force flush of stdout, else print! doesn't print instantly
66 std::io::stdout().flush()?; 66 std::io::stdout().flush()?;
67 let cache_dir = dirs::cache_dir()
68 .unwrap()
69 .join("modlist")
70 .to_string_lossy()
71 .to_string();
67 let default_cfg = Cfg { 72 let default_cfg = Cfg {
68 //TODO get home dir 73 data: cache_dir.clone(),
69 data: String::from("$HOME/.cache/modlist/"), 74 cache: format!("{}/cache", cache_dir),
70 cache: String::from("$HOME/.cache/modlist/cache"),
71 apis: Apis { 75 apis: Apis {
72 modrinth: String::from("https://api.modrinth.com/v2/"), 76 modrinth: String::from("https://api.modrinth.com/v2/"),
73 }, 77 },
74 }; 78 };
79 create_dir_all(path.split("config.toml").collect::<Vec<&str>>()[0])?;
75 let mut file = File::create(path)?; 80 let mut file = File::create(path)?;
76 file.write_all(toml::to_string(&default_cfg)?.as_bytes())?; 81 file.write_all(toml::to_string(&default_cfg)?.as_bytes())?;
77 println!(" ✓"); 82 println!(" ✓");