-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
159 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,159 @@ | ||
#!/usr/bin/make -f | ||
|
||
BRANCH := $(shell git rev-parse --abbrev-ref HEAD) | ||
COMMIT := $(shell git log -1 --format='%H') | ||
GO_VERSION := "1.21" | ||
|
||
# don't override user values | ||
ifeq (,$(VERSION)) | ||
VERSION := $(shell git describe --tags) | ||
# if VERSION is empty, then populate it with branch's name and raw commit hash | ||
ifeq (,$(VERSION)) | ||
VERSION := $(BRANCH)-$(COMMIT) | ||
endif | ||
endif | ||
|
||
PACKAGES_SIMTEST=$(shell go list ./... | grep '/simulation') | ||
LEDGER_ENABLED ?= true | ||
SDK_PACK := $(shell go list -m github.com/cosmos/cosmos-sdk | sed 's/ /\@/g') | ||
TM_VERSION := $(shell go list -m github.com/cometbft/cometbft | sed 's:.* ::') # grab everything after the space in "github.com/cometbft/cometbft v0.37.0" | ||
BUILDDIR ?= $(CURDIR)/build | ||
DOCKER := $(shell which docker) | ||
DOCKER_BUF := $(DOCKER) run --rm -v $(CURDIR):/workspace --workdir /workspace bufbuild/buf:1.7.0 | ||
|
||
export GO111MODULE = on | ||
|
||
# process build tags | ||
|
||
build_tags = netgo | ||
ifeq ($(LEDGER_ENABLED),true) | ||
ifeq ($(OS),Windows_NT) | ||
GCCEXE = $(shell where gcc.exe 2> NUL) | ||
ifeq ($(GCCEXE),) | ||
$(error gcc.exe not installed for ledger support, please install or set LEDGER_ENABLED=false) | ||
else | ||
build_tags += ledger | ||
endif | ||
else | ||
UNAME_S = $(shell uname -s) | ||
ifeq ($(UNAME_S),OpenBSD) | ||
$(warning OpenBSD detected, disabling ledger support (https://github.com/cosmos/cosmos-sdk/issues/1988)) | ||
else | ||
GCC = $(shell command -v gcc 2> /dev/null) | ||
ifeq ($(GCC),) | ||
$(error gcc not installed for ledger support, please install or set LEDGER_ENABLED=false) | ||
else | ||
build_tags += ledger | ||
endif | ||
endif | ||
endif | ||
endif | ||
|
||
ifeq (cleveldb,$(findstring cleveldb,$(medasdigital_BUILD_OPTIONS))) | ||
build_tags += gcc cleveldb | ||
endif | ||
build_tags += $(BUILD_TAGS) | ||
build_tags := $(strip $(build_tags)) | ||
|
||
whitespace := | ||
whitespace += $(whitespace) | ||
comma := , | ||
build_tags_comma_sep := $(subst $(whitespace),$(comma),$(build_tags)) | ||
|
||
# process linker flags | ||
|
||
ldflags = -X github.com/cosmos/cosmos-sdk/version.Name=medasdigital \ | ||
-X github.com/cosmos/cosmos-sdk/version.AppName=medasdigitald \ | ||
-X github.com/cosmos/cosmos-sdk/version.Version=$(VERSION) \ | ||
-X github.com/cosmos/cosmos-sdk/version.Commit=$(COMMIT) \ | ||
-X "github.com/cosmos/cosmos-sdk/version.BuildTags=$(build_tags_comma_sep)" \ | ||
-X github.com/tendermint/tendermint/version.TMCoreSemVer=$(TM_VERSION) | ||
|
||
ifeq (cleveldb,$(findstring cleveldb,$(medasdigital_BUILD_OPTIONS))) | ||
ldflags += -X github.com/cosmos/cosmos-sdk/types.DBBackend=cleveldb | ||
endif | ||
ifeq (,$(findstring nostrip,$(medasdigital_BUILD_OPTIONS))) | ||
ldflags += -w -s | ||
endif | ||
ifeq ($(LINK_STATICALLY),true) | ||
ldflags += -linkmode=external -extldflags "-Wl,-z,muldefs -static" | ||
endif | ||
ldflags += $(LDFLAGS) | ||
ldflags := $(strip $(ldflags)) | ||
|
||
BUILD_FLAGS := -tags "$(build_tags)" -ldflags '$(ldflags)' | ||
# check for nostrip option | ||
ifeq (,$(findstring nostrip,$(medasdigital_BUILD_OPTIONS))) | ||
BUILD_FLAGS += -trimpath | ||
endif | ||
|
||
#$(info $$BUILD_FLAGS is [$(BUILD_FLAGS)]) | ||
|
||
|
||
all: check-go-version install | ||
|
||
install: check-go-version go.sum | ||
go install -mod=readonly $(BUILD_FLAGS) ./cmd/medasdigitald | ||
|
||
build: check-go-version | ||
go build $(BUILD_FLAGS) -x -o bin/medasdigitald ./cmd/medasdigitald | ||
|
||
BUILD_TARGETS := build install | ||
|
||
build-reproducible-all: build-reproducible-amd64 build-reproducible-arm64 | ||
|
||
build-reproducible-amd64: | ||
ARCH=x86_64 PLATFORM=linux/amd64 $(MAKE) build-reproducible-generic | ||
|
||
build-reproducible-arm64: | ||
ARCH=aarch64 PLATFORM=linux/arm64 $(MAKE) build-reproducible-generic | ||
|
||
build-reproducible-generic: go.sum | ||
$(DOCKER) rm $(subst /,-,latest-build-$(PLATFORM)) || true | ||
DOCKER_BUILDKIT=1 $(DOCKER) build -t latest-build-$(PLATFORM) \ | ||
--build-arg ARCH=$(ARCH) \ | ||
--build-arg GO_VERSION=$(GO_VERSION) \ | ||
--build-arg PLATFORM=$(PLATFORM) \ | ||
--build-arg VERSION="$(VERSION)" \ | ||
-f Dockerfile . | ||
$(DOCKER) create -ti --name $(subst /,-,latest-build-$(PLATFORM)) latest-build-$(PLATFORM) medasdigitald | ||
$(DOCKER) cp -a $(subst /,-,latest-build-$(PLATFORM)):/usr/local/bin/medasdigitald medasdigitald_$(subst /,_,$(PLATFORM)) | ||
sha256sum medasdigitald_$(subst /,_,$(PLATFORM)) >> ./medasdigitald_sha256.txt | ||
|
||
# Add check to make sure we are using the proper Go version before proceeding with anything | ||
check-go-version: | ||
@if ! go version | grep -q "go$(GO_VERSION)"; then \ | ||
echo "\033[0;31mERROR:\033[0m Go version $(GO_VERSION) is required for compiling medasdigitald. It looks like you are using" "$(shell go version) \nThere are potential consensus-breaking changes that can occur when running binaries compiled with different versions of Go. Please download Go version $(GO_VERSION) and retry. Thank you!"; \ | ||
exit 1; \ | ||
fi | ||
|
||
|
||
############################################################################### | ||
### Protobuf ### | ||
############################################################################### | ||
|
||
containerProtoVer=0.13.0 | ||
containerProtoImage=ghcr.io/cosmos/proto-builder:$(containerProtoVer) | ||
|
||
proto-gen: | ||
@echo "Generating Protobuf files" | ||
@$(DOCKER) run --rm -v $(CURDIR):/workspace --workdir /workspace $(containerProtoImage) \ | ||
sh ./scripts/protocgen.sh; | ||
|
||
docs: | ||
@echo | ||
@echo "=========== Generate Message ============" | ||
@echo | ||
./scripts/protoc-swagger-gen.sh | ||
|
||
statik -src=client/docs/static -dest=client/docs -f -m | ||
@if [ -n "$(git status --porcelain)" ]; then \ | ||
echo "\033[91mSwagger docs are out of sync!!!\033[0m";\ | ||
exit 1;\ | ||
else \ | ||
echo "\033[92mSwagger docs are in sync\033[0m";\ | ||
fi | ||
@echo | ||
@echo "=========== Generate Complete ============" | ||
@echo | ||
.PHONY: docs |