Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
e71e700c
提交
e71e700c
authored
1月 30, 2019
作者:
Łukasz Magiera
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
commands/get: move FileArchive here
License: MIT Signed-off-by:
Łukasz Magiera
<
magik6k@gmail.com
>
上级
a1510413
隐藏空白字符变更
内嵌
并排
正在显示
1 个修改的文件
包含
95 行增加
和
2 行删除
+95
-2
get.go
core/commands/get.go
+95
-2
没有找到文件。
core/commands/get.go
浏览文件 @
e71e700c
package
commands
import
(
"bufio"
"compress/gzip"
"errors"
"fmt"
"io"
"os"
"path"
"path/filepath"
"strings"
...
...
@@ -14,8 +16,8 @@ import (
"github.com/ipfs/go-ipfs/core/coreapi/interface"
"gx/ipfs/QmQine7gvHncNevKtG9QXxf3nXcwSj6aDDmMm52mHofEEp/tar-utils"
uarchive
"gx/ipfs/QmSMJ4rZbCJaih3y82Ebq7BZqK6vU2FHsKcWKQiE1DPTpS/go-unixfs/archive"
"gx/ipfs/QmWGm4AbZEbnmdgVTza52MSNpEmBdFVqzmAysRbjrRyGbH/go-ipfs-cmds"
"gx/ipfs/QmXWZCd8jfaHmt4UDSnjKmGcrQMw95bDGWqEeVLVJjoANX/go-ipfs-files"
"gx/ipfs/QmYWB8oH6o7qftxoyqTTZhzLrhKCVT7NYahECQTwTtqbgj/pb"
"gx/ipfs/Qmde5VP1qUkyQXKCfmEUA7bP64V2HAptbJ7phuPp7jXWwg/go-ipfs-cmdkit"
)
...
...
@@ -87,7 +89,7 @@ may also specify the level of compression by specifying '-l=<1-9>'.
res
.
SetLength
(
uint64
(
size
))
archive
,
_
:=
req
.
Options
[
archiveOptionName
]
.
(
bool
)
reader
,
err
:=
uarchive
.
F
ileArchive
(
file
,
p
.
String
(),
archive
,
cmplvl
)
reader
,
err
:=
f
ileArchive
(
file
,
p
.
String
(),
archive
,
cmplvl
)
if
err
!=
nil
{
return
err
}
...
...
@@ -247,3 +249,94 @@ func getCompressOptions(req *cmds.Request) (int, error) {
}
return
cmplvl
,
nil
}
// DefaultBufSize is the buffer size for gets. for now, 1MB, which is ~4 blocks.
// TODO: does this need to be configurable?
var
DefaultBufSize
=
1048576
type
identityWriteCloser
struct
{
w
io
.
Writer
}
func
(
i
*
identityWriteCloser
)
Write
(
p
[]
byte
)
(
int
,
error
)
{
return
i
.
w
.
Write
(
p
)
}
func
(
i
*
identityWriteCloser
)
Close
()
error
{
return
nil
}
func
fileArchive
(
f
files
.
Node
,
name
string
,
archive
bool
,
compression
int
)
(
io
.
Reader
,
error
)
{
cleaned
:=
path
.
Clean
(
name
)
_
,
filename
:=
path
.
Split
(
cleaned
)
// need to connect a writer to a reader
piper
,
pipew
:=
io
.
Pipe
()
checkErrAndClosePipe
:=
func
(
err
error
)
bool
{
if
err
!=
nil
{
pipew
.
CloseWithError
(
err
)
return
true
}
return
false
}
// use a buffered writer to parallelize task
bufw
:=
bufio
.
NewWriterSize
(
pipew
,
DefaultBufSize
)
// compression determines whether to use gzip compression.
maybeGzw
,
err
:=
newMaybeGzWriter
(
bufw
,
compression
)
if
checkErrAndClosePipe
(
err
)
{
return
nil
,
err
}
closeGzwAndPipe
:=
func
()
{
if
err
:=
maybeGzw
.
Close
();
checkErrAndClosePipe
(
err
)
{
return
}
if
err
:=
bufw
.
Flush
();
checkErrAndClosePipe
(
err
)
{
return
}
pipew
.
Close
()
// everything seems to be ok.
}
if
!
archive
&&
compression
!=
gzip
.
NoCompression
{
// the case when the node is a file
r
:=
files
.
ToFile
(
f
)
if
r
==
nil
{
return
nil
,
errors
.
New
(
"file is not regular"
)
}
go
func
()
{
if
_
,
err
:=
io
.
Copy
(
maybeGzw
,
r
);
checkErrAndClosePipe
(
err
)
{
return
}
closeGzwAndPipe
()
// everything seems to be ok
}()
}
else
{
// the case for 1. archive, and 2. not archived and not compressed, in which tar is used anyway as a transport format
// construct the tar writer
w
,
err
:=
files
.
NewTarWriter
(
maybeGzw
)
if
checkErrAndClosePipe
(
err
)
{
return
nil
,
err
}
go
func
()
{
// write all the nodes recursively
if
err
:=
w
.
WriteFile
(
f
,
filename
);
checkErrAndClosePipe
(
err
)
{
return
}
w
.
Close
()
// close tar writer
closeGzwAndPipe
()
// everything seems to be ok
}()
}
return
piper
,
nil
}
func
newMaybeGzWriter
(
w
io
.
Writer
,
compression
int
)
(
io
.
WriteCloser
,
error
)
{
if
compression
!=
gzip
.
NoCompression
{
return
gzip
.
NewWriterLevel
(
w
,
compression
)
}
return
&
identityWriteCloser
{
w
},
nil
}
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论