mount,cmount: Add --volname flag and remove special chars from it #2287

Before this change rclone would set the volume name from the
remote:path normally.  However this has `:` and `/` in which make it
difficult to use in macOS.

Now rclone will remove the special characters and replace them with
spaces.  It also allows the volume name to be set with the --volname
flag.
This commit is contained in:
Nick Craig-Wood 2018-05-03 09:34:07 +01:00
parent 1755ffd1f3
commit 6ce32e4661
3 changed files with 14 additions and 2 deletions

View file

@ -53,7 +53,7 @@ func mountOptions(device string, mountpoint string) (options []string) {
// OSX options // OSX options
if runtime.GOOS == "darwin" { if runtime.GOOS == "darwin" {
options = append(options, "-o", "volname="+device) options = append(options, "-o", "volname="+mountlib.VolumeName)
options = append(options, "-o", "noappledouble") options = append(options, "-o", "noappledouble")
options = append(options, "-o", "noapplexattr") options = append(options, "-o", "noapplexattr")
} }

View file

@ -28,7 +28,7 @@ func mountOptions(device string) (options []fuse.MountOption) {
options = []fuse.MountOption{ options = []fuse.MountOption{
fuse.MaxReadahead(uint32(mountlib.MaxReadAhead)), fuse.MaxReadahead(uint32(mountlib.MaxReadAhead)),
fuse.Subtype("rclone"), fuse.Subtype("rclone"),
fuse.FSName(device), fuse.VolumeName(device), fuse.FSName(device), fuse.VolumeName(mountlib.VolumeName),
fuse.NoAppleDouble(), fuse.NoAppleDouble(),
fuse.NoAppleXattr(), fuse.NoAppleXattr(),

View file

@ -5,6 +5,7 @@ import (
"log" "log"
"os" "os"
"runtime" "runtime"
"strings"
"time" "time"
"github.com/ncw/rclone/cmd" "github.com/ncw/rclone/cmd"
@ -29,6 +30,7 @@ var (
ExtraOptions []string ExtraOptions []string
ExtraFlags []string ExtraFlags []string
AttrTimeout = 1 * time.Second // how long the kernel caches attribute for AttrTimeout = 1 * time.Second // how long the kernel caches attribute for
VolumeName string
) )
// Check is folder is empty // Check is folder is empty
@ -228,6 +230,15 @@ be copied to the vfs cache before opening with --vfs-cache-mode full.
} }
} }
// Work out the volume name, removing special
// characters from it if necessary
if VolumeName == "" {
VolumeName = fdst.Name() + ":" + fdst.Root()
}
VolumeName = strings.Replace(VolumeName, ":", " ", -1)
VolumeName = strings.Replace(VolumeName, "/", " ", -1)
VolumeName = strings.TrimSpace(VolumeName)
// Start background task if --background is specified // Start background task if --background is specified
if Daemon { if Daemon {
daemonized := startBackgroundMode() daemonized := startBackgroundMode()
@ -260,6 +271,7 @@ be copied to the vfs cache before opening with --vfs-cache-mode full.
flags.StringArrayVarP(flagSet, &ExtraOptions, "option", "o", []string{}, "Option for libfuse/WinFsp. Repeat if required.") flags.StringArrayVarP(flagSet, &ExtraOptions, "option", "o", []string{}, "Option for libfuse/WinFsp. Repeat if required.")
flags.StringArrayVarP(flagSet, &ExtraFlags, "fuse-flag", "", []string{}, "Flags or arguments to be passed direct to libfuse/WinFsp. Repeat if required.") flags.StringArrayVarP(flagSet, &ExtraFlags, "fuse-flag", "", []string{}, "Flags or arguments to be passed direct to libfuse/WinFsp. Repeat if required.")
flags.BoolVarP(flagSet, &Daemon, "daemon", "", Daemon, "Run mount as a daemon (background mode).") flags.BoolVarP(flagSet, &Daemon, "daemon", "", Daemon, "Run mount as a daemon (background mode).")
flags.StringVarP(flagSet, &VolumeName, "volname", "", VolumeName, "Set the volume name (not supported by all OSes).")
// Add in the generic flags // Add in the generic flags
vfsflags.AddFlags(flagSet) vfsflags.AddFlags(flagSet)