Makefile help target
make help
operator-sdk로 생성된 프로젝트를 보다가 Makefile에 help target이 있었는데, 간편하게 도움말을 작성할 수 있어서 복사해왔습니다.
사용법은 ##@ <category>
아래에 해당 카테고리에 맞는 타겟을 <target>: [dependency] ## <description>
형식으로 나열하면 됩니다. <description>
에 백틱(`
)으로 감싸진 부분은 초록색으로 출력됩니다. 설명이 없는 경우 무시됩니다.
##@ General
# 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-]+:.*?##/ { \
target = $$1; \
help_msg = $$2; \
gsub(/`[^`]+`/, "\033[32m&\033[0m", help_msg); \
gsub(/`/, "", help_msg); \
printf " \033[36m%-15s\033[0m %s\n", target, help_msg \
} \
/^##@/ { \
printf "\n\033[1m%s\033[0m\n", substr($$0, 5) \
} \
' $(MAKEFILE_LIST)
##@ Development
.PHONY: echo
echo: ## Echo value. Usage: `make echo value=<value>`
@echo "value: $(value)"
$ make help
Usage:
make <target>
General
help Display this help.
Development
echo Echo value. Usage: make echo value=<value>