aboutsummaryrefslogtreecommitdiff
path: root/Makefile
blob: 24fda89861dbb9858bcbd2967352654af222cf58 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
SHELL := bash

VERSION ?=
CMD ?=

EMACS ?= emacs

TAG ?= latest

# The order is important for compilation.
for_compile := \
    apheleia-utils.el \
    apheleia-formatter-context.el \
    apheleia-log.el \
    apheleia-formatters.el \
    apheleia-rcs.el \
    apheleia.el
for_checkdoc := *.el
for_checkindent := *.el

.PHONY: help
help: ## Show this message
	@echo "usage:" >&2
	@grep -h "[#]# " $(MAKEFILE_LIST)	| \
		sed 's/^/  make /'		| \
		sed 's/:[^#]*[#]# /|/'		| \
		sed 's/%/LANG/'			| \
		column -t -s'|' >&2

.PHONY: lint
lint: compile checkdoc longlines checkindent fmt-lint ## Run all fast linters

.PHONY: compile
compile: ## Check for byte-compiler errors
	@for file in $(for_compile); do \
	    echo "[compile] $$file" ;\
	    rm -f "$${file}c" ;\
	    $(EMACS) -Q --batch -L . -f batch-byte-compile $$file 2>&1 \
	        | grep -v "^Wrote" \
	        | grep . && exit 1 || true ;\
	done

.PHONY: checkdoc
checkdoc: ## Check for missing or poorly formatted docstrings
	@for file in $(for_checkdoc); do \
	    echo "[checkdoc] $$file" ;\
	    $(EMACS) -Q --batch \
	        --eval "(or (fboundp 'checkdoc-file) (kill-emacs))" \
	        --eval "(setq sentence-end-double-space nil)" \
	        --eval "(checkdoc-file \"$$file\")" 2>&1 \
	        | grep . && exit 1 || true ;\
	done

.PHONY: checkindent
checkindent: ## Ensure that indentation is correct
	@tmpdir="$$(mktemp -d)"; for file in $(for_checkindent); do \
	    echo "[checkindent] $$file" >&2; \
	    emacs -Q --batch \
		-l scripts/apheleia-indent.el \
	        --eval "(setq inhibit-message t)" \
	        --eval "(setq load-path \
	                      (append (list default-directory) load-path))" \
	        --eval "(load (expand-file-name \"apheleia.el\") nil t)" \
	        --eval "(find-file \"$$file\")" \
	        --eval "(indent-region (point-min) (point-max))" \
	        --eval "(write-file \"$$tmpdir/$$file\")"; \
	    (diff <(cat          "$$file" | nl -v1 -ba | \
                           sed "s/\t/: /" | sed "s/^ */$$file:/") \
	          <(cat "$$tmpdir/$$file" | nl -v1 -ba | \
                           sed "s/\t/: /" | sed "s/^ */$$file:/") ) \
	        | grep -F ">" | grep -o "[a-z].*" | grep . && exit 1 || true; \
	done

.PHONY: longlines
longlines: ## Check for long lines
	@scripts/check-line-length.bash

.PHONY: clean
clean: ## Remove build artifacts
	@echo "[clean]" *.elc
	@rm -f *.elc

.PHONY: docker
docker: ## Start a Docker shell; e.g. make docker VERSION=25.3
	@scripts/docker.bash "$(VERSION)" "$(CMD)"

.PHONY: fmt-build  # env vars: FORMATTERS, TAG
fmt-build: ## Build a Docker image with formatters installed
	@COMMON=0 test/formatters/build-image.bash

.PHONY: fmt-build-common  # env var: TAG
fmt-build-common: ## Build a Docker image with just the common base
	@COMMON=1 test/formatters/build-image.bash

.PHONY: fmt-docker  # env var: TAG
fmt-docker: ## Start a Docker shell for testing formatters
	@scripts/docker-run.bash -e FORMATTERS "apheleia-formatters:$(TAG)" "$(CMD)"

.PHONY: fmt-lint
fmt-lint: ## Do basic linting for formatter configuration
	@test/formatters/run-func.bash apheleia-ft-lint

.PHONY: fmt-check
fmt-changed: ## Get list of changed formatters on this PR
	@test/formatters/run-func.bash apheleia-ft-changed

.PHONY: fmt-test  # env var: FORMATTERS
fmt-test: ## Actually run formatter tests
	@test/formatters/run-func.bash apheleia-ft-test