forked from percyfal/pytest-ngsfixtures
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMakefile
More file actions
137 lines (110 loc) · 4.12 KB
/
Makefile
File metadata and controls
137 lines (110 loc) · 4.12 KB
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
131
132
133
134
135
136
137
.PHONY: clean clean-test clean-pyc clean-build docs help conda
.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"
help:
@python -c "$$PRINT_HELP_PYSCRIPT" < $(MAKEFILE_LIST)
clean: clean-build clean-pyc clean-test ## remove all build, test, coverage and Python artifacts
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 {} +
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 {} +
clean-test: ## remove test and coverage artifacts
rm -fr .tox/
rm -f .coverage
rm -fr htmlcov/
clean-snakemake: ## remove snakemake directories
find . -name '.snakemake' -exec rm -fr {} +
lint: ## check style with flake8
flake8 pytest_ngsfixtures tests
test: ## run tests quickly with the default Python
py.test
test-all: ## run tests on every Python version with tox
tox
coverage: ## check code coverage quickly with the default Python
coverage run --source pytest_ngsfixtures -m pytest
coverage report -m
coverage html
$(BROWSER) htmlcov/index.html
docs: ## generate Sphinx HTML documentation, including API docs
rm -f docs/pytest_ngsfixtures.rst
rm -f docs/modules.rst
sphinx-apidoc -o docs/ pytest_ngsfixtures
$(MAKE) -C docs clean
$(MAKE) -C docs html
$(BROWSER) docs/_build/html/index.html
GH_PAGES_SOURCES = docs docs/Makefile pytest_ngsfixtures
GH_PAGES_DOCS = *.html *.inv *.js _*
gh-pages: ## generate Sphinx HTML documentation, including API docs, for gh-pages
python setup.py version 2>/dev/null | grep Version | sed "s/Version://" > .version
git checkout gh-pages
rm -f docs/pytest_ngsfixtures.rst
rm -f docs/modules.rst
git checkout master $(GH_PAGES_SOURCES)
git reset HEAD
sphinx-apidoc -o docs/ pytest_ngsfixtures
$(MAKE) -C docs clean
$(MAKE) -C docs html
rsync -av docs/_build/html/* ./
rm -rf $(GH_PAGES_SOURCES) _build .version __pycache__
git add -A -f $(GH_PAGES_DOCS)
git commit -m "Generated gh-pages for `git log master -1 --pretty=short --abbrev-commit`" && git push origin gh-pages ; git checkout master
gh-pages-dev: ## generate Sphinx HTML documentation, including API docs, for gh-pages-dev
python setup.py version 2>/dev/null | grep Version | sed "s/Version://" > .version
git checkout gh-pages
rm -f docs/pytest_ngsfixtures.rst
rm -f docs/modules.rst
git checkout develop $(GH_PAGES_SOURCES)
git reset HEAD
sphinx-apidoc -o docs/ pytest_ngsfixtures
$(MAKE) -C docs clean
$(MAKE) -C docs html
rsync -av docs/_build/html/* ./
rm -rf $(GH_PAGES_SOURCES) _build .version __pycache__
git add -A -f $(GH_PAGES_DOCS)
git commit -m "Generated gh-pages for `git log develop -1 --pretty=short --abbrev-commit`" && git push origin gh-pages ; git checkout develop
viewdocs: gh-pages ## View documentation
$(BROWSER) docs/_build/html/index.html
servedocs: docs ## compile the docs watching for changes
watchmedo shell-command -p '*.rst' -c '$(MAKE) -C docs html' -R -D .
release: clean clean-snakemake ## package and upload a release
python setup.py sdist upload
python setup.py bdist_wheel upload
current=$(shell git rev-parse --abbrev-ref HEAD)
conda: ## package and upload a conda release
git checkout conda
git merge $(current)
$(MAKE) clean clean-snakemake
conda build conda
anaconda upload $(shell conda build conda --output) --interactive
git checkout $(current)
dist: clean ## builds source and wheel package
python setup.py sdist
python setup.py bdist_wheel
ls -l dist
install: clean ## install the package to the active Python's site-packages
python setup.py install