Renaming vars
This commit is contained in:
parent
48faaa74f4
commit
b5dc9e3db7
31
database.go
31
database.go
@ -23,11 +23,12 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"bazil.org/fuse/fs"
|
||||
"io/ioutil"
|
||||
"path"
|
||||
"path/filepath"
|
||||
"sort"
|
||||
|
||||
"bazil.org/fuse/fs"
|
||||
)
|
||||
|
||||
//
|
||||
@ -48,32 +49,32 @@ func newDatabase(dir string) (*database, error) {
|
||||
return db, nil
|
||||
}
|
||||
|
||||
func (this *database) load(dir string) error {
|
||||
func (db *database) load(dir string) error {
|
||||
var err error
|
||||
|
||||
this.base, err = filepath.Abs(dir)
|
||||
db.base, err = filepath.Abs(dir)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if err := buildNewVersion(this.base); err != nil {
|
||||
if err := buildNewVersion(db.base); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
this.vers, err = this.buildVersions(this.base)
|
||||
db.vers, err = db.buildVersions(db.base)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if lastVer := this.lastVersion(); lastVer != nil {
|
||||
if lastVer := db.lastVersion(); lastVer != nil {
|
||||
return lastVer.resolve()
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *database) save() error {
|
||||
for _, ver := range this.vers {
|
||||
func (db *database) save() error {
|
||||
for _, ver := range db.vers {
|
||||
if err := ver.finalize(); err != nil {
|
||||
return err
|
||||
}
|
||||
@ -82,7 +83,7 @@ func (this *database) save() error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *database) buildVersions(base string) (versionList, error) {
|
||||
func (db *database) buildVersions(base string) (versionList, error) {
|
||||
nodes, err := ioutil.ReadDir(base)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@ -99,7 +100,7 @@ func (this *database) buildVersions(base string) (versionList, error) {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
ver, err := newVersion(path.Join(base, node.Name()), timestamp, this)
|
||||
ver, err := newVersion(path.Join(base, node.Name()), timestamp, db)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
@ -118,15 +119,15 @@ func (this *database) buildVersions(base string) (versionList, error) {
|
||||
return vers, nil
|
||||
}
|
||||
|
||||
func (this *database) lastVersion() *version {
|
||||
count := len(this.vers)
|
||||
func (db *database) lastVersion() *version {
|
||||
count := len(db.vers)
|
||||
if count == 0 {
|
||||
return nil
|
||||
}
|
||||
|
||||
return this.vers[count-1]
|
||||
return db.vers[count-1]
|
||||
}
|
||||
|
||||
func (this *database) Root() (fs.Node, error) {
|
||||
return this.lastVersion().root, nil
|
||||
func (db *database) Root() (fs.Node, error) {
|
||||
return db.lastVersion().root, nil
|
||||
}
|
||||
|
90
dir.go
90
dir.go
@ -51,89 +51,89 @@ func newVersionedDir(node *versionedNode, parent *versionedDir) *versionedDir {
|
||||
return &versionedDir{dirs, files, node, allocInode(), parent}
|
||||
}
|
||||
|
||||
func (this *versionedDir) version() error {
|
||||
if this.node.flags&NodeFlagVer == NodeFlagVer {
|
||||
func (vd *versionedDir) version() error {
|
||||
if vd.node.flags&NodeFlagVer == NodeFlagVer {
|
||||
return nil
|
||||
}
|
||||
|
||||
node := newVersionedNode(this.node.path, this.node.ver.db.lastVersion(), this.node, NodeFlagDir|NodeFlagVer)
|
||||
node := newVersionedNode(vd.node.path, vd.node.ver.db.lastVersion(), vd.node, NodeFlagDir|NodeFlagVer)
|
||||
|
||||
if err := os.MkdirAll(node.rebasedPath(), 0755); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
node.ver.meta.modifyNode(node.path)
|
||||
this.node = node
|
||||
vd.node = node
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedDir) createDir(name string) (*versionedDir, error) {
|
||||
if err := this.version(); err != nil {
|
||||
func (vd *versionedDir) createDir(name string) (*versionedDir, error) {
|
||||
if err := vd.version(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
childPath := path.Join(this.node.path, name)
|
||||
if err := os.Mkdir(this.node.ver.rebasePath(childPath), 0755); err != nil {
|
||||
childPath := path.Join(vd.node.path, name)
|
||||
if err := os.Mkdir(vd.node.ver.rebasePath(childPath), 0755); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
node := newVersionedNode(childPath, this.node.ver, nil, NodeFlagDir)
|
||||
dir := newVersionedDir(node, this)
|
||||
this.dirs[name] = dir
|
||||
node := newVersionedNode(childPath, vd.node.ver, nil, NodeFlagDir)
|
||||
dir := newVersionedDir(node, vd)
|
||||
vd.dirs[name] = dir
|
||||
|
||||
node.ver.meta.createNode(node.path)
|
||||
return dir, nil
|
||||
}
|
||||
|
||||
func (this *versionedDir) createFile(name string, flags int) (*versionedFile, error) {
|
||||
if err := this.version(); err != nil {
|
||||
func (vd *versionedDir) createFile(name string, flags int) (*versionedFile, error) {
|
||||
if err := vd.version(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
childPath := path.Join(this.node.path, name)
|
||||
handle, err := os.OpenFile(this.node.ver.rebasePath(childPath), flags, 0644)
|
||||
childPath := path.Join(vd.node.path, name)
|
||||
handle, err := os.OpenFile(vd.node.ver.rebasePath(childPath), flags, 0644)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
node := newVersionedNode(childPath, this.node.ver, nil, 0)
|
||||
file := newVersionedFile(node, this)
|
||||
node := newVersionedNode(childPath, vd.node.ver, nil, 0)
|
||||
file := newVersionedFile(node, vd)
|
||||
file.handle = handle
|
||||
this.files[name] = file
|
||||
vd.files[name] = file
|
||||
|
||||
node.ver.meta.createNode(node.path)
|
||||
return file, nil
|
||||
}
|
||||
|
||||
func (this *versionedDir) Attr(ctx context.Context, attr *fuse.Attr) error {
|
||||
if err := this.node.attr(attr); err != nil {
|
||||
func (vd *versionedDir) Attr(ctx context.Context, attr *fuse.Attr) error {
|
||||
if err := vd.node.attr(attr); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
attr.Inode = this.inode
|
||||
attr.Inode = vd.inode
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedDir) Getattr(ctx context.Context, req *fuse.GetattrRequest, resp *fuse.GetattrResponse) error {
|
||||
return this.Attr(ctx, &resp.Attr)
|
||||
func (vd *versionedDir) Getattr(ctx context.Context, req *fuse.GetattrRequest, resp *fuse.GetattrResponse) error {
|
||||
return vd.Attr(ctx, &resp.Attr)
|
||||
}
|
||||
|
||||
func (this *versionedDir) Setattr(ctx context.Context, req *fuse.SetattrRequest, resp *fuse.SetattrResponse) error {
|
||||
this.version()
|
||||
return this.node.setAttr(req, resp)
|
||||
func (vd *versionedDir) Setattr(ctx context.Context, req *fuse.SetattrRequest, resp *fuse.SetattrResponse) error {
|
||||
vd.version()
|
||||
return vd.node.setAttr(req, resp)
|
||||
}
|
||||
|
||||
func (this *versionedDir) Create(ctx context.Context, req *fuse.CreateRequest, resp *fuse.CreateResponse) (node fs.Node, handle fs.Handle, err error) {
|
||||
func (vd *versionedDir) Create(ctx context.Context, req *fuse.CreateRequest, resp *fuse.CreateResponse) (node fs.Node, handle fs.Handle, err error) {
|
||||
if req.Mode.IsDir() {
|
||||
var dir *versionedDir
|
||||
if dir, err = this.createDir(req.Name); err == nil {
|
||||
if dir, err = vd.createDir(req.Name); err == nil {
|
||||
node = dir
|
||||
handle = dir
|
||||
}
|
||||
} else if req.Mode.IsRegular() {
|
||||
var file *versionedFile
|
||||
if file, err = this.createFile(req.Name, int(req.Flags)); err == nil {
|
||||
if file, err = vd.createFile(req.Name, int(req.Flags)); err == nil {
|
||||
node = file
|
||||
handle = file
|
||||
}
|
||||
@ -144,13 +144,13 @@ func (this *versionedDir) Create(ctx context.Context, req *fuse.CreateRequest, r
|
||||
return
|
||||
}
|
||||
|
||||
func (this *versionedDir) Mkdir(ctx context.Context, req *fuse.MkdirRequest) (fs.Node, error) {
|
||||
return this.createDir(req.Name)
|
||||
func (vd *versionedDir) Mkdir(ctx context.Context, req *fuse.MkdirRequest) (fs.Node, error) {
|
||||
return vd.createDir(req.Name)
|
||||
}
|
||||
|
||||
func (this *versionedDir) Remove(ctx context.Context, req *fuse.RemoveRequest) error {
|
||||
func (vd *versionedDir) Remove(ctx context.Context, req *fuse.RemoveRequest) error {
|
||||
if req.Dir {
|
||||
node := this.dirs[req.Name].node
|
||||
node := vd.dirs[req.Name].node
|
||||
ver := node.ver
|
||||
|
||||
if node.flags&NodeFlagVer == NodeFlagVer {
|
||||
@ -162,9 +162,9 @@ func (this *versionedDir) Remove(ctx context.Context, req *fuse.RemoveRequest) e
|
||||
}
|
||||
|
||||
ver.meta.removeNode(node.path)
|
||||
delete(this.dirs, req.Name)
|
||||
delete(vd.dirs, req.Name)
|
||||
} else {
|
||||
node := this.files[req.Name].node
|
||||
node := vd.files[req.Name].node
|
||||
ver := node.ver
|
||||
|
||||
if node.flags&NodeFlagVer == NodeFlagVer {
|
||||
@ -176,25 +176,25 @@ func (this *versionedDir) Remove(ctx context.Context, req *fuse.RemoveRequest) e
|
||||
}
|
||||
|
||||
ver.meta.removeNode(node.path)
|
||||
delete(this.files, req.Name)
|
||||
delete(vd.files, req.Name)
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedDir) ReadDirAll(ctx context.Context) ([]fuse.Dirent, error) {
|
||||
entries := []fuse.Dirent{{Inode: this.inode, Name: ".", Type: fuse.DT_Dir}}
|
||||
if this.parent != nil {
|
||||
entry := fuse.Dirent{Inode: this.parent.inode, Name: "..", Type: fuse.DT_Dir}
|
||||
func (vd *versionedDir) ReadDirAll(ctx context.Context) ([]fuse.Dirent, error) {
|
||||
entries := []fuse.Dirent{{Inode: vd.inode, Name: ".", Type: fuse.DT_Dir}}
|
||||
if vd.parent != nil {
|
||||
entry := fuse.Dirent{Inode: vd.parent.inode, Name: "..", Type: fuse.DT_Dir}
|
||||
entries = append(entries, entry)
|
||||
}
|
||||
|
||||
for name, dir := range this.dirs {
|
||||
for name, dir := range vd.dirs {
|
||||
entry := fuse.Dirent{Inode: dir.inode, Name: name, Type: fuse.DT_Dir}
|
||||
entries = append(entries, entry)
|
||||
}
|
||||
|
||||
for name, file := range this.files {
|
||||
for name, file := range vd.files {
|
||||
entry := fuse.Dirent{Inode: file.inode, Name: name, Type: fuse.DT_File}
|
||||
entries = append(entries, entry)
|
||||
}
|
||||
@ -202,12 +202,12 @@ func (this *versionedDir) ReadDirAll(ctx context.Context) ([]fuse.Dirent, error)
|
||||
return entries, nil
|
||||
}
|
||||
|
||||
func (this *versionedDir) Lookup(ctx context.Context, name string) (fs.Node, error) {
|
||||
if dir, ok := this.dirs[name]; ok {
|
||||
func (vd *versionedDir) Lookup(ctx context.Context, name string) (fs.Node, error) {
|
||||
if dir, ok := vd.dirs[name]; ok {
|
||||
return dir, nil
|
||||
}
|
||||
|
||||
if file, ok := this.files[name]; ok {
|
||||
if file, ok := vd.files[name]; ok {
|
||||
return file, nil
|
||||
}
|
||||
|
||||
|
91
file.go
91
file.go
@ -24,7 +24,6 @@ package main
|
||||
|
||||
import (
|
||||
"errors"
|
||||
"io"
|
||||
"os"
|
||||
|
||||
"bazil.org/fuse"
|
||||
@ -47,94 +46,94 @@ func newVersionedFile(node *versionedNode, parent *versionedDir) *versionedFile
|
||||
return &versionedFile{node, allocInode(), parent, nil}
|
||||
}
|
||||
|
||||
func (this *versionedFile) version() error {
|
||||
if this.node.flags&NodeFlagVer == NodeFlagVer {
|
||||
func (vf *versionedFile) version() error {
|
||||
if vf.node.flags&NodeFlagVer == NodeFlagVer {
|
||||
return nil
|
||||
}
|
||||
|
||||
node := newVersionedNode(this.node.path, this.node.ver.db.lastVersion(), this.node, NodeFlagVer)
|
||||
node := newVersionedNode(vf.node.path, vf.node.ver.db.lastVersion(), vf.node, NodeFlagVer)
|
||||
|
||||
if _, err := fileCopy(this.node.rebasedPath(), node.rebasedPath()); err != nil {
|
||||
if _, err := fileCopy(vf.node.rebasedPath(), node.rebasedPath()); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
node.ver.meta.modifyNode(node.path)
|
||||
this.node = node
|
||||
vf.node = node
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedFile) Open(ctx context.Context, req *fuse.OpenRequest, resp *fuse.OpenResponse) (fs.Handle, error) {
|
||||
if this.handle != nil {
|
||||
func (vf *versionedFile) Open(ctx context.Context, req *fuse.OpenRequest, resp *fuse.OpenResponse) (fs.Handle, error) {
|
||||
if vf.handle != nil {
|
||||
return nil, errors.New("attempted to open already opened file")
|
||||
}
|
||||
|
||||
if !req.Flags.IsReadOnly() {
|
||||
if err := this.version(); err != nil {
|
||||
if err := vf.version(); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
}
|
||||
|
||||
handle, err := os.OpenFile(this.node.rebasedPath(), int(req.Flags), 0644)
|
||||
handle, err := os.OpenFile(vf.node.rebasedPath(), int(req.Flags), 0644)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
this.handle = handle
|
||||
return this, nil
|
||||
vf.handle = handle
|
||||
return vf, nil
|
||||
}
|
||||
|
||||
func (this *versionedFile) Attr(ctx context.Context, attr *fuse.Attr) error {
|
||||
this.node.attr(attr)
|
||||
attr.Inode = this.inode
|
||||
func (vf *versionedFile) Attr(ctx context.Context, attr *fuse.Attr) error {
|
||||
vf.node.attr(attr)
|
||||
attr.Inode = vf.inode
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedFile) Getattr(ctx context.Context, req *fuse.GetattrRequest, resp *fuse.GetattrResponse) error {
|
||||
return this.Attr(ctx, &resp.Attr)
|
||||
func (vf *versionedFile) Getattr(ctx context.Context, req *fuse.GetattrRequest, resp *fuse.GetattrResponse) error {
|
||||
return vf.Attr(ctx, &resp.Attr)
|
||||
}
|
||||
|
||||
func (this *versionedFile) Setattr(ctx context.Context, req *fuse.SetattrRequest, resp *fuse.SetattrResponse) error {
|
||||
return this.node.setAttr(req, resp)
|
||||
func (vf *versionedFile) Setattr(ctx context.Context, req *fuse.SetattrRequest, resp *fuse.SetattrResponse) error {
|
||||
return vf.node.setAttr(req, resp)
|
||||
}
|
||||
|
||||
func (this *versionedFile) Read(ctx context.Context, req *fuse.ReadRequest, resp *fuse.ReadResponse) error {
|
||||
if this.handle == nil {
|
||||
func (vf *versionedFile) Read(ctx context.Context, req *fuse.ReadRequest, resp *fuse.ReadResponse) error {
|
||||
if vf.handle == nil {
|
||||
return errors.New("attempted to read from unopened file")
|
||||
}
|
||||
|
||||
resp.Data = make([]byte, req.Size)
|
||||
if _, err := this.handle.ReadAt(resp.Data, req.Offset); err != nil {
|
||||
if _, err := vf.handle.ReadAt(resp.Data, req.Offset); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedFile) ReadAll(ctx context.Context) ([]byte, error) {
|
||||
if this.handle == nil {
|
||||
func (vf *versionedFile) ReadAll(ctx context.Context) ([]byte, error) {
|
||||
if vf.handle == nil {
|
||||
return nil, errors.New("attempted to read from unopened file")
|
||||
}
|
||||
|
||||
info, err := os.Stat(this.node.rebasedPath())
|
||||
info, err := os.Stat(vf.node.rebasedPath())
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
data := make([]byte, info.Size())
|
||||
if _, err := this.handle.Read(data); err != nil {
|
||||
if _, err := vf.handle.Read(data); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return data, nil
|
||||
}
|
||||
|
||||
func (this *versionedFile) Write(ctx context.Context, req *fuse.WriteRequest, resp *fuse.WriteResponse) error {
|
||||
if this.handle == nil {
|
||||
func (vf *versionedFile) Write(ctx context.Context, req *fuse.WriteRequest, resp *fuse.WriteResponse) error {
|
||||
if vf.handle == nil {
|
||||
return errors.New("attempted to write to unopened file")
|
||||
}
|
||||
|
||||
size, err := this.handle.WriteAt(req.Data, req.Offset)
|
||||
size, err := vf.handle.WriteAt(req.Data, req.Offset)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -143,41 +142,21 @@ func (this *versionedFile) Write(ctx context.Context, req *fuse.WriteRequest, re
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedFile) Release(ctx context.Context, req *fuse.ReleaseRequest) error {
|
||||
if this.handle == nil {
|
||||
func (vf *versionedFile) Release(ctx context.Context, req *fuse.ReleaseRequest) error {
|
||||
if vf.handle == nil {
|
||||
return errors.New("attempted to release unopened file")
|
||||
}
|
||||
|
||||
this.handle.Close()
|
||||
this.handle = nil
|
||||
vf.handle.Close()
|
||||
vf.handle = nil
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedFile) Fsync(ctx context.Context, req *fuse.FsyncRequest) error {
|
||||
if this.handle == nil {
|
||||
func (vf *versionedFile) Fsync(ctx context.Context, req *fuse.FsyncRequest) error {
|
||||
if vf.handle == nil {
|
||||
return errors.New("attempted to sync unopened file")
|
||||
}
|
||||
|
||||
return this.handle.Sync()
|
||||
}
|
||||
|
||||
//
|
||||
// file helpers
|
||||
//
|
||||
|
||||
func fileCopy(src, dst string) (int64, error) {
|
||||
srcFile, err := os.Open(src)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
defer srcFile.Close()
|
||||
|
||||
dstFile, err := os.Create(dst)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
defer dstFile.Close()
|
||||
|
||||
return io.Copy(srcFile, dstFile)
|
||||
return vf.handle.Sync()
|
||||
}
|
||||
|
36
meta.go
36
meta.go
@ -48,8 +48,8 @@ func newVersionMetadata(path string) (*versionMetadata, error) {
|
||||
return meta, nil
|
||||
}
|
||||
|
||||
func (this *versionMetadata) filter(nodes versionedNodeMap) {
|
||||
for _, delPath := range this.Deleted {
|
||||
func (m *versionMetadata) filter(nodes versionedNodeMap) {
|
||||
for _, delPath := range m.Deleted {
|
||||
for name, node := range nodes {
|
||||
if strings.HasPrefix(node.path, delPath) {
|
||||
delete(nodes, name)
|
||||
@ -58,47 +58,47 @@ func (this *versionMetadata) filter(nodes versionedNodeMap) {
|
||||
}
|
||||
}
|
||||
|
||||
func (this *versionMetadata) removeNode(path string) {
|
||||
this.Deleted = append(this.Deleted, path)
|
||||
this.dirty = true
|
||||
func (m *versionMetadata) removeNode(path string) {
|
||||
m.Deleted = append(m.Deleted, path)
|
||||
m.dirty = true
|
||||
}
|
||||
|
||||
func (this *versionMetadata) createNode(path string) {
|
||||
this.dirty = true
|
||||
func (m *versionMetadata) createNode(path string) {
|
||||
m.dirty = true
|
||||
}
|
||||
|
||||
func (this *versionMetadata) modifyNode(path string) {
|
||||
this.dirty = true
|
||||
func (m *versionMetadata) modifyNode(path string) {
|
||||
m.dirty = true
|
||||
}
|
||||
|
||||
func (this *versionMetadata) load() error {
|
||||
this.dirty = false
|
||||
func (m *versionMetadata) load() error {
|
||||
m.dirty = false
|
||||
|
||||
if _, err := os.Stat(this.path); os.IsNotExist(err) {
|
||||
if _, err := os.Stat(m.path); os.IsNotExist(err) {
|
||||
return nil
|
||||
}
|
||||
|
||||
bytes, err := ioutil.ReadFile(this.path)
|
||||
bytes, err := ioutil.ReadFile(m.path)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if err := json.Unmarshal(bytes, &this); err != nil {
|
||||
if err := json.Unmarshal(bytes, &m); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionMetadata) save() error {
|
||||
if !this.dirty {
|
||||
func (m *versionMetadata) save() error {
|
||||
if !m.dirty {
|
||||
return nil
|
||||
}
|
||||
|
||||
js, err := json.Marshal(this)
|
||||
js, err := json.Marshal(m)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return ioutil.WriteFile(this.path, js, 0644)
|
||||
return ioutil.WriteFile(m.path, js, 0644)
|
||||
}
|
||||
|
26
node.go
26
node.go
@ -50,13 +50,13 @@ func newVersionedNode(path string, ver *version, parent *versionedNode, flags in
|
||||
return &versionedNode{path, ver, parent, flags}
|
||||
}
|
||||
|
||||
func (this *versionedNode) setAttr(req *fuse.SetattrRequest, resp *fuse.SetattrResponse) error {
|
||||
if err := this.attr(&resp.Attr); err != nil {
|
||||
func (n *versionedNode) setAttr(req *fuse.SetattrRequest, resp *fuse.SetattrResponse) error {
|
||||
if err := n.attr(&resp.Attr); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
if req.Valid&fuse.SetattrMode != 0 {
|
||||
if err := os.Chmod(this.rebasedPath(), req.Mode); err != nil {
|
||||
if err := os.Chmod(n.rebasedPath(), req.Mode); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
@ -71,7 +71,7 @@ func (this *versionedNode) setAttr(req *fuse.SetattrRequest, resp *fuse.SetattrR
|
||||
resp.Attr.Uid = req.Uid
|
||||
}
|
||||
|
||||
if err := os.Chown(this.rebasedPath(), int(resp.Attr.Uid), int(resp.Attr.Gid)); err != nil {
|
||||
if err := os.Chown(n.rebasedPath(), int(resp.Attr.Uid), int(resp.Attr.Gid)); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
@ -84,7 +84,7 @@ func (this *versionedNode) setAttr(req *fuse.SetattrRequest, resp *fuse.SetattrR
|
||||
resp.Attr.Mtime = req.Mtime
|
||||
}
|
||||
|
||||
if err := os.Chtimes(this.rebasedPath(), resp.Attr.Atime, resp.Attr.Mtime); err != nil {
|
||||
if err := os.Chtimes(n.rebasedPath(), resp.Attr.Atime, resp.Attr.Mtime); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
@ -92,25 +92,25 @@ func (this *versionedNode) setAttr(req *fuse.SetattrRequest, resp *fuse.SetattrR
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *versionedNode) rebasedPath() string {
|
||||
return this.ver.rebasePath(this.path)
|
||||
func (n *versionedNode) rebasedPath() string {
|
||||
return n.ver.rebasePath(n.path)
|
||||
}
|
||||
|
||||
func (this *versionedNode) owner(stat syscall.Stat_t) (gid, uid uint32) {
|
||||
func (n *versionedNode) owner(stat syscall.Stat_t) (gid, uid uint32) {
|
||||
gid = stat.Gid
|
||||
uid = stat.Uid
|
||||
return
|
||||
}
|
||||
|
||||
func (this *versionedNode) times(stat syscall.Stat_t) (atime, mtime, ctime time.Time) {
|
||||
func (n *versionedNode) times(stat syscall.Stat_t) (atime, mtime, ctime time.Time) {
|
||||
atime = time.Unix(int64(stat.Atim.Sec), int64(stat.Atim.Nsec))
|
||||
mtime = time.Unix(int64(stat.Mtim.Sec), int64(stat.Mtim.Nsec))
|
||||
ctime = time.Unix(int64(stat.Ctim.Sec), int64(stat.Ctim.Nsec))
|
||||
return
|
||||
}
|
||||
|
||||
func (this *versionedNode) attr(attr *fuse.Attr) error {
|
||||
info, err := os.Stat(this.rebasedPath())
|
||||
func (n *versionedNode) attr(attr *fuse.Attr) error {
|
||||
info, err := os.Stat(n.rebasedPath())
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -119,10 +119,10 @@ func (this *versionedNode) attr(attr *fuse.Attr) error {
|
||||
|
||||
attr.Size = uint64(stat.Size)
|
||||
attr.Blocks = uint64(stat.Blocks)
|
||||
attr.Atime, attr.Mtime, attr.Ctime = this.times(*stat)
|
||||
attr.Atime, attr.Mtime, attr.Ctime = n.times(*stat)
|
||||
attr.Mode = info.Mode()
|
||||
attr.Nlink = uint32(stat.Nlink)
|
||||
attr.Gid, attr.Uid = this.owner(*stat)
|
||||
attr.Gid, attr.Uid = n.owner(*stat)
|
||||
attr.Rdev = uint32(stat.Rdev)
|
||||
|
||||
return nil
|
||||
|
22
util.go
22
util.go
@ -22,7 +22,11 @@
|
||||
|
||||
package main
|
||||
|
||||
import "sync/atomic"
|
||||
import (
|
||||
"io"
|
||||
"os"
|
||||
"sync/atomic"
|
||||
)
|
||||
|
||||
//
|
||||
// utilities
|
||||
@ -33,3 +37,19 @@ var inodeCnt uint64
|
||||
func allocInode() uint64 {
|
||||
return atomic.AddUint64(&inodeCnt, 1)
|
||||
}
|
||||
|
||||
func fileCopy(src, dst string) (int64, error) {
|
||||
srcFile, err := os.Open(src)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
defer srcFile.Close()
|
||||
|
||||
dstFile, err := os.Create(dst)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
defer dstFile.Close()
|
||||
|
||||
return io.Copy(srcFile, dstFile)
|
||||
}
|
||||
|
55
version.go
55
version.go
@ -23,7 +23,6 @@
|
||||
package main
|
||||
|
||||
import (
|
||||
"bazil.org/fuse/fs"
|
||||
"errors"
|
||||
"fmt"
|
||||
"io/ioutil"
|
||||
@ -33,6 +32,8 @@ import (
|
||||
"regexp"
|
||||
"strconv"
|
||||
"time"
|
||||
|
||||
"bazil.org/fuse/fs"
|
||||
)
|
||||
|
||||
//
|
||||
@ -57,22 +58,22 @@ func newVersion(base string, timestamp time.Time, db *database) (*version, error
|
||||
return &version{base, nil, timestamp, meta, nil, db}, nil
|
||||
}
|
||||
|
||||
func (this *version) scanDir(path string) (versionedNodeMap, error) {
|
||||
func (v *version) scanDir(path string) (versionedNodeMap, error) {
|
||||
var baseNodes versionedNodeMap
|
||||
if this.parent != nil {
|
||||
if v.parent != nil {
|
||||
var err error
|
||||
|
||||
baseNodes, err = this.parent.scanDir(path)
|
||||
baseNodes, err = v.parent.scanDir(path)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
this.meta.filter(baseNodes)
|
||||
v.meta.filter(baseNodes)
|
||||
}
|
||||
|
||||
ownNodes := make(versionedNodeMap)
|
||||
{
|
||||
infos, err := ioutil.ReadDir(this.rebasePath(path))
|
||||
infos, err := ioutil.ReadDir(v.rebasePath(path))
|
||||
if !os.IsNotExist(err) {
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@ -87,11 +88,11 @@ func (this *version) scanDir(path string) (versionedNodeMap, error) {
|
||||
childName := info.Name()
|
||||
childPath := filepath.Join(path, childName)
|
||||
|
||||
ownNodes[childName] = newVersionedNode(childPath, this, nil, childFlags)
|
||||
ownNodes[childName] = newVersionedNode(childPath, v, nil, childFlags)
|
||||
}
|
||||
}
|
||||
|
||||
this.meta.filter(ownNodes)
|
||||
v.meta.filter(ownNodes)
|
||||
}
|
||||
|
||||
if baseNodes == nil {
|
||||
@ -106,8 +107,8 @@ func (this *version) scanDir(path string) (versionedNodeMap, error) {
|
||||
return baseNodes, nil
|
||||
}
|
||||
|
||||
func (this *version) buildDir(dir *versionedDir) error {
|
||||
nodes, err := this.scanDir(dir.node.path)
|
||||
func (v *version) buildDir(dir *versionedDir) error {
|
||||
nodes, err := v.scanDir(dir.node.path)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
@ -115,7 +116,7 @@ func (this *version) buildDir(dir *versionedDir) error {
|
||||
for name, node := range nodes {
|
||||
if node.flags&NodeFlagDir == NodeFlagDir {
|
||||
subDir := newVersionedDir(node, dir)
|
||||
if err := this.buildDir(subDir); err != nil {
|
||||
if err := v.buildDir(subDir); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
@ -128,29 +129,29 @@ func (this *version) buildDir(dir *versionedDir) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *version) resolve() error {
|
||||
node := newVersionedNode("/", this, nil, NodeFlagDir)
|
||||
func (v *version) resolve() error {
|
||||
node := newVersionedNode("/", v, nil, NodeFlagDir)
|
||||
root := newVersionedDir(node, nil)
|
||||
|
||||
if err := this.buildDir(root); err != nil {
|
||||
if err := v.buildDir(root); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
this.root = root
|
||||
v.root = root
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *version) rebasePath(paths ...string) string {
|
||||
combined := append([]string{this.base, "root"}, paths...)
|
||||
func (v *version) rebasePath(paths ...string) string {
|
||||
combined := append([]string{v.base, "root"}, paths...)
|
||||
return filepath.Join(combined...)
|
||||
}
|
||||
|
||||
func (this *version) finalize() error {
|
||||
return this.meta.save()
|
||||
func (v *version) finalize() error {
|
||||
return v.meta.save()
|
||||
}
|
||||
|
||||
func (this *version) Root() (fs.Node, error) {
|
||||
return this.root, nil
|
||||
func (v *version) Root() (fs.Node, error) {
|
||||
return v.root, nil
|
||||
}
|
||||
|
||||
//
|
||||
@ -159,16 +160,16 @@ func (this *version) Root() (fs.Node, error) {
|
||||
|
||||
type versionList []*version
|
||||
|
||||
func (this versionList) Len() int {
|
||||
return len(this)
|
||||
func (v versionList) Len() int {
|
||||
return len(v)
|
||||
}
|
||||
|
||||
func (this versionList) Swap(i, j int) {
|
||||
this[i], this[j] = this[j], this[i]
|
||||
func (v versionList) Swap(i, j int) {
|
||||
v[i], v[j] = v[j], v[i]
|
||||
}
|
||||
|
||||
func (this versionList) Less(i, j int) bool {
|
||||
return this[i].timestamp.Unix() < this[j].timestamp.Unix()
|
||||
func (v versionList) Less(i, j int) bool {
|
||||
return v[i].timestamp.Unix() < v[j].timestamp.Unix()
|
||||
}
|
||||
|
||||
//
|
||||
|
Loading…
x
Reference in New Issue
Block a user