Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
G
go-ipfs
概览
概览
详情
活动
周期分析
版本库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
问题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程表
图表
维基
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
jihao
go-ipfs
Commits
6926812b
Unverified
提交
6926812b
authored
11月 02, 2018
作者:
Steven Allen
提交者:
GitHub
11月 02, 2018
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #5666 from overbool/refactor/commands/object
commands/object: use new cmds
上级
f337acd8
e1d1f68f
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
90 行增加
和
117 行删除
+90
-117
diff.go
core/commands/object/diff.go
+30
-40
object.go
core/commands/object/object.go
+0
-0
patch.go
core/commands/object/patch.go
+57
-74
root.go
core/commands/root.go
+3
-3
没有找到文件。
core/commands/object/diff.go
浏览文件 @
6926812b
package
objectcmd
import
(
"bytes"
"fmt"
"io"
cmds
"github.com/ipfs/go-ipfs/commands"
e
"github.com/ipfs/go-ipfs/core/commands/e"
cmdenv
"github.com/ipfs/go-ipfs/core/commands/cmdenv"
coreiface
"github.com/ipfs/go-ipfs/core/coreapi/interface"
"github.com/ipfs/go-ipfs/dagutils"
cmds
"gx/ipfs/QmSXUokcP4TJpFfqozT69AVAYRtzXVMUjzQVkYX41R9Svs/go-ipfs-cmds"
cmdkit
"gx/ipfs/Qmde5VP1qUkyQXKCfmEUA7bP64V2HAptbJ7phuPp7jXWwg/go-ipfs-cmdkit"
)
const
(
verboseOptionName
=
"verbose"
)
type
Changes
struct
{
Changes
[]
*
dagutils
.
Change
}
...
...
@@ -49,34 +52,30 @@ Example:
cmdkit
.
StringArg
(
"obj_b"
,
true
,
false
,
"Object to diff."
),
},
Options
:
[]
cmdkit
.
Option
{
cmdkit
.
BoolOption
(
"verbose"
,
"v"
,
"Print extra information."
),
cmdkit
.
BoolOption
(
verboseOptionName
,
"v"
,
"Print extra information."
),
},
Run
:
func
(
req
cmds
.
Request
,
res
cmds
.
Response
)
{
api
,
err
:=
req
.
InvocContext
()
.
GetApi
(
)
Run
:
func
(
req
*
cmds
.
Request
,
res
cmds
.
ResponseEmitter
,
env
cmds
.
Environment
)
error
{
api
,
err
:=
cmdenv
.
GetApi
(
env
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
a
:=
req
.
Arguments
()
[
0
]
b
:=
req
.
Arguments
()
[
1
]
a
:=
req
.
Arguments
[
0
]
b
:=
req
.
Arguments
[
1
]
pa
,
err
:=
coreiface
.
ParsePath
(
a
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
pb
,
err
:=
coreiface
.
ParsePath
(
b
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
changes
,
err
:=
api
.
Object
()
.
Diff
(
req
.
Context
()
,
pa
,
pb
)
changes
,
err
:=
api
.
Object
()
.
Diff
(
req
.
Context
,
pa
,
pb
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
out
:=
make
([]
*
dagutils
.
Change
,
len
(
changes
))
...
...
@@ -95,45 +94,36 @@ Example:
}
}
re
s
.
SetOutput
(
&
Changes
{
out
})
re
turn
cmds
.
EmitOnce
(
res
,
&
Changes
{
out
})
},
Type
:
Changes
{},
Marshalers
:
cmds
.
MarshalerMap
{
cmds
.
Text
:
func
(
res
cmds
.
Response
)
(
io
.
Reader
,
error
)
{
v
,
err
:=
unwrapOutput
(
res
.
Output
())
if
err
!=
nil
{
return
nil
,
err
}
Encoders
:
cmds
.
EncoderMap
{
cmds
.
Text
:
cmds
.
MakeTypedEncoder
(
func
(
req
*
cmds
.
Request
,
w
io
.
Writer
,
out
*
Changes
)
error
{
verbose
,
_
:=
req
.
Options
[
verboseOptionName
]
.
(
bool
)
verbose
,
_
,
_
:=
res
.
Request
()
.
Option
(
"v"
)
.
Bool
()
changes
,
ok
:=
v
.
(
*
Changes
)
if
!
ok
{
return
nil
,
e
.
TypeErr
(
changes
,
v
)
}
buf
:=
new
(
bytes
.
Buffer
)
for
_
,
change
:=
range
changes
.
Changes
{
for
_
,
change
:=
range
out
.
Changes
{
if
verbose
{
switch
change
.
Type
{
case
dagutils
.
Add
:
fmt
.
Fprintf
(
buf
,
"Added new link %q pointing to %s.
\n
"
,
change
.
Path
,
change
.
After
)
fmt
.
Fprintf
(
w
,
"Added new link %q pointing to %s.
\n
"
,
change
.
Path
,
change
.
After
)
case
dagutils
.
Mod
:
fmt
.
Fprintf
(
buf
,
"Changed %q from %s to %s.
\n
"
,
change
.
Path
,
change
.
Before
,
change
.
After
)
fmt
.
Fprintf
(
w
,
"Changed %q from %s to %s.
\n
"
,
change
.
Path
,
change
.
Before
,
change
.
After
)
case
dagutils
.
Remove
:
fmt
.
Fprintf
(
buf
,
"Removed link %q (was %s).
\n
"
,
change
.
Path
,
change
.
Before
)
fmt
.
Fprintf
(
w
,
"Removed link %q (was %s).
\n
"
,
change
.
Path
,
change
.
Before
)
}
}
else
{
switch
change
.
Type
{
case
dagutils
.
Add
:
fmt
.
Fprintf
(
buf
,
"+ %s %q
\n
"
,
change
.
After
,
change
.
Path
)
fmt
.
Fprintf
(
w
,
"+ %s %q
\n
"
,
change
.
After
,
change
.
Path
)
case
dagutils
.
Mod
:
fmt
.
Fprintf
(
buf
,
"~ %s %s %q
\n
"
,
change
.
Before
,
change
.
After
,
change
.
Path
)
fmt
.
Fprintf
(
w
,
"~ %s %s %q
\n
"
,
change
.
Before
,
change
.
After
,
change
.
Path
)
case
dagutils
.
Remove
:
fmt
.
Fprintf
(
buf
,
"- %s %q
\n
"
,
change
.
Before
,
change
.
Path
)
fmt
.
Fprintf
(
w
,
"- %s %q
\n
"
,
change
.
Before
,
change
.
Path
)
}
}
}
return
buf
,
nil
},
return
nil
}),
},
}
core/commands/object/object.go
浏览文件 @
6926812b
差异被折叠。
点击展开。
core/commands/object/patch.go
浏览文件 @
6926812b
...
...
@@ -3,12 +3,8 @@ package objectcmd
import
(
"fmt"
"io"
"strings"
oldcmds
"github.com/ipfs/go-ipfs/commands"
lgc
"github.com/ipfs/go-ipfs/commands/legacy"
cmdenv
"github.com/ipfs/go-ipfs/core/commands/cmdenv"
e
"github.com/ipfs/go-ipfs/core/commands/e"
coreiface
"github.com/ipfs/go-ipfs/core/coreapi/interface"
"github.com/ipfs/go-ipfs/core/coreapi/interface/options"
...
...
@@ -28,26 +24,12 @@ result. This is the Merkle-DAG version of modifying an object.
Arguments
:
[]
cmdkit
.
Argument
{},
Subcommands
:
map
[
string
]
*
cmds
.
Command
{
"append-data"
:
patchAppendDataCmd
,
"add-link"
:
lgc
.
NewCommand
(
patchAddLinkCmd
)
,
"rm-link"
:
lgc
.
NewCommand
(
patchRmLinkCmd
)
,
"set-data"
:
lgc
.
NewCommand
(
patchSetDataCmd
)
,
"add-link"
:
patchAddLinkCmd
,
"rm-link"
:
patchRmLinkCmd
,
"set-data"
:
patchSetDataCmd
,
},
}
func
objectMarshaler
(
res
oldcmds
.
Response
)
(
io
.
Reader
,
error
)
{
v
,
err
:=
unwrapOutput
(
res
.
Output
())
if
err
!=
nil
{
return
nil
,
err
}
o
,
ok
:=
v
.
(
*
Object
)
if
!
ok
{
return
nil
,
e
.
TypeErr
(
o
,
v
)
}
return
strings
.
NewReader
(
o
.
Hash
+
"
\n
"
),
nil
}
var
patchAppendDataCmd
=
&
cmds
.
Command
{
Helptext
:
cmdkit
.
HelpText
{
Tagline
:
"Append data to the data segment of a dag node."
,
...
...
@@ -67,7 +49,7 @@ the limit will not be respected by the network.
cmdkit
.
StringArg
(
"root"
,
true
,
false
,
"The hash of the node to modify."
),
cmdkit
.
FileArg
(
"data"
,
true
,
false
,
"Data to append."
)
.
EnableStdin
(),
},
Run
:
func
(
req
*
cmds
.
Request
,
re
cmds
.
ResponseEmitter
,
env
cmds
.
Environment
)
error
{
Run
:
func
(
req
*
cmds
.
Request
,
re
s
cmds
.
ResponseEmitter
,
env
cmds
.
Environment
)
error
{
api
,
err
:=
cmdenv
.
GetApi
(
env
)
if
err
!=
nil
{
return
err
...
...
@@ -88,7 +70,7 @@ the limit will not be respected by the network.
return
err
}
return
cmds
.
EmitOnce
(
re
,
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
return
cmds
.
EmitOnce
(
re
s
,
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
},
Type
:
&
Object
{},
Encoders
:
cmds
.
EncoderMap
{
...
...
@@ -99,7 +81,7 @@ the limit will not be respected by the network.
},
}
var
patchSetDataCmd
=
&
old
cmds
.
Command
{
var
patchSetDataCmd
=
&
cmds
.
Command
{
Helptext
:
cmdkit
.
HelpText
{
Tagline
:
"Set the data field of an IPFS object."
,
ShortDescription
:
`
...
...
@@ -114,36 +96,39 @@ Example:
cmdkit
.
StringArg
(
"root"
,
true
,
false
,
"The hash of the node to modify."
),
cmdkit
.
FileArg
(
"data"
,
true
,
false
,
"The data to set the object to."
)
.
EnableStdin
(),
},
Run
:
func
(
req
oldcmds
.
Request
,
res
oldcmds
.
Response
)
{
api
,
err
:=
req
.
InvocContext
()
.
GetApi
()
Run
:
func
(
req
*
cmds
.
Request
,
res
cmds
.
ResponseEmitter
,
env
cmds
.
Environment
)
error
{
api
,
err
:=
cmdenv
.
GetApi
(
env
)
if
err
!=
nil
{
return
err
}
root
,
err
:=
coreiface
.
ParsePath
(
req
.
StringArguments
()
[
0
])
root
,
err
:=
coreiface
.
ParsePath
(
req
.
Arguments
[
0
])
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
data
,
err
:=
req
.
Files
()
.
NextFile
()
data
,
err
:=
req
.
Files
.
NextFile
()
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
p
,
err
:=
api
.
Object
()
.
SetData
(
req
.
Context
()
,
root
,
data
)
p
,
err
:=
api
.
Object
()
.
SetData
(
req
.
Context
,
root
,
data
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
re
s
.
SetOutput
(
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
re
turn
cmds
.
EmitOnce
(
res
,
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
},
Type
:
Object
{},
Marshalers
:
oldcmds
.
MarshalerMap
{
oldcmds
.
Text
:
objectMarshaler
,
Encoders
:
cmds
.
EncoderMap
{
cmds
.
Text
:
cmds
.
MakeTypedEncoder
(
func
(
req
*
cmds
.
Request
,
w
io
.
Writer
,
out
*
Object
)
error
{
fmt
.
Fprintln
(
w
,
out
.
Hash
)
return
nil
}),
},
}
var
patchRmLinkCmd
=
&
old
cmds
.
Command
{
var
patchRmLinkCmd
=
&
cmds
.
Command
{
Helptext
:
cmdkit
.
HelpText
{
Tagline
:
"Remove a link from a given object."
,
ShortDescription
:
`
...
...
@@ -154,35 +139,35 @@ Remove a Merkle-link from the given object and return the hash of the result.
cmdkit
.
StringArg
(
"root"
,
true
,
false
,
"The hash of the node to modify."
),
cmdkit
.
StringArg
(
"name"
,
true
,
false
,
"Name of the link to remove."
),
},
Run
:
func
(
req
oldcmds
.
Request
,
res
oldcmds
.
Response
)
{
api
,
err
:=
req
.
InvocContext
()
.
GetApi
(
)
Run
:
func
(
req
*
cmds
.
Request
,
res
cmds
.
ResponseEmitter
,
env
cmds
.
Environment
)
error
{
api
,
err
:=
cmdenv
.
GetApi
(
env
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
root
,
err
:=
coreiface
.
ParsePath
(
req
.
Arguments
()
[
0
])
root
,
err
:=
coreiface
.
ParsePath
(
req
.
Arguments
[
0
])
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
name
:=
req
.
Arguments
()
[
1
]
p
,
err
:=
api
.
Object
()
.
RmLink
(
req
.
Context
()
,
root
,
name
)
name
:=
req
.
Arguments
[
1
]
p
,
err
:=
api
.
Object
()
.
RmLink
(
req
.
Context
,
root
,
name
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
re
s
.
SetOutput
(
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
re
turn
cmds
.
EmitOnce
(
res
,
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
},
Type
:
Object
{},
Marshalers
:
oldcmds
.
MarshalerMap
{
oldcmds
.
Text
:
objectMarshaler
,
Encoders
:
cmds
.
EncoderMap
{
cmds
.
Text
:
cmds
.
MakeTypedEncoder
(
func
(
req
*
cmds
.
Request
,
w
io
.
Writer
,
out
*
Object
)
error
{
fmt
.
Fprintln
(
w
,
out
.
Hash
)
return
nil
}),
},
}
var
patchAddLinkCmd
=
&
old
cmds
.
Command
{
var
patchAddLinkCmd
=
&
cmds
.
Command
{
Helptext
:
cmdkit
.
HelpText
{
Tagline
:
"Add a link to a given object."
,
ShortDescription
:
`
...
...
@@ -206,44 +191,42 @@ to a file containing 'bar', and returns the hash of the new object.
Options
:
[]
cmdkit
.
Option
{
cmdkit
.
BoolOption
(
"create"
,
"p"
,
"Create intermediary nodes."
),
},
Run
:
func
(
req
oldcmds
.
Request
,
res
oldcmds
.
Response
)
{
api
,
err
:=
req
.
InvocContext
()
.
GetApi
(
)
Run
:
func
(
req
*
cmds
.
Request
,
res
cmds
.
ResponseEmitter
,
env
cmds
.
Environment
)
error
{
api
,
err
:=
cmdenv
.
GetApi
(
env
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
root
,
err
:=
coreiface
.
ParsePath
(
req
.
Arguments
()
[
0
])
root
,
err
:=
coreiface
.
ParsePath
(
req
.
Arguments
[
0
])
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
name
:=
req
.
Arguments
()
[
1
]
name
:=
req
.
Arguments
[
1
]
child
,
err
:=
coreiface
.
ParsePath
(
req
.
Arguments
()
[
2
])
child
,
err
:=
coreiface
.
ParsePath
(
req
.
Arguments
[
2
])
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
create
,
_
,
err
:=
req
.
Option
(
"create"
)
.
Bool
(
)
create
,
_
:=
req
.
Options
[
"create"
]
.
(
bool
)
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
p
,
err
:=
api
.
Object
()
.
AddLink
(
req
.
Context
()
,
root
,
name
,
child
,
p
,
err
:=
api
.
Object
()
.
AddLink
(
req
.
Context
,
root
,
name
,
child
,
options
.
Object
.
Create
(
create
))
if
err
!=
nil
{
res
.
SetError
(
err
,
cmdkit
.
ErrNormal
)
return
return
err
}
re
s
.
SetOutput
(
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
re
turn
cmds
.
EmitOnce
(
res
,
&
Object
{
Hash
:
p
.
Cid
()
.
String
()})
},
Type
:
Object
{},
Marshalers
:
oldcmds
.
MarshalerMap
{
oldcmds
.
Text
:
objectMarshaler
,
Encoders
:
cmds
.
EncoderMap
{
cmds
.
Text
:
cmds
.
MakeTypedEncoder
(
func
(
req
*
cmds
.
Request
,
w
io
.
Writer
,
out
*
Object
)
error
{
fmt
.
Fprintln
(
w
,
out
.
Hash
)
return
nil
}),
},
}
core/commands/root.go
浏览文件 @
6926812b
...
...
@@ -174,14 +174,14 @@ var rootROSubcommands = map[string]*cmds.Command{
"resolve"
:
name
.
IpnsCmd
,
},
},
"object"
:
lgc
.
NewCommand
(
&
oldcmds
.
Command
{
Subcommands
:
map
[
string
]
*
old
cmds
.
Command
{
"object"
:
{
Subcommands
:
map
[
string
]
*
cmds
.
Command
{
"data"
:
ocmd
.
ObjectDataCmd
,
"links"
:
ocmd
.
ObjectLinksCmd
,
"get"
:
ocmd
.
ObjectGetCmd
,
"stat"
:
ocmd
.
ObjectStatCmd
,
},
}
)
,
},
"dag"
:
{
Subcommands
:
map
[
string
]
*
cmds
.
Command
{
"get"
:
dag
.
DagGetCmd
,
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论