Commit 7b15acfb authored by Han-Wen Nienhuys's avatar Han-Wen Nienhuys

fuse: add convenience functions for interpreting SetAttrIn

parent e99f8487
...@@ -200,54 +200,39 @@ func (c *rawBridge) SetAttr(input *fuse.SetAttrIn, out *fuse.AttrOut) (code fuse ...@@ -200,54 +200,39 @@ func (c *rawBridge) SetAttr(input *fuse.SetAttrIn, out *fuse.AttrOut) (code fuse
node := c.toInode(input.NodeId) node := c.toInode(input.NodeId)
var f File var f File
if input.Valid&fuse.FATTR_FH != 0 { if fh, ok := input.GetFh(); ok {
if opened := node.mount.getOpenedFile(input.Fh); opened != nil { if opened := node.mount.getOpenedFile(fh); opened != nil {
f = opened.WithFlags.File f = opened.WithFlags.File
} }
} }
if code.Ok() && input.Valid&fuse.FATTR_MODE != 0 { if permissions, ok := input.GetMode(); ok {
permissions := uint32(07777) & input.Mode
code = node.fsInode.Chmod(f, permissions, &input.Context) code = node.fsInode.Chmod(f, permissions, &input.Context)
} }
if code.Ok() && (input.Valid&(fuse.FATTR_UID|fuse.FATTR_GID) != 0) {
var uid uint32 = ^uint32(0) // means "do not change" in chown(2) uid, uok := input.GetUID()
var gid uint32 = ^uint32(0) gid, gok := input.GetUID()
if input.Valid&fuse.FATTR_UID != 0 {
uid = input.Uid if code.Ok() && (uok || gok) {
}
if input.Valid&fuse.FATTR_GID != 0 {
gid = input.Gid
}
code = node.fsInode.Chown(f, uid, gid, &input.Context) code = node.fsInode.Chown(f, uid, gid, &input.Context)
} }
if code.Ok() && input.Valid&fuse.FATTR_SIZE != 0 { if sz, ok := input.GetSize(); code.Ok() && ok {
code = node.fsInode.Truncate(f, input.Size, &input.Context) code = node.fsInode.Truncate(f, sz, &input.Context)
} }
if code.Ok() && (input.Valid&(fuse.FATTR_ATIME|fuse.FATTR_MTIME|fuse.FATTR_ATIME_NOW|fuse.FATTR_MTIME_NOW) != 0) {
now := time.Now()
var atime *time.Time
var mtime *time.Time
if input.Valid&fuse.FATTR_ATIME != 0 {
if input.Valid&fuse.FATTR_ATIME_NOW != 0 {
atime = &now
} else {
t := time.Unix(int64(input.Atime), int64(input.Atimensec))
atime = &t
}
}
if input.Valid&fuse.FATTR_MTIME != 0 { atime, aok := input.GetATime()
if input.Valid&fuse.FATTR_MTIME_NOW != 0 { mtime, mok := input.GetMTime()
mtime = &now if code.Ok() && (aok || mok) {
} else { var a, m *time.Time
t := time.Unix(int64(input.Mtime), int64(input.Mtimensec))
mtime = &t if aok {
} a = &atime
}
if mok {
m = &mtime
} }
code = node.fsInode.Utimens(f, atime, mtime, &input.Context) code = node.fsInode.Utimens(f, a, m, &input.Context)
} }
if !code.Ok() { if !code.Ok() {
......
...@@ -153,6 +153,79 @@ type SetAttrInCommon struct { ...@@ -153,6 +153,79 @@ type SetAttrInCommon struct {
Unused5 uint32 Unused5 uint32
} }
func (s *SetAttrInCommon) GetFh() (uint64, bool) {
if s.Valid&FATTR_FH != 0 {
return s.Fh, true
}
return 0, false
}
func (s *SetAttrInCommon) GetMode() (uint32, bool) {
if s.Valid&FATTR_MODE != 0 {
return s.Mode & 07777, true
}
return 0, false
}
func (s *SetAttrInCommon) GetUID() (uint32, bool) {
if s.Valid&FATTR_UID != 0 {
return s.Uid, true
}
return ^uint32(0), false
}
func (s *SetAttrInCommon) GetGID() (uint32, bool) {
if s.Valid&FATTR_GID != 0 {
return s.Gid, true
}
return ^uint32(0), false
}
func (s *SetAttrInCommon) GetSize() (uint64, bool) {
if s.Valid&FATTR_SIZE != 0 {
return s.Size, true
}
return 0, false
}
func (s *SetAttrInCommon) GetMTime() (time.Time, bool) {
var t time.Time
if s.Valid&FATTR_MTIME != 0 {
if s.Valid&FATTR_MTIME_NOW != 0 {
t = time.Now()
} else {
t = time.Unix(int64(s.Mtime), int64(s.Mtimensec))
}
return t, true
}
return t, false
}
func (s *SetAttrInCommon) GetATime() (time.Time, bool) {
var t time.Time
if s.Valid&FATTR_ATIME != 0 {
if s.Valid&FATTR_ATIME_NOW != 0 {
t = time.Now()
} else {
t = time.Unix(int64(s.Atime), int64(s.Atimensec))
}
return t, true
}
return t, false
}
func (s *SetAttrInCommon) GetCTime() (time.Time, bool) {
var t time.Time
if s.Valid&FATTR_CTIME != 0 {
t = time.Unix(int64(s.Ctime), int64(s.Ctimensec))
return t, true
}
return t, false
}
const RELEASE_FLUSH = (1 << 0) const RELEASE_FLUSH = (1 << 0)
type ReleaseIn struct { type ReleaseIn struct {
......
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