forked from TrueCloudLab/rclone
mount: allow mounting to root directory on windows
This commit is contained in:
parent
f1147fe1dd
commit
b39fa54ab2
2 changed files with 9 additions and 11 deletions
|
@ -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) {
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue