mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-25 20:35:50 +08:00 
			
		
		
		
	refactor(Makefile): allow overriding default go program (#2310)
This commit is contained in:
		
							
								
								
									
										49
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										49
									
								
								Makefile
									
									
									
									
									
								
							| @ -1,6 +1,7 @@ | |||||||
| DIST := dist | DIST := dist | ||||||
| IMPORT := code.gitea.io/gitea | IMPORT := code.gitea.io/gitea | ||||||
|  |  | ||||||
|  | GO ?= go | ||||||
| SED_INPLACE := sed -i | SED_INPLACE := sed -i | ||||||
|  |  | ||||||
| ifeq ($(OS), Windows_NT) | ifeq ($(OS), Windows_NT) | ||||||
| @ -24,7 +25,7 @@ EXTRA_GOFLAGS ?= | |||||||
|  |  | ||||||
| LDFLAGS := -X "main.Version=$(shell git describe --tags --always | sed 's/-/+/' | sed 's/^v//')" -X "main.Tags=$(TAGS)" | LDFLAGS := -X "main.Version=$(shell git describe --tags --always | sed 's/-/+/' | sed 's/^v//')" -X "main.Tags=$(TAGS)" | ||||||
|  |  | ||||||
| PACKAGES ?= $(filter-out code.gitea.io/gitea/integrations,$(shell go list ./... | grep -v /vendor/)) | PACKAGES ?= $(filter-out code.gitea.io/gitea/integrations,$(shell $(GO) list ./... | grep -v /vendor/)) | ||||||
| SOURCES ?= $(shell find . -name "*.go" -type f) | SOURCES ?= $(shell find . -name "*.go" -type f) | ||||||
|  |  | ||||||
| TAGS ?= | TAGS ?= | ||||||
| @ -52,11 +53,11 @@ all: build | |||||||
|  |  | ||||||
| .PHONY: clean | .PHONY: clean | ||||||
| clean: | clean: | ||||||
| 	go clean -i ./... | 	$(GO) clean -i ./... | ||||||
| 	rm -rf $(EXECUTABLE) $(DIST) $(BINDATA) | 	rm -rf $(EXECUTABLE) $(DIST) $(BINDATA) | ||||||
|  |  | ||||||
| required-gofmt-version: | required-gofmt-version: | ||||||
| 	@go version  | grep -q '\(1.7\|1.8\)' || { echo "We require go version 1.7 or 1.8 to format code" >&2 && exit 1; } | 	@$(GO) version  | grep -q '\(1.7\|1.8\)' || { echo "We require go version 1.7 or 1.8 to format code" >&2 && exit 1; } | ||||||
|  |  | ||||||
| .PHONY: fmt | .PHONY: fmt | ||||||
| fmt: required-gofmt-version | fmt: required-gofmt-version | ||||||
| @ -64,19 +65,19 @@ fmt: required-gofmt-version | |||||||
|  |  | ||||||
| .PHONY: vet | .PHONY: vet | ||||||
| vet: | vet: | ||||||
| 	go vet $(PACKAGES) | 	$(GO) vet $(PACKAGES) | ||||||
|  |  | ||||||
| .PHONY: generate | .PHONY: generate | ||||||
| generate: | generate: | ||||||
| 	@hash go-bindata > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash go-bindata > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/jteeuwen/go-bindata/...; \ | 		$(GO) get -u github.com/jteeuwen/go-bindata/...; \ | ||||||
| 	fi | 	fi | ||||||
| 	go generate $(PACKAGES) | 	$(GO) generate $(PACKAGES) | ||||||
|  |  | ||||||
| .PHONY: generate-swagger | .PHONY: generate-swagger | ||||||
| generate-swagger: | generate-swagger: | ||||||
| 	@hash swagger > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash swagger > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/go-swagger/go-swagger/cmd/swagger; \ | 		$(GO) get -u github.com/go-swagger/go-swagger/cmd/swagger; \ | ||||||
| 	fi | 	fi | ||||||
| 	swagger generate spec -o ./public/swagger.v1.json | 	swagger generate spec -o ./public/swagger.v1.json | ||||||
| 	$(SED_INPLACE) "s;\".ref\": \"#/definitions/GPGKey\";\"type\": \"object\";g" ./public/swagger.v1.json | 	$(SED_INPLACE) "s;\".ref\": \"#/definitions/GPGKey\";\"type\": \"object\";g" ./public/swagger.v1.json | ||||||
| @ -85,28 +86,28 @@ generate-swagger: | |||||||
| .PHONY: errcheck | .PHONY: errcheck | ||||||
| errcheck: | errcheck: | ||||||
| 	@hash errcheck > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash errcheck > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/kisielk/errcheck; \ | 		$(GO) get -u github.com/kisielk/errcheck; \ | ||||||
| 	fi | 	fi | ||||||
| 	errcheck $(PACKAGES) | 	errcheck $(PACKAGES) | ||||||
|  |  | ||||||
| .PHONY: lint | .PHONY: lint | ||||||
| lint: | lint: | ||||||
| 	@hash golint > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash golint > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/golang/lint/golint; \ | 		$(GO) get -u github.com/golang/lint/golint; \ | ||||||
| 	fi | 	fi | ||||||
| 	for PKG in $(PACKAGES); do golint -set_exit_status $$PKG || exit 1; done; | 	for PKG in $(PACKAGES); do golint -set_exit_status $$PKG || exit 1; done; | ||||||
|  |  | ||||||
| .PHONY: misspell-check | .PHONY: misspell-check | ||||||
| misspell-check: | misspell-check: | ||||||
| 	@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/client9/misspell/cmd/misspell; \ | 		$(GO) get -u github.com/client9/misspell/cmd/misspell; \ | ||||||
| 	fi | 	fi | ||||||
| 	misspell -error -i unknwon $(GOFILES) | 	misspell -error -i unknwon $(GOFILES) | ||||||
|  |  | ||||||
| .PHONY: misspell | .PHONY: misspell | ||||||
| misspell: | misspell: | ||||||
| 	@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash misspell > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/client9/misspell/cmd/misspell; \ | 		$(GO) get -u github.com/client9/misspell/cmd/misspell; \ | ||||||
| 	fi | 	fi | ||||||
| 	misspell -w -i unknwon $(GOFILES) | 	misspell -w -i unknwon $(GOFILES) | ||||||
|  |  | ||||||
| @ -122,12 +123,12 @@ fmt-check: required-gofmt-version | |||||||
|  |  | ||||||
| .PHONY: test | .PHONY: test | ||||||
| test: fmt-check | test: fmt-check | ||||||
| 	go test $(PACKAGES) | 	$(GO) test $(PACKAGES) | ||||||
|  |  | ||||||
| .PHONY: test-coverage | .PHONY: test-coverage | ||||||
| test-coverage: unit-test-coverage integration-test-coverage | test-coverage: unit-test-coverage integration-test-coverage | ||||||
| 	@hash gocovmerge > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash gocovmerge > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/wadey/gocovmerge; \ | 		$(GO) get -u github.com/wadey/gocovmerge; \ | ||||||
| 	fi | 	fi | ||||||
| 	for PKG in $(PACKAGES); do\ | 	for PKG in $(PACKAGES); do\ | ||||||
| 	  touch $$GOPATH/src/$$PKG/coverage.out;\ | 	  touch $$GOPATH/src/$$PKG/coverage.out;\ | ||||||
| @ -139,12 +140,12 @@ test-coverage: unit-test-coverage integration-test-coverage | |||||||
|  |  | ||||||
| .PHONY: unit-test-coverage | .PHONY: unit-test-coverage | ||||||
| unit-test-coverage: | unit-test-coverage: | ||||||
| 	for PKG in $(PACKAGES); do go test -cover -coverprofile $$GOPATH/src/$$PKG/coverage.out $$PKG || exit 1; done; | 	for PKG in $(PACKAGES); do $(GO) test -cover -coverprofile $$GOPATH/src/$$PKG/coverage.out $$PKG || exit 1; done; | ||||||
|  |  | ||||||
| .PHONY: test-vendor | .PHONY: test-vendor | ||||||
| test-vendor: | test-vendor: | ||||||
| 	@hash govendor > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash govendor > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/kardianos/govendor; \ | 		$(GO) get -u github.com/kardianos/govendor; \ | ||||||
| 	fi | 	fi | ||||||
| 	govendor list +unused | tee "$(TMPDIR)/wc-gitea-unused" | 	govendor list +unused | tee "$(TMPDIR)/wc-gitea-unused" | ||||||
| 	[ $$(cat "$(TMPDIR)/wc-gitea-unused" | wc -l) -eq 0 ] || echo "Warning: /!\\ Some vendor are not used /!\\" | 	[ $$(cat "$(TMPDIR)/wc-gitea-unused" | wc -l) -eq 0 ] || echo "Warning: /!\\ Some vendor are not used /!\\" | ||||||
| @ -185,26 +186,26 @@ integration-test-coverage: integrations.cover.test | |||||||
| 	GITEA_ROOT=${CURDIR} GITEA_CONF=integrations/mysql.ini ./integrations.cover.test -test.coverprofile=integration.coverage.out | 	GITEA_ROOT=${CURDIR} GITEA_CONF=integrations/mysql.ini ./integrations.cover.test -test.coverprofile=integration.coverage.out | ||||||
|  |  | ||||||
| integrations.test: $(SOURCES) | integrations.test: $(SOURCES) | ||||||
| 	go test -c code.gitea.io/gitea/integrations | 	$(GO) test -c code.gitea.io/gitea/integrations | ||||||
|  |  | ||||||
| integrations.sqlite.test: $(SOURCES) | integrations.sqlite.test: $(SOURCES) | ||||||
| 	go test -c code.gitea.io/gitea/integrations -o integrations.sqlite.test -tags 'sqlite' | 	$(GO) test -c code.gitea.io/gitea/integrations -o integrations.sqlite.test -tags 'sqlite' | ||||||
|  |  | ||||||
| integrations.cover.test: $(SOURCES) | integrations.cover.test: $(SOURCES) | ||||||
| 	go test -c code.gitea.io/gitea/integrations -coverpkg $(shell echo $(PACKAGES) | tr ' ' ',') -o integrations.cover.test | 	$(GO) test -c code.gitea.io/gitea/integrations -coverpkg $(shell echo $(PACKAGES) | tr ' ' ',') -o integrations.cover.test | ||||||
|  |  | ||||||
| .PHONY: check | .PHONY: check | ||||||
| check: test | check: test | ||||||
|  |  | ||||||
| .PHONY: install | .PHONY: install | ||||||
| install: $(wildcard *.go) | install: $(wildcard *.go) | ||||||
| 	go install -v -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' | 	$(GO) install -v -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' | ||||||
|  |  | ||||||
| .PHONY: build | .PHONY: build | ||||||
| build: $(EXECUTABLE) | build: $(EXECUTABLE) | ||||||
|  |  | ||||||
| $(EXECUTABLE): $(SOURCES) | $(EXECUTABLE): $(SOURCES) | ||||||
| 	go build $(GOFLAGS) $(EXTRA_GOFLAGS) -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -o $@ | 	$(GO) build $(GOFLAGS) $(EXTRA_GOFLAGS) -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -o $@ | ||||||
|  |  | ||||||
| .PHONY: docker | .PHONY: docker | ||||||
| docker: | docker: | ||||||
| @ -221,7 +222,7 @@ release-dirs: | |||||||
| .PHONY: release-windows | .PHONY: release-windows | ||||||
| release-windows: | release-windows: | ||||||
| 	@hash xgo > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash xgo > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/karalabe/xgo; \ | 		$(GO) get -u github.com/karalabe/xgo; \ | ||||||
| 	fi | 	fi | ||||||
| 	xgo -dest $(DIST)/binaries -tags 'netgo $(TAGS)' -ldflags '-linkmode external -extldflags "-static" $(LDFLAGS)' -targets 'windows/*' -out gitea-$(VERSION) . | 	xgo -dest $(DIST)/binaries -tags 'netgo $(TAGS)' -ldflags '-linkmode external -extldflags "-static" $(LDFLAGS)' -targets 'windows/*' -out gitea-$(VERSION) . | ||||||
| ifeq ($(CI),drone) | ifeq ($(CI),drone) | ||||||
| @ -231,7 +232,7 @@ endif | |||||||
| .PHONY: release-linux | .PHONY: release-linux | ||||||
| release-linux: | release-linux: | ||||||
| 	@hash xgo > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash xgo > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/karalabe/xgo; \ | 		$(GO) get -u github.com/karalabe/xgo; \ | ||||||
| 	fi | 	fi | ||||||
| 	xgo -dest $(DIST)/binaries -tags 'netgo $(TAGS)' -ldflags '-linkmode external -extldflags "-static" $(LDFLAGS)' -targets 'linux/*' -out gitea-$(VERSION) . | 	xgo -dest $(DIST)/binaries -tags 'netgo $(TAGS)' -ldflags '-linkmode external -extldflags "-static" $(LDFLAGS)' -targets 'linux/*' -out gitea-$(VERSION) . | ||||||
| ifeq ($(CI),drone) | ifeq ($(CI),drone) | ||||||
| @ -241,7 +242,7 @@ endif | |||||||
| .PHONY: release-darwin | .PHONY: release-darwin | ||||||
| release-darwin: | release-darwin: | ||||||
| 	@hash xgo > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | 	@hash xgo > /dev/null 2>&1; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/karalabe/xgo; \ | 		$(GO) get -u github.com/karalabe/xgo; \ | ||||||
| 	fi | 	fi | ||||||
| 	xgo -dest $(DIST)/binaries -tags 'netgo $(TAGS)' -ldflags '$(LDFLAGS)' -targets 'darwin/*' -out gitea-$(VERSION) . | 	xgo -dest $(DIST)/binaries -tags 'netgo $(TAGS)' -ldflags '$(LDFLAGS)' -targets 'darwin/*' -out gitea-$(VERSION) . | ||||||
| ifeq ($(CI),drone) | ifeq ($(CI),drone) | ||||||
| @ -278,7 +279,7 @@ stylesheets: public/css/index.css | |||||||
| .IGNORE: public/css/index.css | .IGNORE: public/css/index.css | ||||||
| public/css/index.css: $(STYLESHEETS) | public/css/index.css: $(STYLESHEETS) | ||||||
| 	@which lessc > /dev/null; if [ $$? -ne 0 ]; then \ | 	@which lessc > /dev/null; if [ $$? -ne 0 ]; then \ | ||||||
| 		go get -u github.com/kib357/less-go/lessc; \ | 		$(GO) get -u github.com/kib357/less-go/lessc; \ | ||||||
| 	fi | 	fi | ||||||
| 	lessc -i $< -o $@ | 	lessc -i $< -o $@ | ||||||
|  |  | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 Bo-Yi Wu
					Bo-Yi Wu