-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
130 lines (105 loc) · 3.34 KB
/
Makefile
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
# These have been configured to only really run short tasks. Longer form tasks
# are usually completed in github actions.
NAME := iAnchor
PACKAGE_NAME := ianchor
DIR := "${CURDIR}"
SOURCE_DIR := ${PACKAGE_NAME}
DIST := dist
DOCDIR := docs
INDEX_HTML := "file://${DIR}/docs/build/html/index.html"
EXAMPLES_DIR := examples
TESTS_DIR := tests
.PHONY: help install-dev check format pre-commit clean docs clean-doc examples clean-build build publish test
help:
@echo "Makefile ${NAME}"
@echo "* install-dev to install all dev requirements and install pre-commit"
@echo "* clean to clean any doc or build files"
@echo "* check to check the source code for issues"
@echo "* format to format the code with black and isort"
@echo "* pre-commit to run the pre-commit check"
@echo "* build to build a dist"
@echo "* docs to generate and view the html files, checks links"
@echo "* examples to run and generate the examples"
@echo "* publish to help publish the current branch to pypi"
@echo "* test to run the tests"
PYTHON ?= python
PYTEST ?= python -m pytest
PIP ?= python -m pip
MAKE ?= make
BLACK ?= black
ISORT ?= isort
PYDOCSTYLE ?= pydocstyle
MYPY ?= mypy
PRECOMMIT ?= pre-commit
FLAKE8 ?= flake8
install-dev:
$(PIP) install -e ".[dev]"
pre-commit install
check-black:
$(BLACK) ${SOURCE_DIR} --check || :
$(BLACK) ${EXAMPLES_DIR} --check || :
$(BLACK) ${TESTS_DIR} --check || :
check-isort:
$(ISORT) ${SOURCE_DIR} --check || :
$(ISORT) ${TESTS_DIR} --check || :
check-pydocstyle:
$(PYDOCSTYLE) ${SOURCE_DIR} || :
check-mypy:
$(MYPY) ${SOURCE_DIR} || :
check-flake8:
$(FLAKE8) ${SOURCE_DIR} || :
$(FLAKE8) ${TESTS_DIR} || :
check: check-black check-isort check-mypy check-flake8 check-pydocstyle
pre-commit:
$(PRECOMMIT) run --all-files
format-black:
$(BLACK) ${SOURCE_DIR}
$(BLACK) ${TESTS_DIR}
$(BLACK) ${EXAMPLES_DIR}
format-isort:
$(ISORT) ${SOURCE_DIR}
$(ISORT) ${TESTS_DIR}
format: format-black format-isort
test:
$(PYTEST) ${TESTS_DIR}
clean-doc:
$(MAKE) -C ${DOCDIR} clean
docs:
$(MAKE) -C ${DOCDIR} docs
@echo
@echo "View docs at:"
@echo ${INDEX_HTML}
examples:
$(MAKE) -C ${DOCDIR} examples
@echo
@echo "View docs at:"
@echo ${INDEX_HTML}
clean-build:
$(PYTHON) setup.py clean
rm -rf ${DIST}
# Build a distribution in ./dist
build:
$(PYTHON) setup.py sdist
# Publish to testpypi
# Will echo the commands to actually publish to be run to publish to actual PyPi
# This is done to prevent accidental publishing but provide the same conveniences
publish: clean build
read -p "Did you update the version number?"
$(PIP) install twine
$(PYTHON) -m twine upload --repository testpypi ${DIST}/*
@echo
@echo "Test with the following:"
@echo "* Create a new virtual environment to install the uplaoded distribution into"
@echo "* Run the following:"
@echo
@echo " pip install --index-url https://test.pypi.org/simple/ --extra-index-url https://pypi.org/simple/ ${NAME}"
@echo
@echo "* Run this to make sure it can import correctly, plus whatever else you'd like to test:"
@echo
@echo " python -c 'import ${PACKAGE_NAME}'"
@echo
@echo "Once you have decided it works, publish to actual pypi with"
@echo
@echo " python -m twine upload dist/*"
# Clean up any builds in ./dist as well as doc, if present
clean: clean-build clean-doc