func (c *FileSystemConnector) Lookup(out *raw.EntryOut, header *raw.InHeader, name string) (code Status) { parent := c.toInode(header.NodeId) if !parent.IsDir() { log.Printf("Lookup %q called on non-Directory node %d", name, header.NodeId) return ENOTDIR } context := (*Context)(&header.Context) outAttr := (*Attr)(&out.Attr) child, code := c.internalLookup(outAttr, parent, name, context) if code == ENOENT && parent.mount.negativeEntry(out) { return OK } if !code.Ok() { return code } if child == nil { log.Println("Lookup returned OK with nil child", name) } child.mount.fillEntry(out) out.NodeId = c.lookupUpdate(child) out.Generation = child.generation out.Ino = out.NodeId return OK }