Initial attempt at getting basic mounting working
This commit is contained in:
parent
8876f44fc8
commit
8c374b672a
@ -23,6 +23,7 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bazil.org/fuse/fs"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
)
|
)
|
||||||
@ -113,6 +114,10 @@ func (this *database) scan(dir string) ([]string, error) {
|
|||||||
return dirs, nil
|
return dirs, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (this *database) Root() (fs.Node, error) {
|
||||||
|
return this.lastVersion().root, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (this *database) AllocInode() uint64 {
|
func (this *database) AllocInode() uint64 {
|
||||||
this.inodeCnt++
|
this.inodeCnt++
|
||||||
return this.inodeCnt
|
return this.inodeCnt
|
||||||
|
10
file.go
10
file.go
@ -25,6 +25,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"bazil.org/fuse"
|
"bazil.org/fuse"
|
||||||
"golang.org/x/net/context"
|
"golang.org/x/net/context"
|
||||||
|
"io/ioutil"
|
||||||
)
|
)
|
||||||
|
|
||||||
type versionedFile struct {
|
type versionedFile struct {
|
||||||
@ -42,6 +43,11 @@ func (this versionedFile) Attr(attr *fuse.Attr) {
|
|||||||
attr.Size = uint64(this.node.info.Size())
|
attr.Size = uint64(this.node.info.Size())
|
||||||
}
|
}
|
||||||
|
|
||||||
func (versionedFile) ReadAll(ctx context.Context) ([]byte, error) {
|
func (this versionedFile) ReadAll(ctx context.Context) ([]byte, error) {
|
||||||
return nil, nil
|
bytes, err := ioutil.ReadFile(this.node.rebasedPath())
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return bytes, nil
|
||||||
}
|
}
|
||||||
|
91
mount.go
91
mount.go
@ -1,91 +0,0 @@
|
|||||||
// Hellofs implements a simple "hello world" file system.
|
|
||||||
package main
|
|
||||||
|
|
||||||
import (
|
|
||||||
"bazil.org/fuse"
|
|
||||||
"bazil.org/fuse/fs"
|
|
||||||
// "flag"
|
|
||||||
// "fmt"
|
|
||||||
"golang.org/x/net/context"
|
|
||||||
"os"
|
|
||||||
)
|
|
||||||
|
|
||||||
// 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
|
|
||||||
}
|
|
24
vfs.go
24
vfs.go
@ -23,6 +23,8 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bazil.org/fuse"
|
||||||
|
"bazil.org/fuse/fs"
|
||||||
"log"
|
"log"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -32,5 +34,25 @@ func main() {
|
|||||||
log.Fatal(err)
|
log.Fatal(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
db.lastVersion().dumpRoot()
|
c, err := fuse.Mount(
|
||||||
|
"mp",
|
||||||
|
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, db)
|
||||||
|
if err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
<-c.Ready
|
||||||
|
if err := c.MountError; err != nil {
|
||||||
|
log.Fatal(err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user