Makefile 1.76 KB
Newer Older
1
2
3
.PHONY: modified_only_fixup extra_quality_checks quality style fixup fix-copies test test-examples docs


4
check_dirs := examples tests src utils
5
6

modified_only_fixup:
7
8
	$(eval modified_py_files := $(shell python utils/get_modified_files.py $(check_dirs)))
	@if test -n "$(modified_py_files)"; then \
9
10
11
12
		echo "Checking/fixing $(modified_py_files)"; \
		black $(modified_py_files); \
		isort $(modified_py_files); \
		flake8 $(modified_py_files); \
13
	else \
14
		echo "No library .py files were modified"; \
15
	fi
16
17
18

# Check that source code meets quality standards

19
extra_quality_checks:
20
	python utils/check_copies.py
21
	python utils/check_dummies.py
22
	python utils/check_repo.py
23
	python utils/style_doc.py src/transformers docs/source --max_len 119
24

25
# this target runs checks on all files
26
quality:
27
28
29
	black --check $(check_dirs)
	isort --check-only $(check_dirs)
	flake8 $(check_dirs)
Sylvain Gugger's avatar
Sylvain Gugger committed
30
	python utils/style_doc.py src/transformers docs/source --max_len 119 --check_only
31
	${MAKE} extra_quality_checks
32
33

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

style:
36
37
	black $(check_dirs)
	isort $(check_dirs)
Sylvain Gugger's avatar
Sylvain Gugger committed
38
	python utils/style_doc.py src/transformers docs/source --max_len 119
39
40

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

42
fixup: modified_only_fixup extra_quality_checks
43

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

fix-copies:
	python utils/check_copies.py --fix_and_overwrite
48
	python utils/check_dummies.py --fix_and_overwrite
49

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"