X-Git-Url: http://git.osdn.net/view?a=blobdiff_plain;f=Makefile;h=da282ce89627c3848bc090d92e646b4f2d49a070;hb=74e62ea1c588d390cc1df9541cfc29477a884051;hp=5dff4f36dbce66b4934dcd92d9113d5f306d9a4b;hpb=981d02c8a9a50c1eadb8def477f73c319a43a3bc;p=bytom%2Fbytom.git diff --git a/Makefile b/Makefile index 5dff4f36..da282ce8 100644 --- a/Makefile +++ b/Makefile @@ -1,80 +1,119 @@ -GOTOOLS = \ - github.com/mitchellh/gox \ - github.com/Masterminds/glide -PACKAGES=$(shell go list ./... | grep -v '/vendor/') -BUILD_TAGS?=bytom -TMHOME = $${TMHOME:-$$HOME/.bytom} - -all: install test - -install: get_vendor_deps copy - @go install --ldflags '-extldflags "-static"' \ - --ldflags "-X github.com/Bytom/blockchain/version.GitCommit=`git rev-parse HEAD`" ./node/ - -build: copy - go build \ - --ldflags "-X github.com/Bytom/blockchain/version.GitCommit=`git rev-parse HEAD`" -o build/node ./node/ - -copy: - cp -r vendor/github.com/golang/crypto vendor/golang.org/x/crypto - cp -r vendor/github.com/golang/net vendor/golang.org/x/net - cp -r vendor/github.com/golang/text vendor/golang.org/x/text - cp -r vendor/github.com/golang/tools vendor/golang.org/x/tools - cp -r vendor/github.com/golang/time vendor/golang.org/x/time - -# dist builds binaries for all platforms and packages them for distribution -dist: - @BUILD_TAGS='$(BUILD_TAGS)' sh -c "'$(CURDIR)/scripts/dist.sh'" +ifndef GOOS +UNAME_S := $(shell uname -s) +ifeq ($(UNAME_S),Darwin) + GOOS := darwin +else ifeq ($(UNAME_S),Linux) + GOOS := linux +else +$(error "$$GOOS is not defined. If you are using Windows, try to re-make using 'GOOS=windows make ...' ") +endif +endif + +PACKAGES := $(shell go list ./... | grep -v '/vendor/' | grep -v '/crypto/ed25519/chainkd') +BUILD_FLAGS := -ldflags "-X github.com/bytom/version.GitCommit=`git rev-parse HEAD`" + +MINER_BINARY32 := miner-$(GOOS)_386 +MINER_BINARY64 := miner-$(GOOS)_amd64 + +BYTOMD_BINARY32 := bytomd-$(GOOS)_386 +BYTOMD_BINARY64 := bytomd-$(GOOS)_amd64 + +BYTOMCLI_BINARY32 := bytomcli-$(GOOS)_386 +BYTOMCLI_BINARY64 := bytomcli-$(GOOS)_amd64 + +VERSION := $(shell awk -F= '/Version =/ {print $$2}' version/version.go | tr -d "\" ") + +MINER_RELEASE32 := miner-$(VERSION)-$(GOOS)_386 +MINER_RELEASE64 := miner-$(VERSION)-$(GOOS)_amd64 + +BYTOMD_RELEASE32 := bytomd-$(VERSION)-$(GOOS)_386 +BYTOMD_RELEASE64 := bytomd-$(VERSION)-$(GOOS)_amd64 + +BYTOMCLI_RELEASE32 := bytomcli-$(VERSION)-$(GOOS)_386 +BYTOMCLI_RELEASE64 := bytomcli-$(VERSION)-$(GOOS)_amd64 + +BYTOM_RELEASE32 := bytom-$(VERSION)-$(GOOS)_386 +BYTOM_RELEASE64 := bytom-$(VERSION)-$(GOOS)_amd64 + +all: test target release-all + +bytomd: + @echo "Building bytomd to cmd/bytomd/bytomd" + @go build $(BUILD_FLAGS) -o cmd/bytomd/bytomd cmd/bytomd/main.go + +bytomcli: + @echo "Building bytomcli to cmd/bytomcli/bytomcli" + @go build $(BUILD_FLAGS) -o cmd/bytomcli/bytomcli cmd/bytomcli/main.go + +target: + mkdir -p $@ + +binary: target/$(BYTOMD_BINARY32) target/$(BYTOMD_BINARY64) target/$(BYTOMCLI_BINARY32) target/$(BYTOMCLI_BINARY64) target/$(MINER_BINARY32) target/$(MINER_BINARY64) + +ifeq ($(GOOS),windows) +release: binary + cd target && cp -f $(MINER_BINARY32) $(MINER_BINARY32).exe + cd target && cp -f $(BYTOMD_BINARY32) $(BYTOMD_BINARY32).exe + cd target && cp -f $(BYTOMCLI_BINARY32) $(BYTOMCLI_BINARY32).exe + cd target && md5sum $(MINER_BINARY32).exe $(BYTOMD_BINARY32).exe $(BYTOMCLI_BINARY32).exe >$(BYTOM_RELEASE32).md5 + cd target && zip $(BYTOM_RELEASE32).zip $(MINER_BINARY32).exe $(BYTOMD_BINARY32).exe $(BYTOMCLI_BINARY32).exe $(BYTOM_RELEASE32).md5 + cd target && rm -f $(MINER_BINARY32) $(BYTOMD_BINARY32) $(BYTOMCLI_BINARY32) $(MINER_BINARY32).exe $(BYTOMD_BINARY32).exe $(BYTOMCLI_BINARY32).exe $(BYTOM_RELEASE32).md5 + cd target && cp -f $(MINER_BINARY64) $(MINER_BINARY64).exe + cd target && cp -f $(BYTOMD_BINARY64) $(BYTOMD_BINARY64).exe + cd target && cp -f $(BYTOMCLI_BINARY64) $(BYTOMCLI_BINARY64).exe + cd target && md5sum $(MINER_BINARY64).exe $(BYTOMD_BINARY64).exe $(BYTOMCLI_BINARY64).exe >$(BYTOM_RELEASE64).md5 + cd target && zip $(BYTOM_RELEASE64).zip $(MINER_BINARY64).exe $(BYTOMD_BINARY64).exe $(BYTOMCLI_BINARY64).exe $(BYTOM_RELEASE64).md5 + cd target && rm -f $(MINER_BINARY64) $(BYTOMD_BINARY64) $(BYTOMCLI_BINARY64) $(MINER_BINARY64).exe $(BYTOMD_BINARY64).exe $(BYTOMCLI_BINARY64).exe $(BYTOM_RELEASE64).md5 +else +release: binary + cd target && md5sum $(MINER_BINARY32) $(BYTOMD_BINARY32) $(BYTOMCLI_BINARY32) >$(BYTOM_RELEASE32).md5 + cd target && tar -czf $(BYTOM_RELEASE32).tgz $(MINER_BINARY32) $(BYTOMD_BINARY32) $(BYTOMCLI_BINARY32) $(BYTOM_RELEASE32).md5 + cd target && rm -f $(MINER_BINARY32) $(BYTOMD_BINARY32) $(BYTOMCLI_BINARY32) $(BYTOM_RELEASE32).md5 + cd target && md5sum $(MINER_BINARY64) $(BYTOMD_BINARY64) $(BYTOMCLI_BINARY64) >$(BYTOM_RELEASE64).md5 + cd target && tar -czf $(BYTOM_RELEASE64).tgz $(MINER_BINARY64) $(BYTOMD_BINARY64) $(BYTOMCLI_BINARY64) $(BYTOM_RELEASE64).md5 + cd target && rm -f $(MINER_BINARY64) $(BYTOMD_BINARY64) $(BYTOMCLI_BINARY64) $(BYTOM_RELEASE64).md5 +endif + +release-all: clean + GOOS=darwin make release + GOOS=linux make release + GOOS=windows make release + +clean: + @echo "Cleaning binaries built" + @rm -rf cmd/bytomd/bytomd + @rm -rf cmd/bytomcli/bytomcli + @rm -rf cmd/miner/miner + @rm -rf target + +target/$(BYTOMD_BINARY32): + CGO_ENABLED=0 GOARCH=386 go build $(BUILD_FLAGS) -o $@ cmd/bytomd/main.go + +target/$(BYTOMD_BINARY64): + CGO_ENABLED=0 GOARCH=amd64 go build $(BUILD_FLAGS) -o $@ cmd/bytomd/main.go + +target/$(BYTOMCLI_BINARY32): + CGO_ENABLED=0 GOARCH=386 go build $(BUILD_FLAGS) -o $@ cmd/bytomcli/main.go + +target/$(BYTOMCLI_BINARY64): + CGO_ENABLED=0 GOARCH=amd64 go build $(BUILD_FLAGS) -o $@ cmd/bytomcli/main.go + +target/$(MINER_BINARY32): + CGO_ENABLED=0 GOARCH=386 go build $(BUILD_FLAGS) -o $@ cmd/miner/main.go + +target/$(MINER_BINARY64): + CGO_ENABLED=0 GOARCH=amd64 go build $(BUILD_FLAGS) -o $@ cmd/miner/main.go test: - @echo "--> Running go test" - @go test $(PACKAGES) + @echo "====> Running go test" + @go test -tags "network" $(PACKAGES) -test_race: - @echo "--> Running go test --race" - @go test -v -race $(PACKAGES) +benchmark: + go test -bench $(PACKAGES) -test_integrations: - @bash ./test/test.sh +functional-tests: + @go test -v -timeout=5m -tags=functional ./test -test100: - @for i in {1..100}; do make test; done +ci: test functional-tests -draw_deps: - # requires brew install graphviz or apt-get install graphviz - go get github.com/RobotsAndPencils/goviz - @goviz -i github.com/tendermint/tendermint/cmd/tendermint -d 3 | dot -Tpng -o dependency-graph.png - -list_deps: - @go list -f '{{join .Deps "\n"}}' ./... | \ - grep -v /vendor/ | sort | uniq | \ - xargs go list -f '{{if not .Standard}}{{.ImportPath}}{{end}}' - -get_deps: - @echo "--> Running go get" - @go get -v -d $(PACKAGES) - @go list -f '{{join .TestImports "\n"}}' ./... | \ - grep -v /vendor/ | sort | uniq | \ - xargs go get -v -d - -get_vendor_deps: ensure_tools - @rm -rf vendor/ - @echo "--> Running glide install" - @glide install - -update_deps: tools - @echo "--> Updating dependencies" - @go get -d -u ./... - -revision: - -echo `git rev-parse --verify HEAD` > $(TMHOME)/revision - -echo `git rev-parse --verify HEAD` >> $(TMHOME)/revision_history - -tools: - go get -u -v $(GOTOOLS) - -ensure_tools: - go get $(GOTOOLS) - - -.PHONY: install build build_race dist test test_race test_integrations test100 draw_deps list_deps get_deps get_vendor_deps update_deps revision tools +.PHONY: all target release-all clean test benchmark