cmount: fix Windows compile (thanks Bill Zissimopoulos)

This commit is contained in:
Nick Craig-Wood 2017-05-07 20:48:17 +01:00
parent e1516e0159
commit caf85737c3
2 changed files with 29 additions and 13 deletions

View file

@ -22,7 +22,6 @@ import (
"github.com/ncw/rclone/fs" "github.com/ncw/rclone/fs"
"github.com/pkg/errors" "github.com/pkg/errors"
"github.com/spf13/cobra" "github.com/spf13/cobra"
"golang.org/x/sys/unix"
) )
// Globals // Globals
@ -40,8 +39,8 @@ var (
writebackCache = false writebackCache = false
maxReadAhead fs.SizeSuffix = 128 * 1024 maxReadAhead fs.SizeSuffix = 128 * 1024
umask = 0 umask = 0
uid = uint32(unix.Geteuid()) uid = uint32(0) // set in mount_unix.go
gid = uint32(unix.Getegid()) gid = uint32(0)
// foreground = false // foreground = false
// default permissions for directories - modified by umask in Mount // default permissions for directories - modified by umask in Mount
dirPerms = os.FileMode(0777) dirPerms = os.FileMode(0777)
@ -49,8 +48,6 @@ var (
) )
func init() { func init() {
umask = unix.Umask(0) // read the umask
unix.Umask(umask) // set it back to what it was
cmd.Root.AddCommand(commandDefintion) cmd.Root.AddCommand(commandDefintion)
commandDefintion.Flags().BoolVarP(&noModTime, "no-modtime", "", noModTime, "Don't read/write the modification time (can speed things up).") commandDefintion.Flags().BoolVarP(&noModTime, "no-modtime", "", noModTime, "Don't read/write the modification time (can speed things up).")
commandDefintion.Flags().BoolVarP(&debugFUSE, "debug-fuse", "", debugFUSE, "Debug the FUSE internals - needs -v.") commandDefintion.Flags().BoolVarP(&debugFUSE, "debug-fuse", "", debugFUSE, "Debug the FUSE internals - needs -v.")
@ -65,8 +62,6 @@ func init() {
commandDefintion.Flags().BoolVarP(&writebackCache, "write-back-cache", "", writebackCache, "Makes kernel buffer writes before sending them to rclone. Without this, writethrough caching is used.") commandDefintion.Flags().BoolVarP(&writebackCache, "write-back-cache", "", writebackCache, "Makes kernel buffer writes before sending them to rclone. Without this, writethrough caching is used.")
commandDefintion.Flags().VarP(&maxReadAhead, "max-read-ahead", "", "The number of bytes that can be prefetched for sequential reads.") commandDefintion.Flags().VarP(&maxReadAhead, "max-read-ahead", "", "The number of bytes that can be prefetched for sequential reads.")
commandDefintion.Flags().IntVarP(&umask, "umask", "", umask, "Override the permission bits set by the filesystem.") commandDefintion.Flags().IntVarP(&umask, "umask", "", umask, "Override the permission bits set by the filesystem.")
commandDefintion.Flags().Uint32VarP(&uid, "uid", "", uid, "Override the uid field set by the filesystem.")
commandDefintion.Flags().Uint32VarP(&gid, "gid", "", gid, "Override the gid field set by the filesystem.")
//commandDefintion.Flags().BoolVarP(&foreground, "foreground", "", foreground, "Do not detach.") //commandDefintion.Flags().BoolVarP(&foreground, "foreground", "", foreground, "Do not detach.")
} }
@ -85,6 +80,10 @@ Start the mount like this
rclone mount remote:path/to/files /path/to/local/mount rclone mount remote:path/to/files /path/to/local/mount
Or on Windows like this where X: is an unused drive letter
rclone mount remote:path/to/files X:
When the program ends, either via Ctrl+C or receiving a SIGINT or SIGTERM signal, When the program ends, either via Ctrl+C or receiving a SIGINT or SIGTERM signal,
the mount is automatically stopped. the mount is automatically stopped.
@ -212,12 +211,14 @@ func mount(f fs.Fs, mountpoint string) (*mountlib.FS, <-chan error, func() error
fs.Debugf(f, "Mounting on %q", mountpoint) fs.Debugf(f, "Mounting on %q", mountpoint)
// Check the mountpoint // Check the mountpoint
fi, err := os.Stat(mountpoint) if runtime.GOOS != "windows" {
if err != nil { fi, err := os.Stat(mountpoint)
return nil, nil, nil, errors.Wrap(err, "mountpoint") if err != nil {
} return nil, nil, nil, errors.Wrap(err, "mountpoint")
if !fi.IsDir() { }
return nil, nil, nil, errors.New("mountpoint is not a directory") if !fi.IsDir() {
return nil, nil, nil, errors.New("mountpoint is not a directory")
}
} }
// Create underlying FS // Create underlying FS

15
cmd/cmount/mount_unix.go Normal file
View file

@ -0,0 +1,15 @@
// +build cgo
// +build linux darwin freebsd
package cmount
import "golang.org/x/sys/unix"
func init() {
umask = unix.Umask(0) // read the umask
unix.Umask(umask) // set it back to what it was
uid = uint32(unix.Geteuid())
gid = uint32(unix.Getegid())
commandDefintion.Flags().Uint32VarP(&uid, "uid", "", uid, "Override the uid field set by the filesystem.")
commandDefintion.Flags().Uint32VarP(&gid, "gid", "", gid, "Override the gid field set by the filesystem.")
}