diff options
author | Felix Lange <fjl@twurst.com> | 2017-05-30 17:21:59 +0800 |
---|---|---|
committer | Felix Lange <fjl@twurst.com> | 2017-06-21 15:56:58 +0800 |
commit | 50c18e6eb818c26ff7b96c37a195686581783f6b (patch) | |
tree | e9c3f7a7ad2a35942a25a1fad5c7e1be0b2b7395 /swarm/fuse/swarmfs_util.go | |
parent | 693d9ccbfbbcf7c32d3ff9fd8a432941e129a4ac (diff) | |
download | dexon-50c18e6eb818c26ff7b96c37a195686581783f6b.tar dexon-50c18e6eb818c26ff7b96c37a195686581783f6b.tar.gz dexon-50c18e6eb818c26ff7b96c37a195686581783f6b.tar.bz2 dexon-50c18e6eb818c26ff7b96c37a195686581783f6b.tar.lz dexon-50c18e6eb818c26ff7b96c37a195686581783f6b.tar.xz dexon-50c18e6eb818c26ff7b96c37a195686581783f6b.tar.zst dexon-50c18e6eb818c26ff7b96c37a195686581783f6b.zip |
swarm/fuse: simplify externalUnmount
The code looked for /usr/bin/diskutil on darwin, but it's actually
located in /usr/sbin. Fix that by not specifying the absolute path.
Also remove weird timeout construction and extra whitespace.
Diffstat (limited to 'swarm/fuse/swarmfs_util.go')
-rw-r--r-- | swarm/fuse/swarmfs_util.go | 42 |
1 files changed, 13 insertions, 29 deletions
diff --git a/swarm/fuse/swarmfs_util.go b/swarm/fuse/swarmfs_util.go index d20ab258e..d39966c0e 100644 --- a/swarm/fuse/swarmfs_util.go +++ b/swarm/fuse/swarmfs_util.go @@ -19,47 +19,31 @@ package fuse import ( + "context" "fmt" - "github.com/ethereum/go-ethereum/log" "os/exec" "runtime" - "time" -) -func externalUnMount(mountPoint string) error { + "github.com/ethereum/go-ethereum/log" +) - var cmd *exec.Cmd +func externalUnmount(mountPoint string) error { + ctx, cancel := context.WithTimeout(context.Background(), unmountTimeout) + defer cancel() + // Try generic umount. + if err := exec.CommandContext(ctx, "umount", mountPoint).Run(); err == nil { + return nil + } + // Try FUSE-specific commands if umount didn't work. switch runtime.GOOS { - case "darwin": - cmd = exec.Command("/usr/bin/diskutil", "umount", "force", mountPoint) - + return exec.CommandContext(ctx, "diskutil", "umount", "force", mountPoint).Run() case "linux": - cmd = exec.Command("fusermount", "-u", mountPoint) - + return exec.CommandContext(ctx, "fusermount", "-u", mountPoint).Run() default: return fmt.Errorf("unmount: unimplemented") } - - errc := make(chan error, 1) - go func() { - defer close(errc) - - if err := exec.Command("umount", mountPoint).Run(); err == nil { - return - } - errc <- cmd.Run() - }() - - select { - - case <-time.After(unmountTimeout): - return fmt.Errorf("umount timeout") - - case err := <-errc: - return err - } } func addFileToSwarm(sf *SwarmFile, content []byte, size int) error { |