mirror of
https://github.com/pesde-pkg/pesde.git
synced 2024-12-13 03:40:37 +00:00
fix: cleanup temp files for cas search algorithm
This commit is contained in:
parent
397ea11ef5
commit
00ea56745e
1 changed files with 13 additions and 8 deletions
21
src/main.rs
21
src/main.rs
|
@ -11,7 +11,7 @@ use indicatif_log_bridge::LogWrapper;
|
|||
use pesde::{AuthConfig, Project, MANIFEST_FILE_NAME};
|
||||
use std::{
|
||||
collections::HashSet,
|
||||
fs::{create_dir_all, hard_link},
|
||||
fs::{create_dir_all, hard_link, remove_file},
|
||||
path::{Path, PathBuf},
|
||||
thread::spawn,
|
||||
};
|
||||
|
@ -37,17 +37,22 @@ struct Cli {
|
|||
|
||||
fn get_linkable_dir(path: &Path) -> PathBuf {
|
||||
let mut curr_path = PathBuf::new();
|
||||
let file_to_try = NamedTempFile::new_in(&curr_path).expect("failed to create temporary file");
|
||||
let file_to_try = NamedTempFile::new_in(path).expect("failed to create temporary file");
|
||||
let temp_file_name = file_to_try.path().file_name().unwrap();
|
||||
|
||||
for component in path.components() {
|
||||
curr_path.push(component);
|
||||
|
||||
if hard_link(
|
||||
file_to_try.path(),
|
||||
curr_path.join(file_to_try.path().file_name().unwrap()),
|
||||
)
|
||||
.is_ok()
|
||||
{
|
||||
let try_path = curr_path.join(temp_file_name);
|
||||
|
||||
if hard_link(file_to_try.path(), &try_path).is_ok() {
|
||||
if let Err(err) = remove_file(&try_path) {
|
||||
log::warn!(
|
||||
"failed to remove temporary file at {}: {err}",
|
||||
try_path.display()
|
||||
);
|
||||
}
|
||||
|
||||
return curr_path;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue