2017-04-25 12:57:06 -04:00
#
2017-05-09 12:38:23 -04:00
# github.com/docker/cli
2017-04-25 12:57:06 -04:00
#
2021-10-11 10:54:09 -04:00
# Sets the name of the company that produced the windows binary.
2022-03-27 04:09:50 -04:00
PACKAGER_NAME ?=
2021-10-11 10:54:09 -04:00
2017-05-14 13:24:10 -04:00
all : binary
2017-06-23 00:52:34 -04:00
_ := $( shell ./scripts/warn-outside-container $( MAKECMDGOALS) )
2022-04-06 13:10:53 -04:00
.PHONY : dev
dev : ## start a build container in interactive mode for in-container development
@if [ -n " ${ DISABLE_WARN_OUTSIDE_CONTAINER } " ] ; then \
echo "you are already in the dev container" ; \
else \
$( MAKE) -f docker.Makefile dev; \
fi
.PHONY : shell
shell : dev ## alias for dev
2017-05-09 17:29:14 -04:00
.PHONY : clean
2017-07-19 11:44:39 -04:00
clean : ## remove build artifacts
2022-02-25 11:05:35 -05:00
rm -rf ./build/* man/man[ 1-9] docs/yaml
2017-04-25 12:57:06 -04:00
2017-08-30 18:06:22 -04:00
.PHONY : test
test : test -unit ## run tests
2021-12-07 08:50:16 -05:00
.PHONY : test -unit
test-unit : ## run unit tests, to change the output format use: GOTESTSUM_FORMAT=(dots|short|standard-quiet|short-verbose|standard-verbose) make test-unit
gotestsum -- $$ { TESTDIRS:-$( shell go list ./... | grep -vE '/vendor/|/e2e/' ) } $( TESTFLAGS)
2017-05-18 04:48:24 -04:00
.PHONY : test -coverage
2017-07-19 11:44:39 -04:00
test-coverage : ## run test coverage
2021-12-07 08:50:16 -05:00
mkdir -p $( CURDIR) /build/coverage
gotestsum -- $( shell go list ./... | grep -vE '/vendor/|/e2e/' ) -coverprofile= $( CURDIR) /build/coverage/coverage.txt
2017-05-18 04:48:24 -04:00
2021-09-26 12:01:38 -04:00
.PHONY : lint
lint : ## run all the lint tools
golangci-lint run
.PHONY : shellcheck
shellcheck : ## run shellcheck validation
find scripts/ contrib/completion/bash -type f | grep -v scripts/winresources | grep -v '.*.ps1' | xargs shellcheck
2018-12-10 08:17:14 -05:00
.PHONY : fmt
2022-04-06 12:34:51 -04:00
fmt : ## run gofmt
2018-12-10 08:17:14 -05:00
go list -f { { .Dir} } ./... | xargs gofmt -w -s -d
2017-05-11 18:52:17 -04:00
.PHONY : binary
2021-09-26 12:01:38 -04:00
binary : ## build executable for Linux
./scripts/build/binary
.PHONY : dynbinary
dynbinary : ## build dynamically linked binary
GO_LINKMODE = dynamic ./scripts/build/binary
2017-05-11 18:52:17 -04:00
2018-12-10 10:30:19 -05:00
.PHONY : plugins
plugins : ## build example CLI plugins
./scripts/build/plugins
2021-12-16 15:15:53 -05:00
.PHONY : vendor
vendor : ## update vendor with go modules
2018-02-02 13:56:00 -05:00
rm -rf vendor
2021-12-16 15:15:53 -05:00
./scripts/vendor update
.PHONY : validate -vendor
validate-vendor : ## validate vendor
./scripts/vendor validate
.PHONY : mod -outdated
mod-outdated : ## check outdated dependencies
./scripts/vendor outdated
2017-05-09 15:37:22 -04:00
2018-01-02 09:47:31 -05:00
.PHONY : authors
authors : ## generate AUTHORS file from git history
scripts/docs/generate-authors.sh
2017-05-10 21:24:32 -04:00
.PHONY : manpages
2017-07-19 11:44:39 -04:00
manpages : ## generate man pages from go source and markdown
2017-06-06 00:59:50 -04:00
scripts/docs/generate-man.sh
2017-05-10 21:24:32 -04:00
.PHONY : yamldocs
2017-07-19 11:44:39 -04:00
yamldocs : ## generate documentation YAML files consumed by docs repo
2017-05-10 21:24:32 -04:00
scripts/docs/generate-yaml.sh
2017-07-19 11:44:39 -04:00
.PHONY : help
help : ## print this help
2019-01-10 07:30:03 -05:00
@awk 'BEGIN {FS = ":.*?## "} /^[a-zA-Z0-9_-]+:.*?## / {gsub("\\\\n",sprintf("\n%22c",""), $$2);printf "\033[36m%-20s\033[0m %s\n", $$1, $$2}' $( MAKEFILE_LIST)