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
1643d64c
Commit
1643d64c
authored
Sep 07, 2011
by
Han-Wen Nienhuys
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Handle existing implied hardlinks, and test for it.
parent
b40418c2
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
71 additions
and
6 deletions
+71
-6
fuse/loopback_test.go
fuse/loopback_test.go
+28
-0
fuse/pathfs.go
fuse/pathfs.go
+43
-6
No files found.
fuse/loopback_test.go
View file @
1643d64c
...
...
@@ -271,6 +271,34 @@ func TestLink(t *testing.T) {
CheckSuccess
(
err
)
}
// Deal correctly with hard links implied by matching client inode
// numbers.
func
TestLinkExisting
(
t
*
testing
.
T
)
{
me
:=
NewTestCase
(
t
)
defer
me
.
Cleanup
()
c
:=
"hello"
err
:=
ioutil
.
WriteFile
(
me
.
orig
+
"/file1"
,
[]
byte
(
c
),
0644
)
CheckSuccess
(
err
)
err
=
os
.
Link
(
me
.
orig
+
"/file1"
,
me
.
orig
+
"/file2"
)
CheckSuccess
(
err
)
f1
,
err
:=
os
.
Lstat
(
me
.
mnt
+
"/file1"
)
CheckSuccess
(
err
)
f2
,
err
:=
os
.
Lstat
(
me
.
mnt
+
"/file2"
)
CheckSuccess
(
err
)
if
f1
.
Ino
!=
f2
.
Ino
{
t
.
Errorf
(
"linked files should have identical inodes %v %v"
,
f1
.
Ino
,
f2
.
Ino
)
}
c1
,
err
:=
ioutil
.
ReadFile
(
me
.
mnt
+
"/file1"
)
CheckSuccess
(
err
)
if
string
(
c1
)
!=
c
{
t
.
Errorf
(
"Content mismatch relative to original."
)
}
}
func
TestSymlink
(
t
*
testing
.
T
)
{
me
:=
NewTestCase
(
t
)
defer
me
.
Cleanup
()
...
...
fuse/pathfs.go
View file @
1643d64c
...
...
@@ -178,6 +178,26 @@ func (me *pathInode) RmChild(name string, child FsNode) {
ch
.
Parent
=
nil
}
func
(
me
*
pathInode
)
setClientInode
(
ino
uint64
)
{
if
ino
==
me
.
clientInode
{
return
}
defer
me
.
Inode
()
.
LockTree
()()
me
.
ifs
.
clientInodeMapMutex
.
Lock
()
defer
me
.
ifs
.
clientInodeMapMutex
.
Unlock
()
if
me
.
clientInode
!=
0
{
me
.
ifs
.
clientInodeMap
[
me
.
clientInode
]
=
nil
,
false
}
me
.
clientInode
=
ino
if
me
.
Parent
!=
nil
{
e
:=
&
clientInodePath
{
me
.
Parent
,
me
.
Name
,
me
,
}
me
.
ifs
.
clientInodeMap
[
ino
]
=
append
(
me
.
ifs
.
clientInodeMap
[
ino
],
e
)
}
}
func
(
me
*
pathInode
)
OnForget
()
{
if
me
.
clientInode
==
0
{
return
...
...
@@ -329,16 +349,30 @@ func (me *pathInode) Lookup(name string) (fi *os.FileInfo, node FsNode, code Sta
fullPath
:=
filepath
.
Join
(
me
.
GetPath
(),
name
)
fi
,
code
=
me
.
fs
.
GetAttr
(
fullPath
,
nil
)
if
code
.
Ok
()
{
pNode
:=
me
.
createChild
(
name
)
node
=
pNode
if
fi
.
Ino
>
0
{
pNode
.
clientInode
=
fi
.
Ino
}
node
=
me
.
findChild
(
fi
.
Ino
,
name
)
}
return
}
func
(
me
*
pathInode
)
findChild
(
ino
uint64
,
name
string
)
(
out
*
pathInode
)
{
if
ino
>
0
{
me
.
ifs
.
clientInodeMapMutex
.
Lock
()
defer
me
.
ifs
.
clientInodeMapMutex
.
Unlock
()
v
:=
me
.
ifs
.
clientInodeMap
[
ino
]
if
len
(
v
)
>
0
{
out
=
v
[
0
]
.
node
}
}
if
out
==
nil
{
out
=
me
.
createChild
(
name
)
out
.
clientInode
=
ino
}
return
out
}
func
(
me
*
pathInode
)
GetAttr
(
file
File
,
context
*
Context
)
(
fi
*
os
.
FileInfo
,
code
Status
)
{
if
file
==
nil
{
// called on a deleted files.
...
...
@@ -353,6 +387,10 @@ func (me *pathInode) GetAttr(file File, context *Context) (fi *os.FileInfo, code
fi
,
code
=
me
.
fs
.
GetAttr
(
me
.
GetPath
(),
context
)
}
if
fi
!=
nil
{
me
.
setClientInode
(
fi
.
Ino
)
}
if
fi
!=
nil
&&
!
fi
.
IsDirectory
()
&&
fi
.
Nlink
==
0
{
fi
.
Nlink
=
1
}
...
...
@@ -395,7 +433,6 @@ func (me *pathInode) Truncate(file File, size uint64, context *Context) (code St
files
:=
me
.
inode
.
Files
(
O_ANYWRITE
)
for
_
,
f
:=
range
files
{
// TODO - pass context
log
.
Println
(
"truncating file"
,
f
)
code
=
f
.
Truncate
(
size
)
if
!
code
.
Ok
()
{
break
...
...
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