summaryrefslogtreecommitdiff
path: root/cli/ops/fs.rs
diff options
context:
space:
mode:
Diffstat (limited to 'cli/ops/fs.rs')
-rw-r--r--cli/ops/fs.rs18
1 files changed, 17 insertions, 1 deletions
diff --git a/cli/ops/fs.rs b/cli/ops/fs.rs
index 116366c8d..068dbaf7e 100644
--- a/cli/ops/fs.rs
+++ b/cli/ops/fs.rs
@@ -394,13 +394,29 @@ fn op_remove(
let is_sync = args.promise_id.is_none();
blocking_json(is_sync, move || {
+ #[cfg(not(unix))]
+ use std::os::windows::prelude::MetadataExt;
+
let metadata = std::fs::symlink_metadata(&path)?;
+
debug!("op_remove {} {}", path.display(), recursive);
let file_type = metadata.file_type();
- if file_type.is_file() || file_type.is_symlink() {
+ if file_type.is_file() {
std::fs::remove_file(&path)?;
} else if recursive {
std::fs::remove_dir_all(&path)?;
+ } else if file_type.is_symlink() {
+ #[cfg(unix)]
+ std::fs::remove_file(&path)?;
+ #[cfg(not(unix))]
+ {
+ use winapi::um::winnt::FILE_ATTRIBUTE_DIRECTORY;
+ if metadata.file_attributes() & FILE_ATTRIBUTE_DIRECTORY != 0 {
+ std::fs::remove_dir(&path)?;
+ } else {
+ std::fs::remove_file(&path)?;
+ }
+ }
} else {
std::fs::remove_dir(&path)?;
}