Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
go-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
go-fuse
Commits
00947164
Commit
00947164
authored
Dec 08, 2011
by
Han-Wen Nienhuys
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Use syscall directly rather than os functions.
parent
3ab227cc
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
7 additions
and
6 deletions
+7
-6
fuse/files.go
fuse/files.go
+3
-2
fuse/loopback.go
fuse/loopback.go
+4
-4
No files found.
fuse/files.go
View file @
00947164
...
@@ -131,12 +131,13 @@ func (me *LoopbackFile) Chown(uid uint32, gid uint32) Status {
...
@@ -131,12 +131,13 @@ func (me *LoopbackFile) Chown(uid uint32, gid uint32) Status {
}
}
func
(
me
*
LoopbackFile
)
GetAttr
()
(
*
Attr
,
Status
)
{
func
(
me
*
LoopbackFile
)
GetAttr
()
(
*
Attr
,
Status
)
{
fi
,
err
:=
me
.
File
.
Stat
()
st
:=
syscall
.
Stat_t
{}
err
:=
syscall
.
Fstat
(
me
.
File
.
Fd
(),
&
st
)
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
ToStatus
(
err
)
return
nil
,
ToStatus
(
err
)
}
}
a
:=
&
Attr
{}
a
:=
&
Attr
{}
a
.
From
FileInfo
(
fi
)
a
.
From
Stat
(
&
st
)
return
a
,
OK
return
a
,
OK
}
}
...
...
fuse/loopback.go
View file @
00947164
...
@@ -37,19 +37,19 @@ func (me *LoopbackFileSystem) GetPath(relPath string) string {
...
@@ -37,19 +37,19 @@ func (me *LoopbackFileSystem) GetPath(relPath string) string {
func
(
me
*
LoopbackFileSystem
)
GetAttr
(
name
string
,
context
*
Context
)
(
a
*
Attr
,
code
Status
)
{
func
(
me
*
LoopbackFileSystem
)
GetAttr
(
name
string
,
context
*
Context
)
(
a
*
Attr
,
code
Status
)
{
fullPath
:=
me
.
GetPath
(
name
)
fullPath
:=
me
.
GetPath
(
name
)
var
err
error
=
nil
var
err
error
=
nil
var
fi
os
.
FileInfo
st
:=
syscall
.
Stat_t
{}
if
name
==
""
{
if
name
==
""
{
// When GetAttr is called for the toplevel directory, we always want
// When GetAttr is called for the toplevel directory, we always want
// to look through symlinks.
// to look through symlinks.
fi
,
err
=
os
.
Stat
(
fullPath
)
err
=
syscall
.
Stat
(
fullPath
,
&
st
)
}
else
{
}
else
{
fi
,
err
=
os
.
Lstat
(
fullPath
)
err
=
syscall
.
Lstat
(
fullPath
,
&
st
)
}
}
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
ToStatus
(
err
)
return
nil
,
ToStatus
(
err
)
}
}
a
=
&
Attr
{}
a
=
&
Attr
{}
a
.
From
FileInfo
(
fi
)
a
.
From
Stat
(
&
st
)
return
a
,
OK
return
a
,
OK
}
}
...
...
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