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


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
19
20
21
# Update src/transformers/dependency_versions_table.py

deps_table_update:
	@python setup.py deps_table_update

22
23
# Check that source code meets quality standards

24
extra_quality_checks: deps_table_update
25
	python utils/check_copies.py
26
	python utils/check_dummies.py
27
	python utils/check_repo.py
28
	python utils/style_doc.py src/transformers docs/source --max_len 119
29

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

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

40
style: deps_table_update
41
42
	black $(check_dirs)
	isort $(check_dirs)
Sylvain Gugger's avatar
Sylvain Gugger committed
43
	python utils/style_doc.py src/transformers docs/source --max_len 119
44
45

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

47
fixup: modified_only_fixup extra_quality_checks
48

49
50
51
52
# Make marked copies of snippets of codes conform to the original

fix-copies:
	python utils/check_copies.py --fix_and_overwrite
53
	python utils/check_dummies.py --fix_and_overwrite
54

55
56
57
58
59
60
61
62
63
# 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/
64
65
66
67
68

# Check that docs can build

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