aboutsummaryrefslogtreecommitdiffstats
path: root/Makefile
diff options
context:
space:
mode:
authorThomas Boerger <thomas@webhippie.de>2016-11-04 13:58:55 +0100
committerThomas Boerger <thomas@webhippie.de>2016-11-04 23:45:47 +0100
commitec054ba582d72c2c0cdd07404dc512da7d142031 (patch)
tree90880e2a5a103267f5005abf957d04eeafb94fba /Makefile
parent7a870080d670a7dd622f32710a708d682ae4ac08 (diff)
downloadgitea-ec054ba582d72c2c0cdd07404dc512da7d142031.tar.gz
gitea-ec054ba582d72c2c0cdd07404dc512da7d142031.zip
Totally refactored the makefile and adjusted travis config
Diffstat (limited to 'Makefile')
-rw-r--r--Makefile160
1 files changed, 109 insertions, 51 deletions
diff --git a/Makefile b/Makefile
index 8e04204caa..f56c4c5181 100644
--- a/Makefile
+++ b/Makefile
@@ -1,74 +1,132 @@
-LDFLAGS += -X "github.com/go-gitea/gitea/modules/setting.BuildTime=$(shell date -u '+%Y-%m-%d %I:%M:%S %Z')"
-LDFLAGS += -X "github.com/go-gitea/gitea/modules/setting.BuildGitHash=$(shell git rev-parse HEAD)"
+DIST := dist
+BIN := bin
-DATA_FILES := $(shell find conf | sed 's/ /\\ /g')
-LESS_FILES := $(wildcard public/less/gogs.less public/less/_*.less)
-GENERATED := modules/bindata/bindata.go public/css/index.css
+EXECUTABLE := gitea
+IMPORT := github.com/go-gitea/gitea
-TAGS = ""
-BUILD_FLAGS = "-v"
+SHA := $(shell git rev-parse --short HEAD)
+DATE := $(shell date -u '+%Y-%m-%d %I:%M:%S %Z')
-RELEASE_ROOT = "release"
-RELEASE_GOGS = "release/gogs"
-NOW = $(shell date -u '+%Y%m%d%I%M%S')
-GOVET = go tool vet -composites=false -methods=false -structtags=false
+BINDATA := $(shell find conf | sed 's/ /\\ /g')
+STYLESHEETS := $(wildcard public/less/index.less public/less/_*.less)
+JAVASCRIPTS :=
-.PHONY: build pack release bindata clean
+LDFLAGS += -X "github.com/go-gitea/gitea/modules/setting.BuildTime=$(DATE)"
+LDFLAGS += -X "github.com/go-gitea/gitea/modules/setting.BuildGitHash=$(SHA)"
-.IGNORE: public/css/index.css
+TARGETS ?= linux/*,darwin/*,windows/*
+PACKAGES ?= $(shell go list ./... | grep -v /vendor/)
-all: build
+TAGS ?=
-check: test
+ifneq ($(TRAVIS_TAG),)
+ VERSION ?= $(TRAVIS_TAG)
+else
+ ifneq ($(TRAVIS_BRANCH),)
+ VERSION ?= $(TRAVIS_BRANCH)
+ else
+ VERSION ?= master
+ endif
+endif
-dist: release
+.PHONY: all
+all: clean test build
-govet:
- $(GOVET) main.go
- $(GOVET) models modules routers
+.PHONY: clean
+clean:
+ go clean -i ./...
+ rm -rf $(BIN) $(DIST)
+
+.PHONY: deps
+deps:
+ @which go-bindata > /dev/null; if [ $$? -ne 0 ]; then \
+ go get -u github.com/jteeuwen/go-bindata/...; \
+ fi
+
+.PHONY: fmt
+fmt:
+ go fmt $(PACKAGES)
+
+.PHONY: vet
+vet:
+ go vet $(PACKAGES)
+
+.PHONY: lint
+lint:
+ @which golint > /dev/null; if [ $$? -ne 0 ]; then \
+ go get -u github.com/golang/lint/golint; \
+ fi
+ for PKG in $(PACKAGES); do golint -set_exit_status $$PKG || exit 1; done;
+
+.PHONY: test
+test:
+ for PKG in $(PACKAGES); do go test -cover -coverprofile $$GOPATH/src/$$PKG/coverage.out $$PKG || exit 1; done;
-build: $(GENERATED)
- go install $(BUILD_FLAGS) -ldflags '$(LDFLAGS)' -tags '$(TAGS)'
- cp '$(GOPATH)/bin/gogs' .
+.PHONY: install
+install: $(BIN)/$(EXECUTABLE)
+ cp $< $(GOPATH)/bin/
-build-dev: $(GENERATED) govet
- go install $(BUILD_FLAGS) -tags '$(TAGS)'
- cp '$(GOPATH)/bin/gogs' .
+.PHONY: build
+build: $(BIN)/$(EXECUTABLE)
-build-dev-race: $(GENERATED) govet
- go install $(BUILD_FLAGS) -race -tags '$(TAGS)'
- cp '$(GOPATH)/bin/gogs' .
+$(BIN)/$(EXECUTABLE): $(wildcard *.go)
+ go build -v -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -o $@
-pack:
- rm -rf $(RELEASE_GOGS)
- mkdir -p $(RELEASE_GOGS)
- cp -r gogs LICENSE README.md README_ZH.md templates public scripts $(RELEASE_GOGS)
- rm -rf $(RELEASE_GOGS)/public/config.codekit $(RELEASE_GOGS)/public/less
- cd $(RELEASE_ROOT) && zip -r gogs.$(NOW).zip "gogs"
+.PHONY: release
+release: release-build release-copy release-check
-release: build pack
+.PHONY: release-build
+release-build:
+ @which xgo > /dev/null; if [ $$? -ne 0 ]; then \
+ go get -u github.com/karalabe/xgo; \
+ fi
+ xgo -dest $(BIN) -tags '$(TAGS)' -ldflags '-s -w $(LDFLAGS)' -targets '$(TARGETS)' -out $(EXECUTABLE)-$(VERSION) $(IMPORT)
-bindata: modules/bindata/bindata.go
+.PHONY: release-copy
+release-copy:
+ mkdir -p $(DIST)/release
+ $(foreach file,$(wildcard $(BIN)/$(EXECUTABLE)-*),cp $(file) $(DIST)/release/$(notdir $(file));)
-modules/bindata/bindata.go: $(DATA_FILES)
- go-bindata -o=$@ -ignore="\\.DS_Store|README.md|TRANSLATORS" -pkg=bindata conf/...
+.PHONY: release-check
+release-check:
+ cd $(DIST)/release; $(foreach file,$(wildcard $(DIST)/release/$(EXECUTABLE)-*),sha256sum $(notdir $(file)) > $(notdir $(file)).sha256;)
-less: public/css/index.css
+.PHONY: latest
+latest: release-build latest-copy latest-check
-public/css/index.css: $(LESS_FILES)
- lessc $< $@
+.PHONY: latest-copy
+latest-copy:
+ mkdir -p $(DIST)/latest
+ $(foreach file,$(wildcard $(BIN)/$(EXECUTABLE)-*),cp $(file) $(DIST)/latest/$(subst $(EXECUTABLE)-$(VERSION),$(EXECUTABLE)-latest,$(notdir $(file)));)
-clean:
- go clean -i ./...
+.PHONY: latest-check
+latest-check:
+ cd $(DIST)/latest; $(foreach file,$(wildcard $(DIST)/latest/$(EXECUTABLE)-*),sha256sum $(notdir $(file)) > $(notdir $(file)).sha256;)
-clean-mac: clean
- find . -name ".DS_Store" -print0 | xargs -0 rm
+.PHONY: publish
+publish: release latest
-test:
- go test -cover -race ./...
+.PHONY: bindata
+bindata: modules/bindata/bindata.go
+
+.IGNORE: modules/bindata/bindata.go
+modules/bindata/bindata.go: $(BINDATA)
+ go-bindata -o=$@ -ignore="\\.go|README.md|TRANSLATORS" -pkg=bindata conf/...
+ go fmt $@
+
+.PHONY: javascripts
+javascripts: public/js/index.js
-fixme:
- grep -rnw "FIXME" routers models modules
+.IGNORE: public/js/index.js
+public/js/index.js: $(JAVASCRIPTS)
+ cat $< >| $@
+
+.PHONY: stylesheets
+stylesheets: public/css/index.css
+
+.IGNORE: public/css/index.css
+public/css/index.css: $(STYLESHEETS)
+ lessc $< $@
-todo:
- grep -rnw "TODO" routers models modules
+.PHONY: generate
+generate: bindata javascripts stylesheets