提交 0f909cb2 作者: Juan Benet

Merge pull request #1853 from CaioAlonso/show-commit-hash

Adds the option to see the current git commit with `ipfs version --commit`
...@@ -5,6 +5,8 @@ else ...@@ -5,6 +5,8 @@ else
go_test=go test go_test=go test
endif endif
commit = `git rev-parse --short HEAD`
ldflags = "-X "github.com/ipfs/go-ipfs/repo/config".CurrentCommit=$(commit)"
all: all:
# no-op. try: # no-op. try:
...@@ -24,7 +26,7 @@ install: ...@@ -24,7 +26,7 @@ install:
cd cmd/ipfs && go install cd cmd/ipfs && go install
build: build:
cd cmd/ipfs && go build -i cd cmd/ipfs && go build -i -ldflags=$(ldflags)
nofuse: nofuse:
cd cmd/ipfs && go install -tags nofuse cd cmd/ipfs && go install -tags nofuse
......
all: install all: install
commit = `git rev-parse --short HEAD`
ldflags = "-X "github.com/ipfs/go-ipfs/repo/config".CurrentCommit=$(commit)"
build: build:
go build go build -ldflags=$(ldflags)
install: build install: build
go install go install
...@@ -11,6 +11,7 @@ import ( ...@@ -11,6 +11,7 @@ import (
type VersionOutput struct { type VersionOutput struct {
Version string Version string
Commit string
} }
var VersionCmd = &cmds.Command{ var VersionCmd = &cmds.Command{
...@@ -21,24 +22,36 @@ var VersionCmd = &cmds.Command{ ...@@ -21,24 +22,36 @@ var VersionCmd = &cmds.Command{
Options: []cmds.Option{ Options: []cmds.Option{
cmds.BoolOption("number", "n", "Only show the version number"), cmds.BoolOption("number", "n", "Only show the version number"),
cmds.BoolOption("commit", "Show the commit hash"),
}, },
Run: func(req cmds.Request, res cmds.Response) { Run: func(req cmds.Request, res cmds.Response) {
res.SetOutput(&VersionOutput{ res.SetOutput(&VersionOutput{
Version: config.CurrentVersionNumber, Version: config.CurrentVersionNumber,
Commit: config.CurrentCommit,
}) })
}, },
Marshalers: cmds.MarshalerMap{ Marshalers: cmds.MarshalerMap{
cmds.Text: func(res cmds.Response) (io.Reader, error) { cmds.Text: func(res cmds.Response) (io.Reader, error) {
v := res.Output().(*VersionOutput) v := res.Output().(*VersionOutput)
commit, found, err := res.Request().Option("commit").Bool()
commitTxt := ""
if err != nil {
return nil, err
}
if found && commit {
commitTxt = "-" + v.Commit
}
number, found, err := res.Request().Option("number").Bool() number, found, err := res.Request().Option("number").Bool()
if err != nil { if err != nil {
return nil, err return nil, err
} }
if found && number { if found && number {
return strings.NewReader(fmt.Sprintln(v.Version)), nil return strings.NewReader(fmt.Sprintln(v.Version + commitTxt)), nil
} }
return strings.NewReader(fmt.Sprintf("ipfs version %s\n", v.Version)), nil
return strings.NewReader(fmt.Sprintf("ipfs version %s%s\n", v.Version, commitTxt)), nil
}, },
}, },
Type: VersionOutput{}, Type: VersionOutput{},
......
...@@ -9,6 +9,8 @@ import ( ...@@ -9,6 +9,8 @@ import (
// CurrentVersionNumber is the current application's version literal // CurrentVersionNumber is the current application's version literal
const CurrentVersionNumber = "0.3.8-dev" const CurrentVersionNumber = "0.3.8-dev"
// CurrentCommit is the current git commit, this is set as a ldflag in the Makefile
var CurrentCommit string
// Version regulates checking if the most recent version is run // Version regulates checking if the most recent version is run
type Version struct { type Version struct {
......
Markdown 格式
0%
您添加了 0 到此讨论。请谨慎行事。
请先完成此评论的编辑!
注册 或者 后发表评论