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
|
{
lib,
buildPythonPackage,
fetchFromGitHub,
jupyterlab,
nbexec,
pandas,
pandas-stubs,
pdfminer-six,
pillow,
pytest-parallel,
pytestCheckHook,
pythonOlder,
types-pillow,
wand,
}:
buildPythonPackage rec {
pname = "pdfplumber";
version = "0.11.0";
format = "setuptools";
disabled = pythonOlder "3.7";
src = fetchFromGitHub {
owner = "jsvine";
repo = "pdfplumber";
rev = "refs/tags/v${version}";
hash = "sha256-sjiCxE2WcvBASANCeookNn1n9M+mY0/8QGOCen+pzqM=";
};
postPatch = ''
substituteInPlace setup.cfg \
--replace "--cov=pdfplumber --cov-report xml:coverage.xml --cov-report term" ""
'';
propagatedBuildInputs = [
pdfminer-six
pillow
wand
];
preCheck = ''
export HOME=$(mktemp -d)
'';
nativeCheckInputs = [
jupyterlab
nbexec
pandas
pandas-stubs
pytest-parallel
pytestCheckHook
types-pillow
];
pythonImportsCheck = [ "pdfplumber" ];
disabledTests = [
# flaky
"test__repr_png_"
];
disabledTestPaths = [
# Tests requires pypdfium2
"tests/test_display.py"
# Tests requires pypdfium2
"tests/test_issues.py"
# Tests require Ghostscript
"tests/test_repair.py"
];
meta = with lib; {
description = "Plumb a PDF for detailed information about each char, rectangle, line, et cetera — and easily extract text and tables";
mainProgram = "pdfplumber";
homepage = "https://github.com/jsvine/pdfplumber";
changelog = "https://github.com/jsvine/pdfplumber/releases/tag/v${version}";
license = licenses.mit;
maintainers = with maintainers; [ happysalada ];
};
}
|