From c1ec7460870e2e7f897ca132060e8cc6b3991e18 Mon Sep 17 00:00:00 2001 From: Salem Yaslem Date: Mon, 8 Feb 2021 04:28:48 +0300 Subject: [PATCH] merge config from previous versions --- src/config_management.rs | 16 ++++++++++++++++ src/main.rs | 1 + 2 files changed, 17 insertions(+) diff --git a/src/config_management.rs b/src/config_management.rs index c5acf57..4ef87a9 100644 --- a/src/config_management.rs +++ b/src/config_management.rs @@ -23,6 +23,22 @@ pub fn initialize() -> PathBuf { config_path } +pub fn merge_previous_version() -> Option { + let config_path: PathBuf = Path::new(&get_user_data_dir().unwrap()) + .join("blue-recorder") + .join("config.ini"); + + // return none if config.ini not exists + if !&config_path.exists() { + return None; + } + + let mut config_string: String = String::from_utf8(std::fs::read(&config_path).unwrap()).unwrap(); + config_string = config_string.replace("Options", "default").replace("True", "1").replace("False", "0"); + std::fs::write(&config_path, config_string).unwrap(); + Some(config_path) +} + fn default() { set("default", "frame", "50"); set("default", "delay", "0"); diff --git a/src/main.rs b/src/main.rs index 278355a..b48fc11 100644 --- a/src/main.rs +++ b/src/main.rs @@ -21,6 +21,7 @@ fn main() { } let builder: Builder = Builder::from_file(Path::new("windows/ui.glade")); + config_management::merge_previous_version(); config_management::initialize(); // get Objects from UI