Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
J
jacobsa-fuse
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
jacobsa-fuse
Commits
02803ae8
Commit
02803ae8
authored
Mar 06, 2015
by
Aaron Jacobs
Browse files
Options
Browse Files
Download
Plain Diff
Support chmod and chtimes.
parents
510f051c
a7d2944d
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
63 additions
and
8 deletions
+63
-8
file_system.go
file_system.go
+4
-1
samples/memfs/fs.go
samples/memfs/fs.go
+1
-1
samples/memfs/inode.go
samples/memfs/inode.go
+15
-1
samples/memfs/memfs_test.go
samples/memfs/memfs_test.go
+31
-5
server.go
server.go
+12
-0
No files found.
file_system.go
View file @
02803ae8
...
...
@@ -433,7 +433,10 @@ type SetInodeAttributesRequest struct {
Inode
InodeID
// The attributes to modify, or nil for attributes that don't need a change.
Size
*
uint64
Size
*
uint64
Mode
*
os
.
FileMode
Atime
*
time
.
Time
Mtime
*
time
.
Time
}
type
SetInodeAttributesResponse
struct
{
...
...
samples/memfs/fs.go
View file @
02803ae8
...
...
@@ -281,7 +281,7 @@ func (fs *memFS) SetInodeAttributes(
defer
inode
.
mu
.
Unlock
()
// Handle the request.
inode
.
SetAttributes
(
req
.
Size
)
inode
.
SetAttributes
(
req
.
Size
,
req
.
Mode
,
req
.
Mtime
)
// Fill in the response.
resp
.
Attributes
=
inode
.
attributes
...
...
samples/memfs/inode.go
View file @
02803ae8
...
...
@@ -18,6 +18,7 @@ import (
"fmt"
"io"
"os"
"time"
"github.com/jacobsa/fuse"
"github.com/jacobsa/fuse/fuseutil"
...
...
@@ -373,7 +374,10 @@ func (inode *inode) WriteAt(p []byte, off int64) (n int, err error) {
// Update attributes from non-nil parameters.
//
// EXCLUSIVE_LOCKS_REQUIRED(inode.mu)
func
(
inode
*
inode
)
SetAttributes
(
size
*
uint64
)
{
func
(
inode
*
inode
)
SetAttributes
(
size
*
uint64
,
mode
*
os
.
FileMode
,
mtime
*
time
.
Time
)
{
// Update the modification time.
inode
.
attributes
.
Mtime
=
inode
.
clock
.
Now
()
...
...
@@ -392,4 +396,14 @@ func (inode *inode) SetAttributes(size *uint64) {
// Update attributes.
inode
.
attributes
.
Size
=
*
size
}
// Change mode?
if
mode
!=
nil
{
inode
.
attributes
.
Mode
=
*
mode
}
// Change mtime?
if
mtime
!=
nil
{
inode
.
attributes
.
Mtime
=
*
mtime
}
}
samples/memfs/memfs_test.go
View file @
02803ae8
...
...
@@ -859,7 +859,6 @@ func (t *MemFSTest) ReadsPastEndOfFile() {
func
(
t
*
MemFSTest
)
Truncate_Smaller
()
{
var
err
error
fileName
:=
path
.
Join
(
t
.
mfs
.
Dir
(),
"foo"
)
// Create a file.
...
...
@@ -888,7 +887,6 @@ func (t *MemFSTest) Truncate_Smaller() {
func
(
t
*
MemFSTest
)
Truncate_SameSize
()
{
var
err
error
fileName
:=
path
.
Join
(
t
.
mfs
.
Dir
(),
"foo"
)
// Create a file.
...
...
@@ -917,7 +915,6 @@ func (t *MemFSTest) Truncate_SameSize() {
func
(
t
*
MemFSTest
)
Truncate_Larger
()
{
var
err
error
fileName
:=
path
.
Join
(
t
.
mfs
.
Dir
(),
"foo"
)
// Create a file.
...
...
@@ -945,9 +942,38 @@ func (t *MemFSTest) Truncate_Larger() {
}
func
(
t
*
MemFSTest
)
Chmod
()
{
AssertTrue
(
false
,
"TODO"
)
var
err
error
fileName
:=
path
.
Join
(
t
.
mfs
.
Dir
(),
"foo"
)
// Create a file.
err
=
ioutil
.
WriteFile
(
fileName
,
[]
byte
(
""
),
0600
)
AssertEq
(
nil
,
err
)
// Chmod it.
err
=
os
.
Chmod
(
fileName
,
0754
)
AssertEq
(
nil
,
err
)
// Stat it.
fi
,
err
:=
os
.
Stat
(
fileName
)
AssertEq
(
nil
,
err
)
ExpectEq
(
os
.
FileMode
(
0754
),
fi
.
Mode
())
}
func
(
t
*
MemFSTest
)
Chtimes
()
{
AssertTrue
(
false
,
"TODO"
)
var
err
error
fileName
:=
path
.
Join
(
t
.
mfs
.
Dir
(),
"foo"
)
// Create a file.
err
=
ioutil
.
WriteFile
(
fileName
,
[]
byte
(
""
),
0600
)
AssertEq
(
nil
,
err
)
// Chtimes it.
expectedMtime
:=
time
.
Now
()
.
Add
(
123
*
time
.
Second
)
.
Round
(
time
.
Second
)
err
=
os
.
Chtimes
(
fileName
,
time
.
Time
{},
expectedMtime
)
AssertEq
(
nil
,
err
)
// Stat it.
fi
,
err
:=
os
.
Stat
(
fileName
)
AssertEq
(
nil
,
err
)
ExpectEq
(
0
,
fi
.
ModTime
()
.
Sub
(
expectedMtime
))
}
server.go
View file @
02803ae8
...
...
@@ -182,6 +182,18 @@ func (s *server) handleFuseRequest(fuseReq bazilfuse.Request) {
req
.
Size
=
&
typed
.
Size
}
if
typed
.
Valid
&
bazilfuse
.
SetattrMode
!=
0
{
req
.
Mode
=
&
typed
.
Mode
}
if
typed
.
Valid
&
bazilfuse
.
SetattrAtime
!=
0
{
req
.
Atime
=
&
typed
.
Atime
}
if
typed
.
Valid
&
bazilfuse
.
SetattrMtime
!=
0
{
req
.
Mtime
=
&
typed
.
Mtime
}
// Call the file system.
resp
,
err
:=
s
.
fs
.
SetInodeAttributes
(
ctx
,
req
)
if
err
!=
nil
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment