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
Levin Zimmermann
go-fuse
Commits
2f1a241e
Commit
2f1a241e
authored
Aug 14, 2010
by
Ivan Krasin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
managerResponse.code -> managerResponse.status
parent
6fb63521
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
27 additions
and
27 deletions
+27
-27
fuse/fuse.go
fuse/fuse.go
+27
-27
No files found.
fuse/fuse.go
View file @
2f1a241e
...
@@ -14,8 +14,8 @@ const (
...
@@ -14,8 +14,8 @@ const (
)
)
type
FileSystem
interface
{
type
FileSystem
interface
{
List
(
parent
string
)
(
names
[]
string
,
code
Status
)
List
(
parent
string
)
(
names
[]
string
,
status
Status
)
GetAttr
(
path
string
)
(
out
*
Attr
,
code
Status
)
GetAttr
(
path
string
)
(
out
*
Attr
,
status
Status
)
}
}
type
Mounted
interface
{
type
Mounted
interface
{
...
@@ -166,8 +166,8 @@ func getAttr(fs FileSystem, h *InHeader, r io.Reader, c *managerClient) (data []
...
@@ -166,8 +166,8 @@ func getAttr(fs FileSystem, h *InHeader, r io.Reader, c *managerClient) (data []
fmt
.
Printf
(
"FUSE_GETATTR: %v, Fh: %d
\n
"
,
in
,
in
.
Fh
)
fmt
.
Printf
(
"FUSE_GETATTR: %v, Fh: %d
\n
"
,
in
,
in
.
Fh
)
out
:=
new
(
AttrOut
)
out
:=
new
(
AttrOut
)
resp
:=
c
.
getPath
(
in
.
Fh
)
resp
:=
c
.
getPath
(
in
.
Fh
)
if
resp
.
code
!=
OK
{
if
resp
.
status
!=
OK
{
return
serialize
(
h
,
resp
.
code
,
nil
)
return
serialize
(
h
,
resp
.
status
,
nil
)
}
}
attr
,
res
:=
fs
.
GetAttr
(
resp
.
path
)
attr
,
res
:=
fs
.
GetAttr
(
resp
.
path
)
if
res
!=
OK
{
if
res
!=
OK
{
...
@@ -199,8 +199,8 @@ func openDir(h *InHeader, r io.Reader, c *managerClient) (data [][]byte, err os.
...
@@ -199,8 +199,8 @@ func openDir(h *InHeader, r io.Reader, c *managerClient) (data [][]byte, err os.
}
}
fmt
.
Printf
(
"FUSE_OPENDIR: %v
\n
"
,
in
)
fmt
.
Printf
(
"FUSE_OPENDIR: %v
\n
"
,
in
)
resp
:=
c
.
openDir
(
h
.
NodeId
)
resp
:=
c
.
openDir
(
h
.
NodeId
)
if
resp
.
code
!=
OK
{
if
resp
.
status
!=
OK
{
return
serialize
(
h
,
resp
.
code
,
nil
)
return
serialize
(
h
,
resp
.
status
,
nil
)
}
}
out
:=
new
(
OpenOut
)
out
:=
new
(
OpenOut
)
out
.
Fh
=
resp
.
fh
out
.
Fh
=
resp
.
fh
...
@@ -217,8 +217,8 @@ func readDir(h *InHeader, r io.Reader, c *managerClient) (data [][]byte, err os.
...
@@ -217,8 +217,8 @@ func readDir(h *InHeader, r io.Reader, c *managerClient) (data [][]byte, err os.
}
}
fmt
.
Printf
(
"FUSE_READDIR: %v
\n
"
,
in
)
fmt
.
Printf
(
"FUSE_READDIR: %v
\n
"
,
in
)
resp
:=
c
.
getDirReader
(
h
.
NodeId
,
in
.
Fh
)
resp
:=
c
.
getDirReader
(
h
.
NodeId
,
in
.
Fh
)
if
resp
.
code
!=
OK
{
if
resp
.
status
!=
OK
{
return
serialize
(
h
,
resp
.
code
,
nil
)
return
serialize
(
h
,
resp
.
status
,
nil
)
}
}
dirRespChan
:=
make
(
chan
*
dirResponse
,
1
)
dirRespChan
:=
make
(
chan
*
dirResponse
,
1
)
fmt
.
Printf
(
"Sending dir request, in.Offset: %v
\n
"
,
in
.
Offset
)
fmt
.
Printf
(
"Sending dir request, in.Offset: %v
\n
"
,
in
.
Offset
)
...
@@ -269,8 +269,8 @@ func lookup(h *InHeader, r *bytes.Buffer, c *managerClient) (data [][]byte, err
...
@@ -269,8 +269,8 @@ func lookup(h *InHeader, r *bytes.Buffer, c *managerClient) (data [][]byte, err
filename
:=
string
(
r
.
Bytes
())
filename
:=
string
(
r
.
Bytes
())
fmt
.
Printf
(
"filename: %s
\n
"
,
filename
)
fmt
.
Printf
(
"filename: %s
\n
"
,
filename
)
resp
:=
c
.
lookup
(
h
.
NodeId
,
filename
)
resp
:=
c
.
lookup
(
h
.
NodeId
,
filename
)
if
resp
.
code
!=
OK
{
if
resp
.
status
!=
OK
{
return
serialize
(
h
,
resp
.
code
,
nil
)
return
serialize
(
h
,
resp
.
status
,
nil
)
}
}
out
:=
new
(
EntryOut
)
out
:=
new
(
EntryOut
)
out
.
NodeId
=
resp
.
nodeId
out
.
NodeId
=
resp
.
nodeId
...
@@ -291,8 +291,8 @@ func releaseDir(h *InHeader, r io.Reader, c *managerClient) (data [][]byte, err
...
@@ -291,8 +291,8 @@ func releaseDir(h *InHeader, r io.Reader, c *managerClient) (data [][]byte, err
}
}
fmt
.
Printf
(
"FUSE_RELEASEDIR: %v
\n
"
,
in
)
fmt
.
Printf
(
"FUSE_RELEASEDIR: %v
\n
"
,
in
)
resp
:=
c
.
closeDir
(
h
.
NodeId
,
in
.
Fh
)
resp
:=
c
.
closeDir
(
h
.
NodeId
,
in
.
Fh
)
if
resp
.
code
!=
OK
{
if
resp
.
status
!=
OK
{
return
serialize
(
h
,
resp
.
code
,
nil
)
return
serialize
(
h
,
resp
.
status
,
nil
)
}
}
return
serialize
(
h
,
OK
,
nil
)
return
serialize
(
h
,
OK
,
nil
)
}
}
...
@@ -333,7 +333,7 @@ type managerResponse struct {
...
@@ -333,7 +333,7 @@ type managerResponse struct {
nodeId
uint64
nodeId
uint64
fh
uint64
fh
uint64
dirReq
chan
*
dirRequest
dirReq
chan
*
dirRequest
code
Status
status
Status
attr
*
Attr
attr
*
Attr
path
string
path
string
}
}
...
@@ -449,7 +449,7 @@ func (m *manager) openDir(req *managerRequest) (resp *managerResponse) {
...
@@ -449,7 +449,7 @@ func (m *manager) openDir(req *managerRequest) (resp *managerResponse) {
m
.
dirHandles
[
h
.
fh
]
=
h
m
.
dirHandles
[
h
.
fh
]
=
h
dir
,
ok
:=
m
.
nodes
[
req
.
nodeId
]
dir
,
ok
:=
m
.
nodes
[
req
.
nodeId
]
if
!
ok
{
if
!
ok
{
resp
.
code
=
ENOENT
resp
.
status
=
ENOENT
return
return
}
}
go
readDirRoutine
(
dir
,
m
.
fs
,
m
.
client
,
h
.
req
)
go
readDirRoutine
(
dir
,
m
.
fs
,
m
.
client
,
h
.
req
)
...
@@ -462,7 +462,7 @@ func (m *manager) getHandle(req *managerRequest) (resp *managerResponse) {
...
@@ -462,7 +462,7 @@ func (m *manager) getHandle(req *managerRequest) (resp *managerResponse) {
resp
=
new
(
managerResponse
)
resp
=
new
(
managerResponse
)
h
,
ok
:=
m
.
dirHandles
[
req
.
fh
]
h
,
ok
:=
m
.
dirHandles
[
req
.
fh
]
if
!
ok
{
if
!
ok
{
resp
.
code
=
ENOENT
resp
.
status
=
ENOENT
return
return
}
}
fmt
.
Printf
(
"Handle found
\n
"
)
fmt
.
Printf
(
"Handle found
\n
"
)
...
@@ -474,7 +474,7 @@ func (m *manager) closeDir(req *managerRequest) (resp *managerResponse) {
...
@@ -474,7 +474,7 @@ func (m *manager) closeDir(req *managerRequest) (resp *managerResponse) {
resp
=
new
(
managerResponse
)
resp
=
new
(
managerResponse
)
h
,
ok
:=
m
.
dirHandles
[
req
.
fh
]
h
,
ok
:=
m
.
dirHandles
[
req
.
fh
]
if
!
ok
{
if
!
ok
{
resp
.
code
=
ENOENT
resp
.
status
=
ENOENT
return
return
}
}
m
.
dirHandles
[
h
.
fh
]
=
nil
,
false
m
.
dirHandles
[
h
.
fh
]
=
nil
,
false
...
@@ -486,12 +486,12 @@ func (m *manager) lookup(req *managerRequest) (resp *managerResponse) {
...
@@ -486,12 +486,12 @@ func (m *manager) lookup(req *managerRequest) (resp *managerResponse) {
resp
=
new
(
managerResponse
)
resp
=
new
(
managerResponse
)
parent
,
ok
:=
m
.
nodes
[
req
.
nodeId
]
parent
,
ok
:=
m
.
nodes
[
req
.
nodeId
]
if
!
ok
{
if
!
ok
{
resp
.
code
=
ENOENT
resp
.
status
=
ENOENT
return
return
}
}
attr
,
code
:=
m
.
fs
.
GetAttr
(
path
.
Join
(
parent
,
req
.
filename
))
attr
,
status
:=
m
.
fs
.
GetAttr
(
path
.
Join
(
parent
,
req
.
filename
))
if
code
!=
OK
{
if
status
!=
OK
{
resp
.
code
=
code
resp
.
status
=
status
}
}
// TODO: sanitize return values, like checking attr != nil
// TODO: sanitize return values, like checking attr != nil
resp
.
attr
=
attr
resp
.
attr
=
attr
...
@@ -512,12 +512,12 @@ func (m *manager) getPath(req *managerRequest) (resp *managerResponse) {
...
@@ -512,12 +512,12 @@ func (m *manager) getPath(req *managerRequest) (resp *managerResponse) {
resp
=
new
(
managerResponse
)
resp
=
new
(
managerResponse
)
h
,
ok
:=
m
.
dirHandles
[
req
.
fh
]
h
,
ok
:=
m
.
dirHandles
[
req
.
fh
]
if
!
ok
{
if
!
ok
{
resp
.
code
=
ENOENT
resp
.
status
=
ENOENT
return
return
}
}
path
,
ok
:=
m
.
nodes
[
h
.
nodeId
]
path
,
ok
:=
m
.
nodes
[
h
.
nodeId
]
if
!
ok
{
if
!
ok
{
resp
.
code
=
ENOENT
resp
.
status
=
ENOENT
return
return
}
}
resp
.
path
=
path
resp
.
path
=
path
...
@@ -527,11 +527,11 @@ func (m *manager) getPath(req *managerRequest) (resp *managerResponse) {
...
@@ -527,11 +527,11 @@ func (m *manager) getPath(req *managerRequest) (resp *managerResponse) {
func
readDirRoutine
(
dir
string
,
fs
FileSystem
,
c
*
managerClient
,
requests
chan
*
dirRequest
)
{
func
readDirRoutine
(
dir
string
,
fs
FileSystem
,
c
*
managerClient
,
requests
chan
*
dirRequest
)
{
defer
close
(
requests
)
defer
close
(
requests
)
dir
=
path
.
Clean
(
dir
)
dir
=
path
.
Clean
(
dir
)
names
,
code
:=
fs
.
List
(
dir
)
names
,
status
:=
fs
.
List
(
dir
)
i
:=
uint64
(
0
)
i
:=
uint64
(
0
)
for
req
:=
range
requests
{
for
req
:=
range
requests
{
if
code
!=
OK
{
if
status
!=
OK
{
req
.
resp
<-
&
dirResponse
{
nil
,
code
}
req
.
resp
<-
&
dirResponse
{
nil
,
status
}
return
return
}
}
if
req
.
offset
!=
i
{
if
req
.
offset
!=
i
{
...
@@ -545,8 +545,8 @@ func readDirRoutine(dir string, fs FileSystem, c *managerClient, requests chan *
...
@@ -545,8 +545,8 @@ func readDirRoutine(dir string, fs FileSystem, c *managerClient, requests chan *
entry
:=
new
(
dirEntry
)
entry
:=
new
(
dirEntry
)
entry
.
name
=
names
[
i
]
entry
.
name
=
names
[
i
]
lookupResp
:=
c
.
lookup
(
req
.
nodeId
,
entry
.
name
)
lookupResp
:=
c
.
lookup
(
req
.
nodeId
,
entry
.
name
)
if
lookupResp
.
code
!=
OK
{
if
lookupResp
.
status
!=
OK
{
req
.
resp
<-
&
dirResponse
{
nil
,
lookupResp
.
code
}
req
.
resp
<-
&
dirResponse
{
nil
,
lookupResp
.
status
}
return
return
}
}
entry
.
nodeId
=
lookupResp
.
nodeId
entry
.
nodeId
=
lookupResp
.
nodeId
...
...
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