IRG / baselines /RCTGAN /Makefile
Zilong-Zhao's picture
first commit
c4ac745
.DEFAULT_GOAL := help
define BROWSER_PYSCRIPT
import os, webbrowser, sys
try:
from urllib import pathname2url
except:
from urllib.request import pathname2url
webbrowser.open("file://" + pathname2url(os.path.abspath(sys.argv[1])))
endef
export BROWSER_PYSCRIPT
define PRINT_HELP_PYSCRIPT
import re, sys
for line in sys.stdin:
match = re.match(r'^([a-zA-Z_-]+):.*?## (.*)$$', line)
if match:
target, help = match.groups()
print("%-20s %s" % (target, help))
endef
export PRINT_HELP_PYSCRIPT
BROWSER := python -c "$$BROWSER_PYSCRIPT"
.PHONY: help
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
# CLEAN TARGETS
.PHONY: clean-build
clean-build: ## remove build artifacts
rm -fr build/
rm -fr dist/
rm -fr .eggs/
find . -name '*.egg-info' -exec rm -fr {} +
find . -name '*.egg' -exec rm -f {} +
.PHONY: clean-pyc
clean-pyc: ## remove Python file artifacts
find . -name '*.pyc' -exec rm -f {} +
find . -name '*.pyo' -exec rm -f {} +
find . -name '*~' -exec rm -f {} +
find . -name '__pycache__' -exec rm -fr {} +
.PHONY: clean-docs
clean-docs: ## remove previously built docs
rm -rf docs/api/ docs/api_reference/api/ docs/tutorials docs/build docs/_build
.PHONY: clean-coverage
clean-coverage: ## remove coverage artifacts
rm -f .coverage
rm -f .coverage.*
rm -fr htmlcov/
.PHONY: clean-test
clean-test: ## remove test artifacts
rm -fr .tox/
rm -fr .pytest_cache
.PHONY: clean
clean: clean-build clean-pyc clean-test clean-coverage clean-docs ## remove all build, test, coverage, docs and Python artifacts
# INSTALL TARGETS
.PHONY: install
install: clean-build clean-pyc ## install the package to the active Python's site-packages
pip install .
.PHONY: install-test
install-test: clean-build clean-pyc ## install the package and test dependencies
pip install .[test]
.PHONY: install-develop
install-develop: clean-build clean-pyc ## install the package in editable mode and dependencies for development
pip install -e .[dev]
MINIMUM := $(shell sed -n '/install_requires = \[/,/]/p' setup.py | grep -v -e '[][]' | sed 's/ *\(.*\),$?$$/\1/g' | tr '>' '=')
.PHONY: install-minimum
install-minimum: ## install the minimum supported versions of the package dependencies
pip install $(MINIMUM)
# LINT TARGETS
.PHONY: lint-sdv
lint-sdv: ## check style with flake8 and isort
flake8 sdv
isort -c --recursive sdv
pydocstyle sdv
.PHONY: lint-tests
lint-tests: ## check style with flake8 and isort
flake8 --ignore=D,SFS2 tests
isort -c --recursive tests
.PHONY: check-dependencies
check-dependencies: ## test if there are any broken dependencies
pip check
.PHONY: lint
lint: ## check style with flake8 and isort
invoke lint
.PHONY: fix-lint
fix-lint: ## fix lint issues using autoflake, autopep8, and isort
find sdv tests -name '*.py' | xargs autoflake --in-place --remove-all-unused-imports --remove-unused-variables
autopep8 --in-place --recursive --aggressive sdv tests
isort --apply --atomic --recursive sdv tests
# TEST TARGETS
.PHONY: test-unit
test-unit: ## run tests quickly with the default Python
invoke unit
.PHONY: test-integration
test-integration: ## run tests quickly with the default Python
invoke integration
.PHONY: test-readme
test-readme: ## run the readme snippets
invoke readme
.PHONY: test-tutorials
test-tutorials: ## run the tutorial notebooks
invoke tutorials
.PHONY: test
test: test-unit test-readme test-tutorials ## test everything that needs test dependencies
.PHONY: test-all
test-all: ## run tests on every Python version with tox
tox -r
.PHONY: coverage
coverage: ## check code coverage quickly with the default Python
coverage run --source sdv -m pytest
coverage report -m
coverage html
$(BROWSER) htmlcov/index.html
# DOCS TARGETS
.PHONY: docs
docs: clean-docs ## generate Sphinx HTML documentation, including API docs
$(MAKE) -C docs html
.PHONY: view-docs
view-docs: ## view the docs in a browser
$(BROWSER) docs/_build/html/index.html
.PHONY: serve-docs
serve-docs: ## compile the docs watching for changes
watchmedo shell-command -W -R -D -p '*.rst;*.md' -c '$(MAKE) -C docs html' docs
# RELEASE TARGETS
.PHONY: dist
dist: clean ## builds source and wheel package
python setup.py sdist
python setup.py bdist_wheel
ls -l dist
.PHONY: publish-confirm
publish-confirm:
@echo "WARNING: This will irreversibly upload a new version to PyPI!"
@echo -n "Please type 'confirm' to proceed: " \
&& read answer \
&& [ "$${answer}" = "confirm" ]
.PHONY: publish-test
publish-test: dist publish-confirm ## package and upload a release on TestPyPI
twine upload --repository-url https://test.pypi.org/legacy/ dist/*
.PHONY: publish
publish: dist publish-confirm ## package and upload a release
twine upload dist/*
.PHONY: bumpversion-release
bumpversion-release: ## Merge master to stable and bumpversion release
git checkout stable || git checkout -b stable
git merge --no-ff master -m"make release-tag: Merge branch 'master' into stable"
bumpversion release
git push --tags origin stable
.PHONY: bumpversion-release-test
bumpversion-release-test: ## Merge master to stable and bumpversion release
git checkout stable || git checkout -b stable
git merge --no-ff master -m"make release-tag: Merge branch 'master' into stable"
bumpversion release --no-tag
@echo git push --tags origin stable
.PHONY: bumpversion-patch
bumpversion-patch: ## Merge stable to master and bumpversion patch
git checkout master
git merge stable
bumpversion --no-tag patch
git push
.PHONY: bumpversion-candidate
bumpversion-candidate: ## Bump the version to the next candidate
bumpversion candidate --no-tag
.PHONY: bumpversion-minor
bumpversion-minor: ## Bump the version the next minor skipping the release
bumpversion --no-tag minor
.PHONY: bumpversion-major
bumpversion-major: ## Bump the version the next major skipping the release
bumpversion --no-tag major
.PHONY: bumpversion-revert
bumpversion-revert: ## Undo a previous bumpversion-release
git checkout master
git branch -D stable
CLEAN_DIR := $(shell git status --short | grep -v ??)
CURRENT_BRANCH := $(shell git rev-parse --abbrev-ref HEAD 2>/dev/null)
CHANGELOG_LINES := $(shell git diff HEAD..origin/stable HISTORY.md 2>&1 | wc -l)
.PHONY: check-clean
check-clean: ## Check if the directory has uncommitted changes
ifneq ($(CLEAN_DIR),)
$(error There are uncommitted changes)
endif
.PHONY: check-master
check-master: ## Check if we are in master branch
ifneq ($(CURRENT_BRANCH),master)
$(error Please make the release from master branch\n)
endif
.PHONY: check-history
check-history: ## Check if HISTORY.md has been modified
ifeq ($(CHANGELOG_LINES),0)
$(error Please insert the release notes in HISTORY.md before releasing)
endif
.PHONY: check-release
check-release: check-clean check-master check-history ## Check if the release can be made
@echo "A new release can be made"
.PHONY: release
release: check-release bumpversion-release publish bumpversion-patch
.PHONY: release-test
release-test: check-release bumpversion-release-test publish-test bumpversion-revert
.PHONY: release-candidate
release-candidate: check-master publish bumpversion-candidate
.PHONY: release-candidate-test
release-candidate-test: check-clean check-master publish-test
.PHONY: release-minor
release-minor: check-release bumpversion-minor release
.PHONY: release-major
release-major: check-release bumpversion-major release