X-Git-Url: https://gerrit.fd.io/r/gitweb?a=blobdiff_plain;f=Makefile;h=6fc229bbad10147098c1274c93e55052b41284e9;hb=278cd54dc581167fcd206d725c04ba69b3109c25;hp=0ae100ba58f9a0ffeaa5254067eb134023464219;hpb=c94a962279858fb13eaacc689f47aed358373e44;p=govpp.git diff --git a/Makefile b/Makefile index 0ae100b..6fc229b 100644 --- a/Makefile +++ b/Makefile @@ -1,23 +1,28 @@ SHELL := /usr/bin/env bash -o pipefail -VERSION ?= $(shell git describe --always --tags --dirty) -COMMIT ?= $(shell git rev-parse HEAD) -BUILD_STAMP ?= $(shell git log -1 --format='%ct') +PROJECT := govpp + +VERSION ?= $(shell git describe --always --tags --dirty) +COMMIT ?= $(shell git rev-parse HEAD) +BUILD_STAMP ?= $(shell git log -1 --format='%ct') BUILD_BRANCH ?= $(shell git rev-parse --abbrev-ref HEAD) BUILD_HOST ?= $(shell hostname) BUILD_USER ?= $(shell id -un) -GO ?= go - GOVPP_PKG := git.fd.io/govpp.git + +VPP_API_DIR ?= ${VPP_DIR}/build-root/install-vpp-native/vpp/share/vpp/api + +VERSION_PKG := $(GOVPP_PKG)/version LDFLAGS = \ - -X ${GOVPP_PKG}/version.version=$(VERSION) \ - -X ${GOVPP_PKG}/version.commitHash=$(COMMIT) \ - -X ${GOVPP_PKG}/version.buildStamp=$(BUILD_STAMP) \ - -X ${GOVPP_PKG}/version.buildBranch=$(BUILD_BRANCH) \ - -X ${GOVPP_PKG}/version.buildUser=$(BUILD_USER) \ - -X ${GOVPP_PKG}/version.buildHost=$(BUILD_HOST) + -X $(VERSION_PKG).version=$(VERSION) \ + -X $(VERSION_PKG).commitHash=$(COMMIT) \ + -X $(VERSION_PKG).buildStamp=$(BUILD_STAMP) \ + -X $(VERSION_PKG).buildBranch=$(BUILD_BRANCH) \ + -X $(VERSION_PKG).buildUser=$(BUILD_USER) \ + -X $(VERSION_PKG).buildHost=$(BUILD_HOST) + ifeq ($(NOSTRIP),) LDFLAGS += -w -s endif @@ -35,8 +40,6 @@ ifeq ($(V),1) GO_BUILD_ARGS += -v endif -VPP_VERSION ?= $(shell dpkg-query -f '\${Version}' -W vpp) - # VPP Docker image to use for api generation (gen-binapi-docker) VPP_IMG ?= ligato/vpp-base:latest # Local VPP directory used for binary api generation (gen-binapi-from-code) @@ -46,70 +49,75 @@ BINAPI_DIR ?= ./binapi # Binapi generator path BINAPI_GENERATOR = ./bin/binapi-generator -bin: - mkdir -p bin +.DEFAULT_GOAL = help -build: ## Build all - @echo "# building ${VERSION}" - $(GO) build ${GO_BUILD_ARGS} ./... +check-%: + @: $(if $(value $*),,$(error $* is undefined)) -cmd-binapi-generator: bin ## Build commands - $(GO) build ${GO_BUILD_ARGS} -o bin ./cmd/binapi-generator +bin: + @mkdir -p bin + +.PHONY: build +build: cmd examples ## Build all +.PHONY: cmd cmd: bin ## Build commands - $(GO) build ${GO_BUILD_ARGS} -o bin ./cmd/... + @go build ${GO_BUILD_ARGS} -o bin ./cmd/... -examples: bin ## Build examples - $(GO) build ${GO_BUILD_ARGS} -o bin ./examples/... +.PHONY: binapi-generator +binapi-generator: bin ## Build only the binapi generator + @go build ${GO_BUILD_ARGS} -o bin ./cmd/binapi-generator/ -clean: ## Clean all - @echo "# cleaning" - $(GO) clean -v ./... +.PHONY: examples +examples: bin ## Build examples + @go build ${GO_BUILD_ARGS} -o bin ./examples/... +.PHONY: test test: ## Run unit tests - $(GO) version @echo "# running tests" - $(GO) test -tags="${GO_BUILD_TAGS}" ./... + go test -tags="${GO_BUILD_TAGS}" ./... -integration: ## Run integration tests +.PHONY: test-integration +test-integration: ## Run integration tests @echo "# running integration tests" - $(GO) test -tags="integration ${GO_BUILD_TAGS}" ./test/integration + go test -tags="integration ${GO_BUILD_TAGS}" ./test/integration +.PHONY: lint lint: ## Run code linter @echo "# running linter" @golint ./... +.PHONY: install install: install-generator install-proxy ## Install all +.PHONY: install-generator install-generator: ## Install binapi-generator @echo "# installing binapi-generator ${VERSION}" - @$(GO) install ${GO_BUILD_ARGS} ./cmd/binapi-generator + @go install ${GO_BUILD_ARGS} ./cmd/binapi-generator +.PHONY: install-proxy install-proxy: ## Install vpp-proxy @echo "# installing vpp-proxy ${VERSION}" - $(GO) install ${GO_BUILD_ARGS} ./cmd/vpp-proxy + @go install ${GO_BUILD_ARGS} ./cmd/vpp-proxy -generate: ## Generate all - @echo "# generating code" - $(GO) generate -x ./... +.PHONY: generate +generate: generate-binapi ## Generate all +.PHONY: generate-binapi generate-binapi: install-generator ## Generate binapi code - @echo "# generating binapi VPP $(VPP_VERSION)" - $(GO) generate -x "$(BINAPI_DIR)" - -gen-binapi-from-code: cmd-binapi-generator - $(eval VPP_API_DIR := ${VPP_DIR}/build-root/install-vpp-native/vpp/share/vpp/api/) - @echo "Generating vpp API.json and go bindings" - @echo "Vpp Directory ${VPP_DIR}" - @echo "Vpp API files ${VPP_API_DIR}" - @echo "Go bindings ${BINAPI_DIR}" - @cd ${VPP_DIR} && make json-api-files - @${BINAPI_GENERATOR} \ - --input-dir=${VPP_API_DIR} \ - --output-dir=${BINAPI_DIR} \ - --gen rpc,rest \ - --no-source-path-info - + @echo "# generating binapi" + @go generate -x "$(BINAPI_DIR)" + +.PHONY: gen-binapi-local +gen-binapi-local: binapi-generator check-VPP_DIR ## Generate binapi code (using locally cloned VPP) + @make -C ${VPP_DIR} json-api-files + @find $(BINAPI_DIR)/*/*.ba.go -delete + @find $(BINAPI_DIR)/* -type d -delete + @./bin/binapi-generator -input-dir=$(VPP_API_DIR) -output-dir=$(BINAPI_DIR) -gen=rpc + @./bin/binapi-generator -input-dir=$(VPP_API_DIR) -input-file=$(VPP_API_DIR)/core/vpe.api.json -output-dir=$(BINAPI_DIR) -gen=http + @sed -i 's@$(VPP_API_DIR)@/usr/share/vpp/api@g' $(BINAPI_DIR)/*/*.ba.go + +.PHONY: gen-binapi-docker gen-binapi-docker: install-generator ## Generate binapi code (using Docker) @echo "# generating binapi in docker image ${VPP_IMG}" $(eval cmds := $(shell go generate -n $(BINAPI_DIR) 2>&1 | tr "\n" ";")) @@ -122,19 +130,8 @@ gen-binapi-docker: install-generator ## Generate binapi code (using Docker) "${VPP_IMG}" \ sh -ec "cd $(BINAPI_DIR) && $(cmds)" -extras: - @make -C extras - +.PHONY: help help: - @echo "List of make targets:" @grep -E '^[a-zA-Z_-]+:.*?## .*$$' $(MAKEFILE_LIST) | awk 'BEGIN {FS = ":.*?## "}; {printf "\033[36m%-30s\033[0m %s\n", $$1, $$2}' -.DEFAULT_GOAL = help - -.PHONY: help \ - build cmd examples clean \ - lint test integration \ - install install-generator install-proxy \ - generate generate-binapi gen-binapi-docker \ - extras