Commit e9fdcab9 authored by Han-Wen Nienhuys's avatar Han-Wen Nienhuys

Bail out early with message if Lookup is called on non-directory node.

parent fe911701
...@@ -40,7 +40,7 @@ func (me *FileSystemConnector) internalLookup(parent *Inode, name string, contex ...@@ -40,7 +40,7 @@ func (me *FileSystemConnector) internalLookup(parent *Inode, name string, contex
} else { } else {
fi, fsNode, code = parent.fsInode.Lookup(name, context) fi, fsNode, code = parent.fsInode.Lookup(name, context)
} }
if child == nil && fsNode != nil { if child == nil && fsNode != nil {
child = fsNode.Inode() child = fsNode.Inode()
} }
...@@ -50,6 +50,10 @@ func (me *FileSystemConnector) internalLookup(parent *Inode, name string, contex ...@@ -50,6 +50,10 @@ func (me *FileSystemConnector) internalLookup(parent *Inode, name string, contex
func (me *FileSystemConnector) Lookup(header *InHeader, name string) (out *EntryOut, code Status) { func (me *FileSystemConnector) Lookup(header *InHeader, name string) (out *EntryOut, code Status) {
parent := me.toInode(header.NodeId) parent := me.toInode(header.NodeId)
if !parent.IsDir() {
log.Printf("Lookup %q called on non-Directory node %d", name, header.NodeId)
return nil, ENOTDIR
}
context := &header.Context context := &header.Context
fi, child, code := me.internalLookup(parent, name, context) fi, child, code := me.internalLookup(parent, name, context)
if !code.Ok() { if !code.Ok() {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment