From 546ed770e728362f80773562d987553aff1ead75 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=99=88=E7=94=9F=E6=9D=82=E7=89=A9=E6=88=BF?= <88823709+TC999@users.noreply.github.com> Date: Wed, 27 Nov 2024 01:33:03 +0800 Subject: [PATCH] =?UTF-8?q?=E4=B8=8D=E5=AE=8C=E5=85=A8=E4=BF=AE=E5=A4=8D?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/scanner.rs | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/scanner.rs b/src/scanner.rs index 1bc54f5..6e31031 100644 --- a/src/scanner.rs +++ b/src/scanner.rs @@ -3,15 +3,15 @@ use std::fs::{self}; use std::sync::{mpsc::Sender, Arc, Mutex}; use std::thread; -pub fn scan_appdata(target: &str, selected_target: &str, tx: Sender<(String, u64)>) { +pub fn scan_appdata(target: &str, selected_target: &str, tx: Sender<(String, u64)>) -> Result<(), String> { let appdata_dir = match dirs::data_dir() { Some(path) => match selected_target { "Local" => path.parent().unwrap().join("Local"), "Roaming" => path, "LocalLow" => path.parent().unwrap().join("LocalLow"), - _ => return, // 如果路径不匹配,返回 + _ => return Err("不支持的目标文件夹".to_string()), // 如果路径不匹配,返回错误 }, - None => return, + None => return Err("无法找到 AppData 目录".to_string()), }; println!("开始扫描文件夹: {}", target); @@ -55,6 +55,9 @@ pub fn scan_appdata(target: &str, selected_target: &str, tx: Sender<(String, u64 } } }); + Ok(()) // 返回成功 + } else { + Err(format!("目录不存在: {}", appdata_dir.display())) } }