mirror of
https://github.com/rustdesk/rustdesk.git
synced 2025-01-07 22:58:04 +08:00
Merge pull request #3588 from 21pages/fix
try create default video save directory at first
This commit is contained in:
commit
2341232ed2
@ -648,17 +648,26 @@ pub fn get_langs() -> String {
|
|||||||
#[inline]
|
#[inline]
|
||||||
pub fn default_video_save_directory() -> String {
|
pub fn default_video_save_directory() -> String {
|
||||||
let appname = crate::get_app_name();
|
let appname = crate::get_app_name();
|
||||||
|
// In order to make the function call results of the UI process and the video process the same, no result check is performed.
|
||||||
|
let try_create = |path: &std::path::Path| {
|
||||||
|
if !path.exists() {
|
||||||
|
if std::fs::create_dir_all(path).is_err() {
|
||||||
|
log::warn!("video directory {:?} create failed.", path);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
path.to_string_lossy().to_string()
|
||||||
|
};
|
||||||
|
|
||||||
#[cfg(any(target_os = "android", target_os = "ios"))]
|
#[cfg(any(target_os = "android", target_os = "ios"))]
|
||||||
if let Ok(home) = config::APP_HOME_DIR.read() {
|
if let Ok(home) = config::APP_HOME_DIR.read() {
|
||||||
let mut path = home.to_owned();
|
let mut path = home.to_owned();
|
||||||
path.push_str("/RustDesk/ScreenRecord");
|
path.push_str("/RustDesk/ScreenRecord");
|
||||||
return path;
|
return try_create(&std::path::Path::from(path));
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Some(user) = directories_next::UserDirs::new() {
|
if let Some(user) = directories_next::UserDirs::new() {
|
||||||
if let Some(video_dir) = user.video_dir() {
|
if let Some(video_dir) = user.video_dir() {
|
||||||
return video_dir.join(appname).to_string_lossy().to_string();
|
return try_create(&video_dir.join(&appname));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -669,12 +678,12 @@ pub fn default_video_save_directory() -> String {
|
|||||||
} else {
|
} else {
|
||||||
"Videos"
|
"Videos"
|
||||||
};
|
};
|
||||||
return home.join(name).join(appname).to_string_lossy().to_string();
|
return try_create(&home.join(name).join(&appname));
|
||||||
}
|
}
|
||||||
|
|
||||||
if let Ok(exe) = std::env::current_exe() {
|
if let Ok(exe) = std::env::current_exe() {
|
||||||
if let Some(dir) = exe.parent() {
|
if let Some(dir) = exe.parent() {
|
||||||
return dir.join("videos").to_string_lossy().to_string();
|
return try_create(&dir.join("videos"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
"".to_owned()
|
"".to_owned()
|
||||||
|
Loading…
Reference in New Issue
Block a user