本文整理汇总了Golang中github.com/jacobsa/fuse/fuseops.CreateFileOp.Handle方法的典型用法代码示例。如果您正苦于以下问题:Golang CreateFileOp.Handle方法的具体用法?Golang CreateFileOp.Handle怎么用?Golang CreateFileOp.Handle使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/jacobsa/fuse/fuseops.CreateFileOp
的用法示例。
在下文中一共展示了CreateFileOp.Handle方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: CreateFile
func (fs *Goofys) CreateFile(
ctx context.Context,
op *fuseops.CreateFileOp) (err error) {
fs.mu.Lock()
parent := fs.getInodeOrDie(op.Parent)
fs.mu.Unlock()
inode, fh := parent.Create(fs, &op.Name)
fs.mu.Lock()
defer fs.mu.Unlock()
nextInode := fs.nextInodeID
fs.nextInodeID++
inode.Id = nextInode
fs.inodes[inode.Id] = inode
fs.inodesCache[*inode.FullName] = inode
op.Entry.Child = inode.Id
op.Entry.Attributes = *inode.Attributes
op.Entry.AttributesExpiration = time.Now().Add(fs.flags.StatCacheTTL)
op.Entry.EntryExpiration = time.Now().Add(fs.flags.TypeCacheTTL)
// Allocate a handle.
handleID := fs.nextHandleID
fs.nextHandleID++
fs.fileHandles[handleID] = fh
op.Handle = handleID
inode.logFuse("<-- CreateFile")
return
}
示例2: CreateFile
// LOCKS_EXCLUDED(fs.mu)
func (fs *fileSystem) CreateFile(
ctx context.Context,
op *fuseops.CreateFileOp) (err error) {
// Create the child.
child, err := fs.createFile(ctx, op.Parent, op.Name, op.Mode)
if err != nil {
return
}
defer fs.unlockAndMaybeDisposeOfInode(child, &err)
// Allocate a handle.
fs.mu.Lock()
handleID := fs.nextHandleID
fs.nextHandleID++
fs.handles[handleID] = handle.NewFileHandle(
child.(*inode.FileInode),
fs.bucket)
op.Handle = handleID
fs.mu.Unlock()
// Fill out the response.
e := &op.Entry
e.Child = child.ID()
e.Attributes, e.AttributesExpiration, err = fs.getAttributes(ctx, child)
if err != nil {
err = fmt.Errorf("getAttributes: %v", err)
return
}
return
}
示例3: CreateFile
// LOCKS_EXCLUDED(fs.mu)
func (fs *fileSystem) CreateFile(
ctx context.Context,
op *fuseops.CreateFileOp) (err error) {
// Find the parent.
fs.mu.Lock()
parent := fs.inodes[op.Parent].(inode.DirInode)
fs.mu.Unlock()
// Create an empty backing object for the child, failing if it already
// exists.
parent.Lock()
o, err := parent.CreateChildFile(ctx, op.Name)
parent.Unlock()
// Special case: *gcs.PreconditionError means the name already exists.
if _, ok := err.(*gcs.PreconditionError); ok {
err = fuse.EEXIST
return
}
// Propagate other errors.
if err != nil {
err = fmt.Errorf("CreateChildFile: %v", err)
return
}
// Attempt to create a child inode using the object we created. If we fail to
// do so, it means someone beat us to the punch with a newer generation
// (unlikely, so we're probably okay with failing here).
fs.mu.Lock()
child := fs.lookUpOrCreateInodeIfNotStale(o.Name, o)
if child == nil {
err = fmt.Errorf("Newly-created record is already stale")
return
}
defer fs.unlockAndMaybeDisposeOfInode(child, &err)
// Allocate a handle.
fs.mu.Lock()
handleID := fs.nextHandleID
fs.nextHandleID++
fs.handles[handleID] = handle.NewFileHandle(
child.(*inode.FileInode),
fs.bucket)
op.Handle = handleID
fs.mu.Unlock()
// Fill out the response.
e := &op.Entry
e.Child = child.ID()
e.Attributes, e.AttributesExpiration, err = fs.getAttributes(ctx, child)
if err != nil {
err = fmt.Errorf("getAttributes: %v", err)
return
}
return
}