Makefile 1.67 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
.PHONY: modified_only_fixup extra_quality_checks quality style fixup fix-copies test test-examples docs


check_dirs := examples templates tests src utils

# get modified files since the branch was made
fork_point_sha := $(shell git merge-base --fork-point master)
joined_dirs    := $(shell echo $(check_dirs) | tr " " "|")
modified_files := $(shell git diff --name-only $(fork_point_sha) | egrep '^($(joined_dirs))')
#$(info modified files are: $(modified_files))

modified_only_fixup:
	@if [ -n "$(modified_files)" ]; then \
		echo "Checking/fixing $(modified_files)"; \
		black $(modified_files); \
		isort $(modified_files); \
		flake8 $(modified_files); \
	else \
		echo "No relevant files were modified"; \
	fi
21
22
23

# Check that source code meets quality standards

24
extra_quality_checks:
25
	python utils/check_copies.py
26
	python utils/check_repo.py
27

28
# this target runs checks on all files
29
quality:
30
31
32
33
	black --check $(check_dirs)
	isort --check-only $(check_dirs)
	flake8 $(check_dirs)
	${MAKE} extra_quality_checks
34
35

# Format source code automatically and check is there are any problems left that need manual fixing
36
37

style:
38
39
40
41
	black $(check_dirs)
	isort $(check_dirs)

# Super fast fix and check target that only works on relevant modified files since the branch was made
42

43
fixup: modified_only_fixup extra_quality_checks
44

45
46
47
48
49
# Make marked copies of snippets of codes conform to the original

fix-copies:
	python utils/check_copies.py --fix_and_overwrite

50
51
52
53
54
55
56
57
58
# Run tests for the library

test:
	python -m pytest -n auto --dist=loadfile -s -v ./tests/

# Run tests for examples

test-examples:
	python -m pytest -n auto --dist=loadfile -s -v ./examples/
59
60
61
62
63

# Check that docs can build

docs:
	cd docs && make html SPHINXOPTS="-W"