X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=Makefile;h=19badb914bc95f228d3a9b298977c332221b90c2;hb=d8596919a650e2f2c9dca2a2d9f1e64d835c08bd;hp=67873d6919a7b54a246700e807f88a5049efd96e;hpb=855c5283e45878d10882870f5bdfbed9e1c98d8e;p=micro.git diff --git a/Makefile b/Makefile index 67873d69..19badb91 100644 --- a/Makefile +++ b/Makefile @@ -1,50 +1,88 @@ .PHONY: runtime -VERSION = $(shell go run tools/build-version.go) +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 go run tools/build-date.go) - -GOBIN ?= $(GOPATH)/bin +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) \ + go run tools/info-plist.go "$(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: deps - go build -ldflags "-s -w -X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(DATE)'" ./cmd/micro +build: + go build -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro + +build-dbg: + go build -ldflags "-s -w $(ADDITIONAL_GO_LINKER_FLAGS) $(DEBUGVAR)" ./cmd/micro + +build-tags: fetch-tags + go build -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro # 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)'" ./cmd/micro + go build -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro # Same as 'build' but installs to $GOBIN afterward -install: deps - go install -ldflags "-s -w -X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(DATE)'" ./cmd/micro +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 -X main.Version=$(VERSION) -X main.CommitHash=$(HASH) -X 'main.CompileDate=$(DATE)'" ./cmd/micro - -# Checks for dependencies -deps: - go get -d ./cmd/micro + go install -ldflags "-s -w $(GOVARS) $(ADDITIONAL_GO_LINKER_FLAGS)" ./cmd/micro -update: - git pull - go get -u -d ./cmd/micro +fetch-tags: + git fetch --tags # 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 + git submodule update --init + rm -f runtime/syntax/*.hdr + 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 + +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 get -d ./cmd/micro - 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