mount: allow mounting to root directory on windows

This commit is contained in:
albertony 2021-02-08 15:50:56 +01:00 committed by Nick Craig-Wood
parent f1147fe1dd
commit b39fa54ab2
2 changed files with 9 additions and 11 deletions

View file

@ -103,8 +103,9 @@ func handleLocalMountpath(mountpath string, opt *mountlib.Options) (string, erro
} else if !os.IsNotExist(err) { } else if !os.IsNotExist(err) {
return "", errors.Wrap(err, "failed to retrieve mountpoint path information") return "", errors.Wrap(err, "failed to retrieve mountpoint path information")
} }
//if isDriveRootPath(mountpath) { // Assume intention with "X:\" was "X:" if isDriveRootPath(mountpath) { // Assume intention with "X:\" was "X:"
// mountpoint = mountpath[:len(mountpath)-1] // WinFsp needs drive mountpoints without trailing path separator mountpath = mountpath[:len(mountpath)-1] // WinFsp needs drive mountpoints without trailing path separator
}
if !isDrive(mountpath) { if !isDrive(mountpath) {
// Assuming directory path, since it is not a pure drive letter string such as "X:". // Assuming directory path, since it is not a pure drive letter string such as "X:".
// Drive letter string can be used as is, since we have already checked it does not exist, // Drive letter string can be used as is, since we have already checked it does not exist,
@ -115,10 +116,7 @@ func handleLocalMountpath(mountpath string, opt *mountlib.Options) (string, erro
} }
parent := filepath.Join(mountpath, "..") parent := filepath.Join(mountpath, "..")
if parent == "" || parent == "." { if parent == "" || parent == "." {
return "", errors.New("mountpoint directory is not valid: " + parent) return "", errors.New("mountpoint parent path is not valid: " + parent)
}
if os.IsPathSeparator(parent[len(parent)-1]) { // Ends in a separator only if it is the root directory
return "", errors.New("mountpoint directory is at root: " + parent)
} }
if _, err := os.Stat(parent); err != nil { if _, err := os.Stat(parent); err != nil {
if os.IsNotExist(err) { if os.IsNotExist(err) {

View file

@ -179,15 +179,15 @@ is an **empty** **existing** directory:
On Windows you can start a mount in different ways. See [below](#mounting-modes-on-windows) On Windows you can start a mount in different ways. See [below](#mounting-modes-on-windows)
for details. The following examples will mount to an automatically assigned drive, for details. The following examples will mount to an automatically assigned drive,
to specific drive letter |X:|, to path |C:\path\to\nonexistent\directory| to specific drive letter |X:|, to path |C:\path\parent\mount|
(which must be **non-existent** subdirectory of an **existing** parent directory or drive, (where parent directory or drive must exist, and mount must **not** exist,
and is not supported when [mounting as a network drive](#mounting-modes-on-windows)), and and is not supported when [mounting as a network drive](#mounting-modes-on-windows)), and
the last example will mount as network share |\\cloud\remote| and map it to an the last example will mount as network share |\\cloud\remote| and map it to an
automatically assigned drive: automatically assigned drive:
rclone @ remote:path/to/files * rclone @ remote:path/to/files *
rclone @ remote:path/to/files X: rclone @ remote:path/to/files X:
rclone @ remote:path/to/files C:\path\to\nonexistent\directory rclone @ remote:path/to/files C:\path\parent\mount
rclone @ remote:path/to/files \\cloud\remote rclone @ remote:path/to/files \\cloud\remote
When the program ends while in foreground mode, either via Ctrl+C or receiving When the program ends while in foreground mode, either via Ctrl+C or receiving
@ -241,14 +241,14 @@ and experience unexpected program errors, freezes or other issues, consider moun
as a network drive instead. as a network drive instead.
When mounting as a fixed disk drive you can either mount to an unused drive letter, When mounting as a fixed disk drive you can either mount to an unused drive letter,
or to a path - which must be **non-existent** subdirectory of an **existing** parent or to a path representing a **non-existent** subdirectory of an **existing** parent
directory or drive. Using the special value |*| will tell rclone to directory or drive. Using the special value |*| will tell rclone to
automatically assign the next available drive letter, starting with Z: and moving backward. automatically assign the next available drive letter, starting with Z: and moving backward.
Examples: Examples:
rclone @ remote:path/to/files * rclone @ remote:path/to/files *
rclone @ remote:path/to/files X: rclone @ remote:path/to/files X:
rclone @ remote:path/to/files C:\path\to\nonexistent\directory rclone @ remote:path/to/files C:\path\parent\mount
rclone @ remote:path/to/files X: rclone @ remote:path/to/files X:
Option |--volname| can be used to set a custom volume name for the mounted Option |--volname| can be used to set a custom volume name for the mounted