Browse Source

refactor

pull/1255/head
Chris Lu 5 years ago
parent
commit
c763a492f5
  1. 12
      weed/filesys/fscache.go

12
weed/filesys/fscache.go

@ -64,7 +64,7 @@ func (c *FsCache) DeleteFsNode(path util.FullPath) {
} }
} }
if t.parent != nil { if t.parent != nil {
t.parent.deleteChild(t.name)
t.parent.disconnectChild(t)
} }
t.deleteSelf() t.deleteSelf()
} }
@ -81,9 +81,8 @@ func (c *FsCache) Move(oldPath util.FullPath, newPath util.FullPath) *FsNode {
} }
} }
if src.parent != nil { if src.parent != nil {
src.parent.deleteChild(src.name)
src.parent.disconnectChild(src)
} }
src.parent = nil
// find new node // find new node
target := c.root target := c.root
@ -95,7 +94,7 @@ func (c *FsCache) Move(oldPath util.FullPath, newPath util.FullPath) *FsNode {
if dir, ok := src.node.(*Dir); ok { if dir, ok := src.node.(*Dir); ok {
dir.name = target.name // target is not Dir, but a shortcut dir.name = target.name // target is not Dir, but a shortcut
} }
parent.deleteChild(target.name)
parent.disconnectChild(target)
target.deleteSelf() target.deleteSelf()
@ -150,10 +149,11 @@ func (n *FsNode) ensureChild(name string) *FsNode {
return t return t
} }
func (n *FsNode) deleteChild(name string) {
func (n *FsNode) disconnectChild(child *FsNode) {
n.childrenLock.Lock() n.childrenLock.Lock()
delete(n.children, name)
delete(n.children, child.name)
n.childrenLock.Unlock() n.childrenLock.Unlock()
child.parent = nil
} }
func (n *FsNode) deleteSelf() { func (n *FsNode) deleteSelf() {

Loading…
Cancel
Save