-
Notifications
You must be signed in to change notification settings - Fork 39
Open
Description
test code
let path = std::path::Path::new("C:\\Users\\path\\to\\folder"); //works fine
let path = std::path::Path::new("\\\\?\\UNC\\Mac\\path\\to\\folder"); //throw an error
let dir = std::fs::OpenOptions::new()
.read(true)
.custom_flags(33554432u32)
.open(path).unwrap();
let entries = cap_std::fs::Dir::from_std_file(dir).entries();
dbg!(entries);
reason
After debugged, I found cap_primitives/src/windows/fs get_path cause this problem.
let wide_final = if wide.starts_with(&['\\' as u16, '\\' as _, '?' as _, '\\' as _]) {
&wide[4..] //throw error
//&wide //change to this and it works
} else {
&wide
};
when path start with \\\\?\\
, \\\\?\\
will be remove, and \\\\?\\UNC\\Mac\\path\\to\\folder
changed to UNC\\Mac\\path\\to\\folder
, so a path not found
error be throwed.
dependency chain
the dependency chain is:
cap_std::fs::dir::Dir::entries
cap_primitives::fs::read_dir::read_base_dir
cap_primitives::windows::fs::read_dir_inner::ReadDirInner::read_base_dir
cap_primitives::windows::fs::read_dir_inner::ReadDirInner::new_unchecked
cap_primitives::windows::fs::get_path::concatenate
cap_primitives::windows::fs::get_path::get_path
cargo.toml
cap-std = "1.0.14"
Metadata
Metadata
Assignees
Labels
No labels