Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
e9779b1c
提交
e9779b1c
authored
10月 31, 2014
作者:
Jeromy
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
address comments from PR
上级
ae339a03
隐藏空白字符变更
内嵌
并排
正在显示
2 个修改的文件
包含
10 行增加
和
13 行删除
+10
-13
importer.go
importer/importer.go
+6
-3
importer_test.go
importer/importer_test.go
+4
-10
没有找到文件。
importer/importer.go
浏览文件 @
e9779b1c
...
@@ -95,6 +95,8 @@ func BuildDagFromFile(fpath string, ds dag.DAGService, mp pin.ManualPinner) (*da
...
@@ -95,6 +95,8 @@ func BuildDagFromFile(fpath string, ds dag.DAGService, mp pin.ManualPinner) (*da
func
BuildDagFromReader
(
r
io
.
Reader
,
ds
dag
.
DAGService
,
mp
pin
.
ManualPinner
,
spl
chunk
.
BlockSplitter
)
(
*
dag
.
Node
,
error
)
{
func
BuildDagFromReader
(
r
io
.
Reader
,
ds
dag
.
DAGService
,
mp
pin
.
ManualPinner
,
spl
chunk
.
BlockSplitter
)
(
*
dag
.
Node
,
error
)
{
blkChan
:=
spl
.
Split
(
r
)
blkChan
:=
spl
.
Split
(
r
)
// grab first block, it will go in the index MultiBlock (faster io)
first
:=
<-
blkChan
first
:=
<-
blkChan
root
:=
&
dag
.
Node
{}
root
:=
&
dag
.
Node
{}
...
@@ -104,13 +106,14 @@ func BuildDagFromReader(r io.Reader, ds dag.DAGService, mp pin.ManualPinner, spl
...
@@ -104,13 +106,14 @@ func BuildDagFromReader(r io.Reader, ds dag.DAGService, mp pin.ManualPinner, spl
mbf
.
AddBlockSize
(
uint64
(
len
(
blk
)))
mbf
.
AddBlockSize
(
uint64
(
len
(
blk
)))
node
:=
&
dag
.
Node
{
Data
:
ft
.
WrapData
(
blk
)}
node
:=
&
dag
.
Node
{
Data
:
ft
.
WrapData
(
blk
)}
nk
,
err
:=
ds
.
Add
(
node
)
nk
,
err
:=
ds
.
Add
(
node
)
if
mp
!=
nil
{
mp
.
PinWithMode
(
nk
,
pin
.
Indirect
)
}
if
err
!=
nil
{
if
err
!=
nil
{
return
nil
,
err
return
nil
,
err
}
}
if
mp
!=
nil
{
mp
.
PinWithMode
(
nk
,
pin
.
Indirect
)
}
// Add a link to this node without storing a reference to the memory
// Add a link to this node without storing a reference to the memory
err
=
root
.
AddNodeLinkClean
(
""
,
node
)
err
=
root
.
AddNodeLinkClean
(
""
,
node
)
if
err
!=
nil
{
if
err
!=
nil
{
...
...
importer/importer_test.go
浏览文件 @
e9779b1c
...
@@ -9,11 +9,10 @@ import (
...
@@ -9,11 +9,10 @@ import (
"os"
"os"
"testing"
"testing"
ds
"github.com/jbenet/go-ipfs/Godeps/_workspace/src/github.com/jbenet/go-datastore"
bsrv
"github.com/jbenet/go-ipfs/blockservice"
"github.com/jbenet/go-ipfs/importer/chunk"
"github.com/jbenet/go-ipfs/importer/chunk"
dag
"github.com/jbenet/go-ipfs/merkledag"
uio
"github.com/jbenet/go-ipfs/unixfs/io"
uio
"github.com/jbenet/go-ipfs/unixfs/io"
u
"github.com/jbenet/go-ipfs/util"
"github.com/jbenet/go-ipfs/util/testutil"
)
)
// NOTE:
// NOTE:
...
@@ -82,15 +81,10 @@ func testFileConsistency(t *testing.T, bs chunk.BlockSplitter, nbytes int) {
...
@@ -82,15 +81,10 @@ func testFileConsistency(t *testing.T, bs chunk.BlockSplitter, nbytes int) {
func
TestBuilderConsistency
(
t
*
testing
.
T
)
{
func
TestBuilderConsistency
(
t
*
testing
.
T
)
{
nbytes
:=
100000
nbytes
:=
100000
dstore
:=
ds
.
NewMapDatastore
()
bserv
,
err
:=
bsrv
.
NewBlockService
(
dstore
,
nil
)
if
err
!=
nil
{
t
.
Fatal
(
err
)
}
dagserv
:=
dag
.
NewDAGService
(
bserv
)
buf
:=
new
(
bytes
.
Buffer
)
buf
:=
new
(
bytes
.
Buffer
)
io
.
CopyN
(
buf
,
rand
.
Reader
,
int64
(
nbytes
))
io
.
CopyN
(
buf
,
u
.
NewTimeSeededRand
()
,
int64
(
nbytes
))
should
:=
dup
(
buf
.
Bytes
())
should
:=
dup
(
buf
.
Bytes
())
dagserv
:=
testutil
.
GetDAGServ
(
t
)
nd
,
err
:=
BuildDagFromReader
(
buf
,
dagserv
,
nil
,
chunk
.
DefaultSplitter
)
nd
,
err
:=
BuildDagFromReader
(
buf
,
dagserv
,
nil
,
chunk
.
DefaultSplitter
)
if
err
!=
nil
{
if
err
!=
nil
{
t
.
Fatal
(
err
)
t
.
Fatal
(
err
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论