2017-09-02 03:43:21 +02:00
|
|
|
{ lib, fetchFromGitHub, buildPythonPackage, pillow, six
|
2018-04-11 13:31:32 +02:00
|
|
|
, tesseract, cuneiform, isPy3k
|
2017-09-02 03:43:21 +02:00
|
|
|
}:
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
2017-11-09 12:26:09 +01:00
|
|
|
pname = "pyocr";
|
2017-09-02 05:18:38 +02:00
|
|
|
version = "0.4.7";
|
2017-11-09 12:26:09 +01:00
|
|
|
name = pname + "-" + version;
|
2018-04-11 13:31:32 +02:00
|
|
|
disabled = !isPy3k;
|
2017-09-02 03:43:21 +02:00
|
|
|
|
|
|
|
# Don't fetch from PYPI because it doesn't contain tests.
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "jflesch";
|
|
|
|
repo = "pyocr";
|
|
|
|
rev = version;
|
2017-09-02 05:18:38 +02:00
|
|
|
sha256 = "1iw73r8yrgjf8g00yzpz62ymqbf89cqhyhl9g430srmsrq7mn2yd";
|
2017-09-02 03:43:21 +02:00
|
|
|
};
|
|
|
|
|
2017-09-02 05:18:38 +02:00
|
|
|
NIX_CUNEIFORM_CMD = "${cuneiform}/bin/cuneiform";
|
|
|
|
NIX_CUNEIFORM_DATA = "${cuneiform}/share/cuneiform";
|
|
|
|
NIX_LIBTESSERACT_PATH = "${tesseract}/lib/libtesseract.so";
|
|
|
|
NIX_TESSDATA_PREFIX = "${tesseract}/share/tessdata";
|
|
|
|
NIX_TESSERACT_CMD = "${tesseract}/bin/tesseract";
|
|
|
|
|
|
|
|
patches = [ ./paths.patch ];
|
2017-09-02 03:43:21 +02:00
|
|
|
|
|
|
|
postPatch = ''
|
2017-09-02 05:18:38 +02:00
|
|
|
substituteInPlace src/pyocr/cuneiform.py \
|
|
|
|
--subst-var NIX_CUNEIFORM_CMD \
|
|
|
|
--subst-var NIX_CUNEIFORM_CMD
|
|
|
|
|
|
|
|
substituteInPlace src/pyocr/tesseract.py \
|
|
|
|
--subst-var NIX_TESSERACT_CMD
|
|
|
|
|
|
|
|
substituteInPlace src/pyocr/libtesseract/tesseract_raw.py \
|
|
|
|
--subst-var NIX_TESSDATA_PREFIX \
|
|
|
|
--subst-var NIX_LIBTESSERACT_PATH
|
2017-09-02 03:43:21 +02:00
|
|
|
|
|
|
|
# Disable specific tests that are probably failing because of this issue:
|
|
|
|
# https://github.com/jflesch/pyocr/issues/52
|
|
|
|
for test in $disabledTests; do
|
|
|
|
file="''${test%%:*}"
|
|
|
|
fun="''${test#*:}"
|
|
|
|
echo "$fun = unittest.skip($fun)" >> "tests/tests_$file.py"
|
|
|
|
done
|
|
|
|
'';
|
|
|
|
|
|
|
|
disabledTests = [
|
|
|
|
"cuneiform:TestTxt.test_basic"
|
|
|
|
"cuneiform:TestTxt.test_european"
|
|
|
|
"cuneiform:TestTxt.test_french"
|
|
|
|
"cuneiform:TestWordBox.test_basic"
|
|
|
|
"cuneiform:TestWordBox.test_european"
|
|
|
|
"cuneiform:TestWordBox.test_french"
|
|
|
|
"libtesseract:TestBasicDoc.test_basic"
|
|
|
|
"libtesseract:TestDigitLineBox.test_digits"
|
|
|
|
"libtesseract:TestLineBox.test_japanese"
|
|
|
|
"libtesseract:TestTxt.test_japanese"
|
|
|
|
"libtesseract:TestWordBox.test_japanese"
|
|
|
|
"tesseract:TestDigitLineBox.test_digits"
|
|
|
|
"tesseract:TestTxt.test_japanese"
|
|
|
|
];
|
|
|
|
|
|
|
|
propagatedBuildInputs = [ pillow six ];
|
|
|
|
|
|
|
|
meta = {
|
|
|
|
homepage = "https://github.com/jflesch/pyocr";
|
|
|
|
description = "A Python wrapper for Tesseract and Cuneiform";
|
|
|
|
license = lib.licenses.gpl3Plus;
|
|
|
|
};
|
|
|
|
}
|