-
Notifications
You must be signed in to change notification settings - Fork 32
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Restructure general workflow, cli, services, processors, docs, tests #40
Merged
+2,169
−605
Merged
Changes from 1 commit
Commits
Show all changes
68 commits
Select commit
Hold shift + click to select a range
11bff34
Stubs for METS, PAGE, resolver and workspace, pylint, unittests
kba abeb696
OcrdMetsFile in its own file
kba f22758b
wip: ResolverCache
kba c54a433
model.ocrd_page: fix indexing off by one
kba 1fc1ee7
recognize works
kba 01045cf
gitignore libreoffice lock files
kba dbaa95c
wip: travis
kba 3a05a34
typo: segent -> segment
kba e3e46ae
ResolverCache working
kba 919cec9
'make test' to run all unit tests
kba f3cc1ae
add EXIF constants
kba db9eb66
OcrdMets: cache fileGrps
kba 98ef09a
:memo: Update README
kba f018657
python3 compat (make PYTHON=python3 test)
kba 18d12ee
create processor class, port exif to new api, extend page, test files…
kba 6d81ea5
rename ocrd.log -> ocrd.utils to contain reusable static code
kba 9641bbd
move to utils, export getLogger, coordinate_string_from_xywh
kba 905aa1e
lazy logging
kba fef9b5c
pylint: stop complaining about lxml
kba ff1e92d
page tag constants
kba 62684c1
OcrdPage: methods for listing/creating regions/lines
kba 728564e
workspace: + save_mets method
kba 8ecce18
utils: xywh_from_coordinate_string as opposite of coordinate_string_f…
kba fb09eba
WIP port segmenting to new api
kba cf724a8
pylint: stop complaining about tesserocr/cv2
kba 9dbe659
MIMETYPE_PAGE = text/page+xml
kba cfb536a
processor: helpers for input/output of files
kba 6cbb851
OcrdPage: prefer "X is not None" over "not X"
kba 48b3cee
tests: assets module
kba b8a942b
mirror module structure in tests
kba 98c099b
segment*/tesseract: use processor shortcuts
kba bb8832f
xsl namespace
kba 50b1f60
workspace: output files are saved with file:// if no url
kba 751f0c2
OcrdPage: typos
kba f323355
xml prettify
kba 9244464
remove cruft from ocrd_xml_base
kba 19e0c19
tests: run all with uniitest discover
kba e4c9fc4
test with pytest
kba 93dfbba
test OcrdPage
kba 3de7a6a
:fire: remove original characterizing/segmenting
kba 468c698
:memo: docstrings in OcrdPage
kba 83de2f7
:fire: remove initializing
kba 02e01c9
start with cli
kba 271d0bf
cli
kba 26b9fff
run_process in ocrd.processor to flexibly create workspace and run pr…
kba 3a9391c
Expose existing processors on web service, extend run-server script
kba 4568bd8
rename binary to 'ocrd', merge run and run_server, update setup.py
kba 3da3e46
CLI: ocrd process is now chainable
kba 4bfd81b
:fire: remove ocrd.webservices
kba e712196
minimal repository web service
kba 0c80139
optionally symlink instead of copy in resolver
kba 74db476
:memo: docs, move code in in processor/__init__.py to processor/base.py
kba 30a97c9
basic setup for documentation with sphinx
kba 32c2ce7
move image manipulation to workspace.resolve_image_as_pil
kba b58e6f6
resolver: allow setting workspace directory explicitly (for testing)
kba fa92fa9
use xmllint --format to optionally canonicalize/pretty print XML
kba cabb273
canonical ID for mets:file: fileGrp@USE + 4-zero-padded index within grp
kba bfdf09a
page: helpers to work with TextLine
kba 38c85a7
processor.add_output_file: pass on ID
kba 9f3c82c
WIP recognition with tesseract3
kba 80d33da
test assets
kba c8232b7
:bug: resolver: use hyper-verbose but uniqe filenames based on url
kba 3693299
:art: remove obsolete pylint exceptions
kba 4e0fa6f
rename tesseract3 -> tesserocr
kba 38d29ab
make 'test-profile' to list most time-consuming lines
kba f911afa
workspace: remove hard-coded reference to INPUT fileGrp
kba 1a2bd9b
:green_heart: travis add @alex-p's tesseract-ocr PPA
kba daade7f
properly skip recognize test, travis
kba File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
📝 docs, move code in in processor/__init__.py to processor/base.py
- v3.0.0b6
- v3.0.0b5
- v3.0.0b4
- v3.0.0b3
- v3.0.0b2
- v3.0.0b1
- v3.0.0a2
- v3.0.0a1
- v2.71.1
- v2.71.0
- v2.70.0
- v2.69.0
- v2.68.0
- v2.67.2
- v2.67.1
- v2.67.0
- v2.66.1
- v2.66.0
- v2.65.0
- v2.64.1
- v2.64.0
- v2.63.3
- v2.63.2
- v2.63.1
- v2.63.0
- v2.62.0
- v2.61.2
- v2.61.1
- v2.61.0
- v2.60.3
- v2.60.2
- v2.60.1
- v2.60.0
- v2.59.1
- v2.59.0
- v2.58.1
- v2.58.0
- v2.57.2
- v2.57.1
- v2.57.0
- v2.56.0
- v2.55.2
- v2.55.1
- v2.55.0
- v2.54.0
- v2.53.0
- v2.52.0
- v2.51.0
- v2.50.0
- v2.49.0
- v2.48.1
- v2.48.0
- v2.47.4
- v2.47.3
- v2.47.2
- v2.47.1
- v2.47.0
- v2.46.0
- v2.45.1
- v2.45.0
- v2.44.0
- v2.43.0
- v2.42.1
- v2.42.0
- v2.41.0
- v2.40.0
- v2.39.0
- v2.38.0
- v2.37.0
- v2.36.0
- v2.35.0
- v2.34.0
- v2.33.0
- v2.32.0
- v2.31.0
- v2.30.0
- v2.29.0
- v2.28.0
- v2.27.0
- v2.26.1
- v2.26.0
- v2.25.1
- v2.25.0
- v2.24.0
- v2.23.3
- v2.23.2
- v2.23.1
- v2.23.0
- v2.22.4
- v2.22.3
- v2.22.2
- v2.22.1
- v2.22.0
- v2.22.0b4
- v2.22.0b3
- v2.22.0b2
- v2.22.0b1
- v2.21.0
- v2.20.2
- v2.20.1
- v2.20.0
- v2.19.0
- v2.18.1
- v2.18.0
- v2.17.2
- v2.17.1
- v2.17.0
- v2.16.3
- v2.16.2
- v2.16.1
- v2.16.0
- v2.15.0
- v2.14.0
- v2.13.2
- v2.13.1
- v2.13.0
- v2.12.7
- v2.12.6
- v2.12.5
- v2.12.4
- v2.12.3
- v2.12.2
- v2.12.1
- v2.12.0
- v2.11.0
- v2.10.5
- v2.10.4
- v2.10.3
- v2.10.2
- v2.10.1
- v2.10.0
- v2.9.0
- v2.8.3
- v2.8.2
- v2.8.1
- v2.8.0
- v2.7.1
- v2.7.0
- v2.6.1
- v2.6.0
- v2.5.3
- v2.5.2
- v2.5.1
- v2.5.0
- v2.4.4
- v2.4.3
- v2.4.2
- v2.4.1
- v2.4.0
- v2.3.1
- v2.3.0
- v2.2.2
- v2.2.1
- v2.2.0
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- v2.0.2
- v2.0.1
- v2.0.0
- v1.0.1
- v1.0.0
- v1.0.0b19
- v1.0.0b18
- v1.0.0b17
- v1.0.0b16
- v1.0.0b15
- v1.0.0b14
- v1.0.0b13
- v1.0.0b12
- v1.0.0b11
- v1.0.0b10
- v1.0.0b9
- v1.0.0b8
- v1.0.0b7
- v1.0.0b6
- v1.0.0b5
- v1.0.0b4
- v1.0.0b3
- v1.0.0b2
- v1.0.0b1
- v1.0.0a4
- v1.0.0a3
- v1.0.0a2
- v0.15.2
- v0.15.1
- v0.15.0
- v0.14.0
- v0.13.3
- v0.13.2
- v0.13.1
- v0.13.0
- v0.12.0
- v0.11.0
- v0.10.0
- v0.9.0
- v0.8.8
- v0.8.7
- v0.8.6
- v0.8.5
- v0.8.4
- v0.8.3
- v0.8.2
- v0.8.1
- v0.8.0
- v0.7.5
- v0.7.4
- v0.7.3
- v0.7.2
- v0.7.1
- v0.7.0
- v0.6.0
- v0.5.0
- v0.4.4
- v0.4.3
- v0.4.2
- v0.4.1
- v0.4.0
- v0.3.2
- v0.3.1
- v0.3.0
- v0.2.5
- v0.2.4
- v0.2.3
- v0.2.2
- v0.2.1
- v0.2.0
- v0.1.0
- v0.0.7
- v0.0.6
- v0.0.5
- v0.0.4
- v0.0.3
- v0.0.2
- v0.0.1
- v0.0.1-pre
- 2.45.1
commit 74db4761812f587218331aa9bdcdb79561d8d30a
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,56 +0,0 @@ | ||
from ocrd.utils import getLogger | ||
log = getLogger('ocrd.processor') | ||
|
||
def run_processor(processor, mets_url=None, resolver=None, workspace=None): | ||
""" | ||
Create a workspace for mets_url and run processor through it | ||
""" | ||
if workspace is None: | ||
if resolver is None: | ||
raise Exception("Need to pass a resolver to create a workspace") | ||
if mets_url is None: | ||
raise Exception("Need to pass mets_url to create a workspace") | ||
workspace = resolver.create_workspace(mets_url) | ||
log.debug("Running processor %s", processor) | ||
processor(workspace).process() | ||
workspace.persist() | ||
|
||
class Processor(object): | ||
""" | ||
A processor runs an algorithm based on the workspace, the mets.xml in the | ||
workspace (and the input files defined therein) as well as optional | ||
parameters. | ||
""" | ||
|
||
def __init__(self, workspace, parameters=None, inputGrp="INPUT", outputGrp="OUTPUT"): | ||
self.workspace = workspace | ||
self.inputGrp = inputGrp | ||
self.outputGrp = outputGrp | ||
self.parameters = parameters if parameters is not None else {} | ||
|
||
def verify(self): | ||
""" | ||
Verify that the input is fulfills the processor's requirements. | ||
""" | ||
return True | ||
|
||
def process(self): | ||
""" | ||
Process the workspace | ||
""" | ||
raise Exception("Must be implemented") | ||
|
||
@property | ||
def input_files(self): | ||
""" | ||
List the input files | ||
""" | ||
return self.workspace.mets.files_in_group(self.inputGrp) | ||
|
||
def add_output_file(self, input_file=None, basename=None, **kwargs): | ||
""" | ||
Add an output file. | ||
""" | ||
if basename is None and input_file is not None: | ||
basename = input_file.basename_without_extension + '.xml' | ||
self.workspace.add_file(self.outputGrp, basename=basename, **kwargs) | ||
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
from ocrd.utils import getLogger | ||
log = getLogger('ocrd.processor') | ||
|
||
def run_processor(processor, mets_url=None, resolver=None, workspace=None): | ||
""" | ||
Create a workspace for mets_url and run processor through it | ||
""" | ||
if workspace is None: | ||
if resolver is None: | ||
raise Exception("Need to pass a resolver to create a workspace") | ||
if mets_url is None: | ||
raise Exception("Need to pass mets_url to create a workspace") | ||
workspace = resolver.create_workspace(mets_url) | ||
log.debug("Running processor %s", processor) | ||
processor(workspace).process() | ||
workspace.persist() | ||
|
||
class Processor(object): | ||
""" | ||
A processor runs an algorithm based on the workspace, the mets.xml in the | ||
workspace (and the input files defined therein) as well as optional | ||
parameters. | ||
""" | ||
|
||
def __init__(self, workspace, parameters=None, inputGrp="INPUT", outputGrp="OUTPUT"): | ||
self.workspace = workspace | ||
self.inputGrp = inputGrp | ||
self.outputGrp = outputGrp | ||
self.parameters = parameters if parameters is not None else {} | ||
|
||
def verify(self): | ||
""" | ||
Verify that the input is fulfills the processor's requirements. | ||
""" | ||
return True | ||
|
||
def process(self): | ||
""" | ||
Process the workspace | ||
""" | ||
raise Exception("Must be implemented") | ||
|
||
@property | ||
def input_files(self): | ||
""" | ||
List the input files | ||
""" | ||
return self.workspace.mets.files_in_group(self.inputGrp) | ||
|
||
def add_output_file(self, input_file=None, basename=None, **kwargs): | ||
""" | ||
Add an output file. | ||
""" | ||
if basename is None and input_file is not None: | ||
basename = input_file.basename_without_extension + '.xml' | ||
self.workspace.add_file(self.outputGrp, basename=basename, **kwargs) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Neat!