2023-11-02 19:25:48 +00:00
|
|
|
SHELL := /bin/bash
|
|
|
|
|
|
|
|
.PHONY: noop
|
2023-11-30 17:41:30 +00:00
|
|
|
noop: help
|
2023-11-02 19:25:48 +00:00
|
|
|
|
|
|
|
##@ Build
|
|
|
|
|
|
|
|
.PHONY: tidy
|
|
|
|
tidy: ## Run go mod tidy.
|
|
|
|
go mod tidy
|
|
|
|
|
|
|
|
##@ Checks
|
|
|
|
|
|
|
|
.PHONY: format
|
|
|
|
format: ## Format the go files.
|
|
|
|
@for f in $$(find . -name '*.go' -print); do \
|
|
|
|
gofmt -s -w $$f ; \
|
|
|
|
done
|
|
|
|
|
|
|
|
.PHONY: lint
|
|
|
|
lint: ## Run the full linting rules.
|
|
|
|
golangci-lint run -v
|
|
|
|
|
|
|
|
.PHONY: vet
|
|
|
|
vet: ## Run go vet.
|
|
|
|
go vet ./...
|
|
|
|
|
|
|
|
##@ Help
|
|
|
|
|
|
|
|
# The help target prints out all targets with their descriptions organized
|
|
|
|
# beneath their categories. The categories are represented by '##@' and the
|
|
|
|
# target descriptions by '##'. The awk commands is responsible for reading the
|
|
|
|
# entire set of makefiles included in this invocation, looking for lines of the
|
|
|
|
# file as xyz: ## something, and then pretty-format the target and help. Then,
|
|
|
|
# if there's a line with ##@ something, that gets pretty-printed as a category.
|
|
|
|
# More info on the usage of ANSI control characters for terminal formatting:
|
|
|
|
# https://en.wikipedia.org/wiki/ANSI_escape_code#SGR_parameters
|
|
|
|
# More info on the awk command:
|
|
|
|
# http://linuxcommand.org/lc3_adv_awk.php
|
|
|
|
.PHONY: help
|
|
|
|
help: ## Display this help.
|
|
|
|
@awk 'BEGIN {FS = ":.*##"; printf "\nUsage:\n make \033[36m<target>\033[0m\n"} /^[a-zA-Z_0-9-]+:.*?##/ { printf " \033[36m%-15s\033[0m %s\n", $$1, $$2 } /^##@/ { printf "\n\033[1m%s\033[0m\n", substr($$0, 5) } ' $(MAKEFILE_LIST)
|