X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=Makefile;h=fc9601aa5c4de5d24a00a15d6c7e643deac6c77d;hb=cf98b7f8245e4ca28518d31147e347d35607d5d4;hp=e03ee2fc7ed7a3045410cf210fcc53db1b27a4e5;hpb=7a013f666ec22bda73af3a814e7ad475bbf4b516;p=micro.git diff --git a/Makefile b/Makefile index e03ee2fc..fc9601aa 100644 --- a/Makefile +++ b/Makefile @@ -1,50 +1,71 @@ -.PHONY: runtime +.PHONY: runtime build generate build-quick -VERSION := $(shell GOOS=$(shell go env GOHOSTOS) GOARCH=$(shell go env GOHOSTARCH) \ +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) \ +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) \ +ADDITIONAL_GO_LINKER_FLAGS = $(shell GOOS=$(shell go env GOHOSTOS) \ GOARCH=$(shell go env GOHOSTARCH) \ - go run tools/info-plist.go "$(VERSION)") + go run tools/info-plist.go "$(shell go env GOOS)" "$(VERSION)") GOBIN ?= $(shell go env GOPATH)/bin +GOVARS = -X github.com/zyedidia/micro/v2/internal/util.Version=$(VERSION) -X github.com/zyedidia/micro/v2/internal/util.CommitHash=$(HASH) -X 'github.com/zyedidia/micro/v2/internal/util.CompileDate=$(DATE)' +DEBUGVAR = -X github.com/zyedidia/micro/v2/internal/util.Debug=ON +VSCODE_TESTS_BASE_URL = 'https://raw.githubusercontent.com/microsoft/vscode/e6a45f4242ebddb7aa9a229f85555e8a3bd987e2/src/vs/editor/test/common/model/' -# Builds micro after checking dependencies but without updating the runtime -build: update - go build -ldflags "-s -w -X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(DATE)' $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro +build: generate build-quick -# Builds micro after building the runtime and checking dependencies -build-all: runtime build - -# Builds micro without checking for dependencies build-quick: - go build -ldflags "-s -w -X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(DATE)' $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro + go build -trimpath -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro + +build-dbg: + go build -trimpath -ldflags "-s -w $(ADDITIONAL_GO_LINKER_FLAGS) $(DEBUGVAR)" ./cmd/micro + +build-tags: fetch-tags generate + go build -trimpath -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro + +build-all: build -# Same as 'build' but installs to $GOBIN afterward -install: update - go install -ldflags "-s -w -X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(DATE)' $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro +install: generate + 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 +install-all: install -# Same as 'build-quick' but installs to $GOBIN afterward -install-quick: - go install -ldflags "-s -w -X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(DATE)' $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro +fetch-tags: + git fetch --tags -update: - git pull - git submodule update --init +generate: + GOOS=$(shell go env GOHOSTOS) GOARCH=$(shell go env GOHOSTARCH) go generate ./runtime -# Builds the runtime -runtime: - go get -u github.com/jteeuwen/go-bindata/... - $(GOBIN)/go-bindata -nometadata -o runtime.go runtime/... - mv runtime.go cmd/micro - gofmt -w cmd/micro/runtime.go +testgen: + mkdir -p tools/vscode-tests + cd tools/vscode-tests && \ + curl --remote-name-all $(VSCODE_TESTS_BASE_URL){editableTextModelAuto,editableTextModel,model.line}.test.ts + tsc tools/vscode-tests/*.ts > /dev/null; true + go run tools/testgen.go tools/vscode-tests/*.js > buffer_generated_test.go + mv buffer_generated_test.go internal/buffer + gofmt -w internal/buffer/buffer_generated_test.go test: - go test ./cmd/micro + go test ./internal/... + go test ./cmd/... + +bench: + for i in 1 2 3; do \ + go test -bench=. ./internal/...; \ + done > benchmark_results + benchstat benchmark_results + +bench-baseline: + for i in 1 2 3; do \ + go test -bench=. ./internal/...; \ + done > benchmark_results_baseline + +bench-compare: + for i in 1 2 3; do \ + go test -bench=. ./internal/...; \ + done > benchmark_results + benchstat -alpha 0.15 benchmark_results_baseline benchmark_results clean: rm -f micro