.PHONY: help clean clean-pyc clean-build list test test-all coverage docs release sdist

NAME = $(shell python -c 'import setuptools; setuptools.setup()' --name)

help:
	@echo
	@echo "style-check - check code with flake8"
	@echo "reformat    - runs black to reformat code"
	@echo "test        - run tests quickly with the default Python"
	@echo "test-all    - run tests on every Python version with tox"
	@echo "coverage    - check code coverage quickly with the default Python"
	@echo "docs        - generate Sphinx HTML documentation, including API docs"
	@echo "sdist       - package"

clean: clean-build clean-pyc

clean-build:
	rm -fr build/
	rm -fr dist/
	rm -fr *.egg-info

clean-pyc:
	find . -name '*.pyc' -exec rm -f {} +
	find . -name '*.pyo' -exec rm -f {} +
	find . -name '*~' -exec rm -f {} +
	find . -name '__pycache__' -exec rm -rf {} +

reformat:
	isort --treat-all-comment-as-code src/$(NAME) tests
	black -l 88 src/$(NAME) tests

style-check:
	flake8 --select C,E,F,W,B,B950 --ignore E501,W503,E203 --max-line-length 88 src/$(NAME) tests/ setup.py

test:
	py.test tests

test-all:
	tox

coverage:
	coverage run --source src/$(NAME) -m pytest tests
	coverage report -m
	coverage html
	open htmlcov/index.html

docs: open ?= open docs/_build/html/index.html
docs:
	rm -f docs/$(NAME).rst
	rm -f docs/modules.rst
	sphinx-apidoc -o docs/ src/$(NAME)
	$(MAKE) -C docs clean
	$(MAKE) -C docs html
	coverage run --source src/$(NAME) -m pytest tests
	coverage report -m
	coverage html
	cp -R htmlcov docs/_build/html
	$(open)

sdist: clean
	python -m build .
	ls -l dist

upload: sdist
	twine check dist/*.tar.gz && twine upload dist/*.tar.gz
