forked from OCR-D/core
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Makefile
215 lines (173 loc) · 5.75 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
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
export
SHELL = /bin/bash
PYTHON = python
PIP = pip
LOG_LEVEL = INFO
PYTHONIOENCODING=utf8
TESTDIR = tests
# PAGE schema version to use. Default: '$(PAGE_VERSION)'
PAGE_VERSION = 2019
SPHINX_APIDOC =
BUILD_ORDER = ocrd_utils ocrd_models ocrd_modelfactory ocrd_validators ocrd
FIND_VERSION = grep version= ocrd_utils/setup.py|grep -Po "([0-9ab]+\.?)+"
# Additional arguments to docker build. Default: '$(DOCKER_ARGS)'
DOCKER_ARGS =
# BEGIN-EVAL makefile-parser --make-help Makefile
help:
@echo ""
@echo " Targets"
@echo ""
@echo " deps-ubuntu Dependencies for deployment in an ubuntu/debian linux"
@echo " deps-test Install test python deps via pip"
@echo " install (Re)install the tool"
@echo " uninstall Uninstall the tool"
@echo " generate-page Regenerate python code from PAGE XSD"
@echo " repo/assets Clone OCR-D/assets to ./repo/assets"
@echo " repo/spec Clone OCR-D/spec to ./repo/spec"
@echo " spec Copy JSON Schema, OpenAPI from OCR-D/spec"
@echo " assets Setup test assets"
@echo " assets-server Start asset server at http://localhost:5001"
@echo " assets-clean Remove symlinks in $(TESTDIR)/assets"
@echo " test Run all unit tests"
@echo " docs Build documentation"
@echo " docs-clean Clean docs"
@echo " docs-coverage Calculate docstring coverage"
@echo " docker Build docker image"
@echo " bashlib Build bash library"
@echo " pypi Build wheels and source dist and twine upload them"
@echo ""
@echo " Variables"
@echo ""
@echo " PAGE_VERSION PAGE schema version to use. Default: '$(PAGE_VERSION)'"
@echo " DOCKER_ARGS Additional arguments to docker build. Default: '$(DOCKER_ARGS)'"
@echo " DOCKER_TAG Docker tag."
@echo " PIP_INSTALL pip install command. Default: $(PIP_INSTALL)"
# END-EVAL
# Docker tag.
DOCKER_TAG = 'ocrd/core'
# pip install command. Default: $(PIP_INSTALL)
PIP_INSTALL = pip install
# Dependencies for deployment in an ubuntu/debian linux
deps-ubuntu:
apt-get install -y python3 python3-pip python3-venv
# Install test python deps via pip
deps-test:
$(PIP) install -r requirements_test.txt
# (Re)install the tool
install: spec
$(PIP) install -U "pip>=19.0.0" wheel
for mod in $(BUILD_ORDER);do (cd $$mod ; $(PIP_INSTALL) .);done
# Uninstall the tool
uninstall:
for mod in $(BUILD_ORDER);do pip uninstall -y $$mod;done
# Regenerate python code from PAGE XSD
generate-page: GDS_PAGE = ocrd_models/ocrd_models/ocrd_page_generateds.py
generate-page: GDS_PAGE_USER = ocrd_models/ocrd_page_user_methods.py
generate-page: repo/assets
generateDS \
-f \
--root-element='PcGts' \
-o $(GDS_PAGE) \
--disable-generatedssuper-lookup \
--user-methods=$(GDS_PAGE_USER) \
repo/assets/data/schema/data/$(PAGE_VERSION).xsd
# hack to prevent #451: enum keys will be strings
sed -i 's/(Enum):$$/(str, Enum):/' $(GDS_PAGE)
# hack to ensure output has pc: prefix
@#sed -i "s/namespaceprefix_=''/namespaceprefix_='pc:'/" $(GDS_PAGE)
sed -i 's/_nsprefix_ = None/_nsprefix_ = "pc"/' $(GDS_PAGE)
# hack to ensure child nodes also have pc: prefix...
sed -i 's/.*_nsprefix_ = child_.prefix$$//' $(GDS_PAGE)
#
# Repos
#
# Clone OCR-D/assets to ./repo/assets
repo/assets:
mkdir -p $(dir $@)
git clone https://github.com/OCR-D/assets "$@"
# Clone OCR-D/spec to ./repo/spec
repo/spec:
mkdir -p $(dir $@)
git clone https://github.com/OCR-D/spec "$@"
#
# Spec
#
.PHONY: spec
# Copy JSON Schema, OpenAPI from OCR-D/spec
spec: repo/spec
cp repo/spec/ocrd_tool.schema.yml ocrd_validators/ocrd_validators/ocrd_tool.schema.yml
cp repo/spec/bagit-profile.yml ocrd_validators/ocrd_validators/bagit-profile.yml
#
# Assets
#
# Setup test assets
assets: repo/assets
mkdir -p $(TESTDIR)/assets
cp -r -t $(TESTDIR)/assets repo/assets/data/*
# Start asset server at http://localhost:5001
assets-server:
cd assets && make start
# Remove symlinks in $(TESTDIR)/assets
assets-clean:
rm -rf $(TESTDIR)/assets
#
# Tests
#
.PHONY: test
# Run all unit tests
test: spec assets
HOME=$(CURDIR)/ocrd_utils $(PYTHON) -m pytest --continue-on-collection-errors $(TESTDIR) -k TestLogging
HOME=$(CURDIR) $(PYTHON) -m pytest --continue-on-collection-errors $(TESTDIR)
test-profile:
$(PYTHON) -m cProfile -o profile $$(which pytest)
$(PYTHON) analyze_profile.py
coverage: assets-clean assets
coverage erase
make test PYTHON="coverage run"
coverage report
coverage html
#
# Documentation
#
.PHONY: docs
# Build documentation
docs:
for mod in $(BUILD_ORDER);do sphinx-apidoc -f -M -e -o docs/api/$$mod $$mod/$$mod 'ocrd_models/ocrd_models/ocrd_page_generateds.py';done
cd docs ; $(MAKE) html
docs-push: gh-pages docs
cp -r docs/build/html/* gh-pages
cd gh-pages; git add . && git commit -m 'Updated docs $$(date)' && git push
# Clean docs
docs-clean:
cd gh-pages ; rm -rf *
cd docs ; rm -rf _build api/ocrd api/ocrd_*
# Calculate docstring coverage
docs-coverage:
for mod in $(BUILD_ORDER);do docstr-coverage $$mod/$$mod -e '.*(ocrd_page_generateds|/ocrd/cli/).*';done
for mod in $(BUILD_ORDER);do echo "# $$mod"; docstr-coverage -v1 $$mod/$$mod -e '.*(ocrd_page_generateds|/ocrd/cli/).*'|sed 's/^/\t/';done
gh-pages:
git clone --branch gh-pages https://github.com/OCR-D/core gh-pages
#
# Clean up
#
pyclean:
rm -f **/*.pyc
find . -name '__pycache__' -exec rm -rf '{}' \;
rm -rf .pytest_cache
#
# Docker
#
# Build docker image
docker:
docker build -t $(DOCKER_TAG) $(DOCKER_ARGS) .
#
# bash library
#
.PHONY: bashlib
# Build bash library
bashlib:
cd ocrd/bashlib; make lib
# Build wheels and source dist and twine upload them
pypi: uninstall install
for mod in $(BUILD_ORDER);do (cd $$mod; $(PYTHON) setup.py sdist bdist_wheel);done
version=`$(FIND_VERSION)`; twine upload ocrd*/dist/ocrd*$$version*{tar.gz,whl}