Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
12116dd6
提交
12116dd6
authored
1月 14, 2015
作者:
Brian Tiger Chow
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
style(fsrepo): rename to counter.Openers
上级
b666163e
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
19 行增加
和
19 行删除
+19
-19
openers.go
repo/fsrepo/counter/openers.go
+7
-7
fsrepo.go
repo/fsrepo/fsrepo.go
+12
-12
没有找到文件。
repo/fsrepo/
opener/counter
.go
→
repo/fsrepo/
counter/openers
.go
浏览文件 @
12116dd6
package
fsrepo
package
counter
import
"path"
// TODO this could be made into something more generic.
type
Counter
struct
{
type
Openers
struct
{
// repos maps repo paths to the number of openers holding an FSRepo handle
// to it
repos
map
[
string
]
int
}
func
New
Counter
()
*
Counter
{
return
&
Counter
{
func
New
OpenersCounter
()
*
Openers
{
return
&
Openers
{
repos
:
make
(
map
[
string
]
int
),
}
}
...
...
@@ -19,13 +19,13 @@ func NewCounter() *Counter {
// NumOpeners returns the number of FSRepos holding a handle to the repo at
// this path. This method is not thread-safe. The caller must have this object
// locked.
func
(
l
*
Counter
)
NumOpeners
(
repoPath
string
)
int
{
func
(
l
*
Openers
)
NumOpeners
(
repoPath
string
)
int
{
return
l
.
repos
[
key
(
repoPath
)]
}
// AddOpener messages that an FSRepo holds a handle to the repo at this path.
// This method is not thread-safe. The caller must have this object locked.
func
(
l
*
Counter
)
AddOpener
(
repoPath
string
)
error
{
func
(
l
*
Openers
)
AddOpener
(
repoPath
string
)
error
{
l
.
repos
[
key
(
repoPath
)]
++
return
nil
}
...
...
@@ -33,7 +33,7 @@ func (l *Counter) AddOpener(repoPath string) error {
// RemoveOpener messgaes that an FSRepo no longer holds a handle to the repo at
// this path. This method is not thread-safe. The caller must have this object
// locked.
func
(
l
*
Counter
)
RemoveOpener
(
repoPath
string
)
error
{
func
(
l
*
Openers
)
RemoveOpener
(
repoPath
string
)
error
{
l
.
repos
[
key
(
repoPath
)]
--
return
nil
}
...
...
repo/fsrepo/fsrepo.go
浏览文件 @
12116dd6
...
...
@@ -12,9 +12,9 @@ import (
repo
"github.com/jbenet/go-ipfs/repo"
config
"github.com/jbenet/go-ipfs/repo/config"
component
"github.com/jbenet/go-ipfs/repo/fsrepo/component"
counter
"github.com/jbenet/go-ipfs/repo/fsrepo/counter"
dir
"github.com/jbenet/go-ipfs/repo/fsrepo/dir"
lockfile
"github.com/jbenet/go-ipfs/repo/fsrepo/lock"
opener
"github.com/jbenet/go-ipfs/repo/fsrepo/opener"
serialize
"github.com/jbenet/go-ipfs/repo/fsrepo/serialize"
debugerror
"github.com/jbenet/go-ipfs/util/debugerror"
)
...
...
@@ -23,22 +23,22 @@ var (
// packageLock must be held to while performing any operation that modifies an
// FSRepo's state field. This includes Init, Open, Close, and Remove.
packageLock
sync
.
Mutex
// protects openerCounter and lockfiles
packageLock
sync
.
Mutex
// protects opener
s
Counter and lockfiles
// lockfiles holds references to the Closers that ensure that repos are
// only accessed by one process at a time.
lockfiles
map
[
string
]
io
.
Closer
// openerCounter prevents the fsrepo from being removed while there exist open
// opener
s
Counter prevents the fsrepo from being removed while there exist open
// FSRepo handles. It also ensures that the Init is atomic.
//
// packageLock also protects numOpenedRepos
//
// If an operation is used when repo is Open and the operation does not
// change the repo's state, the package lock does not need to be acquired.
opener
Counter
*
opener
.
Counter
opener
sCounter
*
counter
.
Openers
)
func
init
()
{
opener
Counter
=
opener
.
New
Counter
()
opener
sCounter
=
counter
.
NewOpeners
Counter
()
lockfiles
=
make
(
map
[
string
]
io
.
Closer
)
}
...
...
@@ -113,7 +113,7 @@ func Remove(repoPath string) error {
packageLock
.
Lock
()
defer
packageLock
.
Unlock
()
if
openerCounter
.
NumOpeners
(
repoPath
)
!=
0
{
if
opener
s
Counter
.
NumOpeners
(
repoPath
)
!=
0
{
return
errors
.
New
(
"repo in use"
)
}
return
os
.
RemoveAll
(
repoPath
)
...
...
@@ -129,7 +129,7 @@ func LockedByOtherProcess(repoPath string) bool {
defer
packageLock
.
Unlock
()
// NB: the lock is only held when repos are Open
return
lockfile
.
Locked
(
repoPath
)
&&
openerCounter
.
NumOpeners
(
repoPath
)
==
0
return
lockfile
.
Locked
(
repoPath
)
&&
opener
s
Counter
.
NumOpeners
(
repoPath
)
==
0
}
// Open returns an error if the repo is not initialized.
...
...
@@ -265,7 +265,7 @@ func IsInitialized(path string) bool {
// private methods below this point. NB: packageLock must held by caller.
// isInitializedUnsynced reports whether the repo is initialized. Caller must
// hold
openerCounter l
ock.
// hold
the packageL
ock.
func
isInitializedUnsynced
(
path
string
)
bool
{
for
_
,
b
:=
range
componentBuilders
()
{
if
!
b
.
IsInitialized
(
path
)
{
...
...
@@ -279,24 +279,24 @@ func isInitializedUnsynced(path string) bool {
// the package mutex.
func
(
r
*
FSRepo
)
transitionToOpened
()
error
{
r
.
state
=
opened
if
countBefore
:=
openerCounter
.
NumOpeners
(
r
.
path
);
countBefore
==
0
{
// #first
if
countBefore
:=
opener
s
Counter
.
NumOpeners
(
r
.
path
);
countBefore
==
0
{
// #first
closer
,
err
:=
lockfile
.
Lock
(
r
.
path
)
if
err
!=
nil
{
return
err
}
lockfiles
[
r
.
path
]
=
closer
}
return
openerCounter
.
AddOpener
(
r
.
path
)
return
opener
s
Counter
.
AddOpener
(
r
.
path
)
}
// transitionToClosed manages the state transition to |closed|. Caller must
// hold the package mutex.
func
(
r
*
FSRepo
)
transitionToClosed
()
error
{
r
.
state
=
closed
if
err
:=
openerCounter
.
RemoveOpener
(
r
.
path
);
err
!=
nil
{
if
err
:=
opener
s
Counter
.
RemoveOpener
(
r
.
path
);
err
!=
nil
{
return
err
}
if
countAfter
:=
openerCounter
.
NumOpeners
(
r
.
path
);
countAfter
==
0
{
if
countAfter
:=
opener
s
Counter
.
NumOpeners
(
r
.
path
);
countAfter
==
0
{
closer
,
ok
:=
lockfiles
[
r
.
path
]
if
!
ok
{
return
errors
.
New
(
"package error: lockfile is not held"
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论