SimpleUnc
On Windows,
fs::canonicalize returns a path prefixed by "\\?\".
such as:
\\?\UNC\server\share\dir
The "\\?\" prefix is called the Win32 File Namespaces.
It has advantages such as long paths,
and is fine for most modern APIs,
but some programs can't handle them.
PowerShell and cmd.exe are examples of such programs.
The SimpleUnc simplifies network share UNC paths
so that these programs can handle.
C:\dir |
Z:\x (network) |
|
|---|---|---|
fs::canonicalize |
\\?\C:\dir |
\\?\UNC\server\share\x |
SimpleUnc |
C:\dir |
\\server\share\x |
SimpleUnc with map_to_drive |
C:\dir |
Z:\x |
Since the simplification may not always be safe, it does so if they are currently mapped to drives.
Let's say your PC has a network share on the Z: drive:
net use Z: \\server\share
If you run the following code on this PC:
let path = r"Z:\dir\file";
let canonicalized = canonicalize?;
println!;
prints:
\\?\UNC\server\share\dir\file
Neither PowerShell nor cmd.exe can handle this path.
With the SimpleUnc:
let path = r"Z:\dir\file";
let simplified = default.canonicalize?;
println!;
prints:
\\server\share\dir\file
This path works fine for PowerShell and cmd.exe.
Drive
If you prefer to use the network drive in the path:
let path = r"Z:\dir\file";
let unc = SimpleUnc ;
let simplified = unc.canonicalize?;
println!;
prints:
Z:\dir\file
Dunce
The SimpleUnc calls the dunce crate
to normalize some other cases, such as:
\\?\C:\foo
to:
C:\foo
You can skip the dunce simplification if you prefer:
let unc = SimpleUnc ;
Other Platforms
On other platforms,
the SimpleUnc returns without doing anything.
You can wrap the calls with #[cfg(windows)] if you prefer,
though it's not necessary to build and run.