]> git.lizzy.rs Git - micro.git/blobdiff - Makefile
Merge branch 'issue_1008' of https://github.com/sum01/micro into sum01-issue_1008
[micro.git] / Makefile
index 7a80b75b53d1f3637efe1176f99438e11c647807..76da995305ca10f0d3c0ef636e968eedb5d49af1 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -1,28 +1,51 @@
 .PHONY: runtime
 
-VERSION = $(shell git describe --tags --abbrev=0)
+VERSION = $(shell GOOS=$(shell go env GOHOSTOS) GOARCH=$(shell go env GOHOSTARCH) \
+       go run tools/build-version.go)
 HASH = $(shell git rev-parse --short HEAD)
+DATE = $(shell GOOS=$(shell go env GOHOSTOS) GOARCH=$(shell go env GOHOSTARCH) \
+       go run tools/build-date.go)
+ADDITIONAL_GO_LINKER_FLAGS = $(shell GOOS=$(shell go env GOHOSTOS) \
+       GOARCH=$(shell go env GOHOSTARCH))
+GOBIN ?= $(shell go env GOPATH)/bin
+GOVARS = -X github.com/zyedidia/micro/internal/util.Version=$(VERSION) -X github.com/zyedidia/micro/internal/util.CommitHash=$(HASH) -X 'github.com/zyedidia/micro/internal/util.CompileDate=$(DATE)' -X github.com/zyedidia/micro/internal/util.Debug=OFF
 
-build: tcell
-       go build -ldflags "-X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(shell date -u '+%B %d, %Y')'" -o micro ./cmd/micro
+# Builds micro after checking dependencies but without updating the runtime
+build:
+       go build -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro
 
-install: build
-       mv micro $(GOPATH)/bin
+build-dbg:
+       go build -ldflags "-s -w $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro
 
-tcell:
-       git -C $(GOPATH)/src/github.com/zyedidia/tcell pull
+# Builds micro after building the runtime and checking dependencies
+build-all: runtime build
 
-deps:
-       go get -d ./cmd/micro
+# Builds micro without checking for dependencies
+build-quick:
+       go build -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro
 
+# Same as 'build' but installs to $GOBIN afterward
+install:
+       go install -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro
+
+# Same as 'build-all' but installs to $GOBIN afterward
+install-all: runtime install
+
+# Same as 'build-quick' but installs to $GOBIN afterward
+install-quick:
+       go install -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)"  ./cmd/micro
+
+# Builds the runtime
 runtime:
-       go get -u github.com/jteeuwen/go-bindata/...
-       $(GOPATH)/bin/go-bindata -nometadata -o runtime.go runtime/...
-       mv runtime.go cmd/micro
+       git submodule update --init
+       go run runtime/syntax/make_headers.go runtime/syntax
+       go build -o tools/bindata ./tools/go-bindata
+       tools/bindata -pkg config -nomemcopy -nometadata -o runtime.go runtime/...
+       mv runtime.go internal/config
+       gofmt -w internal/config/runtime.go
 
 test:
-       go get -d ./cmd/micro
-       go test ./cmd/micro
+       go test ./internal/...
 
 clean:
        rm -f micro