From c7c30e25f22f75b9ed896cb17189b201c2f8f4c6 Mon Sep 17 00:00:00 2001 From: Matthias Loibl Date: Sun, 25 Dec 2016 16:33:09 +0100 Subject: [PATCH] Create a Makefile, delete do script --- Makefile | 58 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ do | 25 ------------------------ 2 files changed, 58 insertions(+), 25 deletions(-) create mode 100644 Makefile delete mode 100755 do diff --git a/Makefile b/Makefile new file mode 100644 index 0000000..d032459 --- /dev/null +++ b/Makefile @@ -0,0 +1,58 @@ +DIST := dist +EXECUTABLE := ana +IMPORT := github.com/dannyvankooten/ana + +LDFLAGS += -extldflags "-static" -X "main.Version=$(shell git describe --tags --always | sed 's/-/+/' | sed 's/^v//')" + +TARGETS ?= linux/*,darwin/*,windows/* +PACKAGES ?= $(shell go list ./... | grep -v /vendor/) +SOURCES ?= $(shell find . -name "*.go" -type f) +ENV ?= $(shell export $(cat .env | xargs)) + +.PHONY: all +all: build + +.PHONY: clean +clean: + go clean -i ./... + rm -rf $(EXECUTABLE) $(DIST) $(BINDATA) + +.PHONY: fmt +fmt: + go fmt $(PACKAGES) + +.PHONY: vet +vet: + go vet $(PACKAGES) + +.PHONY: errcheck +errcheck: + @which errcheck > /dev/null; if [ $$? -ne 0 ]; then \ + go get -u github.com/kisielk/errcheck; \ + fi + errcheck $(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; + +.PHONY: install +install: $(wildcard *.go) + CGO_ENABLED=0 go install -v -ldflags '-w $(LDFLAGS)' + +.PHONY: build +build: $(EXECUTABLE) + +$(EXECUTABLE): $(SOURCES) + CGO_ENABLED=0 go build -v -ldflags '-w $(LDFLAGS)' -o $@ + +.PHONY: docker +docker: + docker build -t metalmatze/ana:latest . diff --git a/do b/do deleted file mode 100755 index 372737f..0000000 --- a/do +++ /dev/null @@ -1,25 +0,0 @@ -#!/bin/bash - -install_dependencies() { - go get "github.com/gorilla/sessions" - go get "golang.org/x/crypto/bcrypt" - go get "github.com/mssola/user_agent" - go get "github.com/gorilla/mux" - go get "github.com/Pallinder/go-randomdata" - go get "github.com/gorilla/handlers" - go get "github.com/go-sql-driver/mysql" - go get -u "github.com/mattes/migrate" - go get "github.com/joho/godotenv" -} - -bin() { - go build -} - -database_migrate() { - export $(cat .env | xargs) - $GOPATH/bin/migrate -url mysql://$ANA_DATABASE_USER:$ANA_DATABASE_PASSWORD@$ANA_DATABSE_HOST/$ANA_DATABASE_NAME -path ./db/migrations $1 $2 $3 -} - -# call first argument -$1 $2 $3 $4