aboutsummaryrefslogtreecommitdiff
path: root/launcher/src/lib.rs
diff options
context:
space:
mode:
Diffstat (limited to 'launcher/src/lib.rs')
-rw-r--r--launcher/src/lib.rs24
1 files changed, 10 insertions, 14 deletions
diff --git a/launcher/src/lib.rs b/launcher/src/lib.rs
index 3e5d0fe..32ae8ee 100644
--- a/launcher/src/lib.rs
+++ b/launcher/src/lib.rs
@@ -1,13 +1,18 @@
-mod constants;
+pub mod constants;
use std::ffi::OsStr;
use std::path::PathBuf;
+use crate::AppDataError::NotFound;
pub enum AppData {
Folder(PathBuf),
Asar(PathBuf)
}
+pub enum AppDataError {
+ NotFound(PathBuf, PathBuf)
+}
+
impl AppData {
pub fn get_path(&self) -> &OsStr {
match self {
@@ -16,9 +21,7 @@ impl AppData {
}
}
- pub fn locate_app(work_dir: &PathBuf) -> Option<AppData> {
- let mut app_data: Option<AppData> = None;
-
+ pub fn locate_app(work_dir: &PathBuf) -> Result<AppData, AppDataError> {
let mut app_path_folder = PathBuf::from(work_dir);
app_path_folder.push(constants::APP_FOLDER_PATH);
@@ -26,18 +29,11 @@ impl AppData {
app_path_asar.push(constants::APP_ASAR_PATH);
if app_path_folder.exists() {
- app_data = Some(AppData::Folder(app_path_folder))
+ Ok(AppData::Folder(app_path_folder))
} else if app_path_asar.exists() {
- app_data = Some(AppData::Asar(app_path_asar))
+ Ok(AppData::Asar(app_path_asar))
} else {
- println!(
- "atomic-launcher: Warning: Could not find Electron-compatible app.\
- Looked in {} and {}. The default atomic-runtime application will be opened instead.",
- app_path_folder.to_str().unwrap(),
- app_path_asar.to_str().unwrap()
- );
+ Err(NotFound(app_path_folder, app_path_asar))
}
-
- app_data
}
}