Adding stub for mounter
This commit is contained in:
parent
654a0b64c3
commit
abe64d8a29
98
mount.go
Normal file
98
mount.go
Normal file
@ -0,0 +1,98 @@
|
||||
// Hellofs implements a simple "hello world" file system.
|
||||
package main
|
||||
|
||||
import (
|
||||
"flag"
|
||||
"fmt"
|
||||
"os"
|
||||
|
||||
"bazil.org/fuse"
|
||||
"bazil.org/fuse/fs"
|
||||
_ "bazil.org/fuse/fs/fstestutil"
|
||||
"golang.org/x/net/context"
|
||||
)
|
||||
|
||||
var Usage = func() {
|
||||
fmt.Fprintf(os.Stderr, "Usage of %s:\n", os.Args[0])
|
||||
fmt.Fprintf(os.Stderr, " %s MOUNTPOINT\n", os.Args[0])
|
||||
flag.PrintDefaults()
|
||||
}
|
||||
|
||||
// func main() {
|
||||
// flag.Usage = Usage
|
||||
// flag.Parse()
|
||||
|
||||
// if flag.NArg() != 1 {
|
||||
// Usage()
|
||||
// os.Exit(2)
|
||||
// }
|
||||
// mountpoint := flag.Arg(0)
|
||||
|
||||
// c, err := fuse.Mount(
|
||||
// mountpoint,
|
||||
// fuse.FSName("helloworld"),
|
||||
// fuse.Subtype("hellofs"),
|
||||
// fuse.LocalVolume(),
|
||||
// fuse.VolumeName("Hello world!"),
|
||||
// )
|
||||
// if err != nil {
|
||||
// log.Fatal(err)
|
||||
// }
|
||||
// defer c.Close()
|
||||
|
||||
// err = fs.Serve(c, FS{})
|
||||
// if err != nil {
|
||||
// log.Fatal(err)
|
||||
// }
|
||||
|
||||
// // check if the mount process has an error to report
|
||||
// <-c.Ready
|
||||
// if err := c.MountError; err != nil {
|
||||
// log.Fatal(err)
|
||||
// }
|
||||
// }
|
||||
|
||||
// FS implements the hello world file system.
|
||||
type FS struct{}
|
||||
|
||||
func (FS) Root() (fs.Node, error) {
|
||||
return Dir{}, nil
|
||||
}
|
||||
|
||||
// Dir implements both Node and Handle for the root directory.
|
||||
type Dir struct{}
|
||||
|
||||
func (Dir) Attr(a *fuse.Attr) {
|
||||
a.Inode = 1
|
||||
a.Mode = os.ModeDir | 0777
|
||||
}
|
||||
|
||||
func (Dir) Lookup(ctx context.Context, name string) (fs.Node, error) {
|
||||
if name == "hello" {
|
||||
return File{}, nil
|
||||
}
|
||||
return nil, fuse.ENOENT
|
||||
}
|
||||
|
||||
var dirDirs = []fuse.Dirent{
|
||||
{Inode: 2, Name: "hello", Type: fuse.DT_File},
|
||||
}
|
||||
|
||||
func (Dir) ReadDirAll(ctx context.Context) ([]fuse.Dirent, error) {
|
||||
return dirDirs, nil
|
||||
}
|
||||
|
||||
// File implements both Node and Handle for the hello file.
|
||||
type File struct{}
|
||||
|
||||
const greeting = "hello, world\n"
|
||||
|
||||
func (File) Attr(a *fuse.Attr) {
|
||||
a.Inode = 2
|
||||
a.Mode = 0777
|
||||
a.Size = uint64(len(greeting))
|
||||
}
|
||||
|
||||
func (File) ReadAll(ctx context.Context) ([]byte, error) {
|
||||
return []byte(greeting), nil
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user