From c21a4fee5891d8abd8c57ff1f54727bcd0c685b2 Mon Sep 17 00:00:00 2001 From: Nick Craig-Wood Date: Mon, 11 Nov 2019 22:08:52 +0000 Subject: [PATCH] mount,cmount: make sure we call unmount when exiting --- cmd/cmount/mount.go | 7 ++++++- cmd/mount/mount.go | 3 +++ 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/cmd/cmount/mount.go b/cmd/cmount/mount.go index b11ad16f4..4c11b470d 100644 --- a/cmd/cmount/mount.go +++ b/cmd/cmount/mount.go @@ -21,6 +21,7 @@ import ( "github.com/pkg/errors" "github.com/rclone/rclone/cmd/mountlib" "github.com/rclone/rclone/fs" + "github.com/rclone/rclone/lib/atexit" "github.com/rclone/rclone/vfs" "github.com/rclone/rclone/vfs/vfsflags" ) @@ -207,7 +208,7 @@ func mount(f fs.Fs, mountpoint string) (*vfs.VFS, <-chan error, func() error, er // If noModTime is set then it func Mount(f fs.Fs, mountpoint string) error { // Mount it - FS, errChan, _, err := mount(f, mountpoint) + FS, errChan, unmount, err := mount(f, mountpoint) if err != nil { return errors.Wrap(err, "failed to mount FUSE fs") } @@ -217,6 +218,10 @@ func Mount(f fs.Fs, mountpoint string) error { sigHup := make(chan os.Signal, 1) signal.Notify(sigHup, syscall.SIGHUP) + atexit.Register(func() { + _ = unmount() + }) + if err := sdnotify.Ready(); err != nil && err != sdnotify.ErrSdNotifyNoSocket { return errors.Wrap(err, "failed to notify systemd") } diff --git a/cmd/mount/mount.go b/cmd/mount/mount.go index e798e3d28..f464e7047 100644 --- a/cmd/mount/mount.go +++ b/cmd/mount/mount.go @@ -137,6 +137,9 @@ func Mount(f fs.Fs, mountpoint string) error { sigHup := make(chan os.Signal, 1) signal.Notify(sigHup, syscall.SIGHUP) atexit.IgnoreSignals() + atexit.Register(func() { + _ = unmount() + }) if err := sdnotify.Ready(); err != nil && err != sdnotify.ErrSdNotifyNoSocket { return errors.Wrap(err, "failed to notify systemd")