forked from TrueCloudLab/rclone
11da2a6c9b
The purpose of this is to make it easier to maintain and eventually to allow the rclone backends to be re-used in other projects without having to use the rclone configuration system. The new code layout is documented in CONTRIBUTING.
31 lines
691 B
Go
31 lines
691 B
Go
// Device reading functions
|
|
|
|
// +build darwin dragonfly freebsd linux netbsd openbsd solaris
|
|
|
|
package local
|
|
|
|
import (
|
|
"os"
|
|
"syscall"
|
|
|
|
"github.com/ncw/rclone/fs"
|
|
"github.com/ncw/rclone/fs/config/flags"
|
|
)
|
|
|
|
var (
|
|
oneFileSystem = flags.BoolP("one-file-system", "x", false, "Don't cross filesystem boundaries.")
|
|
)
|
|
|
|
// readDevice turns a valid os.FileInfo into a device number,
|
|
// returning devUnset if it fails.
|
|
func readDevice(fi os.FileInfo) uint64 {
|
|
if !*oneFileSystem {
|
|
return devUnset
|
|
}
|
|
statT, ok := fi.Sys().(*syscall.Stat_t)
|
|
if !ok {
|
|
fs.Debugf(fi.Name(), "Type assertion fi.Sys().(*syscall.Stat_t) failed from: %#v", fi.Sys())
|
|
return devUnset
|
|
}
|
|
return uint64(statT.Dev)
|
|
}
|