mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 16:40:24 +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