gnu: webkitgtk: Update to 2.28.2.
[jackhill/guix/guix.git] / gnu / packages / python-xyz.scm
1 ;;; GNU Guix --- Functional package management for GNU
2 ;;; Copyright © 2013 Nikita Karetnikov <nikita@karetnikov.org>
3 ;;; Copyright © 2013, 2014, 2015, 2016, 2017, 2018, 2019, 2020 Ludovic Courtès <ludo@gnu.org>
4 ;;; Copyright © 2013, 2014, 2015, 2016, 2019 Andreas Enge <andreas@enge.fr>
5 ;;; Copyright © 2014, 2015 Mark H Weaver <mhw@netris.org>
6 ;;; Copyright © 2014, 2017 Eric Bavier <bavier@member.fsf.org>
7 ;;; Copyright © 2014, 2015 Federico Beffa <beffa@fbengineering.ch>
8 ;;; Copyright © 2015 Omar Radwan <toxemicsquire4@gmail.com>
9 ;;; Copyright © 2015 Pierre-Antoine Rault <par@rigelk.eu>
10 ;;; Copyright © 2015, 2016, 2017, 2018, 2019, 2020 Ricardo Wurmus <rekado@elephly.net>
11 ;;; Copyright © 2015, 2016, 2020 Christopher Allan Webber <cwebber@dustycloud.org>
12 ;;; Copyright © 2015 Eric Dvorsak <eric@dvorsak.fr>
13 ;;; Copyright © 2015, 2016 David Thompson <davet@gnu.org>
14 ;;; Copyright © 2015, 2016, 2017, 2019 Leo Famulari <leo@famulari.name>
15 ;;; Copyright © 2015, 2017 Ben Woodcroft <donttrustben@gmail.com>
16 ;;; Copyright © 2015, 2016 Erik Edrosa <erik.edrosa@gmail.com>
17 ;;; Copyright © 2015, 2016, 2017, 2018, 2019, 2020 Efraim Flashner <efraim@flashner.co.il>
18 ;;; Copyright © 2015, 2017 Kyle Meyer <kyle@kyleam.com>
19 ;;; Copyright © 2015, 2016 Chris Marusich <cmmarusich@gmail.com>
20 ;;; Copyright © 2016 Danny Milosavljevic <dannym+a@scratchpost.org>
21 ;;; Copyright © 2016 Lukas Gradl <lgradl@openmailbox.org>
22 ;;; Copyright © 2016, 2018, 2019 Hartmut Goebel <h.goebel@crazy-compilers.com>
23 ;;; Copyright © 2016 Daniel Pimentel <d4n1@d4n1.org>
24 ;;; Copyright © 2016 Sou Bunnbu <iyzsong@gmail.com>
25 ;;; Copyright © 2016, 2017 Troy Sankey <sankeytms@gmail.com>
26 ;;; Copyright © 2016, 2017 ng0 <ng0@n0.is>
27 ;;; Copyright © 2016 Dylan Jeffers <sapientech@sapientech@openmailbox.org>
28 ;;; Copyright © 2016 David Craven <david@craven.ch>
29 ;;; Copyright © 2016, 2017, 2018, 2019, 2020 Marius Bakke <mbakke@fastmail.com>
30 ;;; Copyright © 2016, 2017 Stefan Reichör <stefan@xsteve.at>
31 ;;; Copyright © 2016, 2017, 2019 Alex Vong <alexvong1995@gmail.com>
32 ;;; Copyright © 2016, 2017, 2018 Arun Isaac <arunisaac@systemreboot.net>
33 ;;; Copyright © 2016, 2017, 2018, 2020 Julien Lepiller <julien@lepiller.eu>
34 ;;; Copyright © 2016, 2017, 2018, 2019, 2020 Tobias Geerinckx-Rice <me@tobias.gr>
35 ;;; Copyright © 2016, 2017 Thomas Danckaert <post@thomasdanckaert.be>
36 ;;; Copyright © 2017 Carlo Zancanaro <carlo@zancanaro.id.au>
37 ;;; Copyright © 2017 Frederick M. Muriithi <fredmanglis@gmail.com>
38 ;;; Copyright © 2017, 2018 Adriano Peluso <catonano@gmail.com>
39 ;;; Copyright © 2017 Ben Sturmfels <ben@sturm.com.au>
40 ;;; Copyright © 2017, 2018, 2019 Mathieu Othacehe <m.othacehe@gmail.com>
41 ;;; Copyright © 2017 José Miguel Sánchez García <jmi2k@openmailbox.org>
42 ;;; Copyright © 2017 Roel Janssen <roel@gnu.org>
43 ;;; Copyright © 2017, 2018, 2019 Kei Kebreau <kkebreau@posteo.net>
44 ;;; Copyright © 2017 Rutger Helling <rhelling@mykolab.com>
45 ;;; Copyright © 2017 Muriithi Frederick Muriuki <fredmanglis@gmail.com>
46 ;;; Copyright © 2017, 2019 Brendan Tildesley <mail@brendan.scot>
47 ;;; Copyright © 2018 Ethan R. Jones <ethanrjones97@gmail.com
48 ;;; Copyright © 2018 Fis Trivial <ybbs.daans@hotmail.com>
49 ;;; Copyright © 2018 Vijayalakshmi Vedantham <vijimay12@gmail.com>
50 ;;; Copyright © 2018 Mathieu Lirzin <mthl@gnu.org>
51 ;;; Copyright © 2018 Adam Massmann <massmannak@gmail.com>
52 ;;; Copyright © 2016, 2018 Tomáš Čech <sleep_walker@gnu.org>
53 ;;; Copyright © 2018, 2019, 2020 Nicolas Goaziou <mail@nicolasgoaziou.fr>
54 ;;; Copyright © 2018 Oleg Pykhalov <go.wigust@gmail.com>
55 ;;; Copyright © 2018, 2019 Clément Lassieur <clement@lassieur.org>
56 ;;; Copyright © 2018, 2019, 2020 Maxim Cournoyer <maxim.cournoyer@gmail.com>
57 ;;; Copyright © 2018 Luther Thompson <lutheroto@gmail.com>
58 ;;; Copyright © 2018 Vagrant Cascadian <vagrant@debian.org>
59 ;;; Copyright © 2019, 2020 Brett Gilio <brettg@gnu.org>
60 ;;; Copyright © 2019 Sam <smbaines8@gmail.com>
61 ;;; Copyright © 2019 Jack Hill <jackhill@jackhill.us>
62 ;;; Copyright © 2019, 2020 Guillaume Le Vaillant <glv@posteo.net>
63 ;;; Copyright © 2019, 2020 Alex Griffin <a@ajgrf.com>
64 ;;; Copyright © 2019 Pierre Langlois <pierre.langlois@gmx.com>
65 ;;; Copyright © 2019 Jacob MacDonald <jaccarmac@gmail.com>
66 ;;; Copyright © 2019 Giacomo Leidi <goodoldpaul@autistici.org>
67 ;;; Copyright © 2019 Wiktor Żelazny <wzelazny@vurv.cz>
68 ;;; Copyright © 2019, 2020 Tanguy Le Carrour <tanguy@bioneland.org>
69 ;;; Copyright © 2019 Mădălin Ionel Patrașcu <madalinionel.patrascu@mdc-berlin.de>
70 ;;; Copyright © 2020 Jakub Kądziołka <kuba@kadziolka.net>
71 ;;; Copyright © 2020 sirgazil <sirgazil@zoho.com>
72 ;;; Copyright © 2020 Sebastian Schott <sschott@mailbox.org>
73 ;;; Copyright © 2020 Alexandros Theodotou <alex@zrythm.org>
74 ;;; Copyright © 2020 Josh Marshall <joshua.r.marshall.1991@gmail.com>
75 ;;; Copyright © 2020 Alexandros Theodotou <alex@zrythm.org>
76 ;;; Copyright © 2020 Lars-Dominik Braun <ldb@leibniz-psychology.org>
77 ;;; Copyright © 2020 Alex ter Weele <alex.ter.weele@gmail.com>
78 ;;; Copyright © 2020 Matthew Kraai <kraai@ftbfs.org>
79 ;;;
80 ;;; This file is part of GNU Guix.
81 ;;;
82 ;;; GNU Guix is free software; you can redistribute it and/or modify it
83 ;;; under the terms of the GNU General Public License as published by
84 ;;; the Free Software Foundation; either version 3 of the License, or (at
85 ;;; your option) any later version.
86 ;;;
87 ;;; GNU Guix is distributed in the hope that it will be useful, but
88 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
89 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
90 ;;; GNU General Public License for more details.
91 ;;;
92 ;;; You should have received a copy of the GNU General Public License
93 ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
94
95 (define-module (gnu packages python-xyz)
96 #:use-module ((guix licenses) #:prefix license:)
97 #:use-module (gnu packages)
98 #:use-module (gnu packages algebra)
99 #:use-module (gnu packages adns)
100 #:use-module (gnu packages attr)
101 #:use-module (gnu packages backup)
102 #:use-module (gnu packages bash)
103 #:use-module (gnu packages check)
104 #:use-module (gnu packages compression)
105 #:use-module (gnu packages crypto)
106 #:use-module (gnu packages databases)
107 #:use-module (gnu packages dbm)
108 #:use-module (gnu packages enchant)
109 #:use-module (gnu packages file)
110 #:use-module (gnu packages fontutils)
111 #:use-module (gnu packages gcc)
112 #:use-module (gnu packages geo)
113 #:use-module (gnu packages ghostscript)
114 #:use-module (gnu packages gl)
115 #:use-module (gnu packages glib)
116 #:use-module (gnu packages gnome)
117 #:use-module (gnu packages graphviz)
118 #:use-module (gnu packages graphics)
119 #:use-module (gnu packages gsasl)
120 #:use-module (gnu packages gstreamer)
121 #:use-module (gnu packages gtk)
122 #:use-module (gnu packages icu4c)
123 #:use-module (gnu packages image)
124 #:use-module (gnu packages imagemagick)
125 #:use-module (gnu packages kerberos)
126 #:use-module (gnu packages libevent)
127 #:use-module (gnu packages libffi)
128 #:use-module (gnu packages linux)
129 #:use-module (gnu packages llvm)
130 #:use-module (gnu packages man)
131 #:use-module (gnu packages maths)
132 #:use-module (gnu packages monitoring)
133 #:use-module (gnu packages multiprecision)
134 #:use-module (gnu packages networking)
135 #:use-module (gnu packages ncurses)
136 #:use-module (gnu packages openstack)
137 #:use-module (gnu packages pcre)
138 #:use-module (gnu packages perl)
139 #:use-module (gnu packages photo)
140 #:use-module (gnu packages pkg-config)
141 #:use-module (gnu packages python)
142 #:use-module (gnu packages python-check)
143 #:use-module (gnu packages python-compression)
144 #:use-module (gnu packages python-crypto)
145 #:use-module (gnu packages python-science)
146 #:use-module (gnu packages python-web)
147 #:use-module (gnu packages qt)
148 #:use-module (gnu packages readline)
149 #:use-module (gnu packages sdl)
150 #:use-module (gnu packages search)
151 #:use-module (gnu packages shells)
152 #:use-module (gnu packages sphinx)
153 #:use-module (gnu packages ssh)
154 #:use-module (gnu packages terminals)
155 #:use-module (gnu packages tex)
156 #:use-module (gnu packages texinfo)
157 #:use-module (gnu packages time)
158 #:use-module (gnu packages tls)
159 #:use-module (gnu packages version-control)
160 #:use-module (gnu packages video)
161 #:use-module (gnu packages web)
162 #:use-module (gnu packages base)
163 #:use-module (gnu packages xml)
164 #:use-module (gnu packages xorg)
165 #:use-module (gnu packages xdisorg)
166 #:use-module (gnu packages tcl)
167 #:use-module (gnu packages bdw-gc)
168 #:use-module (gnu packages serialization)
169 #:use-module (guix packages)
170 #:use-module (guix download)
171 #:use-module (guix git-download)
172 #:use-module (guix hg-download)
173 #:use-module (guix utils)
174 #:use-module (guix build-system gnu)
175 #:use-module (guix build-system cmake)
176 #:use-module (guix build-system python)
177 #:use-module (guix build-system trivial)
178 #:use-module (srfi srfi-1)
179 #:use-module (srfi srfi-26))
180
181 (define-public python-tenacity
182 (package
183 (name "python-tenacity")
184 (version "6.1.0")
185 (source (origin
186 (method url-fetch)
187 (uri (pypi-uri "tenacity" version))
188 (sha256
189 (base32
190 "1j36v9fcpmmd4985ix0cwnvcq71rkrn5cjiiv0id9vkl4kpxh0gv"))))
191 (build-system python-build-system)
192 (native-inputs
193 `(("python-setuptools-scm" ,python-setuptools-scm)
194 ("python-sphinx" ,python-sphinx)
195 ("python-tornado" ,python-tornado)
196 ("python-pytest" ,python-pytest)))
197 (propagated-inputs
198 `(("python-six" ,python-six)))
199 (arguments
200 `(#:phases (modify-phases %standard-phases
201 (replace 'check
202 (lambda _
203 (invoke "pytest")
204 #t)))))
205 (home-page "https://github.com/jd/tenacity")
206 (synopsis "Retrying library for python")
207 (description "Tenacity is a general-purpose python library to simplify the
208 task of adding retry behavior to just about anything.")
209 (license license:asl2.0)))
210
211 (define-public python-colorlog
212 (package
213 (name "python-colorlog")
214 (version "4.1.0")
215 (source (origin
216 (method url-fetch)
217 (uri (pypi-uri "colorlog" version))
218 (sha256
219 (base32
220 "1lpk8zmfv8vz090h5d0hzb4n39wgasxdd3x3bpn3v1x1n9dfzaih"))))
221 (build-system python-build-system)
222 (native-inputs
223 `(("python-pytest" ,python-pytest)))
224 (arguments
225 `(#:phases (modify-phases %standard-phases
226 (replace 'check
227 (lambda _
228 ;; Extend PYTHONPATH so the built package will be found.
229 (setenv "PYTHONPATH"
230 (string-append (getcwd) "/build/lib:"
231 (getenv "PYTHONPATH")))
232 (invoke "pytest" "-p" "no:logging")
233 #t)))))
234 (home-page "https://github.com/borntyping/python-colorlog")
235 (synopsis "Log formatting with colors for python")
236 (description "The @code{colorlog.ColoredFormatter} is a formatter for use
237 with Python's logging module that outputs records using terminal colors.")
238 (license license:expat)))
239
240 (define-public python-pyprind
241 (package
242 (name "python-pyprind")
243 (version "2.11.2")
244 (source (origin
245 (method url-fetch)
246 (uri (pypi-uri "PyPrind" version))
247 (sha256
248 (base32
249 "0xg6m5hr33h9bdlrr42kc58jm2m87a9zsagy7n2m4n407d2snv64"))))
250 (build-system python-build-system)
251 (propagated-inputs
252 `(("python-psutil" ,python-psutil)))
253 (home-page "https://github.com/rasbt/pyprind")
254 (synopsis "Python Progress Bar and Percent Indicator Utility")
255 (description "The PyPrind (Python Progress Indicator) module provides a
256 progress bar and a percentage indicator object that let you track the progress
257 of a loop structure or other iterative computation.")
258 (license license:bsd-3)))
259
260 (define-public python-gphoto2
261 (package
262 (name "python-gphoto2")
263 (version "2.2.1")
264 (source (origin
265 (method url-fetch)
266 (uri (pypi-uri "gphoto2" version))
267 (sha256
268 (base32
269 "118zm25c8mlajfl0pzssnwz4b8lamj9dgymla9rn4nla7l244a0r"))))
270 (build-system python-build-system)
271 (native-inputs
272 `(("pkg-config" ,pkg-config)))
273 (inputs
274 `(("libgphoto2" ,libgphoto2)))
275 (home-page "https://github.com/jim-easterbrook/python-gphoto2")
276 (synopsis "Python interface to libgphoto2")
277 (description "@code{python-gphoto2} is a comprehensive Python interface
278 (or binding) to @code{libgphoto2}. It is built using @code{SWIG} to
279 automatically generate the interface code.")
280 (license license:gpl3+)))
281
282 (define-public python-colour
283 (package
284 (name "python-colour")
285 (version "0.1.5")
286 (source (origin
287 (method url-fetch)
288 (uri (pypi-uri "colour" version))
289 (sha256
290 (base32
291 "1visbisfini5j14bdzgs95yssw6sm4pfzyq1n3lfvbyjxw7i485g"))))
292 (build-system python-build-system)
293 (native-inputs
294 `(("python-d2to1" ,python-d2to1)))
295 (home-page "https://github.com/vaab/colour")
296 (synopsis "Convert and manipulate various color representations")
297 (description "Pythonic way to manipulate color representations (HSL, RVB,
298 web, X11, ...).")
299 (license license:expat)))
300
301 (define-public python-d2to1
302 (package
303 (name "python-d2to1")
304 (version "0.2.12.post1")
305 (source (origin
306 (method url-fetch)
307 (uri (pypi-uri "d2to1" version))
308 (sha256
309 (base32
310 "09fq7pq1z8d006xh5z75rm2lk61v6yn2xhy53z4gsgibhqb2vvs9"))))
311 (build-system python-build-system)
312 (native-inputs
313 `(("python-nose" ,python-nose)))
314 (home-page "https://github.com/embray/d2to1")
315 (synopsis "Allows for distutils2-like setup.cfg files as package metadata
316 in python")
317 (description "The python package d2to1 (the d is for distutils) allows
318 using distutils2-like setup.cfg files for a package's metadata with a
319 distribute/setuptools setup.py script.")
320 (license license:bsd-2)))
321
322 (define-public python-rawkit
323 (package
324 (name "python-rawkit")
325 (version "0.6.0")
326 (source (origin
327 (method url-fetch)
328 (uri (pypi-uri "rawkit" version))
329 (sha256
330 (base32
331 "0vrhrpr70i61y5q5ysk341x1539ff1q1k82g59zq69lv16s0f76s"))))
332 (build-system python-build-system)
333 (native-inputs
334 `(("python-pytest" ,python-pytest)
335 ("python-mock" ,python-mock)))
336 (inputs
337 `(("libraw" ,libraw)))
338 (home-page "https://rawkit.readthedocs.io")
339 (synopsis "Ctypes-based LibRaw binding for Python")
340 (description "The rawkit package provides two modules: rawkit and libraw.
341 The rawkit module provides a high-level Pythonic interface for developing raw
342 photos, while the libraw module provides a CTypes based interface for
343 interacting with the low-level LibRaw C APIs.")
344 (license license:expat)))
345
346 (define-public python-easygui
347 (package
348 (name "python-easygui")
349 (version "0.98.1")
350 (source (origin
351 (method url-fetch)
352 (uri (pypi-uri "easygui" version))
353 (sha256
354 (base32
355 "1zmvmwgxyzvm83818skhn8b4wrci4kmnixaax8q3ia5cn7xrmj6v"))))
356 (build-system python-build-system)
357 (propagated-inputs
358 `(("python-tkinter" ,python "tk")))
359 (home-page "https://github.com/robertlugg/easygui")
360 (synopsis "GUI programming module for Python")
361 (description "EasyGUI is a module for very simple, very easy GUI
362 programming in Python. EasyGUI is different from other GUI generators in that
363 EasyGUI is NOT event-driven. Instead, all GUI interactions are invoked by
364 simple function calls.")
365 (license license:bsd-3)))
366
367 (define-public python-pymediainfo
368 (package
369 (name "python-pymediainfo")
370 (version "4.1")
371 (source
372 (origin
373 (method url-fetch)
374 (uri (pypi-uri "pymediainfo" version))
375 (sha256
376 (base32
377 "0mhpxs7vlqx8w75z93dy7nnvx89kwfdjkla03l19an15rlyqyspd"))))
378 (build-system python-build-system)
379 (native-inputs
380 `(("python-setuptools-scm" ,python-setuptools-scm)
381 ("python-pytest" ,python-pytest)))
382 (inputs
383 `(("libmediainfo" ,libmediainfo)))
384 (arguments
385 `(#:phases
386 (modify-phases %standard-phases
387 (add-after 'unpack 'patch-libmediainfo
388 (lambda _
389 (substitute* "pymediainfo/__init__.py"
390 (("libmediainfo.so.0")
391 (string-append (assoc-ref %build-inputs "libmediainfo")
392 "/lib/libmediainfo.so.0")))
393 #t))
394 (replace 'check
395 (lambda _
396 ;; Extend PYTHONPATH so the built package will be found.
397 (setenv "PYTHONPATH"
398 (string-append (getcwd) "/build/lib:"
399 (getenv "PYTHONPATH")))
400 ;; Skip the only failing test "test_parse_url"
401 (invoke "pytest" "-vv" "-k" "not test_parse_url")
402 #t)))))
403 (home-page
404 "https://github.com/sbraz/pymediainfo")
405 (synopsis
406 "Python wrapper for the mediainfo library")
407 (description
408 "Python wrapper for the mediainfo library to access the technical and tag
409 data for video and audio files.")
410 (license license:expat)))
411
412 (define-public python-psutil
413 (package
414 (name "python-psutil")
415 (version "5.6.5")
416 (source
417 (origin
418 (method url-fetch)
419 (uri (pypi-uri "psutil" version))
420 (sha256
421 (base32 "0isil5jxwwd8awz54qk28rpgjg43i5l6yl70g40vxwa4r4m56lfh"))))
422 (build-system python-build-system)
423 (arguments
424 ;; FIXME: some tests does not return and times out.
425 '(#:tests? #f))
426 (home-page "https://www.github.com/giampaolo/psutil")
427 (synopsis "Library for retrieving information on running processes")
428 (description
429 "psutil (Python system and process utilities) is a library for retrieving
430 information on running processes and system utilization (CPU, memory, disks,
431 network) in Python. It is useful mainly for system monitoring, profiling and
432 limiting process resources and management of running processes. It implements
433 many functionalities offered by command line tools such as: ps, top, lsof,
434 netstat, ifconfig, who, df, kill, free, nice, ionice, iostat, iotop, uptime,
435 pidof, tty, taskset, pmap.")
436 (properties `((python2-variant . ,(delay python2-psutil))))
437 (license license:bsd-3)))
438
439 (define-public python2-psutil
440 (let ((base (package-with-python2 (strip-python2-variant python-psutil))))
441 (package
442 (inherit base)
443 (propagated-inputs
444 `(("python2-enum34" ,python2-enum34) ;optional
445 ,@(package-propagated-inputs base))))))
446
447 (define-public python-shapely
448 (package
449 (name "python-shapely")
450 (version "1.6.4.post2")
451 (source
452 (origin
453 (method url-fetch)
454 (uri (pypi-uri "Shapely" version))
455 (sha256
456 (base32
457 "03r42fmd9alp6r3q95ad6rldq2f7n1wimrw53zy5kpn33yv7pf64"))))
458 (build-system python-build-system)
459 (native-inputs
460 `(("python-cython" ,python-cython)
461 ("python-matplotlib" ,python-matplotlib)
462 ("python-pytest" ,python-pytest)
463 ("python-pytest-cov" ,python-pytest-cov)))
464 (inputs
465 `(("geos" ,geos)))
466 (propagated-inputs
467 `(("python-numpy" ,python-numpy)))
468 (arguments
469 `(#:phases
470 (modify-phases %standard-phases
471 (add-after 'unpack 'patch-geos-path
472 (lambda* (#:key inputs #:allow-other-keys)
473 (let ((geos (assoc-ref inputs "geos"))
474 (glibc (assoc-ref inputs ,(if (%current-target-system)
475 "cross-libc" "libc"))))
476 (substitute* "shapely/geos.py"
477 (("_lgeos = load_dll\\('geos_c', fallbacks=.*\\)")
478 (string-append "_lgeos = load_dll('geos_c', fallbacks=['"
479 geos "/lib/libgeos_c.so'])"))
480 (("free = load_dll\\('c'\\)\\.free")
481 (string-append "free = load_dll('c', fallbacks=['"
482 glibc "/lib/libc.so.6']).free"))))
483 #t)))))
484 (home-page "https://github.com/Toblerity/Shapely")
485 (synopsis "Library for the manipulation and analysis of geometric objects")
486 (description "Shapely is a Python package for manipulation and analysis of
487 planar geometric objects. It is based on the @code{GEOS} library.")
488 (license license:bsd-3)))
489
490 (define-public python-shortuuid
491 (package
492 (name "python-shortuuid")
493 (version "0.5.0")
494 (source
495 (origin
496 (method url-fetch)
497 (uri (pypi-uri "shortuuid" version))
498 (sha256
499 (base32
500 "1f8i4zwj5vmpzbz6b17bljy4399gx5aq7vsyw63sz2qgyjcd73yh"))))
501 (build-system python-build-system)
502 (native-inputs
503 `(("python-pep8" ,python-pep8)))
504 (home-page "https://github.com/skorokithakis/shortuuid")
505 (synopsis "Generator library for concise, unambiguous and URL-safe UUIDs")
506 (description
507 "@code{shortuuid} is a Python library for generating concise, unambiguous
508 and URL-safe UUIDs. UUIDs are generated using the built-in Python @code{uuid}
509 module and then similar looking characters are removed.")
510 (license license:bsd-3)))
511
512 (define-public python-logwrap
513 (package
514 (name "python-logwrap")
515 (version "3.2.1")
516 (source
517 (origin
518 (method url-fetch)
519 (uri (pypi-uri "logwrap" version ".zip"))
520 (sha256
521 (base32
522 "1d2k0hvpbi51vl410y8fbs5m0nxnlh2k7gr2nrh3k81ibhzscsra"))))
523 (build-system python-build-system)
524 (propagated-inputs
525 `(("python-six" ,python-six)
526 ("python-typing" ,python-typing)))
527 (native-inputs
528 `(("unzip" ,unzip)
529 ("python-cython" ,python-cython)
530 ("python-pytest" ,python-pytest)
531 ("python-pytest-cov" ,python-pytest-cov)
532 ("python-pytest-runner" ,python-pytest-runner)))
533 (home-page "https://github.com/penguinolog/logwrap")
534 (synopsis "Decorator for logging function arguments")
535 (description "This package provides a decorator to log function arguments
536 and function call return values in a human-readable way.")
537 (license license:asl2.0)))
538
539 (define-public python2-shapely
540 (package-with-python2 python-shapely))
541
542 (define-public python-clyent
543 (package
544 (name "python-clyent")
545 (version "1.2.1")
546 (source
547 (origin
548 (method url-fetch)
549 (uri (pypi-uri "clyent" version))
550 (sha256
551 (base32
552 "1r9987qmy1pz3hq54160bapqsywpq14waw4w9x3ly8hmq7kpgfbj"))))
553 (build-system python-build-system)
554 (native-inputs
555 `(("python-mock" ,python-mock)))
556 (home-page "https://github.com/binstar/clyent")
557 (synopsis "Command line client library")
558 (description "Clyent is a Python command line utiliy library. It is used
559 by @code{binstar}, @code{binstar-build} and @code{chalmers}.")
560 (license license:bsd-3)))
561
562 (define-public python2-clyent
563 (package-with-python2 python-clyent))
564
565 (define-public python-babel
566 (package
567 (name "python-babel")
568 (version "2.8.0")
569 (source
570 (origin
571 (method url-fetch)
572 (uri (pypi-uri "Babel" version))
573 (sha256
574 (base32
575 "0f0f2vvs1mpdpz2c0mg1mnc3sih8bizmc1h9m67kdsnqs3i2mb0s"))))
576 (build-system python-build-system)
577 (native-inputs
578 `(("python-freezegun" ,python-freezegun)
579 ("python-pytest" ,python-pytest)))
580 (propagated-inputs
581 `(("python-pytz" ,python-pytz)))
582 (arguments
583 `(#:phases (modify-phases %standard-phases
584 (replace 'check
585 (lambda _
586 (invoke "pytest" "-vv" "-k"
587 (string-append
588 ;; XXX: These tests fail when using Pytest 4.x and
589 ;; Babel 2.6.0. Try removing this for later versions.
590 "not test_no_inherit_metazone_marker_never_in_output"
591 " and not test_smoke_dates"
592 " and not test_smoke_numbers")))))))
593 (home-page "http://babel.pocoo.org/")
594 (synopsis
595 "Tools for internationalizing Python applications")
596 (description
597 "Babel is composed of two major parts:
598 - tools to build and work with gettext message catalogs
599 - a Python interface to the CLDR (Common Locale Data Repository), providing
600 access to various locale display names, localized number and date formatting,
601 etc. ")
602 (license license:bsd-3)))
603
604 (define-public python2-babel
605 (package-with-python2 python-babel))
606
607 ;; Sphinx < 2.0 requires this version. Remove once no longer needed.
608 (define-public python2-babel-2.6
609 (package
610 (inherit python2-babel)
611 (version "2.6.0")
612 (source (origin
613 (method url-fetch)
614 (uri (pypi-uri "Babel" version))
615 (sha256
616 (base32
617 "08rxmbx2s4irp0w0gmn498vns5xy0fagm0fg33xa772jiks51flc"))))))
618
619 (define-public python2-backport-ssl-match-hostname
620 (package
621 (name "python2-backport-ssl-match-hostname")
622 (version "3.5.0.1")
623 (source
624 (origin
625 (method url-fetch)
626 (uri (pypi-uri "backports.ssl_match_hostname" version))
627 (sha256
628 (base32
629 "1wndipik52cyqy0677zdgp90i435pmvwd89cz98lm7ri0y3xjajh"))))
630 (build-system python-build-system)
631 (arguments
632 `(#:python ,python-2
633 #:tests? #f)) ; no test target
634 (home-page "https://bitbucket.org/brandon/backports.ssl_match_hostname")
635 (synopsis "Backport of ssl.match_hostname() function from Python 3.5")
636 (description
637 "This backport brings the ssl.match_hostname() function to users of
638 earlier versions of Python. The function checks the hostname in the
639 certificate returned by the server to which a connection has been established,
640 and verifies that it matches the intended target hostname.")
641 (license license:psfl)))
642
643 (define-public python-boolean.py
644 (package
645 (name "python-boolean.py")
646 (version "3.6")
647 (source
648 (origin
649 ;; There's no source tarball on PyPI.
650 (method git-fetch)
651 (uri (git-reference
652 (url "https://github.com/bastikr/boolean.py")
653 (commit (string-append "v" version))))
654 (file-name (git-file-name name version))
655 (sha256
656 (base32 "1wc89y73va58cj7dsx6c199zpxsy9q53dsffsdj6zmc90inqz6qs"))))
657 (build-system python-build-system)
658 (home-page "https://github.com/bastikr/boolean.py")
659 (synopsis "Boolean algebra in one Python module")
660 (description
661 "This is a small Python library that implements boolean algebra.
662 It defines two base elements, @code{TRUE} and @code{FALSE}, and a
663 @code{Symbol} class that can take on one of these two values. Calculations
664 are done only in terms of @code{AND}, @code{OR}, and @code{NOT}---other
665 compositions like @code{XOR} and @code{NAND} are emulated on top of them.
666 Expressions are constructed from parsed strings or directly in Python.")
667 (license license:bsd-2)))
668
669 (define-public python-hdf4
670 (package
671 (name "python-hdf4")
672 (version "0.9")
673 (source
674 (origin
675 (method url-fetch)
676 (uri (pypi-uri name version))
677 (sha256
678 (base32
679 "1hjiyrxvxk9817qyqky3nar4y3fs4z8wxz0n884zzb5wi6skrjks"))))
680 (build-system python-build-system)
681 (native-inputs `(("nose" ,python-nose)))
682 (propagated-inputs `(("numpy" ,python-numpy)))
683 (inputs
684 `(("hdf4" ,hdf4)
685 ("libjpeg" ,libjpeg)
686 ("zlib" ,zlib)))
687 (arguments
688 `(#:phases
689 (modify-phases %standard-phases
690 (replace 'check
691 (lambda _
692 ;; The 'runexamples' script sets PYTHONPATH to CWD, then goes
693 ;; on to import numpy. Somehow this works on their CI system.
694 ;; Let's just manage PYTHONPATH here instead.
695 (substitute* "runexamples.sh"
696 (("export PYTHONPATH=.*") ""))
697 (setenv "PYTHONPATH"
698 (string-append (getcwd) ":"
699 (getenv "PYTHONPATH")))
700 (invoke "./runexamples.sh")
701 (invoke "nosetests" "-v"))))))
702 (home-page "https://github.com/fhs/python-hdf4")
703 (synopsis "Python interface to the NCSA HDF4 library")
704 (description
705 "Python-HDF4 is a python wrapper around the NCSA HDF version 4 library,
706 which implements the SD (Scientific Dataset), VS (Vdata) and V (Vgroup) API’s.
707 NetCDF files can also be read and modified. Python-HDF4 is a fork of
708 @url{http://hdfeos.org/software/pyhdf.php,pyhdf}.")
709 (license license:expat)))
710
711 (define-public python2-hdf4
712 (package-with-python2 python-hdf4))
713
714 (define-public python-h5py
715 (package
716 (name "python-h5py")
717 (version "2.10.0")
718 (source
719 (origin
720 (method url-fetch)
721 (uri (pypi-uri "h5py" version))
722 (sha256
723 (base32
724 "0baipzv8n93m0dq0riyi8rfhzrjrfrfh8zqhszzp1j2xjac2fhc4"))))
725 (build-system python-build-system)
726 (arguments
727 `(#:tests? #f ; no test target
728 #:phases
729 (modify-phases %standard-phases
730 (add-after 'unpack 'fix-hdf5-paths
731 (lambda* (#:key inputs #:allow-other-keys)
732 (let ((prefix (assoc-ref inputs "hdf5")))
733 (substitute* "setup_build.py"
734 (("\\['/opt/local/lib', '/usr/local/lib'\\]")
735 (string-append "['" prefix "/lib" "']"))
736 (("'/opt/local/include', '/usr/local/include'")
737 (string-append "'" prefix "/include" "'")))
738 (substitute* "setup_configure.py"
739 (("\\['/usr/local/lib', '/opt/local/lib'\\]")
740 (string-append "['" prefix "/lib" "']")))
741 #t))))))
742 (propagated-inputs
743 `(("python-six" ,python-six)
744 ("python-numpy" ,python-numpy)))
745 (inputs
746 `(("hdf5" ,hdf5-1.10)))
747 (native-inputs
748 `(("python-cython" ,python-cython)
749 ("python-pkgconfig" ,python-pkgconfig)
750 ("pkg-config" ,pkg-config)))
751 (home-page "https://www.h5py.org/")
752 (synopsis "Read and write HDF5 files from Python")
753 (description
754 "The h5py package provides both a high- and low-level interface to the
755 HDF5 library from Python. The low-level interface is intended to be a
756 complete wrapping of the HDF5 API, while the high-level component supports
757 access to HDF5 files, datasets and groups using established Python and NumPy
758 concepts.")
759 (license license:bsd-3)))
760
761 (define-public python2-h5py
762 (package-with-python2 python-h5py))
763
764 (define-public python-sh
765 (package
766 (name "python-sh")
767 (version "1.12.14")
768 (source
769 (origin
770 (method url-fetch)
771 (uri (pypi-uri "sh" version))
772 (sha256
773 (base32
774 "1z2hx357xp3v4cv44xmqp7lli3frndqpyfmpbxf7n76h7s1zaaxm"))))
775 (build-system python-build-system)
776 (arguments
777 '(#:phases
778 (modify-phases %standard-phases
779 (replace 'check
780 (lambda _
781 ;; XXX: A Python 2 test fails when HOME=/homeless-shelter.
782 (setenv "HOME" "/tmp")
783 (invoke "python" "sh.py" "test"))))))
784 (native-inputs
785 `(("python-coverage" ,python-coverage)))
786 (home-page "https://github.com/amoffat/sh")
787 (synopsis "Python subprocess replacement")
788 (description "This package provides a replacement for Python's
789 @code{subprocess} feature.")
790 (license license:expat)))
791
792 (define-public python2-sh
793 (package-with-python2 python-sh))
794
795 (define-public python-cftime
796 (package
797 (name "python-cftime")
798 (version "1.0.4.2")
799 (source
800 (origin
801 (method url-fetch)
802 (uri (pypi-uri "cftime" version))
803 (sha256
804 (base32 "0w0gi6jnch38hiygl62j4xkcirv4y3dcwrvxl9p7bsk6j27lzihs"))))
805 (build-system python-build-system)
806 (propagated-inputs
807 `(("python-numpy" ,python-numpy)))
808 (native-inputs
809 `(("python-coveralls" ,python-coveralls)
810 ("python-cython" ,python-cython)
811 ("python-pytest-cov" ,python-pytest-cov)))
812 (home-page "https://github.com/Unidata/cftime")
813 (synopsis "Library for time handling")
814 (description
815 "This package provides time-handling functionality that used to be part
816 of the netcdf4 package before.")
817 ;; This package claims to include code under the GPLv3 but is released
818 ;; under ISC.
819 (license (list license:isc license:gpl3+))))
820
821 (define-public python-netcdf4
822 (package
823 (name "python-netcdf4")
824 (version "1.4.2")
825 (source
826 (origin
827 (method url-fetch)
828 (uri (pypi-uri "netCDF4" version))
829 (sha256
830 (base32
831 "0c0sklgrmv15ygliin8qq0hp7vanmbi74m6zpi0r1ksr0hssyd5r"))))
832 (build-system python-build-system)
833 (arguments
834 '(#:phases
835 (modify-phases %standard-phases
836 (add-after 'unpack 'configure-locations
837 (lambda* (#:key inputs #:allow-other-keys)
838 (setenv "HDF5_DIR" (assoc-ref inputs "hdf5"))
839 #t)))))
840 (native-inputs
841 `(("python-cython" ,python-cython)))
842 (propagated-inputs
843 `(("python-numpy" ,python-numpy)
844 ("python-cftime" ,python-cftime)))
845 (inputs
846 `(("netcdf" ,netcdf)
847 ("hdf4" ,hdf4)
848 ("hdf5" ,hdf5)))
849 (home-page "https://github.com/Unidata/netcdf4-python")
850 (synopsis "Python/numpy interface to the netCDF library")
851 (description "Netcdf4-python is a Python interface to the netCDF C
852 library. netCDF version 4 has many features not found in earlier
853 versions of the library and is implemented on top of HDF5. This module
854 can read and write files in both the new netCDF 4 and the old netCDF 3
855 format, and can create files that are readable by HDF5 clients. The
856 API is modelled after @code{Scientific.IO.NetCDF}, and should be familiar
857 to users of that module.")
858 ;; The software is mainly ISC, but includes some files covered
859 ;; by the Expat license.
860 (license (list license:isc license:expat))))
861
862 (define-public python2-netcdf4
863 (package-with-python2 python-netcdf4))
864
865 (define-public python-license-expression
866 (package
867 (name "python-license-expression")
868 (version "0.999")
869 (source
870 (origin
871 (method url-fetch)
872 (uri (pypi-uri "license-expression" version))
873 (sha256
874 (base32 "08ppb0bxbrsxazy88sgpl9yffvdsabw6dkk1nc332wcz2mphwwyf"))))
875 (build-system python-build-system)
876 (propagated-inputs
877 `(("python-boolean.py" ,python-boolean.py)))
878 (home-page "https://github.com/nexB/license-expression")
879 (synopsis "Apply boolean logic to license expressions")
880 (description
881 "This Python module defines a tiny language to evaluate and compare
882 license expressions using boolean logic. Logical combinations of licenses can
883 be tested for equality, containment, and equivalence. They can be normalised
884 and simplified. It supports SPDX license expressions as well as other naming
885 conventions and aliases in the same expression.")
886 (license license:gpl2+)))
887
888 (define-public python-lockfile
889 (package
890 (name "python-lockfile")
891 (version "0.12.2")
892 (source
893 (origin
894 (method url-fetch)
895 (uri (pypi-uri "lockfile" version))
896 (sha256
897 (base32
898 "16gpx5hm73ah5n1079ng0vy381hl802v606npkx4x8nb0gg05vba"))))
899 (build-system python-build-system)
900 (arguments '(#:test-target "check"))
901 (native-inputs
902 `(("python-pbr" ,python-pbr)))
903 (home-page "https://launchpad.net/pylockfile")
904 (synopsis "Platform-independent file locking module")
905 (description
906 "The lockfile package exports a LockFile class which provides a simple
907 API for locking files.")
908 (license license:expat)))
909
910 (define-public python2-lockfile
911 (package-with-python2 python-lockfile))
912
913 (define-public python-filelock
914 (package
915 (name "python-filelock")
916 (version "3.0.12")
917 (source
918 (origin
919 (method url-fetch)
920 (uri (pypi-uri "filelock" version))
921 (sha256
922 (base32
923 "0ngzlvb5j8gqs2nxlp2b0jhzii792h66wsn694qm8kqixr225n0q"))))
924 (build-system python-build-system)
925 (home-page
926 "https://github.com/benediktschmitt/py-filelock")
927 (synopsis "Platform independent file lock")
928 (description "@code{filelock} contains a single module implementing
929 a platform independent file lock in Python, which provides a simple way of
930 inter-process communication.")
931 (license license:unlicense)))
932
933 (define-public python-semantic-version
934 (package
935 (name "python-semantic-version")
936 (version "2.6.0")
937 (source
938 (origin
939 (method url-fetch)
940 (uri (pypi-uri "semantic_version" version))
941 (sha256
942 (base32
943 "1h2l9xyg1zzsda6kjcmfcgycbvrafwci283vcr1v5sbk01l2hhra"))))
944 (build-system python-build-system)
945 (arguments
946 `(#:tests? #f)) ; PyPI tarball lacks tests
947 (home-page "https://github.com/rbarrois/python-semanticversion")
948 (synopsis "Semantic versioning module for Python")
949 (description
950 "The @code{semantic_version} class is a small library for handling
951 @uref{https://semver.org/, semantic versioning} (@dfn{SemVer}) in Python.
952
953 It can compare versions, generate a new version that represents a bump in one of
954 the version levels, and check whether any given string is a proper semantic
955 version identifier.")
956 (license license:bsd-3)))
957
958 (define-public python2-semantic-version
959 (package-with-python2 python-semantic-version))
960
961 (define-public python-serpent
962 (package
963 (name "python-serpent")
964 (version "1.28")
965 (source
966 (origin
967 (method url-fetch)
968 (uri (pypi-uri "serpent" version))
969 (sha256
970 (base32 "1arnckykpkvv2qrp49l1k7q5mr5pisswl0rvdx98x8wsl1n361pk"))))
971 (build-system python-build-system)
972 (native-inputs
973 `(("python-attrs" ,python-attrs)
974 ("python-pytz" ,python-pytz)))
975 (home-page "https://github.com/irmen/Serpent")
976 (synopsis "Serializer for literal Python expressions")
977 (description
978 "Serpent provides @code{ast.literal_eval()}-compatible object tree
979 serialization. It serializes an object tree into bytes (an utf-8 encoded
980 string) that can be decoded and then passed as-is to @code{ast.literal_eval()}
981 to rebuild the original object tree.
982
983 Because only safe literals are encoded, it is safe to send serpent data to
984 other machines, such as over the network.")
985 (properties `((python2-variant . ,(delay python2-serpent))))
986 (license license:expat)))
987
988 (define-public python2-serpent
989 (let ((base (package-with-python2 (strip-python2-variant python-serpent))))
990 (package
991 (inherit base)
992 (propagated-inputs
993 `(("python-enum34" ,python2-enum34)
994 ,@(package-propagated-inputs base))))))
995
996 (define-public python-setuptools
997 (package
998 (name "python-setuptools")
999 (version "41.0.1")
1000 (source
1001 (origin
1002 (method url-fetch)
1003 (uri (pypi-uri "setuptools" version ".zip"))
1004 (sha256
1005 (base32
1006 "04sns22y2hhsrwfy1mha2lgslvpjsjsz8xws7h2rh5a7ylkd28m2"))
1007 (modules '((guix build utils)))
1008 (snippet
1009 '(begin
1010 ;; Remove included binaries which are used to build self-extracting
1011 ;; installers for Windows.
1012 ;; TODO: Find some way to build them ourself so we can include them.
1013 (for-each delete-file (find-files "setuptools" "^(cli|gui).*\\.exe$"))
1014 #t))))
1015 (build-system python-build-system)
1016 ;; FIXME: Tests require pytest, which itself relies on setuptools.
1017 ;; One could bootstrap with an internal untested setuptools.
1018 (arguments
1019 `(#:tests? #f))
1020 (home-page "https://pypi.org/project/setuptools/")
1021 (synopsis
1022 "Library designed to facilitate packaging Python projects")
1023 (description
1024 "Setuptools is a fully-featured, stable library designed to facilitate
1025 packaging Python projects, where packaging includes:
1026 Python package and module definitions,
1027 distribution package metadata,
1028 test hooks,
1029 project installation,
1030 platform-specific details,
1031 Python 3 support.")
1032 ;; TODO: setuptools now bundles the following libraries:
1033 ;; packaging, pyparsing, six and appdirs. How to unbundle?
1034 (license (list license:psfl ; setuptools itself
1035 license:expat ; six, appdirs, pyparsing
1036 license:asl2.0 ; packaging is dual ASL2/BSD-2
1037 license:bsd-2))))
1038
1039 (define-public python2-setuptools
1040 (package-with-python2 python-setuptools))
1041
1042 ;; The setuptools provided by Python 3.7.4 is too new for Tensorflow.
1043 (define-public python-setuptools-for-tensorflow
1044 (hidden-package
1045 (package
1046 (inherit python-setuptools)
1047 (version "39.1.0")
1048 (source (origin
1049 (inherit (package-source python-setuptools))
1050 (uri (pypi-uri "setuptools" version ".zip"))
1051 (sha256
1052 (base32
1053 "1mzdhvfhnv4lggxa8rjl0dzqxvfx377gg5sqs57v89wrp09lwj65")))))))
1054
1055 (define-public python-uniseg
1056 (package
1057 (name "python-uniseg")
1058 (version "0.7.1")
1059 (source
1060 (origin
1061 (method url-fetch)
1062 (uri (pypi-uri "uniseg" version ".zip"))
1063 (sha256
1064 (base32
1065 "05jsazvz6nbmh6l3v1rph5ydkqn1hzx1pyggdyvgp2qgmgrnmiz2"))))
1066 (build-system python-build-system)
1067 (arguments
1068 '(#:tests? #f)) ; The test suite requires network access.
1069 (native-inputs
1070 `(("unzip" ,unzip)))
1071 (home-page
1072 "https://bitbucket.org/emptypage/uniseg-python")
1073 (synopsis
1074 "Python library to determine Unicode text segmentations")
1075 (description
1076 "Uniseg is a Python package used to determine Unicode text segmentations.
1077 Supported segmentations include:
1078 @enumerate
1079 @item @dfn{Code point} (any value in the Unicode codespace)
1080 @item @dfn{Grapheme cluster} (user-perceived character made of a single or
1081 multiple Unicode code points, e.g. \"G\" + acute-accent)
1082 @item Word break
1083 @item Sentence break
1084 @item Line break
1085 @end enumerate")
1086 (license license:expat)))
1087
1088 (define-public python2-uniseg
1089 (package-with-python2 python-uniseg))
1090
1091 (define-public python-humanfriendly
1092 (package
1093 (name "python-humanfriendly")
1094 (version "4.4.1")
1095 (source
1096 (origin
1097 (method url-fetch)
1098 (uri (pypi-uri "humanfriendly" version))
1099 (sha256
1100 (base32
1101 "0pisgizjql86785jchfjv217g0lsgk114g2lja5j4y3lsc3b9szi"))))
1102 (build-system python-build-system)
1103 (arguments
1104 `(;; XXX: Tests depend on coloredlogs, which in turn depends on humanfriendly.
1105 #:tests? #f))
1106 (propagated-inputs
1107 `(("python-monotonic" ,python-monotonic)))
1108 (home-page "https://humanfriendly.readthedocs.io")
1109 (synopsis "Human-friendly input and output in Python")
1110 (description
1111 "The functions and classes in @code{humanfriendly} can be used to make
1112 text interfaces more user-friendly. It includes tools to parse and format
1113 numbers, file sizes, and timespans, timers for long-running operations, menus
1114 to allow the user to choose from a list of options, and terminal interaction
1115 helpers.")
1116 (license license:expat)))
1117
1118 (define-public python2-humanfriendly
1119 (package-with-python2 python-humanfriendly))
1120
1121 (define-public python-textparser
1122 (package
1123 (name "python-textparser")
1124 (version "0.23.0")
1125 (source
1126 (origin
1127 (method url-fetch)
1128 (uri (pypi-uri "textparser" version))
1129 (sha256
1130 (base32
1131 "0w5lyhrsvzs5a9q1l3sjgxgljrvd3ybf796w93kc39wayzvd02gh"))))
1132 (build-system python-build-system)
1133 (home-page "https://github.com/eerimoq/textparser")
1134 (synopsis "Fast text parser for Python")
1135 (description "This library provides a text parser written in the Python
1136 language. It aims to be fast.")
1137 (license license:expat)))
1138
1139 (define-public python-aenum
1140 (package
1141 (name "python-aenum")
1142 (version "2.2.3")
1143 (source
1144 (origin
1145 (method url-fetch)
1146 (uri (pypi-uri "aenum" version))
1147 (sha256
1148 (base32
1149 "1s3008rklv4n1kvmq6xdbdfyrpl0gf1rhqasmd27s5kwyjmlqcx4"))))
1150 (build-system python-build-system)
1151 (arguments
1152 `(#:phases (modify-phases %standard-phases
1153 (replace 'check
1154 (lambda _
1155 (format #t "current working dir ~s~%" (getcwd))
1156 (setenv "PYTHONPATH"
1157 (string-append ".:" (getenv "PYTHONPATH")))
1158 ;; We must run the test suite module directly, as it
1159 ;; fails to define the 'tempdir' variable in scope for
1160 ;; the tests otherwise
1161 ;; (see:https://bitbucket.org/stoneleaf/aenum/\
1162 ;; issues/32/running-tests-with-python-setuppy-test).
1163 (invoke "python3" "aenum/test.py")
1164 ;; This one fails with "NameError: name
1165 ;; 'test_pickle_dump_load' is not defined" (see:
1166 ;; https://bitbucket.org/stoneleaf/aenum/issues/33
1167 ;; /error-running-the-test_v3py-test-suite).
1168 ;; (invoke "python3" "aenum/test_v3.py")
1169 #t)))))
1170 (home-page "https://bitbucket.org/stoneleaf/aenum")
1171 (synopsis "Advanced enumerations, namedtuples and constants for Python")
1172 (description "The aenum library includes an @code{Enum} base class, a
1173 metaclass-based @code{NamedTuple} implementation and a @code{NamedConstant}
1174 class.")
1175 (license license:bsd-3)))
1176
1177 (define-public python-can
1178 (package
1179 (name "python-can")
1180 (version "3.3.2")
1181 (source
1182 (origin
1183 (method url-fetch)
1184 (uri (pypi-uri "python-can" version))
1185 (sha256
1186 (base32
1187 "0bkbxi45sckzir6s0j3h01pkfn4vkz3ymih2zjp7zw77wz0vbvsz"))))
1188 (build-system python-build-system)
1189 (arguments
1190 `(#:phases (modify-phases %standard-phases
1191 (add-after 'unpack 'fix-broken-tests
1192 ;; The tests try to run two scripts it expects should be
1193 ;; in PATH, but they aren't at this time (see:
1194 ;; https://github.com/hardbyte/python-can/issues/805).
1195 (lambda _
1196 (substitute* "test/test_scripts.py"
1197 (("\"can_logger\\.py --help\"") "")
1198 (("\"can_player\\.py --help\"") ""))
1199 #t)))))
1200 (propagated-inputs
1201 `(("python-aenum" ,python-aenum)
1202 ("python-wrapt" ,python-wrapt)))
1203 (native-inputs
1204 `(("python-codecov" ,python-codecov)
1205 ("python-future" ,python-future)
1206 ("python-hypothesis" ,python-hypothesis)
1207 ("python-mock" ,python-mock)
1208 ("python-pyserial" ,python-pyserial)
1209 ("python-pytest" ,python-pytest)
1210 ("python-pytest-cov" ,python-pytest-cov)
1211 ("python-pytest-runner" ,python-pytest-runner)
1212 ("python-pytest-timeout" ,python-pytest-timeout)))
1213 (home-page "https://github.com/hardbyte/python-can")
1214 (synopsis "Controller Area Network (CAN) interface module for Python")
1215 (description "This package defines the @code{can} module, which provides
1216 controller area network (CAN) support for Python developers; providing common
1217 abstractions to different hardware devices, and a suite of utilities for
1218 sending and receiving messages on a CAN bus.")
1219 (license license:gpl3+)))
1220
1221 (define-public python-diskcache
1222 (package
1223 (name "python-diskcache")
1224 (version "4.1.0")
1225 (source
1226 (origin
1227 (method url-fetch)
1228 (uri (pypi-uri "diskcache" version))
1229 (sha256
1230 (base32
1231 "1q2wz5sj16zgyy1zpq516qgbnfwsavk1pl2qks0f4r62z5cmmvmw"))))
1232 (build-system python-build-system)
1233 (arguments
1234 `(#:tests? #f)) ;test suite not included in the release
1235 (home-page "http://www.grantjenks.com/docs/diskcache/")
1236 (synopsis "Disk and file backed cache library")
1237 (description "DiskCache is a disk and file backed persistent cache.")
1238 (license license:asl2.0)))
1239
1240 (define-public python-bitstruct
1241 (package
1242 (name "python-bitstruct")
1243 (version "8.9.0")
1244 (source
1245 (origin
1246 (method url-fetch)
1247 (uri (pypi-uri "bitstruct" version))
1248 (sha256
1249 (base32
1250 "1fpc1qh1vss05ap29xvhjp200fm0q4pvgcjl0qpryh7ay6xgr5vx"))))
1251 (build-system python-build-system)
1252 (home-page "https://github.com/eerimoq/bitstruct")
1253 (synopsis "Python values to and C bit field structs converter")
1254 (description "This module performs conversions between Python values and C
1255 bit field structs represented as Python byte strings. It is intended to have
1256 a similar interface as the @code{struct} module from Python, but working on
1257 bits instead of primitive data types like @code{char}, @code{int}, etc.")
1258 (license license:expat)))
1259
1260 (define-public python-cantools
1261 (package
1262 (name "python-cantools")
1263 (version "33.1.1")
1264 (source
1265 (origin
1266 ;; We take the sources from the Git repository as the documentation is
1267 ;; not included with the PyPI archive.
1268 (method git-fetch)
1269 (uri (git-reference
1270 (url "https://github.com/eerimoq/cantools.git")
1271 (commit version)))
1272 (file-name (git-file-name name version))
1273 (sha256
1274 (base32
1275 "1aad137yd8b4jkfvlv812qsxmxcgra7g1p4wbxfsjy1cbf8fbq9q"))))
1276 (build-system python-build-system)
1277 (arguments
1278 `(#:phases
1279 (modify-phases %standard-phases
1280 (add-after 'build 'build-doc
1281 (lambda _
1282 ;; See: https://github.com/eerimoq/cantools/issues/190.
1283 (substitute* "README.rst"
1284 (("https://github.com/eerimoq/cantools/raw/master\
1285 /docs/monitor.png")
1286 "monitor.png"))
1287 (with-directory-excursion "docs"
1288 (invoke "make" "man" "info"))))
1289 (add-after 'install 'install-doc
1290 (lambda* (#:key outputs #:allow-other-keys)
1291 (let* ((out (assoc-ref outputs "out"))
1292 (info (string-append out "/share/info"))
1293 (man1 (string-append out "/share/man/man1")))
1294 (format #t "CWD: ~s~%" (getcwd))
1295 (install-file "docs/_build/texinfo/cantools.info" info)
1296 (install-file "docs/_build/man/cantools.1" man1)
1297 #t))))))
1298 (native-inputs
1299 `(("sphinx" ,python-sphinx)
1300 ("texinfo" ,texinfo)))
1301 (propagated-inputs
1302 `(("python-bitstruct" ,python-bitstruct)
1303 ("python-can" ,python-can)
1304 ("python-diskcache" ,python-diskcache)
1305 ("python-textparser" ,python-textparser)))
1306 (home-page "https://github.com/eerimoq/cantools")
1307 (synopsis "Tools for the Controller Area Network (CAN) bus protocol")
1308 (description "This package includes Controller Area Network (CAN) related
1309 tools that can be used to:
1310 @itemize
1311 @item parse DBC, KCD, SYM, ARXML 4 and CDD files
1312 @item encode and decode CAN messages
1313 @item multiplex simple and extended signals
1314 @item diagnose DID encoding and decoding
1315 @item dump the CAN decoder output
1316 @item test CAN nodes
1317 @item generate C source code
1318 @item monitor the CAN bus
1319 @end itemize")
1320 (license license:expat)))
1321
1322 (define-public python-capturer
1323 (package
1324 (name "python-capturer")
1325 (version "2.4")
1326 (source
1327 (origin
1328 (method url-fetch)
1329 (uri (pypi-uri "capturer" version))
1330 (sha256
1331 (base32
1332 "05d6ji4j8ipiq0br7bwam38qc6hd9l1djmfxlzrxx19ziyjl4089"))))
1333 (build-system python-build-system)
1334 (arguments
1335 `(#:tests? #f))
1336 (propagated-inputs
1337 `(("python-humanfriendly" ,python-humanfriendly)))
1338 (home-page "https://capturer.readthedocs.io")
1339 (synopsis "Capture stdout and stderr streams of the current process")
1340 (description
1341 "The capturer package makes it easy to capture the stdout and stderr
1342 streams of the current process and subprocesses. Output can be relayed
1343 to the terminal in real time but is also available to the Python program
1344 for additional processing.")
1345 (license license:expat)))
1346
1347 (define-public python2-capturer
1348 (package-with-python2 python-capturer))
1349
1350 (define-public python-case
1351 (package
1352 (name "python-case")
1353 (version "1.5.3")
1354 (source
1355 (origin
1356 (method url-fetch)
1357 (uri (pypi-uri "case" version))
1358 (sha256
1359 (base32
1360 "1cagg06vfph864s6l5jb0zqliwxh647bki8j6lf4a4qrv40jnhs8"))))
1361 (build-system python-build-system)
1362 (propagated-inputs
1363 `(("python-mock" ,python-mock)
1364 ("python-nose" ,python-nose)
1365 ("python-six" ,python-six)
1366 ("python-unittest2" ,python-unittest2)))
1367 (native-inputs
1368 `(("python-coverage" ,python-coverage)))
1369 (home-page "https://github.com/celery/case")
1370 (synopsis "Unittest utilities and convenience methods")
1371 (description
1372 "The @code{case} package provides utilities on top of unittest, including
1373 some helpful Python 2 compatibility convenience methods.")
1374 (license license:bsd-3)))
1375
1376 (define-public python-verboselogs
1377 (package
1378 (name "python-verboselogs")
1379 (version "1.7")
1380 (source
1381 (origin
1382 (method url-fetch)
1383 (uri (pypi-uri "verboselogs" version))
1384 (sha256
1385 (base32
1386 "09z4d1jiasn7k1hs5af2ckmnrd0i1d1m04bhfjhv7z6svzfdwgg3"))))
1387 (build-system python-build-system)
1388 (arguments
1389 `(#:phases
1390 (modify-phases %standard-phases
1391 (replace 'check
1392 (lambda _
1393 ;; Do not run pylint plugin test, as astroid is an old
1394 ;; unsupported version.
1395 (invoke "pytest" "-v" "-k" "not test_pylint_plugin"
1396 "verboselogs/tests.py"))))))
1397 (native-inputs
1398 `(("python-mock" ,python-mock)
1399 ("python-pytest" ,python-pytest)))
1400 (home-page "https://verboselogs.readthedocs.io")
1401 (synopsis "Verbose logging level for Python's logging module")
1402 (description
1403 "The @code{verboselogs} package extends Python's @code{logging} module to
1404 add the log levels NOTICE, SPAM, SUCCESS and VERBOSE.")
1405 (license license:expat)))
1406
1407 (define-public python2-verboselogs
1408 (package-with-python2 python-verboselogs))
1409
1410 (define-public python-coloredlogs
1411 (package
1412 (name "python-coloredlogs")
1413 (version "10.0")
1414 (source
1415 (origin
1416 (method url-fetch)
1417 (uri (pypi-uri "coloredlogs" version))
1418 (sha256
1419 (base32
1420 "0dkw6xp0r1dwgz4s2f58npx5nxfq51wf4l6qkm5ib27slgfs4sdq"))))
1421 (build-system python-build-system)
1422 (arguments
1423 `(;Tests require some updated modules
1424 #:tests? #f))
1425 (propagated-inputs
1426 `(("python-capturer" ,python-capturer)))
1427 (home-page "https://coloredlogs.readthedocs.io")
1428 (synopsis "Colored stream handler for Python's logging module")
1429 (description
1430 "The @code{coloredlogs} package enables colored terminal output for
1431 Python's logging module. The @code{ColoredFormatter} class inherits from
1432 @code{logging.Formatter} and uses ANSI escape sequences to render your logging
1433 messages in color.")
1434 (license license:expat)))
1435
1436 (define-public python2-coloredlogs
1437 (package-with-python2 python-coloredlogs))
1438
1439 (define-public python-editorconfig
1440 (package
1441 (name "python-editorconfig")
1442 (version "0.12.2")
1443 (source
1444 (origin
1445 (method url-fetch)
1446 (uri (pypi-uri "EditorConfig" version))
1447 (sha256
1448 (base32
1449 "0v55z351p9qkyp3bbspwywwn28sbcknhirngjbj779n3z52z63hv"))))
1450 (build-system python-build-system)
1451 (home-page "https://editorconfig.org/")
1452 (synopsis "EditorConfig bindings for python")
1453 (description "The EditorConfig project consists of a file format for
1454 defining coding styles and a collection of text editor plugins that enable
1455 editors to read the file format and adhere to defined styles. EditorConfig
1456 files are easily readable and they work nicely with version control systems.")
1457 ;; "fnmatch.py" and "ini.py" are licensed under psfl, the rest is bsd-2.
1458 (license (list license:bsd-2 license:psfl))))
1459
1460 (define-public python-et-xmlfile
1461 (package
1462 (name "python-et-xmlfile")
1463 (version "1.0.1")
1464 (source
1465 (origin
1466 (method url-fetch)
1467 (uri (pypi-uri "et_xmlfile" version))
1468 (sha256
1469 (base32
1470 "0nrkhcb6jdrlb6pwkvd4rycw34y3s931hjf409ij9xkjsli9fkb1"))))
1471 (build-system python-build-system)
1472 (arguments
1473 `(#:phases (modify-phases %standard-phases
1474 (replace 'check
1475 (lambda _
1476 (invoke "pytest"))))))
1477 (native-inputs
1478 `(("python-pytest" ,python-pytest)
1479 ("python-lxml" ,python-lxml))) ;used for the tests
1480 (home-page "https://bitbucket.org/openpyxl/et_xmlfile")
1481 (synopsis "Low memory implementation of @code{lxml.xmlfile}")
1482 (description "This Python library is based upon the @code{xmlfile} module
1483 from @code{lxml}. It aims to provide a low memory, compatible implementation
1484 of @code{xmlfile}.")
1485 (license license:expat)))
1486
1487 (define-public python2-et-xmlfile
1488 (package-with-python2 python-et-xmlfile))
1489
1490 (define-public python-openpyxl
1491 (package
1492 (name "python-openpyxl")
1493 (version "2.6.2")
1494 (source
1495 (origin
1496 ;; We use the upstream repository, as the tests are not included in the
1497 ;; PyPI releases.
1498 (method hg-fetch)
1499 (uri (hg-reference
1500 (url "https://bitbucket.org/openpyxl/openpyxl")
1501 (changeset version)))
1502 (file-name (string-append name "-" version "-checkout"))
1503 (sha256
1504 (base32 "1qhij6kcvdxqjy4g6193nsv4q7fy8n4fwyd3c2z047idlm6s3j4w"))))
1505 (build-system python-build-system)
1506 (arguments
1507 `(#:phases (modify-phases %standard-phases
1508 (replace 'check
1509 (lambda _
1510 (invoke "pytest"))))))
1511 (native-inputs
1512 ;; For the test suite.
1513 `(("python-lxml" ,python-lxml)
1514 ("python-pillow" ,python-pillow)
1515 ("python-pytest" ,python-pytest)))
1516 (propagated-inputs
1517 `(("python-et-xmlfile" ,python-et-xmlfile)
1518 ("python-jdcal" ,python-jdcal)))
1519 (home-page "https://openpyxl.readthedocs.io")
1520 (synopsis "Python library to read/write Excel 2010 XLSX/XLSM files")
1521 (description "This Python library allows reading and writing to the Excel XLSX, XLSM,
1522 XLTX and XLTM file formats that are defined by the Office Open XML (OOXML)
1523 standard.")
1524 (license license:expat)))
1525
1526 (define-public python-eventlet
1527 (package
1528 (name "python-eventlet")
1529 (version "0.25.1")
1530 (source
1531 (origin
1532 (method url-fetch)
1533 (uri (pypi-uri "eventlet" version))
1534 (sha256
1535 (base32
1536 "1hgz8jq19wlz8vwqj900ry8cjv578nz4scc91mlc8944yid6573c"))))
1537 (build-system python-build-system)
1538 (propagated-inputs
1539 `(("python-greenlet" ,python-greenlet)))
1540 (arguments
1541 ;; TODO: Requires unpackaged 'enum-compat'.
1542 '(#:tests? #f))
1543 (home-page "https://eventlet.net")
1544 (synopsis "Concurrent networking library for Python")
1545 (description
1546 "Eventlet is a concurrent networking library for Python that
1547 allows you to change how you run your code, not how you write it.
1548 It uses @code{epoll} or @code{libevent} for highly scalable non-blocking I/O.
1549 Coroutines ensure that the developer uses a blocking style of programming
1550 that is similar to threading, but provide the benefits of non-blocking I/O.
1551 The event dispatch is implicit, which means you can easily use @code{Eventlet}
1552 from the Python interpreter, or as a small part of a larger application.")
1553 (license license:expat)))
1554
1555 (define-public python2-eventlet
1556 (let ((base (package-with-python2
1557 (strip-python2-variant python-eventlet))))
1558 (package (inherit base)
1559 (propagated-inputs
1560 `(("python2-enum34" ,python2-enum34)
1561 ,@(package-propagated-inputs base))))))
1562
1563 (define-public python-six
1564 (package
1565 (name "python-six")
1566 (version "1.12.0")
1567 (source
1568 (origin
1569 (method url-fetch)
1570 (uri (pypi-uri "six" version))
1571 (sha256
1572 (base32
1573 "0wxs1q74v07ssjywbbm7x6h5v9qx209ld2yfsif4060sxi0h2sni"))))
1574 (build-system python-build-system)
1575 (arguments
1576 `(#:phases
1577 (modify-phases %standard-phases
1578 (replace 'check
1579 (lambda _
1580 (invoke "py.test" "-v"))))))
1581 (native-inputs
1582 `(("python-py" ,python-py)
1583 ("python-pytest" ,python-pytest-bootstrap)))
1584 (home-page "https://pypi.org/project/six/")
1585 (synopsis "Python 2 and 3 compatibility utilities")
1586 (description
1587 "Six is a Python 2 and 3 compatibility library. It provides utility
1588 functions for smoothing over the differences between the Python versions with
1589 the goal of writing Python code that is compatible on both Python versions.
1590 Six supports every Python version since 2.5. It is contained in only one
1591 Python file, so it can be easily copied into your project.")
1592 (license license:x11)))
1593
1594 (define-public python2-six
1595 (package-with-python2 python-six))
1596
1597 (define-public python-six-bootstrap
1598 (package
1599 (inherit python-six)
1600 (name "python-six-bootstrap")
1601 (native-inputs `())
1602 (arguments `(#:tests? #f))))
1603
1604 (define-public python2-six-bootstrap
1605 (package-with-python2 python-six-bootstrap))
1606
1607 (define-public python-schedule
1608 (package
1609 (name "python-schedule")
1610 (version "0.4.3")
1611 (source
1612 (origin
1613 (method url-fetch)
1614 (uri (pypi-uri "schedule" version))
1615 (sha256
1616 (base32
1617 "0vplyjcbfrq50sphlwya749z8p2pcyi2nycw3518i0qpd9a6189i"))))
1618 (build-system python-build-system)
1619 (native-inputs
1620 `(("python-pytest" ,python-pytest)
1621 ("python-mock" ,python-mock)))
1622 (home-page "https://github.com/dbader/schedule")
1623 (synopsis "Schedule periodic function calls in Python")
1624 (description
1625 "Schedule is an in-process scheduler for periodic jobs that uses the
1626 builder pattern for configuration. Schedule lets you run Python functions (or
1627 any other callable) periodically at pre-determined intervals using a simple,
1628 human-friendly syntax.")
1629 (license license:expat)))
1630
1631 (define-public python2-schedule
1632 (package-with-python2 python-schedule))
1633
1634 (define-public python2-mechanize
1635 (package
1636 (name "python2-mechanize")
1637 (version "0.2.5")
1638 (source
1639 (origin
1640 (method url-fetch)
1641 (uri (pypi-uri "mechanize" version))
1642 (sha256
1643 (base32
1644 "0rj7r166i1dyrq0ihm5rijfmvhs8a04im28lv05c0c3v206v4rrf"))))
1645 (build-system python-build-system)
1646 (arguments
1647 `(#:python ,python-2 ; apparently incompatible with Python 3
1648 #:tests? #f))
1649 ;; test fails with message
1650 ;; AttributeError: 'module' object has no attribute 'test_pullparser'
1651 ;; (python-3.3.2) or
1652 ;; AttributeError: 'module' object has no attribute 'test_urllib2_localnet'
1653 ;; (python-2.7.5).
1654 ;; The source code is from March 2011 and probably not up-to-date
1655 ;; with respect to python unit tests.
1656 (home-page "http://wwwsearch.sourceforge.net/mechanize/")
1657 (synopsis
1658 "Stateful programmatic web browsing in Python")
1659 (description
1660 "Mechanize implements stateful programmatic web browsing in Python,
1661 after Andy Lester’s Perl module WWW::Mechanize.")
1662 (license (license:non-copyleft
1663 "file://COPYING"
1664 "See COPYING in the distribution."))))
1665
1666
1667 (define-public python-simplejson
1668 (package
1669 (name "python-simplejson")
1670 (version "3.14.0")
1671 (source
1672 (origin
1673 (method url-fetch)
1674 (uri (pypi-uri "simplejson" version))
1675 (sha256
1676 (base32
1677 "1lkv3xlf7ryzi69zqfdbkvpxdfy1rg1rq2yzcnxgf4km5m6difqy"))))
1678 (build-system python-build-system)
1679 (home-page "http://simplejson.readthedocs.org/en/latest/")
1680 (synopsis
1681 "Json library for Python")
1682 (description
1683 "JSON (JavaScript Object Notation) is a subset of JavaScript
1684 syntax (ECMA-262 3rd edition) used as a lightweight data interchange
1685 format.
1686
1687 Simplejson exposes an API familiar to users of the standard library marshal
1688 and pickle modules. It is the externally maintained version of the json
1689 library contained in Python 2.6, but maintains compatibility with Python 2.5
1690 and (currently) has significant performance advantages, even without using
1691 the optional C extension for speedups. Simplejson is also supported on
1692 Python 3.3+.")
1693 (license license:x11)))
1694
1695 (define-public python2-simplejson
1696 (package-with-python2 python-simplejson))
1697
1698
1699 (define-public python-pyicu
1700 (package
1701 (name "python-pyicu")
1702 (version "2.4.3")
1703 (source
1704 (origin
1705 (method url-fetch)
1706 (uri (pypi-uri "PyICU" version))
1707 (sha256
1708 (base32
1709 "075bw66b3w0nw6mc5k32fwmrhyrmq3d7da3q2mw212qfmm0pgjn0"))))
1710 (build-system python-build-system)
1711 (inputs
1712 `(("icu4c" ,icu4c)))
1713 (native-inputs
1714 `(("python-pytest" ,python-pytest)
1715 ("python-six" ,python-six)))
1716 (home-page "https://github.com/ovalhub/pyicu")
1717 (synopsis "Python extension wrapping the ICU C++ API")
1718 (description
1719 "PyICU is a python extension wrapping the ICU C++ API.")
1720 (license license:x11)))
1721
1722 (define-public python2-pyicu
1723 (package-with-python2 python-pyicu))
1724
1725 (define-public python2-dogtail
1726 ;; Python 2 only, as it leads to "TabError: inconsistent use of tabs and
1727 ;; spaces in indentation" with Python 3.
1728 (package
1729 (name "python2-dogtail")
1730 (version "0.9.9")
1731 (source (origin
1732 (method url-fetch)
1733 (uri (pypi-uri "dogtail" version))
1734 (sha256
1735 (base32
1736 "0p5wfssvzr9w0bvhllzbbd8fnp4cca2qxcpcsc33dchrmh5n552x"))))
1737 (build-system python-build-system)
1738 (arguments `(#:python ,python-2
1739 #:tests? #f)) ; invalid command "test"
1740 ;; Currently no offical homepage.
1741 (home-page "https://pypi.org/project/dogtail/")
1742 (synopsis "GUI test tool and automation framework written in Python")
1743 (description
1744 "Dogtail is a GUI test tool and automation framework written in Python.
1745 It uses Accessibility (a11y) technologies to communicate with desktop
1746 applications. dogtail scripts are written in Python and executed like any
1747 other Python program.")
1748 (license license:gpl2+)))
1749
1750 (define-public python-empy
1751 (package
1752 (name "python-empy")
1753 (version "3.3.3")
1754 (source (origin
1755 (method url-fetch)
1756 (uri (string-append "http://www.alcyone.com/software/empy/empy-"
1757 version ".tar.gz"))
1758 (sha256
1759 (base32
1760 "1mxfy5mgp473ga1pgz2nvm8ds6z4g3hdky8523z6jzvcs9ny6hcq"))))
1761 (build-system python-build-system)
1762 (arguments
1763 `(#:tests? #f)) ; python2 only
1764 (home-page "http://www.alcyone.com/software/empy/")
1765 (synopsis "Templating system for Python")
1766 (description
1767 "EmPy is a system for embedding Python expressions and statements in
1768 template text; it takes an EmPy source file, processes it, and produces
1769 output. This is accomplished via expansions, which are special signals to the
1770 EmPy system and are set off by a special prefix (by default the at sign, @@).
1771 EmPy can expand arbitrary Python expressions and statements in this way, as
1772 well as a variety of special forms. Textual data not explicitly delimited in
1773 this way is sent unaffected to the output, allowing Python to be used in
1774 effect as a markup language. Also supported are callbacks via hooks,
1775 recording and playback via diversions, and dynamic, chainable filters. The
1776 system is highly configurable via command line options and embedded
1777 commands.")
1778 (license license:lgpl2.1+)))
1779
1780 (define-public python2-empy
1781 (let ((base (package-with-python2 (strip-python2-variant python-empy))))
1782 (package
1783 (inherit base)
1784 (arguments `(,@(package-arguments base)
1785 #:tests? #t)))))
1786
1787 (define-public python2-element-tree
1788 (package
1789 (name "python2-element-tree")
1790 (version "1.2.6")
1791 (source (origin
1792 (method url-fetch)
1793 (uri (string-append
1794 "http://effbot.org/media/downloads/elementtree-"
1795 version "-20050316.tar.gz"))
1796 (sha256
1797 (base32
1798 "016bphqnlg0l4vslahhw4r0aanw95bpypy65r1i1acyb2wj5z7dj"))))
1799 (build-system python-build-system)
1800 (arguments
1801 `(#:python ,python-2 ; seems to be part of Python 3
1802 #:tests? #f)) ; no 'test' sub-command
1803 (synopsis "Toolkit for XML processing in Python")
1804 (description
1805 "ElementTree is a Python library supporting lightweight XML processing.")
1806 (home-page "https://effbot.org/zone/element-index.htm")
1807 (license (license:x11-style
1808 "http://docs.python.org/2/license.html"
1809 "Like \"CWI LICENSE AGREEMENT FOR PYTHON 0.9.0 THROUGH 1.2\"."))))
1810
1811 (define-public python2-pybugz
1812 (package
1813 (name "python2-pybugz")
1814 (version "0.6.11")
1815 (source (origin
1816 (method url-fetch)
1817 (uri (string-append
1818 "http://bits.liquidx.net/projects/pybugz/pybugz-"
1819 version ".tar.gz"))
1820 (sha256
1821 (base32
1822 "17ni00p08gp5lkxlrrcnvi3x09fmajnlbz4da03qcgl9q21ym4jd"))
1823 (patches (search-patches "pybugz-stty.patch"
1824 "pybugz-encode-error.patch"))))
1825 (build-system python-build-system)
1826 (arguments
1827 `(#:python ,python-2 ; SyntaxError with Python 3
1828 #:tests? #f)) ; no 'test' sub-command
1829 (propagated-inputs
1830 `(("element-tree" ,python2-element-tree)))
1831 (synopsis "Python and command-line interface to Bugzilla")
1832 (description
1833 "PyBugz is a Python library and command-line tool to query the Bugzilla
1834 bug tracking system. It is meant as an aid to speed up interaction with the
1835 bug tracker.")
1836 (home-page "http://www.liquidx.net/pybugz/")
1837 (license license:gpl2)))
1838
1839 (define-public python2-enum
1840 (package
1841 (name "python2-enum")
1842 (version "0.4.6")
1843 (source (origin
1844 (method url-fetch)
1845 (uri (pypi-uri "enum" version))
1846 (sha256
1847 (base32
1848 "13lk3yrwj42vl30kw3c194f739nrfrdg64s6i0v2p636n4k8brsl"))))
1849 (build-system python-build-system)
1850 (arguments
1851 `(#:python ,python-2))
1852 (home-page "https://pypi.org/project/enum/")
1853 (synopsis "Robust enumerated type support in Python")
1854 (description
1855 "This provides a module for robust enumerations in Python. It has
1856 been superseded by the Python standard library and is provided only for
1857 compatibility.")
1858 ;; Choice of either license.
1859 (license (list license:gpl3+ license:psfl))))
1860
1861 (define-public python-enum34
1862 (package
1863 (name "python-enum34")
1864 (version "1.1.6")
1865 (source
1866 (origin
1867 (method url-fetch)
1868 (uri (pypi-uri "enum34" version))
1869 (sha256
1870 (base32
1871 "1cgm5ng2gcfrkrm3hc22brl6chdmv67b9zvva9sfs7gn7dwc9n4a"))))
1872 (build-system python-build-system)
1873 (home-page "https://pypi.org/project/enum34/")
1874 (synopsis "Backported Python 3.4 Enum")
1875 (description
1876 "Enum34 is the new Python stdlib enum module available in Python 3.4
1877 backported for previous versions of Python from 2.4 to 3.3.")
1878 (license license:bsd-3)))
1879
1880 (define-public python2-enum34
1881 (package-with-python2 python-enum34))
1882
1883 (define-public python-parse-type
1884 (package
1885 (name "python-parse-type")
1886 (version "0.4.2")
1887 (source
1888 (origin
1889 (method url-fetch)
1890 (uri (pypi-uri "parse_type" version))
1891 (sha256
1892 (base32
1893 "0g3b6gsdwnm8dpkh2vn34q6dzxm9gl908ggyzcv31n9xbp3vv5pm"))))
1894 (build-system python-build-system)
1895 (propagated-inputs
1896 `(("python-six" ,python-six)
1897 ("python-parse" ,python-parse)))
1898 (native-inputs
1899 `(("python-pytest" ,python-pytest)
1900 ("python-pytest-runner" ,python-pytest-runner)))
1901 (home-page "https://github.com/jenisys/parse_type")
1902 (synopsis "Extended parse module")
1903 (description
1904 "Parse_type extends the python parse module.")
1905 (properties
1906 `((python2-variant . ,(delay python2-parse-type))))
1907 (license license:bsd-3)))
1908
1909 (define-public python2-parse-type
1910 (let ((base (package-with-python2
1911 (strip-python2-variant python-parse-type))))
1912 (package (inherit base)
1913 (propagated-inputs
1914 `(("python2-enum34" ,python2-enum34)
1915 ,@(package-propagated-inputs base))))))
1916
1917 (define-public python-parse
1918 (package
1919 (name "python-parse")
1920 (version "1.8.4")
1921 (source
1922 (origin
1923 (method url-fetch)
1924 (uri (pypi-uri "parse" version))
1925 (sha256
1926 (base32
1927 "0f8997xr8nq2nq35iiviq8ningd1zvy59fg503xfpbi2dwhgdkf3"))))
1928 (build-system python-build-system)
1929 (arguments
1930 `(#:phases
1931 (modify-phases %standard-phases
1932 (replace 'check
1933 (lambda _ (invoke "python" "test_parse.py"))))))
1934 (home-page "https://github.com/r1chardj0n3s/parse")
1935 (synopsis "Parse strings")
1936 (description
1937 "Parse strings using a specification based on the Python @code{format()}
1938 syntax.")
1939 (license license:x11)))
1940
1941 (define-public python-polib
1942 (package
1943 (name "python-polib")
1944 (version "1.0.8")
1945 (source (origin
1946 (method url-fetch)
1947 (uri (pypi-uri "polib" version))
1948 (sha256
1949 (base32
1950 "1pq2hbm3m2q0cjdszk8mc4qa1vl3wcblh5nfyirlfnzb2pcy7zss"))))
1951 (build-system python-build-system)
1952 (home-page "https://bitbucket.org/izi/polib/wiki/Home")
1953 (synopsis "Manipulate, create and modify gettext files")
1954 (description "Polib can manipulate any gettext format (po, pot and mo)
1955 files. It can be used to create po files from scratch or to modify
1956 existing ones.")
1957 (license license:expat)))
1958
1959 (define-public python2-polib
1960 (let ((base (package-with-python2 (strip-python2-variant python-polib))))
1961 (package
1962 (inherit base)
1963 (arguments `(,@(package-arguments base)
1964 ;; Tests don't work with python2.
1965 #:tests? #f)))))
1966
1967 (define-public python-poyo
1968 (package
1969 (name "python-poyo")
1970 (version "0.5.0")
1971 (source
1972 (origin
1973 (method url-fetch)
1974 (uri (pypi-uri "poyo" version))
1975 (sha256
1976 (base32
1977 "1pflivs6j22frz0v3dqxnvc8yb8fb52g11lqr88z0i8cg2m5csg2"))))
1978 (build-system python-build-system)
1979 (home-page "https://github.com/hackebrot/poyo")
1980 (synopsis "Lightweight YAML Parser for Python")
1981 (description
1982 "This package provides a lightweight YAML Parser for Python. It supports
1983 only a chosen subset of the YAML format that is required to parse cookiecutter
1984 user configuration files. It does not have support for serializing into YAML
1985 and is not compatible with JSON.")
1986 (license license:expat)))
1987
1988 (define-public scons
1989 (package
1990 (name "scons")
1991 (version "3.0.4")
1992 (source (origin
1993 (method git-fetch)
1994 (uri (git-reference
1995 (url "https://github.com/SCons/scons.git")
1996 (commit version)))
1997 (file-name (git-file-name name version))
1998 (sha256
1999 (base32
2000 "1xy8jrwz87y589ihcld4hv7wn122sjbz914xn8h50ww77wbhk8hn"))))
2001 (build-system python-build-system)
2002 (arguments
2003 `(#:use-setuptools? #f ; still relies on distutils
2004 #:tests? #f ; no 'python setup.py test' command
2005 #:phases
2006 (modify-phases %standard-phases
2007 (add-before 'build 'bootstrap
2008 (lambda _
2009 (substitute* "src/engine/SCons/compat/__init__.py"
2010 (("sys.modules\\[new\\] = imp.load_module\\(old, \\*imp.find_module\\(old\\)\\)")
2011 "sys.modules[new] = __import__(old)"))
2012 (substitute* "src/engine/SCons/Platform/__init__.py"
2013 (("mod = imp.load_module\\(full_name, file, path, desc\\)")
2014 "mod = __import__(full_name)"))
2015 (invoke "python" "bootstrap.py" "build/scons" "DEVELOPER=guix")
2016 (chdir "build/scons")
2017 #t)))))
2018 (home-page "https://scons.org/")
2019 (synopsis "Software construction tool written in Python")
2020 (description
2021 "SCons is a software construction tool. Think of SCons as an improved,
2022 cross-platform substitute for the classic Make utility with integrated
2023 functionality similar to autoconf/automake and compiler caches such as ccache.
2024 In short, SCons is an easier, more reliable and faster way to build
2025 software.")
2026 (license license:x11)))
2027
2028 (define-public scons-python2
2029 (package
2030 (inherit (package-with-python2 scons))
2031 (name "scons-python2")))
2032
2033 (define-public python-extras
2034 (package
2035 (name "python-extras")
2036 (version "1.0.0")
2037 (source
2038 (origin
2039 (method url-fetch)
2040 (uri (pypi-uri "extras" version))
2041 (sha256
2042 (base32
2043 "0khvm08rcwm62wc47j8niyl6h13f8w51c8669ifivjdr23g3cbhk"))))
2044 (build-system python-build-system)
2045 (arguments
2046 ;; FIXME: Circular dependency on testtools.
2047 '(#:tests? #f))
2048 (home-page "https://github.com/testing-cabal/extras")
2049 (synopsis "Useful extensions to the Python standard library")
2050 (description
2051 "Extras is a set of extensions to the Python standard library.")
2052 (license license:expat)))
2053
2054 (define-public python2-extras
2055 (package-with-python2 python-extras))
2056
2057 (define-public python-mimeparse
2058 (package
2059 (name "python-mimeparse")
2060 (version "1.6.0")
2061 (source
2062 (origin
2063 (method url-fetch)
2064 (uri (pypi-uri "python-mimeparse" version))
2065 (sha256
2066 (base32
2067 "0y2g6cl660bpz11srgqyvvm8gmywpgyx8g0xfvbiyr0af0yv1r3n"))))
2068 (build-system python-build-system)
2069 (arguments
2070 '(#:phases
2071 (modify-phases %standard-phases
2072 (replace 'check
2073 (lambda _
2074 (invoke "./mimeparse_test.py"))))))
2075 (home-page
2076 "https://github.com/dbtsai/python-mimeparse")
2077 (synopsis "Python library for parsing MIME types")
2078 (description
2079 "Mimeparse provides basic functions for parsing MIME type names and
2080 matching them against a list of media-ranges.")
2081 (license license:expat)))
2082
2083 (define-public python2-mimeparse
2084 (package-with-python2 python-mimeparse))
2085
2086 (define-public python-miniboa
2087 (package
2088 (name "python-miniboa")
2089 (version "1.0.7")
2090 (source
2091 (origin
2092 (method url-fetch)
2093 (uri (pypi-uri "miniboa" version))
2094 (sha256
2095 (base32
2096 "09jh3pn4rh7kh7jayanf8jzy6gp03791b5a193w6148cf3i6k9m3"))))
2097 (build-system python-build-system)
2098 (home-page "https://github.com/shmup/miniboa")
2099 (synopsis "Simple, single-threaded Telnet server")
2100 (description
2101 "Miniboa is a simple, asynchronous, single-threaded, poll-based Telnet
2102 server.")
2103 (license license:asl2.0)))
2104
2105 (define-public python2-miniboa
2106 (package-with-python2 python-miniboa))
2107
2108 (define-public python-pafy
2109 (package
2110 (name "python-pafy")
2111 (version "0.5.3.1")
2112 (source
2113 (origin
2114 (method url-fetch)
2115 (uri (pypi-uri "pafy" version))
2116 (sha256
2117 (base32
2118 "1a7dxi95m1043rxx1r5x3ngb66nwlq6aqcasyqqjzmmmjps4zrim"))))
2119 (build-system python-build-system)
2120 (arguments
2121 `(#:tests? #f)) ; Currently pafy can not find itself in the tests
2122 (propagated-inputs
2123 ;; Youtube-dl is a python package which is imported in the file
2124 ;; "backend_youtube_dl.py", therefore it needs to be propagated.
2125 `(("youtube-dl" ,youtube-dl)))
2126 (home-page "https://np1.github.io/pafy/")
2127 (synopsis "Retrieve YouTube content and metadata")
2128 (description
2129 "@code{pafy} is a python library to retrieve YouTube content and metadata.")
2130 (license license:lgpl3+)))
2131
2132 (define-public python2-funcsigs
2133 (package
2134 (name "python2-funcsigs")
2135 (version "1.0.2")
2136 (source (origin
2137 (method url-fetch)
2138 (uri (pypi-uri "funcsigs" version))
2139 (sha256
2140 (base32
2141 "0l4g5818ffyfmfs1a924811azhjj8ax9xd1cffr1mzd3ycn0zfx7"))))
2142 (build-system python-build-system)
2143 (arguments
2144 `(#:python ,python-2))
2145 (native-inputs
2146 `(("python2-unittest2" ,python2-unittest2)))
2147 (home-page "http://funcsigs.readthedocs.org")
2148 (synopsis "Python function signatures from PEP362")
2149 (description
2150 "Backport of @code{funcsigs} which was introduced in Python 3.3.")
2151 (license license:asl2.0)))
2152
2153 (define-public python2-funcsigs-bootstrap
2154 (package
2155 (inherit python2-funcsigs)
2156 (name "python2-funcsigs-bootstrap")
2157 (native-inputs `())
2158 (arguments
2159 `(#:tests? #f
2160 ,@(package-arguments python2-funcsigs)))))
2161
2162 (define-public python-py
2163 (package
2164 (name "python-py")
2165 (version "1.8.0")
2166 (source
2167 (origin
2168 (method url-fetch)
2169 (uri (pypi-uri "py" version))
2170 (sha256
2171 (base32
2172 "0lsy1gajva083pzc7csj1cvbmminb7b4l6a0prdzyb3fd829nqyw"))))
2173 (build-system python-build-system)
2174 (arguments
2175 ;; FIXME: "ImportError: 'test' module incorrectly imported from
2176 ;; '/gnu/store/...-python-pytest-mimimal-3.0.5/lib/python3.5/site-packages'.
2177 ;; Expected '/tmp/guix-build-python-py-1.4.31.drv-0/py-1.4.31/py'.
2178 ;; Is this module globally installed?"
2179 '(#:tests? #f))
2180 (native-inputs
2181 `(("python-setuptools-scm" ,python-setuptools-scm)))
2182 (home-page "https://github.com/pytest-dev/py")
2183 (synopsis "Python library for parsing, I/O, instrospection, and logging")
2184 (description
2185 "Py is a Python library for file name parsing, .ini file parsing, I/O,
2186 code introspection, and logging.")
2187 (license license:expat)))
2188
2189 (define-public python2-py
2190 (package-with-python2 python-py))
2191
2192 ;; Recent versions of python-fixtures and python-testrepository need
2193 ;; python-pbr for packaging, which itself needs these two packages for
2194 ;; testing.
2195 ;; To fix this circular dependency, we use a build of python-pbr, based on the
2196 ;; same source, just without any test dependencies and with tests disabled.
2197 ;; python-pbr-minmal is then used to package python-fixtures and
2198 ;; python-testrepository.
2199 ;; Strictly speaking we currently could remove the test-requirements from the
2200 ;; normal python-pbr package (and save this package) since test are disabled
2201 ;; there anyway. But this may change in future.
2202 (define-public python-pbr-minimal
2203 (package
2204 (name "python-pbr-minimal")
2205 (version "3.0.1")
2206 (source
2207 (origin
2208 (method url-fetch)
2209 (uri (pypi-uri "pbr" version))
2210 (sha256
2211 (base32
2212 "14fs5acnalnb3h62s7q7av239j541fk0n0z0lawh4h09b1s93s6p"))))
2213 (build-system python-build-system)
2214 (arguments
2215 `(#:tests? #f))
2216 (home-page "https://docs.openstack.org/pbr/latest/")
2217 (synopsis "Minimal build of python-pbr used for bootstrapping")
2218 (description
2219 "Used only for bootstrapping python2-pbr, you should not need this.")
2220 (license license:asl2.0)))
2221
2222 (define-public python2-pbr-minimal
2223 (package-with-python2 python-pbr-minimal))
2224
2225 (define-public python-pbr
2226 (package
2227 (inherit python-pbr-minimal)
2228 (name "python-pbr")
2229 (arguments
2230 `(#:tests? #f)) ;; Most tests seem to use the Internet.
2231 (propagated-inputs
2232 `(("git" ,git))) ;; pbr actually uses the "git" binary.
2233 (native-inputs
2234 `(("python-fixtures" ,python-fixtures-bootstrap)
2235 ;; discover, coverage, hacking, subunit
2236 ("python-mock" ,python-mock)
2237 ("python-six" ,python-six)
2238 ("python-sphinx" ,python-sphinx)
2239 ("python-testrepository" ,python-testrepository-bootstrap)
2240 ("python-testresources" ,python-testresources-bootstrap)
2241 ("python-testscenarios" ,python-testscenarios-bootstrap)
2242 ("python-testtools" ,python-testtools-bootstrap)
2243 ("python-virtualenv" ,python-virtualenv)))
2244 (synopsis "Enhance the default behavior of Python’s setuptools")
2245 (description
2246 "Python Build Reasonableness (PBR) is a library that injects some useful
2247 and sensible default behaviors into your setuptools run. It will set
2248 versions, process requirements files and generate AUTHORS and ChangeLog file
2249 from git information.
2250 ")))
2251
2252 (define-public python2-pbr
2253 (package-with-python2 python-pbr))
2254
2255 (define-public python-pyrsistent
2256 (package
2257 (name "python-pyrsistent")
2258 (version "0.16.0")
2259 (home-page "https://github.com/tobgu/pyrsistent")
2260 (source (origin
2261 (method url-fetch)
2262 (uri (pypi-uri "pyrsistent" version))
2263 (sha256
2264 (base32
2265 "1lrsjgblnapfimd0alsi1as5nz2lfqv97131l7d6anbjzq2rjri8"))))
2266 (build-system python-build-system)
2267 (native-inputs
2268 `(("python-hypothesis" ,python-hypothesis)
2269 ("python-pytest" ,python-pytest)
2270 ("python-pytest-runner" ,python-pytest-runner)))
2271 (propagated-inputs
2272 `(("python-six" ,python-six)))
2273 (synopsis "Persistent data structures for Python")
2274 (description
2275 "Pyrsistent is a number of persistent collections (by some referred to as
2276 functional data structures). Persistent in the sense that they are immutable.
2277
2278 All methods on a data structure that would normally mutate it instead return a
2279 new copy of the structure containing the requested updates. The original
2280 structure is left untouched.")
2281 (license license:expat)))
2282
2283 (define-public python2-pyrsistent
2284 (package-with-python2 python-pyrsistent))
2285
2286 (define-public python-exif-read
2287 (package
2288 (name "python-exif-read")
2289 (version "2.1.2")
2290 (source (origin
2291 (method url-fetch)
2292 (uri (pypi-uri "ExifRead" version))
2293 (sha256
2294 (base32
2295 "1b90jf6m9vxh9nanhpyvqdq7hmfx5iggw1l8kq10jrs6xgr49qkr"))))
2296 (build-system python-build-system)
2297 (arguments `(#:tests? #f)) ; no tests
2298 (home-page "https://github.com/ianare/exif-py")
2299 (synopsis "Python library to extract EXIF data from image files")
2300 (description
2301 "ExifRead is a Python library to extract EXIF data from tiff and jpeg
2302 files.")
2303 (license license:bsd-3)))
2304
2305 (define-public python2-exif-read
2306 (package-with-python2 python-exif-read))
2307
2308 (define-public python-pyld
2309 (package
2310 (name "python-pyld")
2311 (version "1.0.5")
2312 (source (origin
2313 (method url-fetch)
2314 (uri (pypi-uri "PyLD" version))
2315 (sha256
2316 (base32
2317 "1ywbdbsrkg533qh8xn9ifjh2mvam6v5msrjyqq73jfpvcp89qvff"))))
2318 (build-system python-build-system)
2319 (home-page "https://github.com/digitalbazaar/pyld")
2320 (synopsis "Python implementation of the JSON-LD specification")
2321 (description
2322 "PyLD is an implementation of the JSON-LD specification.")
2323 (license license:bsd-3)))
2324
2325 (define-public python2-pyld
2326 (package-with-python2 python-pyld))
2327
2328 (define-public python-click
2329 (package
2330 (name "python-click")
2331 (version "7.0")
2332 (source
2333 (origin
2334 (method url-fetch)
2335 (uri (pypi-uri "click" version))
2336 (sha256
2337 (base32
2338 "1mzjixd4vjbjvzb6vylki9w1556a9qmdh35kzmq6cign46av952v"))))
2339 (build-system python-build-system)
2340 (arguments
2341 `(#:phases
2342 (modify-phases %standard-phases
2343 (add-after 'unpack 'fix-paths
2344 (lambda* (#:key inputs #:allow-other-keys)
2345 (let ((glibc (assoc-ref inputs ,(if (%current-target-system)
2346 "cross-libc" "libc"))))
2347 (substitute* "click/_unicodefun.py"
2348 (("'locale'")
2349 (string-append "'" glibc "/bin/locale'"))))
2350 #t))
2351 (replace 'check
2352 (lambda _
2353 (invoke "python" "-m" "pytest"))))))
2354 (native-inputs
2355 `(("python-pytest" ,python-pytest)))
2356 (home-page "https://palletsprojects.com/p/click/")
2357 (synopsis "Command line library for Python")
2358 (description
2359 "Click is a Python package for creating command line interfaces in a
2360 composable way with as little code as necessary. Its name stands for
2361 \"Command Line Interface Creation Kit\". It's highly configurable but comes
2362 with sensible defaults out of the box.")
2363 (license license:bsd-3)))
2364
2365 (define-public python2-click
2366 (package-with-python2 python-click))
2367
2368 (define-public python-wheel
2369 (package
2370 (name "python-wheel")
2371 (version "0.33.6")
2372 (source
2373 (origin
2374 (method url-fetch)
2375 (uri (pypi-uri "wheel" version))
2376 (sha256
2377 (base32
2378 "0ii6f34rvpjg3nmw4bc2h7fhdsy38y1h93hghncfs5akfrldmj8h"))))
2379 (build-system python-build-system)
2380 (arguments
2381 ;; FIXME: The test suite runs "python setup.py bdist_wheel", which in turn
2382 ;; fails to find the newly-built bdist_wheel library, even though it is
2383 ;; available on PYTHONPATH. What search path is consulted by setup.py?
2384 '(#:tests? #f))
2385 (home-page "https://bitbucket.org/pypa/wheel/")
2386 (synopsis "Format for built Python packages")
2387 (description
2388 "A wheel is a ZIP-format archive with a specially formatted filename and
2389 the @code{.whl} extension. It is designed to contain all the files for a PEP
2390 376 compatible install in a way that is very close to the on-disk format. Many
2391 packages will be properly installed with only the @code{Unpack} step and the
2392 unpacked archive preserves enough information to @code{Spread} (copy data and
2393 scripts to their final locations) at any later time. Wheel files can be
2394 installed with a newer @code{pip} or with wheel's own command line utility.")
2395 (license license:expat)))
2396
2397 (define-public python2-wheel
2398 (package-with-python2 python-wheel))
2399
2400 (define-public python-vcversioner
2401 (package
2402 (name "python-vcversioner")
2403 (version "2.16.0.0")
2404 (source
2405 (origin
2406 (method url-fetch)
2407 (uri (pypi-uri "vcversioner" version))
2408 (sha256
2409 (base32
2410 "16z10sm78jd7ca3jbkgc3q5i8a8q7y1h21q1li21yy3rlhbhrrns"))))
2411 (build-system python-build-system)
2412 (synopsis "Python library for version number discovery")
2413 (description "Vcversioner is a Python library that inspects tagging
2414 information in a variety of version control systems in order to discover
2415 version numbers.")
2416 (home-page "https://github.com/habnabit/vcversioner")
2417 (license license:isc)))
2418
2419 (define-public python2-vcversioner
2420 (package-with-python2 python-vcversioner))
2421
2422 (define-public python-jdcal
2423 (package
2424 (name "python-jdcal")
2425 (version "1.4")
2426 (source
2427 (origin
2428 (method url-fetch)
2429 (uri (pypi-uri "jdcal" version))
2430 (sha256
2431 (base32
2432 "1ja6j2xq97bsl6rv09mhdx7n0xnrsfx0mj5xqza0mxghqmkm02pa"))))
2433 (build-system python-build-system)
2434 (arguments
2435 `(#:phases (modify-phases %standard-phases
2436 (replace 'check
2437 (lambda _
2438 (invoke "pytest"))))))
2439 (native-inputs
2440 `(("python-pytest" ,python-pytest)))
2441 (home-page "https://github.com/phn/jdcal")
2442 (synopsis "Functions to convert between Julian dates Gregorian dates")
2443 (description "This Python library provides functions for converting
2444 between Julian dates and Gregorian dates.")
2445 (license license:bsd-2)))
2446
2447 (define-public python2-jdcal
2448 (package-with-python2 python-jdcal))
2449
2450 (define-public python-jsondiff
2451 (package
2452 (name "python-jsondiff")
2453 (version "1.2.0")
2454 (source
2455 (origin
2456 (method url-fetch)
2457 (uri (pypi-uri "jsondiff" version))
2458 (sha256
2459 (base32
2460 "00v3689175aqzdscrxpffm712ylp8jvcpqdg51ca22ni6721p51l"))))
2461 (build-system python-build-system)
2462 (native-inputs
2463 `(("python-nose" ,python-nose)
2464 ("python-nose-random" ,python-nose-random)))
2465 (home-page
2466 "https://github.com/fzumstein/jsondiff")
2467 (synopsis "Compare JSON and JSON-like structures in Python")
2468 (description "@code{jsondiff} is a Python library which lets you
2469 compare, diff, and patch JSON and JSON-like structures in Python.")
2470 (license license:expat)))
2471
2472 (define-public python-jsonschema
2473 (package
2474 (name "python-jsonschema")
2475 (version "3.2.0")
2476 (source (origin
2477 (method url-fetch)
2478 (uri (pypi-uri "jsonschema" version))
2479 (sha256
2480 (base32
2481 "0ykr61yiiizgvm3bzipa3l73rvj49wmrybbfwhvpgk3pscl5pa68"))))
2482 (build-system python-build-system)
2483 (arguments
2484 '(#:phases
2485 (modify-phases %standard-phases
2486 (replace 'check
2487 (lambda* (#:key inputs outputs #:allow-other-keys)
2488 (add-installed-pythonpath inputs outputs)
2489 (setenv "PYTHONPATH" (string-append ".:" (getenv "PYTHONPATH")))
2490 (invoke "trial" "jsonschema"))))))
2491 (native-inputs
2492 `(("python-setuptools_scm" ,python-setuptools-scm)
2493 ("python-twisted" ,python-twisted)))
2494 (propagated-inputs
2495 `(("python-attrs" ,python-attrs)
2496 ("python-importlib-metadata" ,python-importlib-metadata) ;; python < 3.8
2497 ("python-pyrsistent" ,python-pyrsistent)
2498 ("python-six" ,python-six)))
2499 (home-page "https://github.com/Julian/jsonschema")
2500 (synopsis "Implementation of JSON Schema for Python")
2501 (description
2502 "Jsonschema is an implementation of JSON Schema for Python.")
2503 (license license:expat)
2504 (properties `((python2-variant . ,(delay python2-jsonschema))))))
2505
2506 (define-public python2-jsonschema
2507 (let ((jsonschema (package-with-python2
2508 (strip-python2-variant python-jsonschema))))
2509 (package (inherit jsonschema)
2510 (propagated-inputs
2511 `(("python2-functools32" ,python2-functools32)
2512 ,@(package-propagated-inputs jsonschema))))))
2513
2514 (define-public python-schema
2515 (package
2516 (name "python-schema")
2517 (version "0.6.6")
2518 (source
2519 (origin
2520 (method url-fetch)
2521 (uri (pypi-uri "schema" version))
2522 (sha256
2523 (base32
2524 "1lw28j9w9vxyigg7vkfkvi6ic9lgjkdnfvnxdr7pklslqvzmk2vm"))))
2525 (build-system python-build-system)
2526 (native-inputs
2527 `(("python-pytest" ,python-pytest)))
2528 (home-page "https://github.com/keleshev/schema")
2529 (synopsis "Simple data validation library")
2530 (description
2531 "@code{python-schema} is a library for validating Python data
2532 structures, such as those obtained from config-files, forms, external
2533 services or command-line parsing, converted from JSON/YAML (or
2534 something else) to Python data-types.")
2535 (license license:psfl)))
2536
2537 (define-public python2-schema
2538 (package-with-python2 python-schema))
2539
2540 (define-public python-schema-0.5
2541 (package (inherit python-schema)
2542 (version "0.5.0")
2543 (source
2544 (origin
2545 (method url-fetch)
2546 (uri (pypi-uri "schema" version))
2547 (sha256
2548 (base32
2549 "10zqvpaky51kgb8nd42bk7jwl8cn2zvayxjpdc1wwmpybj92x67s"))))))
2550
2551 (define-public python2-schema-0.5
2552 (package-with-python2 python-schema-0.5))
2553
2554 (define-public python-kitchen
2555 (package
2556 (name "python-kitchen")
2557 (version "1.2.5")
2558 (source
2559 (origin
2560 (method url-fetch)
2561 (uri (pypi-uri "kitchen" version))
2562 (sha256
2563 (base32
2564 "1zakh6l0yjvwic9p0nkvmbidpnkygkxbigh2skmb5gccyrhbp7xg"))))
2565 (build-system python-build-system)
2566 (propagated-inputs
2567 `(("python-chardet" ,python-chardet)))
2568 (home-page "https://github.com/fedora-infra/kitchen")
2569 (synopsis "Python API for snippets")
2570 (description "@code{kitchen} module provides a python API for all sorts of
2571 little useful snippets of code that everybody ends up writing for their projects
2572 but never seem big enough to build an independent release. Use kitchen and stop
2573 cutting and pasting that code over and over.")
2574 (license (list license:lgpl2.1+
2575 ;; subprocess.py, test_subprocess.py,
2576 ;; kitchen/pycompat25/defaultdict.py:
2577 license:psfl))))
2578
2579 (define-public python2-kitchen
2580 (package-with-python2 python-kitchen))
2581
2582 (define-public python-unidecode
2583 (package
2584 (name "python-unidecode")
2585 (version "1.1.1")
2586 (source (origin
2587 (method url-fetch)
2588 (uri (pypi-uri "Unidecode" version))
2589 (sha256
2590 (base32
2591 "1s6cp2lv4m0f00hjckjz8p6m7d3n3v16jvg353llf5ia1iqsnsib"))))
2592 (build-system python-build-system)
2593 (home-page "https://pypi.org/project/Unidecode/")
2594 (synopsis "ASCII transliterations of Unicode text")
2595 (description
2596 "Unidecode provides ASCII transliterations of Unicode text. Unidecode is
2597 useful when integrating with legacy code that doesn't support Unicode, or for
2598 ease of entry of non-Roman names on a US keyboard, or when constructing ASCII
2599 machine identifiers from human-readable Unicode strings that should still be
2600 somewhat intelligible.")
2601 (license license:gpl2+)))
2602
2603 (define-public python2-unidecode
2604 (package-with-python2 python-unidecode))
2605
2606 (define-public python-text-unidecode
2607 (package
2608 (name "python-text-unidecode")
2609 (version "1.3")
2610 (source (origin
2611 (method url-fetch)
2612 (uri (pypi-uri "text-unidecode" version))
2613 (sha256
2614 (base32
2615 "14xb99fdv52j21dsljgsbmbaqv10ps4b453p229r29sdn4xn1mms"))))
2616 (build-system python-build-system)
2617 (arguments
2618 '(#:phases (modify-phases %standard-phases
2619 (replace 'check
2620 (lambda _
2621 (setenv "PYTHONPATH"
2622 (string-append "./build/lib:"
2623 (getenv "PYTHONPATH")))
2624 (invoke "pytest" "-vv"))))))
2625 (native-inputs
2626 `(("python-pytest" ,python-pytest)))
2627 (home-page "https://github.com/kmike/text-unidecode/")
2628 (synopsis "Decode Unicode data")
2629 (description
2630 "@code{text-unidecode} is a basic Python port of the @code{Text::Unidecode}
2631 Perl library. It can create ASCII representations of Unicode data. In general
2632 users should prefer the @code{python-unidecode} package which offers better
2633 memory usage and transliteration quality.")
2634 ;; The user can choose either license.
2635 (license (list license:clarified-artistic license:gpl2+))))
2636
2637 (define-public python2-text-unidecode
2638 (package-with-python2 python-text-unidecode))
2639
2640 (define-public python-pyjwt
2641 (package
2642 (name "python-pyjwt")
2643 (version "1.7.1")
2644 (source
2645 (origin
2646 (method url-fetch)
2647 (uri (pypi-uri "PyJWT" version))
2648 (sha256
2649 (base32
2650 "15hflax5qkw1v6nssk1r0wkj83jgghskcmn875m3wgvpzdvajncd"))
2651 (modules '((guix build utils)))
2652 (snippet
2653 '(begin
2654 (for-each delete-file-recursively
2655 (find-files "." "\\.pyc$"))
2656 #t))))
2657 (build-system python-build-system)
2658 (native-inputs
2659 `(("python-pytest" ,python-pytest)
2660 ("python-pytest-cov" ,python-pytest-cov)
2661 ("python-pytest-runner" ,python-pytest-runner)))
2662 (home-page "https://github.com/progrium/pyjwt")
2663 (synopsis "JSON Web Token implementation in Python")
2664 (description
2665 "PyJWT is a JSON Web Token implementation written in Python.")
2666 (license license:expat)))
2667
2668 (define-public python2-pyjwt
2669 (package-with-python2 python-pyjwt))
2670
2671 (define-public python-pykka
2672 (package
2673 (name "python-pykka")
2674 (version "1.2.1")
2675 (source
2676 (origin
2677 (method url-fetch)
2678 (uri (pypi-uri "Pykka" version))
2679 (sha256
2680 (base32
2681 "049w3r0mdnnw7xv19jiq7rvls9k7xs73x05b4qs5d6z4vvmgyiz8"))))
2682 (build-system python-build-system)
2683 (native-inputs
2684 `(("python-mock" ,python-mock)
2685 ("python-nose" ,python-nose)
2686 ("python-gevent" ,python-gevent)
2687 ("python-eventlet" ,python-eventlet)))
2688 (home-page "https://www.pykka.org/")
2689 (synopsis "Pykka is a Python implementation of the actor model")
2690 (description
2691 "Pykka is a Python implementation of the actor model.
2692 The actor model introduces some simple rules to control the sharing
2693 of state and cooperation between execution units, which makes it
2694 easier to build concurrent applications.")
2695 (license license:asl2.0)))
2696
2697 (define-public python2-pykka
2698 (package-with-python2 python-pykka))
2699
2700 (define-public python-pymsgbox
2701 (package
2702 (name "python-pymsgbox")
2703 (version "1.0.6")
2704 (source
2705 (origin
2706 (method git-fetch)
2707 (uri (git-reference
2708 ;; LICENSE.txt is not present on pypi
2709 (url "https://github.com/asweigart/PyMsgBox")
2710 (commit "55926b55f46caa969c5ddb87990ebea2737bd66f")))
2711 (file-name (git-file-name name version))
2712 (sha256
2713 (base32
2714 "0zy7rjfpwlrd8b64j7jk2lb8m2npc21rnpwakpfvwgl4nxdy80rg"))))
2715 (arguments
2716 ;; Circular dependency to run tests:
2717 ;; Tests need pyautogui, which depends on pymsgbox.
2718 '(#:tests? #f))
2719 (build-system python-build-system)
2720 (home-page "https://github.com/asweigart/PyMsgBox")
2721 (synopsis "Python module for JavaScript-like message boxes")
2722 (description
2723 "PyMsgBox is a simple, cross-platform, pure Python module for
2724 JavaScript-like message boxes. Types of dialog boxes include:
2725 @enumerate
2726 @item alert
2727 @item confirm
2728 @item prompt
2729 @item password
2730 @end enumerate
2731 ")
2732 (license license:bsd-3)))
2733
2734 (define-public python-pympler
2735 (package
2736 (name "python-pympler")
2737 (home-page "https://pythonhosted.org/Pympler/")
2738 (version "0.8")
2739 (source (origin
2740 (method url-fetch)
2741 (uri (pypi-uri "Pympler" version))
2742 (sha256
2743 (base32
2744 "08mrpnb6cv2nvfncvr8a9a8bpwhnasa924anapnjvnaw5jcd4k7p"))))
2745 (build-system python-build-system)
2746 (arguments
2747 `(#:phases (modify-phases %standard-phases
2748 (delete 'check)
2749 (add-after 'install 'check
2750 (lambda* (#:key inputs outputs #:allow-other-keys)
2751 (add-installed-pythonpath inputs outputs)
2752 (invoke "python" "setup.py" "test"))))))
2753 (synopsis "Measure, monitor and analyze memory behavior")
2754 (description
2755 "Pympler is a development tool to measure, monitor and analyze
2756 the memory behavior of Python objects in a running Python application.
2757
2758 By pympling a Python application, detailed insight in the size and the
2759 lifetime of Python objects can be obtained. Undesirable or unexpected
2760 runtime behavior like memory bloat and other @samp{pymples} can easily
2761 be identified.
2762
2763 A web profiling frontend exposes process statistics, garbage
2764 visualisation and class tracker statistics.")
2765 (license license:asl2.0)))
2766
2767 (define-public python2-pympler
2768 (package-with-python2 python-pympler))
2769
2770 (define-public python-itsdangerous
2771 (package
2772 (name "python-itsdangerous")
2773 (version "1.1.0")
2774 (source
2775 (origin
2776 (method url-fetch)
2777 (uri (pypi-uri "itsdangerous" version))
2778 (sha256
2779 (base32
2780 "068zpbksq5q2z4dckh2k1zbcq43ay74ylqn77rni797j0wyh66rj"))))
2781 (build-system python-build-system)
2782 (home-page "https://palletsprojects.com/p/itsdangerous/")
2783 (synopsis "Python library for passing data to/from untrusted environments")
2784 (description
2785 "Itsdangerous provides various helpers to pass trusted data to untrusted
2786 environments and back.")
2787 (license license:bsd-3)))
2788
2789 (define-public python2-itsdangerous
2790 (package-with-python2 python-itsdangerous))
2791
2792 (define-public python-pyyaml
2793 (package
2794 (name "python-pyyaml")
2795 (version "5.3.1")
2796 (source
2797 (origin
2798 (method url-fetch)
2799 (uri (pypi-uri "PyYAML" version))
2800 (sha256
2801 (base32
2802 "0pb4zvkfxfijkpgd1b86xjsqql97ssf1knbd1v53wkg1qm9cgsmq"))))
2803 (build-system python-build-system)
2804 (inputs
2805 `(("libyaml" ,libyaml)))
2806 (home-page "https://pyyaml.org")
2807 (synopsis "YAML parser and emitter for Python")
2808 (description
2809 "PyYAML is a YAML parser and emitter for Python. PyYAML features a
2810 complete YAML 1.1 parser, Unicode support, pickle support, capable extension
2811 API, and sensible error messages. PyYAML supports standard YAML tags and
2812 provides Python-specific tags that represent an arbitrary Python object.")
2813 (license license:expat)))
2814
2815 (define-public python2-pyyaml
2816 (package-with-python2 python-pyyaml))
2817
2818 (define-public python-vine
2819 (package
2820 (name "python-vine")
2821 (version "1.1.4")
2822 (source
2823 (origin
2824 (method url-fetch)
2825 (uri (pypi-uri "vine" version))
2826 (sha256
2827 (base32
2828 "0wkskb2hb494v9gixqnf4bl972p4ibcmxdykzpwjlfa5picns4aj"))))
2829 (build-system python-build-system)
2830 (native-inputs
2831 `(("python-pytest" ,python-pytest)
2832 ("python-case" ,python-case)))
2833 (home-page "https://github.com/celery/vine")
2834 (synopsis "Promises for Python")
2835 (description
2836 "@code{vine} provides a special implementation of promises in that it can
2837 be used both for \"promise of a value\" and lazy evaluation. The biggest
2838 upside for this is that everything in a promise can also be a promise,
2839 e.g. filters, callbacks and errbacks can all be promises.")
2840 (license license:bsd-3)))
2841
2842 (define-public python-virtualenv
2843 (package
2844 (name "python-virtualenv")
2845 (version "20.0.10")
2846 (source
2847 (origin
2848 (method url-fetch)
2849 (uri (pypi-uri "virtualenv" version))
2850 (sha256
2851 (base32
2852 "0y6x41l3ja891993i4adylbbyly0r4m52n2d0a0y9y4h3lzyh4l5"))))
2853 (build-system python-build-system)
2854 (native-inputs
2855 `(("python-mock" ,python-mock)
2856 ("python-pytest" ,python-pytest)
2857 ;; NOTE: guix lint remarks that "python-setuptools should probably not
2858 ;; be an input at all". However, removing the input makes the build error:
2859 ;; File "setup.py", line 4, in <module>
2860 ;; raise RuntimeError("setuptools >= 41 required to build")
2861 ("python-setuptools" ,python-setuptools)
2862 ("python-setuptools-scm" ,python-setuptools-scm)))
2863 (propagated-inputs
2864 `(("python-appdirs" ,python-appdirs)
2865 ("python-distlib" ,python-distlib)
2866 ("python-filelock" ,python-filelock)
2867 ("python-six" ,python-six)
2868 ("python-importlib-metadata" ,python-importlib-metadata)))
2869 (home-page "https://virtualenv.pypa.io/")
2870 (synopsis "Virtual Python environment builder")
2871 (description
2872 "Virtualenv is a tool to create isolated Python environments.")
2873 (properties `((python2-variant . ,(delay python2-virtualenv))))
2874 (license license:expat)))
2875
2876 (define-public python2-virtualenv
2877 (let ((base (package-with-python2 (strip-python2-variant python-virtualenv))))
2878 (package
2879 (inherit base)
2880 (arguments
2881 `(#:python ,python-2
2882 #:phases
2883 (modify-phases %standard-phases
2884 (add-after 'set-paths 'adjust-PYTHONPATH
2885 (lambda* (#:key inputs #:allow-other-keys)
2886 (let* ((python (assoc-ref inputs "python"))
2887 (python-sitedir (string-append python "/lib/python2.7"
2888 "/site-packages")))
2889 ;; XXX: 'python2' always comes first on PYTHONPATH
2890 ;; and shadows the 'setuptools' input. Move python2
2891 ;; last: this should be fixed in python-build-system
2892 ;; in a future rebuild cycle.
2893 (setenv "PYTHONPATH"
2894 (string-append (string-join (delete python-sitedir
2895 (string-split
2896 (getenv "PYTHONPATH")
2897 #\:))
2898 ":")
2899 ":" python-sitedir))
2900 (format #t "environment variable `PYTHONPATH' changed to `~a'~%"
2901 (getenv "PYTHONPATH"))
2902 #t))))))
2903 (propagated-inputs
2904 `(("python-contextlib2" ,python2-contextlib2)
2905 ,@(package-propagated-inputs base))))))
2906
2907 (define-public python-markupsafe
2908 (package
2909 (name "python-markupsafe")
2910 (version "1.1.1")
2911 (source
2912 (origin
2913 (method url-fetch)
2914 (uri (pypi-uri "MarkupSafe" version))
2915 (sha256
2916 (base32
2917 "0sqipg4fk7xbixqd8kq6rlkxj664d157bdwbh93farcphf92x1r9"))))
2918 (build-system python-build-system)
2919 (arguments
2920 `(#:modules ((ice-9 ftw)
2921 (srfi srfi-1)
2922 (srfi srfi-26)
2923 (guix build utils)
2924 (guix build python-build-system))
2925 #:phases (modify-phases %standard-phases
2926 (replace 'check
2927 (lambda _
2928 (let ((cwd (getcwd))
2929 (libdir (find (cut string-prefix? "lib." <>)
2930 (scandir "build"))))
2931 (setenv "PYTHONPATH"
2932 (string-append cwd "/build/" libdir ":"
2933 (getenv "PYTHONPATH")))
2934 (invoke "pytest" "-vv")))))))
2935 (native-inputs
2936 `(("python-pytest" ,python-pytest)))
2937 (home-page "https://github.com/mitsuhiko/markupsafe")
2938 (synopsis "XML/HTML/XHTML markup safe string implementation for Python")
2939 (description
2940 "Markupsafe provides an XML/HTML/XHTML markup safe string implementation
2941 for Python.")
2942 (license license:bsd-3)))
2943
2944 (define-public python2-markupsafe
2945 (package-with-python2 python-markupsafe))
2946
2947 (define-public python-jinja2
2948 (package
2949 (name "python-jinja2")
2950 (version "2.11.1")
2951 (source
2952 (origin
2953 (method url-fetch)
2954 (uri (pypi-uri "Jinja2" version))
2955 (sha256
2956 (base32
2957 "0l72c11n959yzb8d3ankckb6yhjhm6x729zm7rkpk040qzxpy64k"))))
2958 (build-system python-build-system)
2959 (arguments
2960 '(#:phases (modify-phases %standard-phases
2961 (replace 'check
2962 (lambda* (#:key tests? #:allow-other-keys)
2963 (if tests?
2964 (begin
2965 (setenv "PYTHONPATH"
2966 (string-append "./build/lib:"
2967 (getenv "PYTHONPATH")))
2968 (invoke "pytest" "-vv"))
2969 (format #t "test suite not run~%"))
2970 #t)))))
2971 (native-inputs
2972 `(("python-pytest" ,python-pytest)))
2973 (propagated-inputs
2974 `(("python-markupsafe" ,python-markupsafe)))
2975 (home-page "http://jinja.pocoo.org/")
2976 (synopsis "Python template engine")
2977 (description
2978 "Jinja2 is a small but fast and easy to use stand-alone template engine
2979 written in pure Python.")
2980 (license license:bsd-3)))
2981
2982 (define-public python2-jinja2
2983 (package-with-python2 python-jinja2))
2984
2985 (define-public python-jinja2-time
2986 (package
2987 (name "python-jinja2-time")
2988 (version "0.2.0")
2989 (source
2990 (origin
2991 (method url-fetch)
2992 (uri (pypi-uri "jinja2-time" version))
2993 (sha256
2994 (base32
2995 "0h0dr7cfpjnjj8bgl2vk9063a53649pn37wnlkd8hxjy656slkni"))))
2996 (build-system python-build-system)
2997 (propagated-inputs
2998 `(("python-arrow" ,python-arrow)
2999 ("python-jinja2" ,python-jinja2)))
3000 (home-page
3001 "https://github.com/hackebrot/jinja2-time")
3002 (synopsis "Jinja2 Extension for Dates and Times")
3003 (description
3004 "This package provides an extension for the template engine Jinja2. It
3005 adds a 'now' tag providing a convenient access to the arrow.now() API from
3006 templates. A format string can be provided to control the output.")
3007 (license license:expat)))
3008
3009 (define-public python-pystache
3010 (package
3011 (name "python-pystache")
3012 (version "0.5.4")
3013 (source (origin
3014 (method url-fetch)
3015 (uri (pypi-uri "pystache" version))
3016 (sha256
3017 (base32
3018 "0nmqsfmiw4arjxqkmf9z66ml950pcdjk6aq4gin4sywmzdjw5fzp"))))
3019 (build-system python-build-system)
3020 (arguments
3021 '(#:tests? #f)) ; FIXME: Python 3 tests are failing.
3022 (home-page "http://defunkt.io/pystache/")
3023 (synopsis "Python logic-less template engine")
3024 (description
3025 "Pystache is a Python implementation of the framework agnostic,
3026 logic-free templating system Mustache.")
3027 (license license:expat)
3028 (properties `((python2-variant . ,(delay python2-pystache))))))
3029
3030 (define-public python2-pystache
3031 (package (inherit (package-with-python2
3032 (strip-python2-variant python-pystache)))
3033 (arguments
3034 `(#:python ,python-2
3035 #:phases
3036 (modify-phases %standard-phases
3037 (replace 'check
3038 (lambda _
3039 (invoke "python" "test_pystache.py"))))))))
3040
3041 (define-public python-joblib
3042 (package
3043 (name "python-joblib")
3044 (version "0.14.1")
3045 (source (origin
3046 (method url-fetch)
3047 (uri (pypi-uri "joblib" version))
3048 (sha256
3049 (base32
3050 "1j464w137w6s367gl697j1l63g52akydrxgv4czlck36ynjfwc06"))))
3051 (build-system python-build-system)
3052 (arguments
3053 `(#:phases
3054 (modify-phases %standard-phases
3055 (replace 'check
3056 (lambda _ (invoke "pytest" "-v" "joblib"))))))
3057 (native-inputs
3058 `(("python-pytest" ,python-pytest)))
3059 (home-page "https://joblib.readthedocs.io/")
3060 (synopsis "Using Python functions as pipeline jobs")
3061 (description
3062 "Joblib is a set of tools to provide lightweight pipelining in Python.
3063 In particular, joblib offers: transparent disk-caching of the output values
3064 and lazy re-evaluation (memoize pattern), easy simple parallel computing
3065 logging and tracing of the execution.")
3066 (license license:bsd-3)))
3067
3068 (define-public python2-joblib
3069 (package-with-python2 python-joblib))
3070
3071 (define-public python-daemon
3072 (package
3073 (name "python-daemon")
3074 (version "2.2.3")
3075 (source
3076 (origin
3077 (method url-fetch)
3078 (uri (pypi-uri "python-daemon" version))
3079 (sha256
3080 (base32
3081 "09fcjdjzk9ywmpnrj62iyxqgcygzdafsz41qlrk2dknzbagcmzmg"))))
3082 (build-system python-build-system)
3083 (arguments
3084 `(#:phases
3085 (modify-phases %standard-phases
3086 (add-before 'check 'disable-tests
3087 (lambda _
3088 ;; FIXME: Determine why test fails
3089 (substitute* "test/test_daemon.py"
3090 (("test_detaches_process_context")
3091 "skip_test_detaches_process_context"))
3092 #t)))))
3093 (propagated-inputs
3094 `(("python-lockfile" ,python-lockfile)))
3095 (native-inputs
3096 `(("python-unittest2" ,python-unittest2)
3097 ("python-testtools" ,python-testtools)
3098 ("python-testscenarios" ,python-testscenarios)
3099 ("python-mock" ,python-mock)
3100 ("python-docutils" ,python-docutils)))
3101 (home-page "https://pagure.io/python-daemon/")
3102 (synopsis "Python library for making a Unix daemon process")
3103 (description "Python-daemon is a library that assists a Python program to
3104 turn itself into a well-behaved Unix daemon process, as specified in PEP 3143.
3105
3106 This library provides a @code{DaemonContext} class that manages the following
3107 important tasks for becoming a daemon process:
3108 @enumerate
3109 @item Detach the process into its own process group.
3110 @item Set process environment appropriate for running inside a chroot.
3111 @item Renounce suid and sgid privileges.
3112 @item Close all open file descriptors.
3113 @item Change the working directory, uid, gid, and umask.
3114 @item Set appropriate signal handlers.
3115 @item Open new file descriptors for stdin, stdout, and stderr.
3116 @item Manage a specified PID lock file.
3117 @item Register cleanup functions for at-exit processing.
3118 @end enumerate")
3119 ;; Only setup.py is gpl3+, everything else is apache 2.0 licensed.
3120 (license (list license:asl2.0 license:gpl3+))))
3121
3122 (define-public python-anytree
3123 (package
3124 (name "python-anytree")
3125 (version "2.8.0")
3126 (source (origin
3127 (method url-fetch)
3128 (uri (pypi-uri "anytree" version))
3129 (sha256
3130 (base32
3131 "1aycpc387wqz7h9w2p53qxn43qsh3m6by6ak4kkc66x9aprr63rz"))))
3132 (build-system python-build-system)
3133 (propagated-inputs
3134 `(("python-six" ,python-six)))
3135 (native-inputs
3136 `(;; For tests.
3137 ("graphviz" ,graphviz) ;for 'dot'
3138 ("python-nose" ,python-nose)))
3139 (home-page "https://github.com/c0fec0de/anytree")
3140 (synopsis "Lightweight tree data library")
3141 (description
3142 "@code{anytree} is a simple, lightweight, and extensible tree data
3143 structure for Python.")
3144 (license license:asl2.0)))
3145
3146 (define-public python-docutils
3147 (package
3148 (name "python-docutils")
3149 (version "0.16")
3150 (source
3151 (origin
3152 (method url-fetch)
3153 (uri (pypi-uri "docutils" version))
3154 (sha256
3155 (base32
3156 "1z3qliszqca9m719q3qhdkh0ghh90g500avzdgi7pl77x5h3mpn2"))))
3157 (build-system python-build-system)
3158 (arguments
3159 '(#:phases (modify-phases %standard-phases
3160 (replace 'check
3161 (lambda* (#:key tests? #:allow-other-keys)
3162 (if tests?
3163 (invoke "python" "test/alltests.py")
3164 (format #t "test suite not run~%"))
3165 #t)))))
3166 (home-page "http://docutils.sourceforge.net/")
3167 (synopsis "Python Documentation Utilities")
3168 (description
3169 "Docutils is a modular system for processing documentation into useful
3170 formats, such as HTML, XML, and LaTeX. For input Docutils supports
3171 reStructuredText.")
3172 ;; Most of the source code is public domain, but some source files are
3173 ;; licensed under the PFSL, BSD 2-clause, and GPLv3+ licenses.
3174 (license (list license:public-domain license:psfl license:bsd-2 license:gpl3+))))
3175
3176 (define-public python2-docutils
3177 (package-with-python2 python-docutils))
3178
3179 ;; python2-sphinx fails its test suite with newer versions.
3180 (define-public python2-docutils-0.14
3181 (package
3182 (inherit python2-docutils)
3183 (version "0.14")
3184 (source (origin
3185 (method url-fetch)
3186 (uri (pypi-uri "docutils" version))
3187 (sha256
3188 (base32
3189 "0x22fs3pdmr42kvz6c654756wja305qv6cx1zbhwlagvxgr4xrji"))))))
3190
3191 (define-public python-pygments
3192 (package
3193 (name "python-pygments")
3194 (version "2.5.2")
3195 (source
3196 (origin
3197 (method url-fetch)
3198 (uri (pypi-uri "Pygments" version))
3199 (sha256
3200 (base32
3201 "1zmhnswy0wxfn0xprs9aqsvx2c3kmzfn2wx14q8cv3vpkxdamj4q"))))
3202 (build-system python-build-system)
3203 (arguments
3204 ;; FIXME: Tests require sphinx, which depends on this.
3205 '(#:tests? #f))
3206 (home-page "https://pygments.org/")
3207 (synopsis "Syntax highlighting")
3208 (description
3209 "Pygments is a syntax highlighting package written in Python.")
3210 (license license:bsd-2)))
3211
3212 (define-public python2-pygments
3213 (package-with-python2 python-pygments))
3214
3215 (define-public python-bumpversion
3216 (package
3217 (name "python-bumpversion")
3218 (version "0.5.3")
3219 (source
3220 (origin
3221 (method url-fetch)
3222 (uri (pypi-uri "bumpversion" version))
3223 (sha256
3224 (base32
3225 "0zn7694yfipxg35ikkfh7kvgl2fissha3dnqad2c5bvsvmrwhi37"))))
3226 (build-system python-build-system)
3227 (home-page "https://github.com/peritus/bumpversion")
3228 (synopsis "Tool to bump software version")
3229 (description "This tool provides a command-line interface (CLI) to bump a
3230 software version simply.")
3231 (license license:expat)))
3232
3233 (define-public python-deprecated
3234 (package
3235 (name "python-deprecated")
3236 (version "1.2.5")
3237 (source
3238 (origin
3239 (method git-fetch)
3240 (uri (git-reference
3241 (url "https://github.com/tantale/deprecated.git")
3242 (commit (string-append "v" version))))
3243 (file-name (git-file-name name version))
3244 (sha256
3245 (base32
3246 "14909glxxwwc4b9qpz2b9jdriwzi5n65ichw85xqppap5f79wcwz"))))
3247 (build-system python-build-system)
3248 (arguments
3249 `(#:phases (modify-phases %standard-phases
3250 (replace 'check
3251 (lambda _
3252 (invoke "pytest"))))))
3253 (propagated-inputs
3254 `(("python-wrapt" ,python-wrapt)))
3255 (native-inputs
3256 `(("python-bumpversion" ,python-bumpversion)
3257 ("python-pytest" ,python-pytest)
3258 ("python-pytest-cov" ,python-pytest-cov)
3259 ("python-sphinx" ,python-sphinx)
3260 ("python-tox" ,python-tox)))
3261 (home-page "https://github.com/tantale/deprecated")
3262 (synopsis "Python decorator to deprecate classes, functions or methods")
3263 (description "The @code{deprecated} decorator provides a convenient way to deprecate
3264 to deprecate classes, functions or methods.")
3265 (license license:expat)))
3266
3267 (define-public python-pygithub
3268 (package
3269 (name "python-pygithub")
3270 (version "1.43.8")
3271 (source
3272 ;; We fetch from the Git repo because there are no tests in the PyPI
3273 ;; archive.
3274 (origin
3275 (method git-fetch)
3276 (uri (git-reference
3277 (url "https://github.com/PyGithub/PyGithub.git")
3278 (commit (string-append "v" version))))
3279 (file-name (git-file-name name version))
3280 (sha256
3281 (base32 "1625v558xga5mwhl9jqmibywy5qafmg1vqrirqz6zfq1la1d22mw"))))
3282 (build-system python-build-system)
3283 (arguments
3284 `(#:phases (modify-phases %standard-phases
3285 ;; Some tests rely on the network.
3286 (add-after 'unpack 'disable-failing-tests
3287 (lambda _
3288 (substitute* "tests/Issue142.py"
3289 (("testDecodeJson") "disabled_testDecodeJson"))
3290 #t))
3291 (add-before 'check 'prepare-for-tests
3292 (lambda _
3293 (for-each (lambda (f)
3294 (chmod f #o666))
3295 (find-files "./tests"))
3296 (system* "python" "-m" "lib2to3" "-w" "-n" "tests")
3297 (setenv "PYTHONPATH"
3298 (string-append "./tests:" (getenv "PYTHONPATH")))
3299 #t)))))
3300 (propagated-inputs
3301 `(("python-deprecated" ,python-deprecated)
3302 ("python-pyjwt" ,python-pyjwt)
3303 ("python-requests" ,python-requests)))
3304 (native-inputs `(("python-httpretty" ,python-httpretty)))
3305 (home-page "https://pygithub.readthedocs.io/en/latest/")
3306 (synopsis "Python library for the GitHub API")
3307 (description "This library allows managing GitHub resources such as
3308 repositories, user profiles, and organizations in your Python applications,
3309 using version 3 of the GitHub application programming interface (API).")
3310 (license license:lgpl3+)))
3311
3312 (define-public python-rellu
3313 (package
3314 (name "python-rellu")
3315 (version "0.7")
3316 (source
3317 (origin
3318 (method url-fetch)
3319 (uri (pypi-uri "rellu" version))
3320 (sha256
3321 (base32
3322 "1w0arpj1sm7vh29nrbnca4pnp8sx42l07r17inwqcjjf9bhng66x"))))
3323 (build-system python-build-system)
3324 (propagated-inputs
3325 `(("python-invoke" ,python-invoke)
3326 ("python-pygithub" ,python-pygithub)))
3327 (home-page "https://github.com/robotframework/rellu")
3328 (synopsis "Utilities to create PyPI releases")
3329 (description "This collection of utilities contains tooling and templates
3330 to assist in creating releases on GitHub and publishing them on PyPI. It is
3331 designed to be used by Robot Framework and tools and libraries in its
3332 ecosystem, but can naturally be used also by other projects.")
3333 (license license:asl2.0)))
3334
3335 (define-public python-robotframework
3336 (package
3337 (name "python-robotframework")
3338 (version "3.1.2")
3339 ;; There are no tests in the PyPI archive.
3340 (source
3341 (origin
3342 (method git-fetch)
3343 (uri (git-reference
3344 (url "https://github.com/robotframework/robotframework.git")
3345 (commit (string-append "v" version))))
3346 (file-name (git-file-name name version))
3347 (sha256
3348 (base32 "16gnxy0qinh8fhs0qvhff5z2xh49c3cqgm0d7bfjw120df6x7fym"))
3349 (patches (search-patches
3350 "python-robotframework-honor-source-date-epoch.patch"))))
3351 (build-system python-build-system)
3352 (arguments
3353 `(#:phases (modify-phases %standard-phases
3354 (add-before 'build 'build-and-install-doc
3355 (lambda* (#:key outputs #:allow-other-keys)
3356 (let* ((doc-output (assoc-ref outputs "doc"))
3357 (doc (string-append doc-output "/share/"
3358 ,name "-" ,version "/")))
3359 (invoke "invoke" "library-docs" "all")
3360 (mkdir-p doc)
3361 (copy-recursively "doc/libraries"
3362 (string-append doc "/libraries"))
3363 #t)))
3364 (replace 'check
3365 (lambda _
3366 (invoke "python" "utest/run.py"))))))
3367 (native-inputs
3368 `(("python-invoke" ,python-invoke)
3369 ("python-rellu" ,python-rellu)
3370 ("python:tk" ,python "tk"))) ;used when building the HTML doc
3371 (outputs '("out" "doc"))
3372 (home-page "https://robotframework.org")
3373 (synopsis "Generic automation framework")
3374 (description "Robot Framework is a generic automation framework for
3375 acceptance testing, acceptance test driven development (ATDD), and robotic
3376 process automation (RPA).")
3377 (license license:asl2.0)))
3378
3379 (define-public python-robotframework-lint
3380 ;; There is no properly tagged release; the commit below seems to correspond
3381 ;; to the 0.9 stable release available from PyPI. The tests are not
3382 ;; included in the PyPI archive, so we fetch the sources from the upstream
3383 ;; Git repo.
3384 (let ((commit "e851879bab1f63e4e53b34a4dc8a67ed95102830")
3385 (revision "1"))
3386 (package
3387 (name "python-robotframework-lint")
3388 (version (git-version "0.9.0" revision commit))
3389 (source
3390 (origin
3391 (method git-fetch)
3392 (uri (git-reference
3393 (url "https://github.com/boakley/robotframework-lint.git")
3394 (commit commit)))
3395 (file-name (git-file-name name version))
3396 (sha256
3397 (base32
3398 "1p6fknqg5sb9qz5857ji4a877657vgfjm5v3zn45994parx6ml1m"))))
3399 (build-system python-build-system)
3400 (arguments
3401 `(#:phases
3402 (modify-phases %standard-phases
3403 (replace 'check
3404 (lambda _
3405 (invoke "python" "-m" "robot" "-A"
3406 "tests/conf/default.args" "tests"))))))
3407 (propagated-inputs
3408 `(("python-robotframework" ,python-robotframework)))
3409 (home-page "https://github.com/boakley/robotframework-lint/")
3410 (synopsis "Static analysis tool (linter) for Robot Framework")
3411 (description "This package provides the @code{rflint} command-line
3412 utility, a static analysis tool (linter) for Robot Framework source files.")
3413 (license license:asl2.0))))
3414
3415 (define-public python-robotframework-sshlibrary
3416 (package
3417 (name "python-robotframework-sshlibrary")
3418 (version "3.3.0")
3419 ;; There are no tests in the PyPI archive.
3420 (source
3421 (origin
3422 (method git-fetch)
3423 (uri (git-reference
3424 (url "https://github.com/robotframework/SSHLibrary.git")
3425 (commit (string-append "v" version))))
3426 (file-name (git-file-name name version))
3427 (sha256
3428 (base32
3429 "1mk6dz2jqqndbx4yji09012q6rmadnqdywi7czvj62b0s07dr3r2"))))
3430 (build-system python-build-system)
3431 (arguments
3432 `(#:phases
3433 (modify-phases %standard-phases
3434 (add-before 'build 'build-and-install-doc
3435 (lambda* (#:key outputs #:allow-other-keys)
3436 (let* ((doc-output (assoc-ref outputs "doc"))
3437 (doc (string-append doc-output "/share/"
3438 ,name "-" ,version "/")))
3439 (invoke "chmod" "-R" "+w" "docs")
3440 (invoke "invoke" "kw-docs" "project-docs")
3441 (mkdir-p doc)
3442 (for-each delete-file (find-files "docs" "\\.rst"))
3443 (copy-recursively "docs" doc)
3444 #t)))
3445 (replace 'check
3446 (lambda _
3447 ;; Some tests require an SSH server; we remove them.
3448 (delete-file "utest/test_client_api.py")
3449 (delete-file "utest/test_scp.py")
3450 (invoke "python" "utest/run.py"))))))
3451 (propagated-inputs
3452 `(("python-robotframework" ,python-robotframework)
3453 ("python-paramiko" ,python-paramiko)
3454 ("python-scp" ,python-scp)))
3455 (native-inputs
3456 `(("openssh" ,openssh)
3457 ("which" ,which)
3458 ;; To generate the documentation
3459 ("python-docutils" ,python-docutils)
3460 ("python-invoke" ,python-invoke)
3461 ("python-pygments" ,python-pygments)
3462 ("python-rellu" ,python-rellu)))
3463 (outputs '("out" "doc"))
3464 (home-page "https://github.com/robotframework/SSHLibrary")
3465 (synopsis "Robot Framework library for SSH and SFTP")
3466 (description "SSHLibrary is a Robot Framework library providing support
3467 for SSH and SFTP. It has the following main usages:
3468 @itemize @bullet
3469 @item Executing commands on the remote machine, either blocking or non-blocking.
3470 @item Writing and reading in an interactive shell.
3471 @item Transferring files and directories over SFTP.
3472 @item Ensuring that files and directories exist on the remote machine.
3473 @end itemize")
3474 (license license:asl2.0)))
3475
3476 (define-public python-rstr
3477 (package
3478 (name "python-rstr")
3479 (version "2.2.6")
3480 (source
3481 (origin
3482 (method url-fetch)
3483 (uri (pypi-uri "rstr" version))
3484 (sha256
3485 (base32
3486 "197dw8mbq0pjjz1l6h1ksi62vgn7x55d373ch74y06744qiq5sjx"))))
3487 (build-system python-build-system)
3488 (home-page
3489 "http://bitbucket.org/leapfrogdevelopment/rstr/overview")
3490 (synopsis "Generate random strings in Python")
3491 (description "This package provides a python module for generating
3492 random strings of various types. It could be useful for fuzz testing,
3493 generating dummy data, or other applications. It has no dependencies
3494 outside the standard library.")
3495 (license license:bsd-3)))
3496
3497 (define-public python-scp
3498 (package
3499 (name "python-scp")
3500 (version "0.13.2")
3501 (source
3502 (origin
3503 (method url-fetch)
3504 (uri (pypi-uri "scp" version))
3505 (sha256
3506 (base32
3507 "1crlpw9lnn58fs1c1rmh7s7s9y5gkgpgjsqlvg9qa51kq1knx7gg"))))
3508 (build-system python-build-system)
3509 (arguments
3510 '(#:tests? #f)) ;tests require an SSH server
3511 (propagated-inputs
3512 `(("python-paramiko" ,python-paramiko)))
3513 (home-page "https://github.com/jbardin/scp.py")
3514 (synopsis "SCP protocol module for Python and Paramiko")
3515 (description "The scp module extends the Paramiko library to send and
3516 receive files via the SCP1 protocol, as implemented by the OpenSSH
3517 @command{scp} program.")
3518 (license license:gpl2+)))
3519
3520 (define-public python-rst.linker
3521 (package
3522 (name "python-rst.linker")
3523 (version "1.11")
3524 (source
3525 (origin
3526 (method url-fetch)
3527 (uri (pypi-uri "rst.linker" version))
3528 (sha256
3529 (base32 "0pqsfqqx8h0pq21k8l3k62kznrgaj2ala93c64s4d9rpbr4mgkd2"))))
3530 (build-system python-build-system)
3531 (propagated-inputs
3532 `(("python-dateutil" ,python-dateutil)
3533 ("python-six" ,python-six)))
3534 (native-inputs
3535 `(("python-setuptools-scm" ,python-setuptools-scm)))
3536 ;; Test would require path.py, which would introduce a cyclic dependence.
3537 (arguments `(#:tests? #f))
3538 ;; Note: As of version 1.7 the documentation is not worth building.
3539 (home-page "https://github.com/jaraco/rst.linker")
3540 (synopsis "Sphinx plugin to add links and timestamps")
3541 (description "rst.linker automatically replaces text by a
3542 reStructuredText external reference or timestamps. It's primary purpose is to
3543 augment the changelog, but it can be used for other documents, too.")
3544 (license license:expat)))
3545
3546 (define-public python2-rst.linker
3547 (package-with-python2 python-rst.linker))
3548
3549 (define-public python-feedgenerator
3550 (package
3551 (name "python-feedgenerator")
3552 (version "1.9")
3553 (source
3554 (origin
3555 (method url-fetch)
3556 (uri (pypi-uri "feedgenerator" version))
3557 (sha256
3558 (base32
3559 "01mirwkm7xfx539hmvj7g9da1j51gw5lsx74dr0glizskjm5vq2s"))
3560 (modules '((guix build utils)))
3561 (snippet
3562 '(begin
3563 ;; Remove pre-compiled .pyc files from source.
3564 (for-each delete-file-recursively
3565 (find-files "." "__pycache__" #:directories? #t))
3566 (for-each delete-file (find-files "." "\\.pyc$"))
3567 #t))))
3568 (build-system python-build-system)
3569 (propagated-inputs
3570 `(("python-pytz" ,python-pytz)
3571 ("python-six" ,python-six)))
3572 (home-page "https://github.com/getpelican/feedgenerator")
3573 (synopsis
3574 "Standalone version of Django's Atom/RSS feed generator")
3575 (description
3576 "Feedgenerator-py3k is a standalone version of Django's feedgenerator,
3577 which can produce feeds in RSS 2.0, RSS 0.91, and Atom formats.")
3578 (license license:bsd-3)))
3579
3580 (define-public python2-feedgenerator
3581 (package-with-python2 python-feedgenerator))
3582
3583 (define-public python-toml
3584 (package
3585 (name "python-toml")
3586 (version "0.9.4")
3587 (source
3588 (origin
3589 (method url-fetch)
3590 (uri (pypi-uri "toml" version))
3591 (sha256
3592 (base32
3593 "0bdbpbip67wdm6c7xwc6mmbmskyradj4cdxn1iibj4fcx1nbv1lf"))))
3594 (build-system python-build-system)
3595 (arguments
3596 `(#:tests? #f)) ;no tests suite in release
3597 (home-page "https://github.com/uiri/toml")
3598 (synopsis "Library for TOML")
3599 (description
3600 "@code{toml} is a library for parsing and creating Tom's Obvious, Minimal
3601 Language (TOML) configuration files.")
3602 (license license:expat)))
3603
3604 (define-public python-jsonrpc-server
3605 (package
3606 (name "python-jsonrpc-server")
3607 (version "0.3.2")
3608 (source
3609 (origin
3610 (method url-fetch)
3611 (uri (pypi-uri "python-jsonrpc-server" version))
3612 (sha256
3613 (base32
3614 "0ddgdp26dfxaz6isjbb12974b3rxavgsqrn2zrmck62cmipg5g05"))))
3615 (build-system python-build-system)
3616 (propagated-inputs
3617 `(("python-future" ,python-future)
3618 ("python-mock" ,python-mock)
3619 ("python-pytest" ,python-pytest)
3620 ("python-ujson" ,python-ujson)))
3621 (home-page
3622 "https://github.com/palantir/python-jsonrpc-server")
3623 (synopsis "JSON RPC 2.0 server library")
3624 (description
3625 "This package provides a JSON RPC 2.0 server library for Python.")
3626 (license license:expat)))
3627
3628 (define-public python-pydocstyle
3629 (package
3630 (name "python-pydocstyle")
3631 (version "3.0.0")
3632 (source
3633 (origin
3634 (method url-fetch)
3635 (uri (pypi-uri "pydocstyle" version))
3636 (sha256
3637 (base32
3638 "1m1xv9clkg9lgzyza6dnj359z04vh5g0h49nhzghv7lg81gchhap"))))
3639 (build-system python-build-system)
3640 (propagated-inputs
3641 `(("python-six" ,python-six)
3642 ("python-snowballstemmer" ,python-snowballstemmer)))
3643 (home-page
3644 "https://github.com/PyCQA/pydocstyle/")
3645 (synopsis "Python docstring style checker")
3646 (description
3647 "This package provides a style checker for the Python Language
3648 Server (PLS).")
3649 (license license:expat)))
3650
3651 (define-public python-language-server
3652 (package
3653 (name "python-language-server")
3654 (version "0.31.7")
3655 (source
3656 (origin
3657 (method url-fetch)
3658 (uri (pypi-uri "python-language-server" version))
3659 (sha256
3660 (base32
3661 "0f8rljff4h2ay9m2n9ang7axai37nzd39zd7m6c90rci5wh8cmxh"))))
3662 (build-system python-build-system)
3663 (propagated-inputs
3664 `(("python-pluggy" ,python-pluggy)
3665 ("python-jsonrpc-server" ,python-jsonrpc-server)
3666 ;; Note: Remove the special versions of Jedi and Parso when updating
3667 ;; this package.
3668 ("python-jedi" ,python-jedi-0.15)
3669 ("python-yapf" ,python-yapf)
3670 ("python-pyflakes" ,python-pyflakes)
3671 ("python-pydocstyle" ,python-pydocstyle)
3672 ("python-pycodestyle" ,python-pycodestyle)
3673 ("python-mccabe" ,python-mccabe)
3674 ("python-rope" ,python-rope)
3675 ("python-autopep8" ,python-autopep8)
3676 ("python-flake8" ,python-flake8)
3677 ("python-pylint" ,python-pylint)))
3678 (home-page "https://github.com/palantir/python-language-server")
3679 (synopsis "Python implementation of the Language Server Protocol")
3680 (description
3681 "The Python Language Server (pyls) is an implementation of the Python 3
3682 language specification for the Language Server Protocol (LSP). This tool is
3683 used in text editing environments to provide a complete and integrated
3684 feature-set for programming Python effectively.")
3685 (license license:expat)))
3686
3687 (define-public python-pathspec
3688 (package
3689 (name "python-pathspec")
3690 (version "0.7.0")
3691 (source
3692 (origin
3693 (method url-fetch)
3694 (uri (pypi-uri "pathspec" version))
3695 (sha256
3696 (base32
3697 "15lvs4awlg8xzl0l4gk9y53xx4yqmqvsv44pglv39m70y85afajn"))))
3698 (build-system python-build-system)
3699 (home-page "https://github.com/cpburnz/python-path-specification")
3700 (synopsis "Utility library for gitignore style pattern matching of file paths")
3701 (description
3702 "This package provides a utility library for gitignore style pattern
3703 matching of file paths.")
3704 (license license:mpl2.0)))
3705
3706 (define-public python-black
3707 (package
3708 (name "python-black")
3709 (version "19.10b0")
3710 (source
3711 (origin
3712 (method url-fetch)
3713 (uri (pypi-uri "black" version))
3714 (sha256
3715 (base32
3716 "0f8mr0yzj78q1dx7v6ggbgfir2wv0n5z2shfbbvfdq7910xbgvf2"))))
3717 (build-system python-build-system)
3718 (arguments
3719 `(#:phases
3720 (modify-phases %standard-phases
3721 (add-after 'patch-source-shebangs 'patch-extra-shebangs
3722 (lambda _
3723 (let ((python3 (which "python3")))
3724 (substitute* '("tests/data/fmtonoff.py"
3725 "tests/data/string_prefixes.py"
3726 "tests/data/function.py"
3727 "tests/data/python37.py")
3728 (("#!/usr/bin/env python3(\\.[0-9]+)?" _ minor-version)
3729 (string-append "#!" python3 (if (string? minor-version)
3730 minor-version
3731 "")))))
3732 #t))
3733 (add-after 'unpack 'disable-broken-tests
3734 (lambda _
3735 ;; These tests are supposed to be skipped when the blackd
3736 ;; dependencies are missing, but this doesn't quite work.
3737 (substitute* "tests/test_black.py"
3738 (("( *)class BlackDTestCase.*" match indent)
3739 (string-append indent "@unittest.skip(\"no blackd deps\")\n"
3740 indent "class BlackDTestCase(unittest.TestCase):\n"))
3741 (("web.Application") "False")
3742 (("@unittest_run_loop") ""))
3743
3744 ;; Patching the above file breaks the self test
3745 (substitute* "tests/test_black.py"
3746 (("( *)def test_self" match indent)
3747 (string-append indent "@unittest.skip(\"guix\")\n" match)))
3748 #t)))))
3749 (propagated-inputs
3750 `(("python-click" ,python-click)
3751 ("python-attrs" ,python-attrs)
3752 ("python-appdirs" ,python-appdirs)
3753 ("python-pathspec" ,python-pathspec)
3754 ("python-regex" ,python-regex)
3755 ("python-toml" ,python-toml)
3756 ("python-typed-ast" ,python-typed-ast)))
3757 (native-inputs
3758 `(("python-setuptools-scm" ,python-setuptools-scm)))
3759 (home-page "https://github.com/ambv/black")
3760 (synopsis "The uncompromising code formatter")
3761 (description "Black is the uncompromising Python code formatter.")
3762 (license license:expat)))
3763
3764 (define-public python-blinker
3765 (package
3766 (name "python-blinker")
3767 (version "1.4")
3768 (source
3769 (origin
3770 (method url-fetch)
3771 (uri (pypi-uri "blinker" version))
3772 (sha256
3773 (base32
3774 "1dpq0vb01p36jjwbhhd08ylvrnyvcc82yxx3mwjx6awrycjyw6j7"))))
3775 (build-system python-build-system)
3776 (home-page "https://pythonhosted.org/blinker/")
3777 (synopsis "Fast, simple object-to-object and broadcast signaling")
3778 (description
3779 "Blinker provides a fast dispatching system that allows any number of
3780 interested parties to subscribe to events, or \"signals\".")
3781 (license license:expat)))
3782
3783 (define-public python2-blinker
3784 (package-with-python2 python-blinker))
3785
3786 (define-public pelican
3787 (package
3788 (name "pelican")
3789 (version "4.2.0")
3790 (source
3791 (origin
3792 (method url-fetch)
3793 (uri (pypi-uri "pelican" version))
3794 (sha256
3795 (base32
3796 "0mp7hjyhs38ag1hyfcy882g400z0babqi72pnli46dqijfhajzmy"))))
3797 (build-system python-build-system)
3798 (propagated-inputs
3799 `(("python-blinker" ,python-blinker)
3800 ("python-dateutil" ,python-dateutil)
3801 ("python-docutils" ,python-docutils)
3802 ("python-feedgenerator" ,python-feedgenerator)
3803 ("python-jinja2" ,python-jinja2)
3804 ("python-markdown" ,python-markdown)
3805 ("python-pygments" ,python-pygments)
3806 ("python-pytz" ,python-pytz)
3807 ("python-six" ,python-six)
3808 ("python-unidecode" ,python-unidecode)))
3809 (home-page "https://getpelican.com/")
3810 (arguments
3811 `(;; XXX Requires a lot more packages to do unit tests :P
3812 #:tests? #f))
3813 (synopsis "Python-based static site publishing system")
3814 (description
3815 "Pelican is a tool to generate a static blog from reStructuredText,
3816 Markdown input files, and more. Pelican uses Jinja2 for templating
3817 and is very extensible.")
3818 (license license:agpl3+)))
3819
3820 (define-public mallard-ducktype
3821 (package
3822 (name "mallard-ducktype")
3823 (version "1.0.2")
3824 (source
3825 (origin
3826 (method git-fetch)
3827 ;; git-reference because tests are not included in pypi source tarball
3828 ;; https://issues.guix.gnu.org/issue/36755#2
3829 (uri (git-reference
3830 (url "https://github.com/projectmallard/mallard-ducktype.git")
3831 (commit version)))
3832 (file-name (git-file-name name version))
3833 (sha256
3834 (base32
3835 "1jk9bfz7g04ip78s03b0xak6d54rj4h9zpgadkziy1ji216g6y4c"))))
3836 (build-system python-build-system)
3837 (arguments
3838 '(#:phases
3839 (modify-phases %standard-phases
3840 (replace 'check
3841 (lambda _
3842 (with-directory-excursion "tests"
3843 (invoke "sh" "runtests")))))))
3844 (home-page "http://projectmallard.org")
3845 (synopsis "Convert Ducktype to Mallard documentation markup")
3846 (description
3847 "Ducktype is a lightweight syntax that can represent all the semantics
3848 of the Mallard XML documentation system. Ducktype files can be converted to
3849 Mallard using the @command{ducktype} tool. The yelp-tools package
3850 provides additional functionality on the produced Mallard documents.")
3851 (license license:expat)))
3852
3853 (define-public python-cython
3854 (package
3855 (name "python-cython")
3856 (version "0.29.16")
3857 (source
3858 (origin
3859 (method url-fetch)
3860 (uri (pypi-uri "Cython" version))
3861 (sha256
3862 (base32
3863 "01gs10myw0rw4jsikvqs0859fg7gficxhv508cxvnb4l9wl5a9r3"))))
3864 (build-system python-build-system)
3865 ;; we need the full python package and not just the python-wrapper
3866 ;; because we need libpython3.3m.so
3867 (inputs
3868 `(("python" ,python)))
3869 (arguments
3870 `(#:phases
3871 (modify-phases %standard-phases
3872 (add-before 'check 'set-HOME
3873 ;; some tests require access to "$HOME/.cython"
3874 (lambda _ (setenv "HOME" "/tmp") #t))
3875 (replace 'check
3876 (lambda _
3877 ;; Disable compiler optimizations to greatly reduce the running
3878 ;; time of the test suite.
3879 (setenv "CFLAGS" "-O0")
3880
3881 (invoke "python" "runtests.py" "-vv"
3882 "-j" (number->string (parallel-job-count))))))))
3883 (home-page "https://cython.org/")
3884 (synopsis "C extensions for Python")
3885 (description "Cython is an optimising static compiler for both the Python
3886 programming language and the extended Cython programming language. It makes
3887 writing C extensions for Python as easy as Python itself.")
3888 (license license:asl2.0)
3889 (properties `((python2-variant . ,(delay python2-cython))))))
3890
3891 (define-public python2-cython
3892 (let ((base (package-with-python2 (strip-python2-variant python-cython))))
3893 (package
3894 (inherit base)
3895 (name "python2-cython")
3896 (inputs
3897 `(("python-2" ,python-2))) ;this is not automatically changed
3898 (arguments
3899 (substitute-keyword-arguments (package-arguments base)
3900 ((#:phases phases)
3901 `(modify-phases ,phases
3902 ;; XXX: On i686-linux, running the parallel tests fails on many-core
3903 ;; systems, see <https://github.com/cython/cython/issues/2807>.
3904 ;; TODO: Move this logic to the regular check phase in a future
3905 ;; rebuild cycle.
3906 ,@(if (string-prefix? "i686" (%current-system))
3907 '((replace 'check
3908 (lambda _
3909 (setenv "CFLAGS" "-O0")
3910 (invoke "python" "runtests.py" "-vv"
3911 "-j" (number->string (parallel-job-count))
3912 "-x" "run.parallel"))))
3913 '())
3914 (add-before 'check 'adjust-test_embed
3915 (lambda _
3916 (substitute* "runtests.py"
3917 ;; test_embed goes great lengths to find the static libpythonX.Y.a
3918 ;; so it can give the right -L flag to GCC when embedding static
3919 ;; builds of Python. It is unaware that the Python "config"
3920 ;; directory (where the static library lives) was renamed in
3921 ;; Python 3, and falls back to sysconfig.get_config_var('LIBDIR'),
3922 ;; which works fine, because that is where the shared library is.
3923 ;;
3924 ;; It also appears to be unaware that the Makefile in Demos/embed
3925 ;; already unconditionally pass the static library location to GCC,
3926 ;; after checking sysconfig.get_config_var('LIBPL).
3927 ;;
3928 ;; The effect is that the linker is unable to resolve libexpat
3929 ;; symbols when building for Python 2, because neither the Python 2
3930 ;; shared library nor Expat is available. To fix it, we can either
3931 ;; add Expat as an input and make it visible to the linker, or just
3932 ;; prevent it from overriding the Python shared library location.
3933 ;; The end result is identical, so we take the easy route.
3934 ((" or libname not in os\\.listdir\\(libdir\\)")
3935 ""))
3936 #t)))))))))
3937
3938 ;; The RPython toolchain currently does not support Python 3.
3939 (define-public python2-rpython
3940 (package
3941 (name "python2-rpython")
3942 (version "0.2.1")
3943 (source
3944 (origin
3945 (method url-fetch)
3946 (uri (pypi-uri "rpython" version))
3947 (sha256
3948 (base32
3949 "02z9cvxf0y41dcvwnvf2zn0albhhw1drvjjbq27m6i1piw1k6fc0"))))
3950 (build-system python-build-system)
3951 (arguments `(#:python ,python-2))
3952 (native-inputs
3953 `(("python2-pytest" ,python2-pytest))) ; needed for running tests
3954 (home-page "https://rpython.readthedocs.org")
3955 (synopsis "Framework for implementing interpreters and virtual machines")
3956 (description "RPython is a translation and support framework for
3957 producing implementations of dynamic languages, emphasizing a clean separation
3958 between language specification and implementation aspects.")
3959 (license license:expat)))
3960
3961 ;; NOTE: when upgrading numpy please make sure that python-pandas and
3962 ;; python-scipy still build, as these three packages are often used together.
3963 (define-public python-numpy
3964 (package
3965 (name "python-numpy")
3966 (version "1.17.3")
3967 (source
3968 (origin
3969 (method url-fetch)
3970 (uri (string-append
3971 "https://github.com/numpy/numpy/releases/download/v"
3972 version "/numpy-" version ".tar.gz"))
3973 (sha256
3974 (base32
3975 "1ak9dmjja0q90a7fsxli51ypcwssh8c4pb6f8wkrsnf2xgdk6dy9"))))
3976 (build-system python-build-system)
3977 (inputs
3978 `(("openblas" ,openblas)
3979 ("lapack" ,lapack)))
3980 (native-inputs
3981 `(("python-cython" ,python-cython)
3982 ("python-pytest" ,python-pytest)
3983 ("gfortran" ,gfortran)))
3984 (arguments
3985 `(#:phases
3986 (modify-phases %standard-phases
3987 (add-before 'build 'configure-blas-lapack
3988 (lambda* (#:key inputs #:allow-other-keys)
3989 (call-with-output-file "site.cfg"
3990 (lambda (port)
3991 (format port
3992 "[openblas]
3993 libraries = openblas
3994 library_dirs = ~a/lib
3995 include_dirs = ~a/include
3996
3997 # backslash-n to make emacs happy
3998 \n[lapack]
3999 lapack_libs = lapack
4000 library_dirs = ~a/lib
4001 include_dirs = ~a/include
4002 "
4003 (assoc-ref inputs "openblas")
4004 (assoc-ref inputs "openblas")
4005 (assoc-ref inputs "lapack")
4006 (assoc-ref inputs "lapack"))))
4007 #t))
4008 (add-before 'build 'fix-executable-paths
4009 (lambda* (#:key inputs #:allow-other-keys)
4010 ;; Make /gnu/store/...-bash-.../bin/sh the default shell,
4011 ;; instead of /bin/sh.
4012 (substitute* "numpy/distutils/exec_command.py"
4013 (("(os.environ.get\\('SHELL', ')(/bin/sh'\\))" match match-start match-end)
4014 (string-append match-start (assoc-ref inputs "bash") match-end)))
4015 ;; Use "gcc" executable, not "cc".
4016 (substitute* "numpy/distutils/system_info.py"
4017 (("c = distutils\\.ccompiler\\.new_compiler\\(\\)")
4018 "c = distutils.ccompiler.new_compiler(); c.set_executables(compiler='gcc',compiler_so='gcc',linker_exe='gcc',linker_so='gcc -shared')"))
4019 #t))
4020 ;; Tests can only be run after the library has been installed and not
4021 ;; within the source directory.
4022 (delete 'check)
4023 (add-after 'install 'check
4024 (lambda* (#:key outputs inputs #:allow-other-keys)
4025 ;; Make installed package available for running the tests
4026 (add-installed-pythonpath inputs outputs)
4027 ;; Make sure "f2py" etc is found.
4028 (setenv "PATH" (string-append (assoc-ref outputs "out") "/bin"
4029 ":" (getenv "PATH")))
4030 (with-directory-excursion "/tmp"
4031 (invoke "python" "-c"
4032 "import numpy; numpy.test(verbose=2)")))))))
4033 (home-page "https://numpy.org")
4034 (synopsis "Fundamental package for scientific computing with Python")
4035 (description "NumPy is the fundamental package for scientific computing
4036 with Python. It contains among other things: a powerful N-dimensional array
4037 object, sophisticated (broadcasting) functions, tools for integrating C/C++
4038 and Fortran code, useful linear algebra, Fourier transform, and random number
4039 capabilities.")
4040 (properties `((python2-variant . ,(delay python2-numpy))))
4041 (license license:bsd-3)))
4042
4043 ;; Numpy 1.16.x are the last versions that support Python 2.
4044 (define-public python2-numpy
4045 (let ((numpy (package-with-python2
4046 (strip-python2-variant python-numpy))))
4047 (package/inherit
4048 numpy
4049 (version "1.16.5")
4050 (source (origin
4051 (method url-fetch)
4052 (uri (string-append
4053 "https://github.com/numpy/numpy/releases/download/v"
4054 version "/numpy-" version ".tar.gz"))
4055 (sha256
4056 (base32
4057 "0lg1cycxzi4rvvrd5zxinpdz0ni792fpx6xjd75z1923zcac8qrb")))))))
4058
4059 ;; NOTE: NumPy 1.8 is packaged only for Python 2 because it is of
4060 ;; interest only for legacy code going back to NumPy's predecessor
4061 ;; Numeric.
4062 (define-public python2-numpy-1.8
4063 (package (inherit python2-numpy)
4064 (version "1.8.2")
4065 (source
4066 (origin
4067 (method git-fetch)
4068 (uri (git-reference
4069 (url "https://github.com/numpy/numpy")
4070 (commit (string-append "v" version))))
4071 (file-name (git-file-name "numpy" version))
4072 (sha256
4073 (base32
4074 "0ikgi15rsqwbkfsjjxrwh40lqyal2wvyp3923y6w6ch3dcr82sfk"))))
4075 (arguments
4076 (substitute-keyword-arguments (package-arguments python2-numpy)
4077 ((#:phases phases)
4078 `(modify-phases ,phases
4079 (replace 'configure-blas-lapack
4080 (lambda* (#:key inputs #:allow-other-keys)
4081 (call-with-output-file "site.cfg"
4082 (lambda (port)
4083 (format port
4084 "[openblas]
4085 libraries = openblas,lapack
4086 library_dirs = ~a/lib:~a/lib
4087 include_dirs = ~a/include:~a/include
4088 "
4089 (assoc-ref inputs "openblas")
4090 (assoc-ref inputs "lapack")
4091 (assoc-ref inputs "openblas")
4092 (assoc-ref inputs "lapack"))))
4093 #t))))))
4094 (native-inputs
4095 `(("python2-nose" ,python2-nose)))
4096 (description "NumPy is the fundamental package for scientific computing
4097 with Python. It contains among other things: a powerful N-dimensional array
4098 object, sophisticated (broadcasting) functions, tools for integrating C/C++
4099 and Fortran code, useful linear algebra, Fourier transform, and random number
4100 capabilities. Version 1.8 is the last one to contain the numpy.oldnumeric API
4101 that includes the compatibility layer numpy.oldnumeric with NumPy's predecessor
4102 Numeric.")
4103 (license license:bsd-3)))
4104
4105 (define-public python-munch
4106 (package
4107 (name "python-munch")
4108 (version "2.0.4")
4109 (source
4110 (origin
4111 (method url-fetch)
4112 (uri (pypi-uri "munch" version))
4113 (sha256
4114 (base32
4115 "1cmqg91xnqx8gvnh4pmp0bfl1dfcm65d5p9mg73zz8pkjhx6h80l"))))
4116 (build-system python-build-system)
4117 (home-page "https://github.com/Infinidat/munch")
4118 (synopsis "Dot-accessible dictionary")
4119 (description "Munch is a dot-accessible dictionary similar to JavaScript
4120 objects.")
4121 (license license:expat)))
4122
4123 (define-public python2-munch
4124 (package-with-python2 python-munch))
4125
4126 (define-public python-colormath
4127 (package
4128 (name "python-colormath")
4129 (version "3.0.0")
4130 (source
4131 (origin
4132 (method url-fetch)
4133 (uri (pypi-uri "colormath" version))
4134 (sha256
4135 (base32
4136 "05qjycgxp3p2f9n6lmic68sxmsyvgnnlyl4z9w7dl9s56jphaiix"))))
4137 (build-system python-build-system)
4138 (propagated-inputs
4139 `(("python-networkx" ,python-networkx)
4140 ("python-numpy" ,python-numpy)))
4141 (home-page "https://github.com/gtaylor/python-colormath")
4142 (synopsis "Color math and conversion library")
4143 (description
4144 "This is a Python library for color math and conversions.")
4145 (license license:bsd-3)))
4146
4147 (define-public python2-colormath
4148 (package-with-python2 python-colormath))
4149
4150 (define-public python-spectra
4151 (package
4152 (name "python-spectra")
4153 (version "0.0.11")
4154 (source
4155 (origin
4156 (method url-fetch)
4157 (uri (pypi-uri "spectra" version))
4158 (sha256
4159 (base32
4160 "1f322x914bhkg6r5gv1vmnir3iy0k5kih0fd2gp3rdkw32jn5cwf"))))
4161 (build-system python-build-system)
4162 (arguments
4163 `(#:phases
4164 (modify-phases %standard-phases
4165 (replace 'check
4166 (lambda _ (invoke "nosetests" "-v"))))))
4167 (propagated-inputs
4168 `(("python-colormath" ,python-colormath)))
4169 (native-inputs
4170 `(("python-nose" ,python-nose)))
4171 (home-page "https://github.com/jsvine/spectra")
4172 (synopsis "Color scales and color conversion")
4173 (description
4174 "This package provides a Python library intended to make color math,
4175 color scales, and color space conversion easy. It has support for:
4176
4177 @enumerate
4178 @item Color scales
4179 @item Color ranges
4180 @item Color blending
4181 @item Brightening/darkening colors
4182 @item Saturating/desaturating colors
4183 @item Conversion to/from multiple color spaces.
4184 @end enumerate\n")
4185 (license license:expat)))
4186
4187 (define-public python2-spectra
4188 (package-with-python2 python-spectra))
4189
4190 (define-public python-numpy-documentation
4191 (package
4192 (name "python-numpy-documentation")
4193 (version (package-version python-numpy))
4194 (source (package-source python-numpy))
4195 (build-system python-build-system)
4196 (native-inputs
4197 `(("python-matplotlib" ,python-matplotlib)
4198 ("python-numpy" ,python-numpy)
4199 ("pkg-config" ,pkg-config)
4200 ("python-sphinx" ,python-sphinx)
4201 ("python-numpydoc" ,python-numpydoc)
4202 ("texlive" ,(texlive-union (list texlive-fonts-cm-super
4203 texlive-fonts-ec
4204 texlive-generic-ifxetex
4205 texlive-generic-pdftex
4206 texlive-amsfonts
4207 texlive-latex-capt-of
4208 texlive-latex-cmap
4209 texlive-latex-environ
4210 texlive-latex-eqparbox
4211 texlive-latex-etoolbox
4212 texlive-latex-expdlist
4213 texlive-latex-fancyhdr
4214 texlive-latex-fancyvrb
4215 texlive-latex-fncychap
4216 texlive-latex-float
4217 texlive-latex-framed
4218 texlive-latex-geometry
4219 texlive-latex-graphics
4220 texlive-latex-hyperref
4221 texlive-latex-mdwtools
4222 texlive-latex-multirow
4223 texlive-latex-needspace
4224 texlive-latex-oberdiek
4225 texlive-latex-parskip
4226 texlive-latex-preview
4227 texlive-latex-tabulary
4228 texlive-latex-threeparttable
4229 texlive-latex-titlesec
4230 texlive-latex-trimspaces
4231 texlive-latex-ucs
4232 texlive-latex-upquote
4233 texlive-latex-url
4234 texlive-latex-varwidth
4235 texlive-latex-wrapfig)))
4236 ("texinfo" ,texinfo)
4237 ("perl" ,perl)
4238 ("scipy-sphinx-theme"
4239 ,(origin ; The build script expects scipy-sphinx-theme as a git submodule
4240 (method git-fetch)
4241 (uri (git-reference
4242 (url "https://github.com/scipy/scipy-sphinx-theme.git")
4243 (commit "c466764e2231ba132c09826b5b138fffa1cfcec3")))
4244 (sha256
4245 (base32
4246 "0q2y87clwlsgc7wvlsn9pzyssybcq10plwhq2w1ydykfsyyqbmkl"))))
4247 ,@(package-native-inputs python-numpy)))
4248 (arguments
4249 `(#:tests? #f ; we're only generating the documentation
4250 #:phases
4251 (modify-phases %standard-phases
4252 (delete 'build)
4253 (replace 'install
4254 (lambda* (#:key inputs outputs #:allow-other-keys)
4255 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
4256 (doc (string-append
4257 data "/doc/" ,name "-"
4258 ,(package-version python-numpy)))
4259 (info-reader (string-append data "/info"))
4260 (html (string-append doc "/html"))
4261 (scipy-sphinx-theme "scipy-sphinx-theme")
4262 (sphinx-theme-checkout (assoc-ref inputs scipy-sphinx-theme))
4263 (pyver ,(string-append "PYVER=")))
4264
4265 ;; FIXME: this is needed to for texlive-union to generate
4266 ;; fonts, which are not found.
4267 (setenv "HOME" "/tmp")
4268
4269 (with-directory-excursion "doc"
4270 (copy-recursively sphinx-theme-checkout scipy-sphinx-theme)
4271 (mkdir-p html)
4272 (invoke "make" "html" pyver)
4273 (invoke "make" "latex" "PAPER=a4" pyver)
4274 (invoke "make" "-C" "build/latex"
4275 "all-pdf" "PAPER=a4" pyver)
4276 ;; FIXME: Generation of the info file fails.
4277 ;; (invoke "make" "info" pyver)
4278 ;; (mkdir-p info)
4279 ;; (copy-file "build/texinfo/numpy.info"
4280 ;; (string-append info "/numpy.info"))
4281 (for-each (lambda (file)
4282 (copy-file (string-append "build/latex" file)
4283 (string-append doc file)))
4284 '("/numpy-ref.pdf" "/numpy-user.pdf"))
4285 (with-directory-excursion "build/html"
4286 (for-each (lambda (file)
4287 (let* ((dir (dirname file))
4288 (tgt-dir (string-append html "/" dir)))
4289 (unless (equal? "." dir)
4290 (mkdir-p tgt-dir))
4291 (install-file file html)))
4292 (find-files "." ".*")))))
4293 #t)))))
4294 (home-page (package-home-page python-numpy))
4295 (synopsis "Documentation for the python-numpy package")
4296 (description (package-description python-numpy))
4297 (license (package-license python-numpy))))
4298
4299 (define-public python2-numpy-documentation
4300 (let ((numpy-documentation (package-with-python2 python-numpy-documentation)))
4301 (package
4302 (inherit numpy-documentation)
4303 (native-inputs `(("python2-functools32" ,python2-functools32)
4304 ,@(package-native-inputs numpy-documentation))))))
4305
4306 (define-public python-pygit2
4307 (package
4308 (name "python-pygit2")
4309 (version "1.1.0")
4310 (source
4311 (origin
4312 (method url-fetch)
4313 (uri (pypi-uri "pygit2" version))
4314 (sha256
4315 (base32 "1hs0pqqzn1yjxqk86nq7p0lvsklwnlyi5xwyzr7d5nrs19dmsjbg"))))
4316 (build-system python-build-system)
4317 (arguments
4318 '(#:tests? #f)) ; tests don't run correctly in our environment
4319 (propagated-inputs
4320 `(("python-cached-property" ,python-cached-property)
4321 ("python-cffi" ,python-cffi)
4322 ("libgit2" ,libgit2)))
4323 (native-inputs
4324 `(("python-pytest" ,python-pytest)))
4325 (home-page "https://github.com/libgit2/pygit2")
4326 (synopsis "Python bindings for libgit2")
4327 (description "Pygit2 is a set of Python bindings to the libgit2 shared
4328 library, libgit2 implements Git plumbing.")
4329 ;; GPL2.0 only, with linking exception.
4330 (license license:gpl2)))
4331
4332 (define-public python-pyparsing
4333 (package
4334 (name "python-pyparsing")
4335 (version "2.3.1")
4336 (source
4337 (origin
4338 (method url-fetch)
4339 (uri (pypi-uri "pyparsing" version))
4340 (sha256
4341 (base32 "0yk6xl885b91dmlhlsap7x78hk2rdr879fln9anbq6k4ca42djb6"))))
4342 (build-system python-build-system)
4343 (outputs '("out" "doc"))
4344 (arguments
4345 `(#:tests? #f ; no test target
4346 #:phases
4347 (modify-phases %standard-phases
4348 (add-after 'install 'install-doc
4349 (lambda* (#:key outputs #:allow-other-keys)
4350 (let* ((doc (string-append (assoc-ref outputs "doc")
4351 "/share/doc/" ,name "-" ,version))
4352 (html-doc (string-append doc "/html"))
4353 (examples (string-append doc "/examples")))
4354 (mkdir-p html-doc)
4355 (mkdir-p examples)
4356 (for-each
4357 (lambda (dir tgt)
4358 (map (lambda (file)
4359 (install-file file tgt))
4360 (find-files dir ".*")))
4361 (list "docs" "htmldoc" "examples")
4362 (list doc html-doc examples))
4363 #t))))))
4364 (home-page "https://github.com/pyparsing/pyparsing")
4365 (synopsis "Python parsing class library")
4366 (description
4367 "The pyparsing module is an alternative approach to creating and
4368 executing simple grammars, vs. the traditional lex/yacc approach, or the use
4369 of regular expressions. The pyparsing module provides a library of classes
4370 that client code uses to construct the grammar directly in Python code.")
4371 (license license:expat)))
4372
4373 (define-public python2-pyparsing
4374 (package-with-python2 python-pyparsing))
4375
4376 (define-public python-numpydoc
4377 (package
4378 (name "python-numpydoc")
4379 (version "0.8.0")
4380 (source
4381 (origin
4382 (method url-fetch)
4383 (uri (pypi-uri "numpydoc" version))
4384 (sha256
4385 (base32
4386 "1zazxg3m8j4fksv3f7v7vpf4bj9qb1vj3r326am0vdip141vzx31"))))
4387 (build-system python-build-system)
4388 (propagated-inputs
4389 `(("python-sphinx" ,python-sphinx)))
4390 (native-inputs
4391 `(("python-nose" ,python-nose)))
4392 (home-page "https://pypi.org/project/numpydoc/")
4393 (synopsis
4394 "Numpy's Sphinx extensions")
4395 (description
4396 "Sphinx extension to support docstrings in Numpy format.")
4397 (license license:bsd-2)))
4398
4399 (define-public python2-numpydoc
4400 (package-with-python2 python-numpydoc))
4401
4402 (define-public python-numexpr
4403 (package
4404 (name "python-numexpr")
4405 (version "2.6.5")
4406 (source
4407 (origin
4408 (method url-fetch)
4409 (uri (pypi-uri "numexpr" version))
4410 (sha256
4411 (base32
4412 "1frnbcwmsi312154x274xl28xazr1k8vjby83fwyla2n10a81bgq"))))
4413 (build-system python-build-system)
4414 (arguments `(#:tests? #f)) ; no tests included
4415 (propagated-inputs
4416 `(("python-numpy" ,python-numpy)))
4417 (home-page "https://github.com/pydata/numexpr")
4418 (synopsis "Fast numerical expression evaluator for NumPy")
4419 (description
4420 "Numexpr is a fast numerical expression evaluator for NumPy. With it,
4421 expressions that operate on arrays are accelerated and use less memory than
4422 doing the same calculation in Python. In addition, its multi-threaded
4423 capabilities can make use of all your cores, which may accelerate
4424 computations, most specially if they are not memory-bounded (e.g. those using
4425 transcendental functions).")
4426 (license license:expat)))
4427
4428 (define-public python2-numexpr
4429 (package-with-python2 python-numexpr))
4430
4431 (define-public python-cycler
4432 (package
4433 (name "python-cycler")
4434 (version "0.10.0")
4435 (source (origin
4436 (method url-fetch)
4437 (uri (pypi-uri "cycler" version))
4438 (sha256
4439 (base32
4440 "1n69n23fak1gjxlrbhqisi2b9pv3ckrfj98llx3p53953082syyd"))))
4441 (build-system python-build-system)
4442 (arguments
4443 ;; XXX: The current version requires 'coveralls' which we don't have.
4444 ;; Enable this for the next release which uses 'python-pytest'.
4445 '(#:tests? #f))
4446 (propagated-inputs
4447 `(("python-six" ,python-six)))
4448 (home-page "http://matplotlib.org/cycler/")
4449 (synopsis "Composable keyword argument iterator")
4450 (description
4451 "When using @code{matplotlib} and plotting more than one line, it is
4452 common to want to be able to want to be able to cycle over one or more artist
4453 styles; but the plotting logic can quickly become involved.
4454 To address this and enable easy cycling over arbitrary @code{kwargs}, the
4455 @code{Cycler} class was developed.")
4456 (license license:bsd-3)))
4457
4458 (define-public python2-cycler
4459 (package-with-python2 python-cycler))
4460
4461 (define-public python-colorspacious
4462 (package
4463 (name "python-colorspacious")
4464 (version "1.1.2")
4465 (source
4466 (origin
4467 (method git-fetch)
4468 (uri (git-reference
4469 (url "https://github.com/njsmith/colorspacious.git")
4470 (commit (string-append "v" version))))
4471 (file-name (git-file-name name version))
4472 (sha256
4473 (base32 "0x7nkphr6g5ql5fvgss8l56rgiyjgh6fm8zzs73i94ci9wzlm63w"))))
4474 (build-system python-build-system)
4475 (propagated-inputs
4476 `(("python-numpy" ,python-numpy)))
4477 (native-inputs
4478 `(("python-nose" ,python-nose)))
4479 (arguments
4480 `(#:phases
4481 (modify-phases %standard-phases
4482 (replace 'check
4483 (lambda _
4484 (invoke "nosetests" "--all-modules" "-v" "colorspacious"))))))
4485 (home-page "https://github.com/njsmith/colorspacious")
4486 (synopsis "Python library for colorspace conversions")
4487 (description "@code{colorspacious} is a Python library that lets you
4488 convert between colorspaces like sRGB, XYZ, CIEL*a*b*, CIECAM02, CAM02-UCS, etc.")
4489 (license license:expat)))
4490
4491 (define-public python2-colorspacious
4492 (package-with-python2 python-colorspacious))
4493
4494 (define-public python-matplotlib
4495 (package
4496 (name "python-matplotlib")
4497 (version "3.1.2")
4498 (source
4499 (origin
4500 (method url-fetch)
4501 (uri (pypi-uri "matplotlib" version))
4502 (sha256
4503 (base32
4504 "1nmshfqh7wyg15i16hx1yiylcvzkws29ivn66n3i0wyqwcpjr3lf"))))
4505 (build-system python-build-system)
4506 (propagated-inputs ; the following packages are all needed at run time
4507 `(("python-cycler" ,python-cycler)
4508 ("python-kiwisolver" ,python-kiwisolver)
4509 ("python-pyparsing" ,python-pyparsing)
4510 ("python-pygobject" ,python-pygobject)
4511 ("gobject-introspection" ,gobject-introspection)
4512 ("python-tkinter" ,python "tk")
4513 ("python-dateutil" ,python-dateutil)
4514 ("python-numpy" ,python-numpy)
4515 ("python-pillow" ,python-pillow)
4516 ("python-pytz" ,python-pytz)
4517 ("python-six" ,python-six)
4518 ;; From version 1.4.0 'matplotlib' makes use of 'cairocffi' instead of
4519 ;; 'pycairo'. However, 'pygobject' makes use of a 'pycairo' 'context'
4520 ;; object. For this reason we need to import both libraries.
4521 ;; https://cairocffi.readthedocs.io/en/stable/cffi_api.html#converting-pycairo-wrappers-to-cairocffi
4522 ("python-pycairo" ,python-pycairo)
4523 ("python-cairocffi" ,python-cairocffi)))
4524 (inputs
4525 `(("libpng" ,libpng)
4526 ("imagemagick" ,imagemagick)
4527 ("freetype" ,freetype)
4528 ("cairo" ,cairo)
4529 ("glib" ,glib)
4530 ;; FIXME: Add backends when available.
4531 ;("python-wxpython" ,python-wxpython)
4532 ("tcl" ,tcl)
4533 ("tk" ,tk)))
4534 (native-inputs
4535 `(("pkg-config" ,pkg-config)
4536 ("python-pytest" ,python-pytest)
4537 ("python-mock" ,python-mock)
4538 ("unzip" ,unzip)
4539 ("jquery-ui"
4540 ,(origin
4541 (method url-fetch)
4542 (uri "https://jqueryui.com/resources/download/jquery-ui-1.12.1.zip")
4543 (sha256
4544 (base32
4545 "0kb21xf38diqgxcdi1z3s9ssq36pldvyqxy56hn6pcva6rs3c8zq"))))))
4546 (arguments
4547 `(#:phases
4548 (modify-phases %standard-phases
4549 ;; XXX We disable all image comparison tests because we're using a
4550 ;; newer version of FreeType than matplotlib expects. This leads to
4551 ;; minor differences throughout the tests.
4552 (add-after 'unpack 'fix-and-disable-failing-tests
4553 (lambda _
4554 (substitute* (append (find-files "lib/matplotlib/tests/"
4555 "test_.*\\.py$")
4556 (find-files "lib/mpl_toolkits/tests"
4557 "test_.*\\.py$"))
4558 (("^from matplotlib" match)
4559 (string-append "import pytest\n" match))
4560 (("( *)@image_comparison" match indent)
4561 (string-append indent
4562 "@pytest.mark.skip(reason=\"unknown minor image differences\")\n"
4563 match)))
4564 (substitute* "lib/matplotlib/tests/test_animation.py"
4565 (("/bin/sh") (which "sh")))
4566 (for-each delete-file
4567 ;; test_normal_axes, test_get_tightbbox_polar
4568 '("lib/matplotlib/tests/test_axes.py"
4569 ;; We don't use the webagg backend and this test forces it.
4570 "lib/matplotlib/tests/test_backend_webagg.py"
4571 ;; test_outward_ticks
4572 "lib/matplotlib/tests/test_tightlayout.py"
4573 ;; test_hidden_axes fails with minor extent
4574 ;; differences, possibly due to the use of a
4575 ;; different version of FreeType.
4576 "lib/matplotlib/tests/test_constrainedlayout.py"
4577 ;; Fontconfig returns no fonts.
4578 "lib/matplotlib/tests/test_font_manager.py"))
4579 #t))
4580 (add-before 'install 'install-jquery-ui
4581 (lambda* (#:key outputs inputs #:allow-other-keys)
4582 (let ((dir (string-append (assoc-ref outputs "out")
4583 "/lib/python3.7/site-packages/matplotlib/backends/web_backend/")))
4584 (mkdir-p dir)
4585 (invoke "unzip"
4586 (assoc-ref inputs "jquery-ui")
4587 "-d" dir))
4588 #t))
4589 (replace 'check
4590 (lambda* (#:key outputs inputs #:allow-other-keys)
4591 (add-installed-pythonpath inputs outputs)
4592 (invoke "python" "tests.py" "-v"
4593 "-m" "not network and not webagg")))
4594 (add-before 'build 'configure-environment
4595 (lambda* (#:key outputs inputs #:allow-other-keys)
4596 (let ((cairo (assoc-ref inputs "cairo")))
4597 ;; Setting this directory in the 'basedirlist' of 'setup.cfg'
4598 ;; has not effect.
4599 (setenv "LD_LIBRARY_PATH" (string-append cairo "/lib"))
4600 (setenv "HOME" (getcwd))
4601 (call-with-output-file "setup.cfg"
4602 (lambda (port)
4603 (format port "[directories]~%
4604 basedirlist = ~a,~a~%
4605 [packages]~%
4606 tests = True~%"
4607 (assoc-ref inputs "tcl")
4608 (assoc-ref inputs "tk")))))
4609 #t)))))
4610 (home-page "https://matplotlib.org/")
4611 (synopsis "2D plotting library for Python")
4612 (description
4613 "Matplotlib is a Python 2D plotting library which produces publication
4614 quality figures in a variety of hardcopy formats and interactive environments
4615 across platforms. Matplotlib can be used in Python scripts, the python and
4616 ipython shell, web application servers, and six graphical user interface
4617 toolkits.")
4618 (license license:psfl)
4619 (properties `((python2-variant . ,(delay python2-matplotlib))))))
4620
4621 (define-public python2-matplotlib
4622 (let ((matplotlib (package-with-python2
4623 (strip-python2-variant python-matplotlib))))
4624 (package (inherit matplotlib)
4625 (version "2.2.4")
4626 (source
4627 (origin
4628 (method url-fetch)
4629 (uri (pypi-uri "matplotlib" version))
4630 (sha256
4631 (base32
4632 "09i1gnrra1590brc1f8d5rh2zvnknmfgzp613ab0462qkrwj15h2"))))
4633 (arguments
4634 (substitute-keyword-arguments (package-arguments matplotlib)
4635 ((#:phases phases)
4636 `(modify-phases ,phases
4637 (replace 'install-jquery-ui
4638 (lambda* (#:key outputs inputs #:allow-other-keys)
4639 (let ((dir (string-append (assoc-ref outputs "out")
4640 "/lib/python2.7/site-packages/"
4641 "matplotlib/backends/web_backend/")))
4642 (mkdir-p dir)
4643 (invoke "unzip"
4644 (assoc-ref inputs "jquery-ui")
4645 "-d" dir))
4646 #t))
4647 (delete 'fix-and-disable-failing-tests)
4648 (delete 'check))))) ; These tests weren't run the the past.
4649 ;; Make sure to use special packages for Python 2 instead
4650 ;; of those automatically rewritten by package-with-python2.
4651 (propagated-inputs
4652 `(("python2-pycairo" ,python2-pycairo)
4653 ("python2-backports-functools-lru-cache"
4654 ,python2-backports-functools-lru-cache)
4655 ("python2-functools32" ,python2-functools32)
4656 ("python2-pygobject-2" ,python2-pygobject-2)
4657 ("python2-subprocess32" ,python2-subprocess32)
4658 ("python2-tkinter" ,python-2 "tk")
4659 ,@(fold alist-delete (package-propagated-inputs matplotlib)
4660 '("python-pycairo" "python-pygobject" "python-tkinter")))))))
4661
4662 (define-public python-matplotlib-documentation
4663 (package
4664 (name "python-matplotlib-documentation")
4665 (version (package-version python-matplotlib))
4666 (source (package-source python-matplotlib))
4667 (build-system python-build-system)
4668 (native-inputs
4669 `(("python-matplotlib" ,python-matplotlib)
4670 ("python-colorspacious" ,python-colorspacious)
4671 ("python-sphinx" ,python-sphinx)
4672 ("python-sphinx-copybutton" ,python-sphinx-copybutton)
4673 ("python-sphinx-gallery" ,python-sphinx-gallery)
4674 ("python-numpydoc" ,python-numpydoc)
4675 ("python-ipython" ,python-ipython)
4676 ("python-ipykernel" ,python-ipykernel)
4677 ("python-mock" ,python-mock)
4678 ("graphviz" ,graphviz)
4679 ("texlive" ,(texlive-union (list texlive-amsfonts
4680 texlive-latex-amsmath
4681 texlive-latex-enumitem
4682 texlive-latex-expdlist
4683 texlive-latex-geometry
4684 texlive-latex-preview
4685 texlive-latex-type1cm
4686 texlive-latex-ucs
4687
4688 texlive-generic-pdftex
4689
4690 texlive-fonts-ec
4691 texlive-fonts-adobe-times
4692 texlive-fonts-txfonts)))
4693 ("texinfo" ,texinfo)
4694 ,@(package-native-inputs python-matplotlib)))
4695 (arguments
4696 `(#:tests? #f ; we're only generating documentation
4697 #:phases
4698 (modify-phases %standard-phases
4699 ;; The tests in python-matplotlib are run after the install phase, so
4700 ;; we need to delete the extra phase here.
4701 (delete 'check)
4702 (replace 'build
4703 (lambda _
4704 (chdir "doc")
4705 (setenv "PYTHONPATH"
4706 (string-append (getenv "PYTHONPATH")
4707 ":" (getcwd) "/../examples/units"))
4708 (substitute* "conf.py"
4709 ;; Don't use git.
4710 (("^SHA = check_output.*")
4711 (string-append "SHA = \"" ,version "\"\n"))
4712 ;; Don't fetch intersphinx files from the Internet
4713 (("^explicit_order_folders" m)
4714 (string-append "intersphinx_mapping = {}\n" m))
4715 (("'sphinx.ext.intersphinx',") "")
4716 ;; Disable URL embedding which requires internet access.
4717 (("'https://docs.scipy.org/doc/numpy'") "None")
4718 (("'https://docs.scipy.org/doc/scipy/reference'") "None"))
4719 (invoke "make"
4720 "SPHINXBUILD=sphinx-build"
4721 "SPHINXOPTS=" ; don't abort on warnings
4722 "html" "texinfo")))
4723 (replace 'install
4724 (lambda* (#:key inputs outputs #:allow-other-keys)
4725 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
4726 (doc (string-append data "/doc/python-matplotlib-" ,version))
4727 (info (string-append data "/info"))
4728 (html (string-append doc "/html")))
4729 (mkdir-p html)
4730 (mkdir-p info)
4731 (copy-recursively "build/html" html)
4732 (symlink (string-append html "/_images")
4733 (string-append info "/matplotlib-figures"))
4734 (with-directory-excursion "build/texinfo"
4735 (substitute* "matplotlib.texi"
4736 (("@image\\{([^,]*)" all file)
4737 (string-append "@image{matplotlib-figures/" file)))
4738 (symlink (string-append html "/_images")
4739 "./matplotlib-figures")
4740 (invoke "makeinfo" "--no-split"
4741 "-o" "matplotlib.info" "matplotlib.texi"))
4742 (install-file "build/texinfo/matplotlib.info" info))
4743 #t)))))
4744 (home-page (package-home-page python-matplotlib))
4745 (synopsis "Documentation for the python-matplotlib package")
4746 (description (package-description python-matplotlib))
4747 (license (package-license python-matplotlib))))
4748
4749 (define-public python2-matplotlib-documentation
4750 (let ((parent (package-with-python2 python-matplotlib-documentation)))
4751 (package
4752 (inherit parent)
4753 (native-inputs
4754 (alist-delete "python-sphinx-copybutton"
4755 (package-native-inputs parent))))))
4756
4757 (define-public python-matplotlib-venn
4758 (package
4759 (name "python-matplotlib-venn")
4760 (version "0.11.5")
4761 (source
4762 (origin
4763 (method url-fetch)
4764 (uri (pypi-uri "matplotlib-venn" version ".zip"))
4765 (sha256
4766 (base32
4767 "13w3i1wih0mij08hrgppzg0g9z50y54rc28l6gdi1r5w45l7l0dy"))))
4768 (build-system python-build-system)
4769 (arguments '(#:tests? #f)) ; tests are not included
4770 (propagated-inputs
4771 `(("python-matplotlib" ,python-matplotlib)
4772 ("python-numpy" ,python-numpy)
4773 ("python-scipy" ,python-scipy)))
4774 (native-inputs
4775 `(("unzip" ,unzip)))
4776 (home-page "https://github.com/konstantint/matplotlib-venn")
4777 (synopsis "Plot area-proportional Venn diagrams")
4778 (description
4779 "This package provides tools for plotting area-proportional two- and
4780 three-way Venn diagrams in @code{matplotlib}.")
4781 (license license:expat)))
4782
4783 (define-public python2-pysnptools
4784 (package
4785 (name "python2-pysnptools")
4786 (version "0.3.13")
4787 (source
4788 (origin
4789 (method url-fetch)
4790 (uri (pypi-uri "pysnptools" version))
4791 (sha256
4792 (base32
4793 "0lnis5xsl7bi0hz4f7gbicahzi5zlxkc21nk3g374xv8fb5hb3qm"))))
4794 (build-system python-build-system)
4795 (arguments
4796 `(#:python ,python-2 ; only Python 2.7 is supported
4797 #:tests? #f)) ; test files (e.g. examples/toydata.bim) not included
4798 (propagated-inputs
4799 `(("python2-numpy" ,python2-numpy)
4800 ("python2-scipy" ,python2-scipy)
4801 ("python2-pandas" ,python2-pandas)))
4802 (native-inputs
4803 `(("python2-cython" ,python2-cython)))
4804 (home-page "http://microsoftgenomics.github.io/PySnpTools/")
4805 (synopsis "Library for reading and manipulating genetic data")
4806 (description
4807 "PySnpTools is a library for reading and manipulating genetic data. It
4808 can, for example, efficiently read whole PLINK *.bed/bim/fam files or parts of
4809 those files. It can also efficiently manipulate ranges of integers using set
4810 operators such as union, intersection, and difference.")
4811 (license license:asl2.0)))
4812
4813 (define-public python-socksipy-branch
4814 (package
4815 (name "python-socksipy-branch")
4816 (version "1.01")
4817 (source
4818 (origin
4819 (method url-fetch)
4820 (uri (pypi-uri "SocksiPy-branch" version))
4821 (sha256
4822 (base32
4823 "01l41v4g7fy9fzvinmjxy6zcbhgqaif8dhdqm4w90fwcw9h51a8p"))))
4824 (build-system python-build-system)
4825 (arguments
4826 `(#:tests? #f)) ; There are no tests
4827 (home-page "https://code.google.com/archive/p/socksipy-branch/")
4828 (synopsis "Python SOCKS module")
4829 (description
4830 "SocksiPy - A Python SOCKS client module. It provides a
4831 socket-like interface that supports connections to any TCP
4832 service through the use of a SOCKS4, SOCKS5 or HTTP proxy.
4833 The original version was developed by Dan Haim, this is a
4834 branch created by Mario Vilas to address some open issues,
4835 as the original project seems to have been abandoned circa 2007.")
4836 (license license:bsd-3)))
4837
4838 (define-public python2-socksipy-branch
4839 (package-with-python2 python-socksipy-branch))
4840
4841 (define-public python-socksipychain
4842 (let ((commit "eb5ee8741ce006ac0c5c3e2e83204062c348c155")
4843 (revision "1")
4844 (version "2.1.1"))
4845 (package
4846 (name "python-socksipychain")
4847 (version (git-version version revision commit))
4848 (source
4849 (origin
4850 (method git-fetch)
4851 (uri (git-reference
4852 (url "https://github.com/pagekite/PySocksipyChain.git")
4853 (commit commit)))
4854 (file-name (git-file-name name version))
4855 (sha256
4856 (base32
4857 "0fpphn6xnpm7qk8a914s4abycsbq9w6qkci07my632v0fylnm5n7"))))
4858 (build-system python-build-system)
4859 (arguments
4860 `(#:tests? #f)) ; Tests try to access the network.
4861 (home-page "http://pagekite.net/wiki/Floss/PySocksipyChain/")
4862 (synopsis "Python SOCKS module with chained proxies support")
4863 (description
4864 "SocksiPyChain is a modified version of the SocksiPy SOCKS module, which
4865 adds support for arbitrary chaining of proxy servers and various modes of
4866 TLS/SSL encryption. It was developed for use in PageKite, and also includes
4867 a simple netcat replacement with chaining support.")
4868 (license license:bsd-3))))
4869
4870 (define-public python-pycodestyle
4871 (package
4872 (name "python-pycodestyle")
4873 (version "2.5.0")
4874 (source
4875 (origin
4876 (method url-fetch)
4877 (uri (pypi-uri "pycodestyle" version))
4878 (sha256
4879 (base32
4880 "0v4prb05n21bm8650v0a01k1nyqjdmkrsm3zycfxh2j5k9n962p4"))))
4881 (build-system python-build-system)
4882 (home-page "https://pycodestyle.readthedocs.io/")
4883 (synopsis "Python style guide checker")
4884 (description "@code{pycodestyle} (formerly pep8) is a tool to check
4885 Python code against some of the style conventions in
4886 @url{http://www.python.org/dev/peps/pep-0008/,PEP 8}.")
4887 (license license:expat)))
4888
4889 (define-public python2-pycodestyle
4890 (package-with-python2 python-pycodestyle))
4891
4892 (define-public python-multidict
4893 (package
4894 (name "python-multidict")
4895 (version "4.7.5")
4896 (source
4897 (origin
4898 (method url-fetch)
4899 (uri (pypi-uri "multidict" version))
4900 (sha256
4901 (base32
4902 "07ikq2c72kd263hpldw55y0px2l3g34hjk66ml9lryh1jv287qmf"))))
4903 (build-system python-build-system)
4904 (arguments
4905 '(#:modules ((ice-9 ftw)
4906 (srfi srfi-1)
4907 (srfi srfi-26)
4908 (guix build utils)
4909 (guix build python-build-system))
4910 #:phases (modify-phases %standard-phases
4911 (replace 'check
4912 (lambda* (#:key tests? #:allow-other-keys)
4913 (if tests?
4914 (begin
4915 (let ((libdir (find (cut string-prefix? "lib." <>)
4916 (scandir "build"))))
4917 (setenv "PYTHONPATH"
4918 (string-append "./build/" libdir ":"
4919 (getenv "PYTHONPATH")))
4920 (invoke "pytest" "-vv")))
4921 (format #t "test suite not run~%"))
4922 #t)))))
4923 (native-inputs
4924 `(("python-pytest" ,python-pytest)
4925 ("python-pytest-cov" ,python-pytest-cov)))
4926 (home-page "https://github.com/aio-libs/multidict/")
4927 (synopsis "Multidict implementation")
4928 (description "Multidict is dict-like collection of key-value pairs
4929 where key might be occurred more than once in the container.")
4930 (license license:asl2.0)))
4931
4932 (define-public python-orderedmultidict
4933 (package
4934 (name "python-orderedmultidict")
4935 (version "0.7.11")
4936 (source
4937 (origin
4938 (method url-fetch)
4939 (uri (pypi-uri "orderedmultidict" version))
4940 (sha256
4941 (base32
4942 "0dls862ibm7qbq4fnvwx0xn1v9hwyzywbff8xjjdr42dd75208yw"))))
4943 (build-system python-build-system)
4944 (arguments
4945 `(#:phases
4946 (modify-phases %standard-phases
4947 (add-after 'unpack 'fix-tests
4948 (lambda _
4949 ;; The package uses nosetest for running the tests.
4950 ;; Adding this initfile allows to run the test suite
4951 ;; without requiring nosetest.
4952 (with-output-to-file "tests/__init__.py" newline)
4953 #t)))))
4954 (propagated-inputs
4955 `(("python-six" ,python-six)))
4956 (native-inputs
4957 `(("python-pycodestyle" ,python-pycodestyle)))
4958 (home-page "https://github.com/gruns/orderedmultidict")
4959 (synopsis "Python Ordered Multivalue Dictionary - omdict")
4960 (description "This package contains a library for ordered multivalue
4961 dictionaries. A multivalue dictionary is a dictionary that can store
4962 multiple values for the same key. An ordered multivalue dictionary is a
4963 multivalue dictionary that retains the order of insertions and deletions.")
4964 (license license:unlicense)))
4965
4966 (define-public python2-orderedmultidict
4967 (package-with-python2 python-orderedmultidict))
4968
4969 (define-public python-autopep8
4970 (package
4971 (name "python-autopep8")
4972 (version "1.3.5")
4973 (source
4974 (origin
4975 (method url-fetch)
4976 (uri (pypi-uri "autopep8" version))
4977 (sha256
4978 (base32
4979 "192bvhzi4d0claqxgzymvv7k3qnj627742bc8sgxpzjj42pd9112"))))
4980 (build-system python-build-system)
4981 (propagated-inputs
4982 `(("python-pycodestyle" ,python-pycodestyle)))
4983 (home-page "https://github.com/hhatto/autopep8")
4984 (synopsis "Format Python code according to the PEP 8 style guide")
4985 (description
4986 "@code{autopep8} automatically formats Python code to conform to
4987 the PEP 8 style guide. It uses the pycodestyle utility to determine
4988 what parts of the code needs to be formatted. @code{autopep8} is
4989 capable of fixing most of the formatting issues that can be reported
4990 by pycodestyle.")
4991 (license (license:non-copyleft
4992 "https://github.com/hhatto/autopep8/blob/master/LICENSE"))))
4993
4994 (define-public python2-autopep8
4995 (package-with-python2 python-autopep8))
4996
4997 (define-public python-distlib
4998 (package
4999 (name "python-distlib")
5000 (version "0.3.0")
5001 (source
5002 (origin
5003 (method url-fetch)
5004 (uri (pypi-uri "distlib" version ".zip"))
5005 (sha256
5006 (base32
5007 "08fyi2r246733vharl2yckw20rilci28r91mzrnnvcr638inw5if"))))
5008 (build-system python-build-system)
5009 (arguments
5010 `(#:phases
5011 (modify-phases %standard-phases
5012 (add-before 'build 'no-/bin/sh
5013 (lambda _
5014 (substitute* '("distlib/scripts.py" "tests/test_scripts.py")
5015 (("/bin/sh") (which "sh")))
5016 #t))
5017 (add-before 'check 'prepare-test-env
5018 (lambda _
5019 (setenv "HOME" "/tmp")
5020 ;; NOTE: Any value works, the variable just has to be present.
5021 (setenv "SKIP_ONLINE" "1")
5022 #t)))))
5023 (native-inputs `(("unzip" ,unzip)))
5024 (home-page "https://bitbucket.org/pypa/distlib")
5025 (synopsis "Distribution utilities")
5026 (description "Distlib is a library which implements low-level functions that
5027 relate to packaging and distribution of Python software. It is intended to be
5028 used as the basis for third-party packaging tools.")
5029 (license license:psfl)))
5030
5031 (define-public python-distutils-extra
5032 (package
5033 (name "python-distutils-extra")
5034 (version "2.38")
5035 (source
5036 (origin
5037 (method url-fetch)
5038 (uri (string-append "https://launchpad.net/python-distutils-extra/trunk/"
5039 version "/+download/python-distutils-extra-"
5040 version ".tar.gz"))
5041 (sha256
5042 (base32
5043 "0lx15kcbby9zisx33p2h5hgakgwh2bvh0ibag8z0px4j6ifhs41x"))))
5044 (build-system python-build-system)
5045 (home-page "https://launchpad.net/python-distutils-extra/")
5046 (synopsis "Enhancements to Python's distutils")
5047 (description
5048 "The python-distutils-extra module enables you to easily integrate
5049 gettext support, themed icons, and scrollkeeper-based documentation into
5050 Python's distutils.")
5051 (license license:gpl2)))
5052
5053 (define-public python2-distutils-extra
5054 (package-with-python2 python-distutils-extra))
5055
5056 (define-public python2-elib.intl
5057 (package
5058 (name "python2-elib.intl")
5059 (version "0.0.3")
5060 (source
5061 (origin
5062 ;; This project doesn't tag releases or publish tarballs, so we take
5063 ;; source from a (semi-arbitrary, i.e. latest as of now) git commit.
5064 (method git-fetch)
5065 (uri (git-reference
5066 (url "https://github.com/dieterv/elib.intl.git")
5067 (commit "d09997cfef")))
5068 (file-name (string-append name "-" version "-checkout"))
5069 (sha256
5070 (base32
5071 "0y7vzff9xgbnaay7m0va1arl6g68ncwrvbgwl7jqlclsahzzb09d"))))
5072 (build-system python-build-system)
5073 (arguments
5074 ;; incompatible with Python 3 (exception syntax)
5075 `(#:python ,python-2
5076 #:tests? #f))
5077 (home-page "https://github.com/dieterv/elib.intl")
5078 (synopsis "Enhanced internationalization for Python")
5079 (description
5080 "The elib.intl module provides enhanced internationalization (I18N)
5081 services for your Python modules and applications.")
5082 (license license:lgpl3+)))
5083
5084 (define-public python-olefile
5085 (package
5086 (name "python-olefile")
5087 (version "0.46")
5088 (source
5089 (origin
5090 (method url-fetch)
5091 (uri (string-append "https://github.com/decalage2/olefile/releases/"
5092 "download/v" version "/olefile-" version ".tar.gz"))
5093 (file-name (string-append name "-" version ".tar.gz"))
5094 (sha256
5095 (base32
5096 "1kjxh4gr651hpqkjfv89cfzr40hyvf3vjlda7mifiail83j7j07m"))))
5097 (build-system python-build-system)
5098 (home-page "https://www.decalage.info/python/olefileio")
5099 (synopsis "Read and write Microsoft OLE2 files.")
5100 (description
5101 "@code{olefile} can parse, read and write Microsoft OLE2 files (Structured
5102 Storage or Compound Document, Microsoft Office). It is an improved version of
5103 the OleFileIO module from PIL, the Python Image Library.")
5104 (license license:bsd-3)))
5105
5106 (define-public python2-olefile
5107 (package-with-python2 python-olefile))
5108
5109 (define-public python-pillow
5110 (package
5111 (name "python-pillow")
5112 (version "6.2.1")
5113 (source
5114 (origin
5115 (method url-fetch)
5116 (uri (pypi-uri "Pillow" version))
5117 (sha256
5118 (base32
5119 "1c8wkzc58f5wdh006jvmwdk3wxld1xgagcbdvj7iv17qi0m9fkmz"))))
5120 (build-system python-build-system)
5121 (native-inputs
5122 `(("python-pytest" ,python-pytest)))
5123 (inputs
5124 `(("freetype" ,freetype)
5125 ("lcms" ,lcms)
5126 ("libjpeg" ,libjpeg)
5127 ("libtiff" ,libtiff)
5128 ("libwebp" ,libwebp)
5129 ("openjpeg" ,openjpeg)
5130 ("zlib" ,zlib)))
5131 (propagated-inputs
5132 `(("python-olefile" ,python-olefile)))
5133 (arguments
5134 `(#:phases
5135 (modify-phases %standard-phases
5136 (add-after 'unpack 'patch-ldconfig
5137 (lambda _
5138 (substitute* "setup.py"
5139 (("\\['/sbin/ldconfig', '-p'\\]") "['true']"))))
5140 (replace 'check
5141 (lambda* (#:key outputs inputs tests? #:allow-other-keys)
5142 (if tests?
5143 (begin
5144 (setenv "HOME" (getcwd))
5145 ;; Make installed package available for running the tests.
5146 (add-installed-pythonpath inputs outputs)
5147 (invoke "python" "selftest.py" "--installed")
5148 (invoke "python" "-m" "pytest" "-vv"))
5149 #t))))))
5150 (home-page "https://python-pillow.org")
5151 (synopsis "Fork of the Python Imaging Library")
5152 (description
5153 "The Python Imaging Library adds image processing capabilities to your
5154 Python interpreter. This library provides extensive file format support, an
5155 efficient internal representation, and fairly powerful image processing
5156 capabilities. The core image library is designed for fast access to data
5157 stored in a few basic pixel formats. It should provide a solid foundation for
5158 a general image processing tool.")
5159 (license (license:x11-style
5160 "http://www.pythonware.com/products/pil/license.htm"
5161 "The PIL Software License"))))
5162
5163 (define-public python2-pillow
5164 (package-with-python2 python-pillow))
5165
5166 (define-public python-pycparser
5167 (package
5168 (name "python-pycparser")
5169 (version "2.19")
5170 (source
5171 (origin
5172 (method url-fetch)
5173 (uri (pypi-uri "pycparser" version))
5174 (sha256
5175 (base32
5176 "1cr5dcj9628lkz1qlwq3fv97c25363qppkmcayqvd05dpy573259"))))
5177 (outputs '("out" "doc"))
5178 (build-system python-build-system)
5179 (native-inputs
5180 `(("pkg-config" ,pkg-config)))
5181 (arguments
5182 `(#:phases
5183 (modify-phases %standard-phases
5184 (replace 'check
5185 (lambda _
5186 (with-directory-excursion "tests"
5187 (invoke "python" "all_tests.py"))
5188 #t))
5189 (add-after 'install 'install-doc
5190 (lambda* (#:key outputs #:allow-other-keys)
5191 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5192 (doc (string-append data "/doc/" ,name "-" ,version))
5193 (examples (string-append doc "/examples")))
5194 (mkdir-p examples)
5195 (for-each (lambda (file)
5196 (copy-file (string-append "." file)
5197 (string-append doc file)))
5198 '("/README.rst" "/CHANGES" "/LICENSE"))
5199 (copy-recursively "examples" examples)
5200 #t))))))
5201 (home-page "https://github.com/eliben/pycparser")
5202 (synopsis "C parser in Python")
5203 (description
5204 "Pycparser is a complete parser of the C language, written in pure Python
5205 using the PLY parsing library. It parses C code into an AST and can serve as
5206 a front-end for C compilers or analysis tools.")
5207 (license license:bsd-3)))
5208
5209 (define-public python2-pycparser
5210 (package-with-python2 python-pycparser))
5211
5212 (define-public python-pywavelets
5213 (package
5214 (name "python-pywavelets")
5215 (version "1.0.1")
5216 (home-page "https://github.com/PyWavelets/pywt")
5217 (source (origin
5218 (method url-fetch)
5219 (uri (pypi-uri "PyWavelets" version))
5220 (sha256
5221 (base32
5222 "1p3qv2v66ghnqrb1f98wyyhp9dz71jwcd6kfpsax65sfdpiyqp1w"))))
5223 (build-system python-build-system)
5224 (arguments
5225 '(#:modules ((ice-9 ftw)
5226 (srfi srfi-1)
5227 (srfi srfi-26)
5228 (guix build utils)
5229 (guix build python-build-system))
5230 #:phases (modify-phases %standard-phases
5231 (replace 'check
5232 (lambda _
5233 (let ((cwd (getcwd))
5234 (libdir (find (cut string-prefix? "lib." <>)
5235 (scandir "build"))))
5236 (with-directory-excursion (string-append cwd "/build/" libdir)
5237 (invoke "nosetests" "-v" "."))))))))
5238 (native-inputs
5239 `(("python-matplotlib" ,python-matplotlib) ;for tests
5240 ("python-nose" ,python-nose)))
5241 (propagated-inputs
5242 `(("python-numpy" ,python-numpy)))
5243 (synopsis "Wavelet transforms in Python")
5244 (description
5245 "PyWavelets is a library for wavelet transforms in Python. Wavelets are
5246 mathematical basis functions that are localized in both time and frequency.
5247 Wavelet transforms are time-frequency transforms employing wavelets. They are
5248 similar to Fourier transforms, the difference being that Fourier transforms are
5249 localized only in frequency instead of in time and frequency.")
5250 (license license:expat)))
5251
5252 (define-public python2-pywavelets
5253 (package-with-python2 python-pywavelets))
5254
5255 (define-public python-pywinrm
5256 (package
5257 (name "python-pywinrm")
5258 (version "0.4.1")
5259 (source
5260 (origin
5261 (method url-fetch)
5262 (uri (pypi-uri "pywinrm" version))
5263 (sha256
5264 (base32
5265 "10gabhhg3rgacd5ahmi2r128z99fzbrbx6mz1nnq0dxmhmn5rpjf"))))
5266 (build-system python-build-system)
5267 (propagated-inputs
5268 `(("python-six" ,python-six)
5269 ("python-requests_ntlm" ,python-requests_ntlm)
5270 ("python-xmltodict" ,python-xmltodict)
5271 ("python-kerberos" ,python-kerberos)))
5272 (native-inputs
5273 `(("python-mock" ,python-mock)
5274 ("python-pytest" ,python-pytest)))
5275 (home-page "https://github.com/diyan/pywinrm/")
5276 (synopsis
5277 "Python library for Windows Remote Management (WinRM)")
5278 (description
5279 "pywinrm is a Python client for the Windows Remote Management (WinRM)
5280 service. It allows you to invoke commands on target Windows machines from
5281 any machine that can run Python.")
5282 (license license:expat)))
5283
5284 (define-public python-xcffib
5285 (package
5286 (name "python-xcffib")
5287 (version "0.6.0")
5288 (source
5289 (origin
5290 (method url-fetch)
5291 (uri (pypi-uri "xcffib" version))
5292 (sha256
5293 (base32
5294 "04k91yxyb3pgc5lvxmivh8w71yjrap2g57yk3s73x4rm4nvjq51n"))))
5295 (build-system python-build-system)
5296 (inputs
5297 `(("libxcb" ,libxcb)))
5298 (propagated-inputs
5299 `(("python-cffi" ,python-cffi) ; used at run time
5300 ("python-six" ,python-six)))
5301 (arguments
5302 `(;; FIXME: Tests need more work. See ".travis.yml" in the repository.
5303 #:tests? #f
5304 #:phases
5305 (modify-phases %standard-phases
5306 (add-after 'unpack 'fix-libxcb-path
5307 (lambda* (#:key inputs #:allow-other-keys)
5308 (let ((libxcb (assoc-ref inputs "libxcb")))
5309 (substitute* '("xcffib/__init__.py")
5310 (("^soname = \"") (string-append "soname = \"" libxcb "/lib/")))
5311 #t)))
5312 (add-after 'install 'install-doc
5313 (lambda* (#:key outputs #:allow-other-keys)
5314 (let ((doc (string-append (assoc-ref outputs "out") "/share"
5315 "/doc/" ,name "-" ,version)))
5316 (mkdir-p doc)
5317 (copy-file "README.md"
5318 (string-append doc "/README.md"))
5319 #t))))))
5320 (home-page "https://github.com/tych0/xcffib")
5321 (synopsis "XCB Python bindings")
5322 (description
5323 "Xcffib is a replacement for xpyb, an XCB Python bindings. It adds
5324 support for Python 3 and PyPy. It is based on cffi.")
5325 (license license:expat)))
5326
5327 (define-public python2-xcffib
5328 (package-with-python2 python-xcffib))
5329
5330 (define-public python-cairocffi
5331 (package
5332 (name "python-cairocffi")
5333 (version "0.9.0")
5334 (source
5335 (origin
5336 (method url-fetch)
5337 (uri (pypi-uri "cairocffi" version))
5338 (sha256
5339 (base32
5340 "0dq3k4zhqd8cwsf3nyjqvjqm8wkvrjn1wjf44rl3v0h8kqx6qf0m"))
5341 (patches (search-patches "python-cairocffi-dlopen-path.patch"))))
5342 (build-system python-build-system)
5343 (outputs '("out" "doc"))
5344 (inputs
5345 `(("glib" ,glib)
5346 ("gtk+" ,gtk+)
5347 ("gdk-pixbuf" ,gdk-pixbuf)
5348 ("cairo" ,cairo)
5349 ("pango" ,pango)))
5350 (native-inputs
5351 `(("pkg-config" ,pkg-config)
5352 ("python-pytest" ,python-pytest)
5353 ("python-pytest-cov" ,python-pytest-cov)
5354 ("python-pytest-runner" ,python-pytest-runner)
5355 ("python-sphinx" ,python-sphinx)
5356 ("python-docutils" ,python-docutils)))
5357 (propagated-inputs
5358 `(("python-xcffib" ,python-xcffib))) ; used at run time
5359 (arguments
5360 `(#:phases
5361 (modify-phases %standard-phases
5362 (add-after 'unpack 'patch-paths
5363 (lambda* (#:key inputs outputs #:allow-other-keys)
5364 (substitute* (find-files "." "\\.py$")
5365 (("dlopen\\(ffi, 'cairo'")
5366 (string-append "dlopen(ffi, '" (assoc-ref inputs "cairo")
5367 "/lib/libcairo.so.2'"))
5368 (("dlopen\\(ffi, 'gdk-3'")
5369 (string-append "dlopen(ffi, '" (assoc-ref inputs "gtk+")
5370 "/lib/libgtk-3.so.0'"))
5371 (("dlopen\\(ffi, 'gdk_pixbuf-2.0'")
5372 (string-append "dlopen(ffi, '" (assoc-ref inputs "gdk-pixbuf")
5373 "/lib/libgdk_pixbuf-2.0.so.0'"))
5374 (("dlopen\\(ffi, 'glib-2.0'")
5375 (string-append "dlopen(ffi, '" (assoc-ref inputs "glib")
5376 "/lib/libglib-2.0.so.0'"))
5377 (("dlopen\\(ffi, 'gobject-2.0'")
5378 (string-append "dlopen(ffi, '" (assoc-ref inputs "glib")
5379 "/lib/libgobject-2.0.so.0'"))
5380 (("dlopen\\(ffi, 'pangocairo-1.0'")
5381 (string-append "dlopen(ffi, '" (assoc-ref inputs "pango")
5382 "/lib/libpangocairo-1.0.so.0'"))
5383 (("dlopen\\(ffi, 'pango-1.0'")
5384 (string-append "dlopen(ffi, '" (assoc-ref inputs "pango")
5385 "/lib/libpango-1.0.so.0'")))
5386 #t))
5387 (add-after 'install 'install-doc
5388 (lambda* (#:key inputs outputs #:allow-other-keys)
5389 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5390 (doc (string-append data "/doc/" ,name "-" ,version))
5391 (html (string-append doc "/html")))
5392 (setenv "LD_LIBRARY_PATH"
5393 (string-append (assoc-ref inputs "cairo") "/lib" ":"
5394 (assoc-ref inputs "gdk-pixbuf") "/lib"))
5395 (setenv "LANG" "en_US.UTF-8")
5396 (mkdir-p html)
5397 (for-each (lambda (file)
5398 (copy-file (string-append "." file)
5399 (string-append doc file)))
5400 '("/README.rst" "/CHANGES" "/LICENSE"))
5401 (system* "python" "setup.py" "build_sphinx")
5402 (copy-recursively "docs/_build/html" html)
5403 #t))))))
5404 (home-page "https://github.com/Kozea/cairocffi")
5405 (synopsis "Python bindings and object-oriented API for Cairo")
5406 (description
5407 "Cairocffi is a CFFI-based drop-in replacement for Pycairo, a set of
5408 Python bindings and object-oriented API for cairo. Cairo is a 2D vector
5409 graphics library with support for multiple backends including image buffers,
5410 PNG, PostScript, PDF, and SVG file output.")
5411 (license license:bsd-3)))
5412
5413 (define-public python2-cairocffi
5414 (package-with-python2 python-cairocffi))
5415
5416 (define-public python-decorator
5417 (package
5418 (name "python-decorator")
5419 (version "4.3.0")
5420 (source
5421 (origin
5422 (method url-fetch)
5423 (uri (pypi-uri "decorator" version))
5424 (sha256
5425 (base32 "0308djallnh00v112y5b7nadl657ysmkp6vc8xn51d6yzc9zm7n3"))))
5426 (build-system python-build-system)
5427 (home-page "https://pypi.org/project/decorator/")
5428 (synopsis "Python module to simplify usage of decorators")
5429 (description
5430 "The aim of the decorator module is to simplify the usage of decorators
5431 for the average programmer, and to popularize decorators usage giving examples
5432 of useful decorators, such as memoize, tracing, redirecting_stdout, locked,
5433 etc. The core of this module is a decorator factory.")
5434 (license license:expat)))
5435
5436 (define-public python2-decorator
5437 (package-with-python2 python-decorator))
5438
5439 (define-public python-drmaa
5440 (package
5441 (name "python-drmaa")
5442 (version "0.7.7")
5443 (source
5444 (origin
5445 (method url-fetch)
5446 (uri (pypi-uri "drmaa" version))
5447 (sha256
5448 (base32 "0xzqriqyvk5b8hszbavsyxd29wm3sxirm8zvvdm73rs2iq7w4hkx"))))
5449 (build-system python-build-system)
5450 ;; The test suite requires libdrmaa which is provided by the cluster
5451 ;; environment. At runtime the environment variable DRMAA_LIBRARY_PATH
5452 ;; should be set to the path of the libdrmaa library.
5453 (arguments '(#:tests? #f))
5454 (native-inputs
5455 `(("python-nose" ,python-nose)))
5456 (home-page "https://pypi.org/project/drmaa/")
5457 (synopsis "Python bindings for the DRMAA library")
5458 (description
5459 "A Python package for Distributed Resource Management (DRM) job
5460 submission and control. This package is an implementation of the DRMAA 1.0
5461 Python language binding specification.")
5462 (license license:bsd-3)))
5463
5464 (define-public python2-drmaa
5465 (package-with-python2 python-drmaa))
5466
5467 (define-public python-grako
5468 (package
5469 (name "python-grako")
5470 (version "3.99.9")
5471 (source
5472 (origin
5473 (method url-fetch)
5474 (uri
5475 (pypi-uri "grako" version ".zip"))
5476 (sha256
5477 (base32
5478 "0r63i68wcnv63rfjkasq1ah81frz61a6mzbcnaxhrkdpx84p7hzw"))))
5479 (build-system python-build-system)
5480 (arguments '(#:tests? #f)) ; Test file 'grako.ebnf' is missing from archive.
5481 (native-inputs
5482 `(("unzip" ,unzip)
5483 ("python-pytest" ,python-pytest)
5484 ("python-pytest-runner" ,python-pytest-runner)))
5485 (home-page "https://bitbucket.org/neogeny/grako")
5486 (synopsis "EBNF parser generator")
5487 (description
5488 "Grako takes a grammar in a variation of EBNF as input, and outputs a
5489 memoizing PEG/Packrat parser in Python.")
5490 (license license:bsd-3)))
5491
5492 (define-public python2-grako
5493 (package-with-python2 python-grako))
5494
5495 (define-public python-gridmap
5496 (package
5497 (name "python-gridmap")
5498 (version "0.13.0")
5499 (source
5500 (origin
5501 (method git-fetch)
5502 (uri (git-reference
5503 (url "https://github.com/pygridtools/gridmap.git")
5504 (commit (string-append "v" version))))
5505 (file-name (git-file-name name version))
5506 (sha256
5507 (base32 "1478lbwsr1w24cii2x01m2910fvh8r43ghnb78nc972a96hqiknm"))))
5508 (build-system python-build-system)
5509 (arguments
5510 '(#:tests? #f)) ; FIXME: Requires python-cherrypy.
5511 (propagated-inputs
5512 `(("python-psutil" ,python-psutil)
5513 ("python-drmaa" ,python-drmaa)
5514 ("python-pyzmq" ,python-pyzmq)))
5515 (home-page "https://github.com/pygridtools/gridmap")
5516 (synopsis "Create jobs on a cluster directly from Python")
5517 (description
5518 "Gridmap is a Python package to allow you to easily create jobs on the
5519 cluster directly from Python. You can directly map Python functions onto the
5520 cluster without needing to write any wrapper code yourself.")
5521 (license license:gpl3+)))
5522
5523 (define-public python2-gridmap
5524 (package-with-python2 python-gridmap))
5525
5526 (define-public python-honcho
5527 (package
5528 (name "python-honcho")
5529 (version "1.0.1")
5530 (source
5531 (origin
5532 (method git-fetch)
5533 (uri (git-reference
5534 (url "https://github.com/nickstenning/honcho.git")
5535 (commit (string-append "v" version))))
5536 (file-name (git-file-name name version))
5537 (sha256
5538 (base32 "11bd87474qpif20xdcn0ra1idj5k16ka51i658wfpxwc6nzsn92b"))))
5539 (build-system python-build-system)
5540 (native-inputs
5541 `(("python-pytest" ,python-pytest)
5542 ("python-mock" ,python-mock)
5543 ("python-tox" ,python-tox)
5544 ("which" ,which))) ;for tests
5545 (propagated-inputs
5546 `(("python-jinja2" ,python-jinja2)))
5547 (arguments
5548 `(#:phases
5549 (modify-phases %standard-phases
5550 (delete 'check)
5551 (add-after 'install 'check
5552 (lambda* (#:key outputs inputs #:allow-other-keys)
5553 ;; fix honcho path in testsuite
5554 (substitute* "tests/conftest.py"
5555 (("'honcho'") (string-append "'" (assoc-ref outputs "out")
5556 "/bin/honcho" "'")))
5557 ;; It's easier to run tests after install.
5558 ;; Make installed package available for running the tests
5559 (add-installed-pythonpath inputs outputs)
5560 (invoke "py.test" "-v"))))))
5561 (home-page "https://github.com/nickstenning/honcho")
5562 (synopsis "Manage Procfile-based applications")
5563 (description
5564 "A Procfile is a file which describes how to run an application
5565 consisting of several processes. honcho starts all listed processes.
5566 The output of all running processes is collected by honcho and
5567 displayed.")
5568 (license license:expat)))
5569
5570 (define-public python2-honcho
5571 (package-with-python2 python-honcho))
5572
5573 (define-public python-pexpect
5574 (package
5575 (name "python-pexpect")
5576 (version "4.8.0")
5577 (source
5578 (origin
5579 (method url-fetch)
5580 (uri (pypi-uri "pexpect" version))
5581 (sha256
5582 (base32 "032cg337h8awydgypz6f4wx848lw8dyrj4zy988x0lyib4ws8rgw"))))
5583 (build-system python-build-system)
5584 (arguments
5585 `(#:phases
5586 (modify-phases %standard-phases
5587 (add-before 'check 'prepare-tests
5588 (lambda _
5589 (substitute* (find-files "tests")
5590 (("/bin/ls") (which "ls"))
5591 (("/bin/echo") (which "echo"))
5592 (("/bin/which") (which "which"))
5593 ;; Many tests try to use the /bin directory which
5594 ;; is not present in the build environment.
5595 ;; Use one that's non-empty and unlikely to change.
5596 (("/bin'") "/dev'")
5597 ;; Disable failing test. See upstream bug report
5598 ;; https://github.com/pexpect/pexpect/issues/568
5599 (("def test_bash") "def _test_bash"))
5600 ;; XXX: Socket connection test gets "Connection reset by peer".
5601 ;; Why does it not work? Delete for now.
5602 (delete-file "tests/test_socket.py")
5603 #t))
5604 (replace 'check (lambda _ (invoke "nosetests" "-v"))))))
5605 (native-inputs
5606 `(("python-nose" ,python-nose)
5607 ("python-pytest" ,python-pytest)
5608 ("man-db" ,man-db)
5609 ("which" ,which)
5610 ("bash-full" ,bash))) ;full Bash for 'test_replwrap.py'
5611 (propagated-inputs
5612 `(("python-ptyprocess" ,python-ptyprocess)))
5613 (home-page "http://pexpect.readthedocs.org/")
5614 (synopsis "Controlling interactive console applications")
5615 (description
5616 "Pexpect is a pure Python module for spawning child applications;
5617 controlling them; and responding to expected patterns in their output.
5618 Pexpect works like Don Libes’ Expect. Pexpect allows your script to spawn a
5619 child application and control it as if a human were typing commands.")
5620 (license license:isc)))
5621
5622 (define-public python2-pexpect
5623 (package-with-python2 python-pexpect))
5624
5625 (define-public python-setuptools-scm
5626 (package
5627 (name "python-setuptools-scm")
5628 (version "3.2.0")
5629 (source (origin
5630 (method url-fetch)
5631 (uri (pypi-uri "setuptools_scm" version))
5632 (sha256
5633 (base32
5634 "0n3knn3p1sqlx31k2lahn7z9bacvlv8nhlfidj77vz50bxqlgasj"))))
5635 (build-system python-build-system)
5636 (home-page "https://github.com/pypa/setuptools_scm/")
5637 (synopsis "Manage Python package versions in SCM metadata")
5638 (description
5639 "Setuptools_scm handles managing your Python package versions in
5640 @dfn{software configuration management} (SCM) metadata instead of declaring
5641 them as the version argument or in a SCM managed file.")
5642 (license license:expat)))
5643
5644 ;; Needed by python-lazy-object-proxy, remove on next update cycle.
5645 (define-public python-setuptools-scm-3.3
5646 (package
5647 (inherit python-setuptools-scm)
5648 (version "3.3.3")
5649 (source (origin
5650 (method url-fetch)
5651 (uri (pypi-uri "setuptools_scm" version))
5652 (sha256
5653 (base32
5654 "19cyndx23xmpbhz4qrwmfwsmnnaczd0dw7qg977ksq2dbvxy29dx"))))))
5655
5656 (define-public python2-setuptools-scm
5657 (package-with-python2 python-setuptools-scm))
5658
5659 (define-public python-pathlib2
5660 (package
5661 (name "python-pathlib2")
5662 (version "2.3.3")
5663 (source
5664 (origin
5665 (method url-fetch)
5666 (uri (pypi-uri "pathlib2" version))
5667 (sha256
5668 (base32
5669 "0hpp92vqqgcd8h92msm9slv161b1q160igjwnkf2ag6cx0c96695"))))
5670 (build-system python-build-system)
5671 (propagated-inputs
5672 `(("python-scandir" ,python-scandir)
5673 ("python-six" ,python-six)))
5674 (home-page "https://pypi.org/project/pathlib2/")
5675 (synopsis "Object-oriented file system paths")
5676 (description "The goal of pathlib2 is to provide a backport of the
5677 standard @code{pathlib} module which tracks the standard library module, so
5678 all the newest features of the standard @code{pathlib} can be used also on
5679 older Python versions.")
5680 (license license:expat)))
5681
5682 (define-public python2-importlib-resources
5683 (package
5684 (name "python2-importlib-resources")
5685 (version "1.0.2")
5686 (source (origin
5687 (method url-fetch)
5688 (uri (pypi-uri "importlib_resources" version))
5689 (sha256
5690 (base32
5691 "0y3hg12iby1qyaspnbisz4s4vxax7syikk3skznwqizqyv89y9yk"))))
5692 (build-system python-build-system)
5693 (arguments
5694 `(#:python ,python-2))
5695 (native-inputs
5696 `(("python-wheel" ,python2-wheel)))
5697 (propagated-inputs
5698 `(("python-pathlib2" ,python2-pathlib2)
5699 ("python-typing" ,python2-typing)))
5700 (home-page "https://gitlab.com/python-devs/importlib_resources")
5701 (synopsis "Backport of @code{importlib.resources} from Python 3.7")
5702 (description
5703 "This package provides an implementation of @code{importlib.resources}
5704 for older versions of Python.")
5705 (license license:asl2.0)))
5706
5707 (define-public python-importlib-metadata
5708 (package
5709 (name "python-importlib-metadata")
5710 (version "1.4.0")
5711 (source
5712 (origin
5713 (method url-fetch)
5714 (uri (pypi-uri "importlib_metadata" version))
5715 (sha256
5716 (base32 "1n76444v7zn910xrhh8954jdn4byxbn9f1jck6b85a716mbh2z7i"))))
5717 (build-system python-build-system)
5718 (propagated-inputs
5719 `(("python-zipp" ,python-zipp)))
5720 (native-inputs
5721 `(("python-setuptools-scm" ,python-setuptools-scm)
5722 ("python-packaging" ,python-packaging)))
5723 (home-page "https://importlib-metadata.readthedocs.io/")
5724 (synopsis "Read metadata from Python packages")
5725 (description
5726 "@code{importlib_metadata} is a library which provides an API for
5727 accessing an installed Python package's metadata, such as its entry points or
5728 its top-level name. This functionality intends to replace most uses of
5729 @code{pkg_resources} entry point API and metadata API. Along with
5730 @code{importlib.resources} in Python 3.7 and newer, this can eliminate the
5731 need to use the older and less efficient @code{pkg_resources} package.")
5732 (properties `((python2-variant . ,(delay python2-importlib-metadata))))
5733 (license license:asl2.0)))
5734
5735 (define-public python2-importlib-metadata
5736 (let ((base (package-with-python2 (strip-python2-variant
5737 python-importlib-metadata))))
5738 (package/inherit
5739 base
5740 (name "python2-importlib-metadata")
5741 (propagated-inputs
5742 `(("python-configparser" ,python2-configparser)
5743 ("python-contextlib2" ,python2-contextlib2)
5744 ("python-importlib-resources" ,python2-importlib-resources)
5745 ("python-pathlib2" ,python2-pathlib2)
5746 ,@(package-propagated-inputs base))))))
5747
5748 (define-public python-jaraco-packaging
5749 (package
5750 (name "python-jaraco-packaging")
5751 (version "6.1")
5752 (source
5753 (origin
5754 (method url-fetch)
5755 (uri (pypi-uri "jaraco.packaging" version))
5756 (sha256
5757 (base32
5758 "0zimrnkh33b9g8ffw11mjh6kvs54cy5gcjw1h5cl1r7dc833dmkm"))))
5759 (build-system python-build-system)
5760 (propagated-inputs
5761 `(("python-pytest" ,python-pytest)
5762 ("python-pytest-checkdocs" ,python-pytest-checkdocs)
5763 ("python-pytest-flake8" ,python-pytest-flake8)
5764 ("python-rst.linker" ,python-rst.linker)
5765 ("python-setuptools" ,python-setuptools)
5766 ("python-setuptools-scm" ,python-setuptools-scm)
5767 ("python-six" ,python-six)
5768 ("python-sphinx" ,python-sphinx)))
5769 (home-page "https://github.com/jaraco/jaraco.packaging")
5770 (synopsis "Tools to supplement packaging Python releases")
5771 (description
5772 "This package provides various tools to supplement packaging Python
5773 releases.")
5774 (license license:expat)))
5775
5776 (define-public python-pathpy
5777 (package
5778 (name "python-pathpy")
5779 (version "11.5.1")
5780 (source
5781 (origin
5782 (method url-fetch)
5783 (uri (pypi-uri "path.py" version))
5784 (sha256
5785 (base32 "0ir9j1haq2jbi7aip6k2fa9l7q1l03k4hp1awxhjhcwzsnwp3ll8"))))
5786 (outputs '("out" "doc"))
5787 (build-system python-build-system)
5788 (propagated-inputs
5789 `(("python-appdirs" ,python-appdirs)
5790 ("python-importlib-metadata" ,python-importlib-metadata)))
5791 (native-inputs
5792 `(("python-setuptools-scm" ,python-setuptools-scm)
5793 ("python-sphinx" ,python-sphinx)
5794 ("python-rst.linker" ,python-rst.linker)
5795 ("python-pytest" ,python-pytest)
5796 ("python-pytest-runner" ,python-pytest-runner)
5797 ("python-jaraco-packaging" ,python-jaraco-packaging)))
5798 (arguments
5799 `(#:phases
5800 (modify-phases %standard-phases
5801 (add-after 'build 'build-doc
5802 (lambda _
5803 (setenv "LANG" "en_US.UTF-8")
5804 (invoke "python" "setup.py" "build_sphinx")))
5805 (add-after 'install 'install-doc
5806 (lambda* (#:key outputs #:allow-other-keys)
5807 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5808 (doc (string-append data "/doc/" ,name "-" ,version))
5809 (html (string-append doc "/html")))
5810 (mkdir-p html)
5811 (for-each (lambda (file)
5812 (copy-file file (string-append doc "/" file)))
5813 '("README.rst" "CHANGES.rst"))
5814 (copy-recursively "build/sphinx/html" html)
5815 #t)))
5816 (replace 'check
5817 (lambda _
5818 ;; The import time test aborts if an import takes longer than
5819 ;; 100ms. It may very well take a little longer than that.
5820 (invoke "pytest" "-v" "-k" "not test_import_time"))))))
5821 (home-page "https://github.com/jaraco/path.py")
5822 (synopsis "Python module wrapper for built-in os.path")
5823 (description
5824 "@code{path.py} implements path objects as first-class entities, allowing
5825 common operations on files to be invoked on those path objects directly.")
5826 (license license:expat)))
5827
5828 (define-public python2-pathpy
5829 (package-with-python2 python-pathpy))
5830
5831 (define-public python-simplegeneric
5832 (package
5833 (name "python-simplegeneric")
5834 (version "0.8.1")
5835 (source
5836 (origin
5837 (method url-fetch)
5838 (uri (pypi-uri "simplegeneric" version ".zip"))
5839 (sha256
5840 (base32 "0wwi1c6md4vkbcsfsf8dklf3vr4mcdj4mpxkanwgb6jb1432x5yw"))))
5841 (build-system python-build-system)
5842 (native-inputs
5843 `(("unzip" ,unzip)))
5844 (home-page "http://cheeseshop.python.org/pypi/simplegeneric")
5845 (synopsis "Python module for simple generic functions")
5846 (description
5847 "The simplegeneric module lets you define simple single-dispatch generic
5848 functions, akin to Python’s built-in generic functions like @code{len()},
5849 @code{iter()} and so on. However, instead of using specially-named methods,
5850 these generic functions use simple lookup tables, akin to those used by
5851 e.g. @code{pickle.dump()} and other generic functions found in the Python
5852 standard library.")
5853 (license license:zpl2.1)))
5854
5855 (define-public python2-simplegeneric
5856 (package-with-python2 python-simplegeneric))
5857
5858 (define-public python-ipython-genutils
5859 ;; TODO: This package is retired, check if can be removed, see description.
5860 (package
5861 (name "python-ipython-genutils")
5862 (version "0.1.0")
5863 (source
5864 (origin
5865 (method url-fetch)
5866 (uri (pypi-uri "ipython_genutils" version))
5867 (sha256
5868 (base32 "19l2pp1c64ansr89l3cqh19jdi2ixhssdzx0vz4n6r52a6i281is"))))
5869 (build-system python-build-system)
5870 (arguments `(#:tests? #f)) ; no tests
5871 (home-page "https://ipython.org")
5872 (synopsis "Vestigial utilities from IPython")
5873 (description
5874 "This package provides retired utilities from IPython. No packages
5875 outside IPython/Jupyter should depend on it.
5876
5877 This package shouldn't exist. It contains some common utilities shared by
5878 Jupyter and IPython projects during The Big Split. As soon as possible, those
5879 packages will remove their dependency on this, and this package will go
5880 away.")
5881 (license license:bsd-3)))
5882
5883 (define-public python2-ipython-genutils
5884 (package-with-python2 python-ipython-genutils))
5885
5886 (define-public python-ipyparallel
5887 (package
5888 (name "python-ipyparallel")
5889 (version "6.2.4")
5890 (source
5891 (origin
5892 (method url-fetch)
5893 (uri (pypi-uri "ipyparallel" version))
5894 (sha256
5895 (base32
5896 "0rf0dbpxf5z82bw8lsjj45r3wdd4wc74anz4wiiaf2rbjqlb1ivn"))))
5897 (build-system python-build-system)
5898 (arguments
5899 `(#:tests? #f ; RuntimeError: IO Loop failed to start
5900 #:phases
5901 (modify-phases %standard-phases
5902 (add-before 'check 'prepare-for-tests
5903 (lambda _
5904 (setenv "HOME" (getcwd))
5905 #t)))))
5906 (propagated-inputs
5907 `(("python-dateutil" ,python-dateutil)
5908 ("python-decorator" ,python-decorator)
5909 ("python-ipykernel" ,python-ipykernel)
5910 ("python-ipython" ,python-ipython)
5911 ("python-ipython-genutils" ,python-ipython-genutils)
5912 ("python-jupyter-client" ,python-jupyter-client)
5913 ("python-pyzmq" ,python-pyzmq)
5914 ("python-tornado" ,python-tornado)
5915 ("python-traitlets" ,python-traitlets)))
5916 (native-inputs
5917 `(("python-ipython" ,python-ipython)
5918 ("python-mock" ,python-mock)
5919 ("python-nose" ,python-nose)
5920 ("python-pytest" ,python-pytest)
5921 ("python-pytest-cov" ,python-pytest-cov)
5922 ("python-testpath" ,python-testpath)))
5923 (home-page "https://ipython.org/")
5924 (synopsis "Interactive Parallel Computing with IPython")
5925 (description
5926 "@code{ipyparallel} is a Python package and collection of CLI scripts for
5927 controlling clusters for Jupyter. @code{ipyparallel} contains the following
5928 CLI scripts:
5929 @enumerate
5930 @item ipcluster - start/stop a cluster
5931 @item ipcontroller - start a scheduler
5932 @item ipengine - start an engine
5933 @end enumerate")
5934 (license license:bsd-3)))
5935
5936 (define-public python2-ipyparallel
5937 (let ((ipyparallel (package-with-python2 python-ipyparallel)))
5938 (package
5939 (inherit ipyparallel)
5940 (propagated-inputs
5941 `(("python2-futures" ,python2-futures)
5942 ,@(package-propagated-inputs ipyparallel))))))
5943
5944 (define-public python-ipython-cluster-helper
5945 (package
5946 (name "python-ipython-cluster-helper")
5947 (version "0.6.4")
5948 (source
5949 (origin
5950 (method url-fetch)
5951 (uri (pypi-uri "ipython-cluster-helper" version))
5952 (sha256
5953 (base32
5954 "1l6mlwxlkxpbvawfwk6qffich7ahg9hq2bxfissgz6144p3k4arj"))
5955 (modules '((guix build utils)))
5956 (snippet
5957 '(begin (substitute* "requirements.txt"
5958 (("ipython.*") "ipython\n"))
5959 #t))))
5960 (build-system python-build-system)
5961 (arguments
5962 `(#:tests? #f ; Test suite can't find IPython.
5963 #:phases
5964 (modify-phases %standard-phases
5965 (replace 'check
5966 (lambda* (#:key inputs outputs tests? #:allow-other-keys)
5967 (if tests?
5968 (begin
5969 (setenv "HOME" (getcwd))
5970 (add-installed-pythonpath inputs outputs)
5971 (invoke "python" "example/example.py" "--local"))
5972 #t))))))
5973 (propagated-inputs
5974 `(("python-ipyparallel" ,python-ipyparallel)
5975 ("python-ipython" ,python-ipython)
5976 ("python-netifaces" ,python-netifaces)
5977 ("python-pyzmq" ,python-pyzmq)
5978 ("python-setuptools" ,python-setuptools)
5979 ("python-six" ,python-six)))
5980 (home-page "https://github.com/roryk/ipython-cluster-helper")
5981 (synopsis
5982 "Simplify IPython cluster start up and use for multiple schedulers")
5983 (description
5984 "@code{ipython-cluster-helper} creates a throwaway parallel IPython
5985 profile, launches a cluster and returns a view. On program exit it shuts the
5986 cluster down and deletes the throwaway profile.")
5987 (license license:expat)))
5988
5989 (define-public python2-ipython-cluster-helper
5990 (package-with-python2 python-ipython-cluster-helper))
5991
5992 (define-public python-traitlets
5993 (package
5994 (name "python-traitlets")
5995 (version "4.3.3")
5996 (source
5997 (origin
5998 (method url-fetch)
5999 (uri (pypi-uri "traitlets" version))
6000 (sha256
6001 (base32
6002 "1xsrwgivpkxlbr4dfndfsi098s29yqgswgjc1qqn69yxklvfw8yh"))))
6003 (build-system python-build-system)
6004 (arguments
6005 `(#:phases
6006 (modify-phases %standard-phases
6007 (replace 'check (lambda _ (invoke "pytest" "-vv" "traitlets"))))))
6008 (propagated-inputs
6009 `(("python-ipython-genutils" ,python-ipython-genutils)
6010 ("python-decorator" ,python-decorator)))
6011 (native-inputs
6012 `(("python-pytest" ,python-pytest)))
6013 (properties `((python2-variant . ,(delay python2-traitlets))))
6014 (home-page "https://ipython.org")
6015 (synopsis "Configuration system for Python applications")
6016 (description
6017 "Traitlets is a framework that lets Python classes have attributes with
6018 type checking, dynamically calculated default values, and ‘on change’
6019 callbacks. The package also includes a mechanism to use traitlets for
6020 configuration, loading values from files or from command line arguments. This
6021 is a distinct layer on top of traitlets, so you can use traitlets in your code
6022 without using the configuration machinery.")
6023 (license license:bsd-3)))
6024
6025 (define-public python2-traitlets
6026 (let ((traitlets (package-with-python2 (strip-python2-variant python-traitlets))))
6027 (package
6028 (inherit traitlets)
6029 (propagated-inputs
6030 `(("python2-enum34" ,python2-enum34)
6031 ,@(package-propagated-inputs traitlets))))))
6032
6033 (define-public python-jupyter-core
6034 (package
6035 (name "python-jupyter-core")
6036 (version "4.4.0")
6037 (source
6038 (origin
6039 (method url-fetch)
6040 (uri (string-append (pypi-uri "jupyter_core" version)))
6041 (sha256
6042 (base32
6043 "1dy083rarba8prn9f9srxq3c7n7vyql02ycrqq306c40lr57aw5s"))))
6044 (build-system python-build-system)
6045 ;; FIXME: not sure how to run the tests
6046 (arguments `(#:tests? #f))
6047 (propagated-inputs
6048 `(("python-traitlets" ,python-traitlets)))
6049 (home-page "http://jupyter.org/")
6050 (synopsis "Jupyter base package")
6051 (description
6052 "Jupyter core is the base package on which Jupyter projects rely.")
6053 (license license:bsd-3)))
6054
6055 (define-public python2-jupyter-core
6056 (package-with-python2 python-jupyter-core))
6057
6058 (define-public python-jupyter-client
6059 (package
6060 (name "python-jupyter-client")
6061 (version "5.2.4")
6062 (source
6063 (origin
6064 (method url-fetch)
6065 (uri (pypi-uri "jupyter_client" version))
6066 (sha256
6067 (base32
6068 "0l9mh7ccrpl3lppym3dnky8n1nk7xarzzdcxf4q2s7aw203cpydm"))))
6069 (build-system python-build-system)
6070 ;; Tests fail because of missing native python kernel which I assume is
6071 ;; provided by the ipython package, which we cannot use because it would
6072 ;; cause a dependency cycle.
6073 (arguments
6074 `(#:tests? #f
6075
6076 #:phases (modify-phases %standard-phases
6077 (add-after 'unpack 'set-tool-file-names
6078 (lambda* (#:key inputs #:allow-other-keys)
6079 (let ((iproute (assoc-ref inputs "iproute")))
6080 (substitute* "jupyter_client/localinterfaces.py"
6081 (("'ip'")
6082 (string-append "'" iproute "/sbin/ip'")))
6083 #t))))))
6084 (inputs
6085 `(("iproute" ,iproute)))
6086 (propagated-inputs
6087 `(("python-pyzmq" ,python-pyzmq)
6088 ("python-traitlets" ,python-traitlets)
6089 ("python-jupyter-core" ,python-jupyter-core)))
6090 (home-page "http://jupyter.org/")
6091 (synopsis "Jupyter protocol implementation and client libraries")
6092 (description
6093 "The @code{jupyter_client} package contains the reference implementation
6094 of the Jupyter protocol. It also provides client and kernel management APIs
6095 for working with kernels, and the @code{jupyter kernelspec} entrypoint for
6096 installing @code{kernelspec}s for use with Jupyter frontends.")
6097 (license license:bsd-3)))
6098
6099 (define-public python2-jupyter-client
6100 (package-with-python2 python-jupyter-client))
6101
6102 (define-public python-ipykernel
6103 (package
6104 (name "python-ipykernel")
6105 (version "5.1.3")
6106 (source
6107 (origin
6108 (method url-fetch)
6109 (uri (pypi-uri "ipykernel" version))
6110 (sha256
6111 (base32 "1a08y677lpn80qzvv7z0smgggmr5m5ayf0bs6vds47xpxl9sss5k"))))
6112 (build-system python-build-system)
6113 (arguments
6114 `(#:phases
6115 (modify-phases %standard-phases
6116 (replace 'check
6117 (lambda _
6118 (setenv "HOME" "/tmp")
6119 (invoke "pytest" "-v")
6120 #t))
6121 (add-after 'install 'set-python-file-name
6122 (lambda* (#:key outputs #:allow-other-keys)
6123 ;; Record the absolute file name of the 'python' executable in
6124 ;; 'kernel.json'.
6125 (let ((out (assoc-ref outputs "out")))
6126 (substitute* (string-append out "/share/jupyter"
6127 "/kernels/python3/kernel.json")
6128 (("\"python\"")
6129 (string-append "\"" (which "python") "\"")))
6130 #t))))))
6131 (propagated-inputs
6132 `(("python-ipython" ,python-ipython)
6133 ;; imported at runtime during connect
6134 ("python-jupyter-client" ,python-jupyter-client)))
6135 (native-inputs
6136 `(("python-flaky" ,python-flaky)
6137 ("python-nose" ,python-nose)
6138 ("python-pytest" ,python-pytest)))
6139 (home-page "https://ipython.org")
6140 (synopsis "IPython Kernel for Jupyter")
6141 (description
6142 "This package provides the IPython kernel for Jupyter.")
6143 (properties `((python2-variant . ,(delay python2-ipykernel))))
6144 (license license:bsd-3)))
6145
6146 ;; Version 5.x and above no longer support Python 2.
6147 (define-public python2-ipykernel
6148 (package
6149 (name "python2-ipykernel")
6150 (version "4.10.1")
6151 (source
6152 (origin
6153 (method url-fetch)
6154 (uri (pypi-uri "ipykernel" version))
6155 (sha256
6156 (base32 "1yzmdiy1djsszqp54jzd8ym8h4hpl67zjq83j2kxbkp0rwmlpdzf"))))
6157 (build-system python-build-system)
6158 (arguments
6159 `(#:python ,python-2))
6160 (propagated-inputs
6161 `(("python2-ipython" ,python2-ipython)
6162 ;; imported at runtime during connect
6163 ("python2-jupyter-client" ,python2-jupyter-client)
6164 ("python2-tornado" ,python2-tornado)
6165 ("python2-traitlets" ,python2-traitlets)))
6166 (native-inputs
6167 `(("python2-mock" ,python2-mock)
6168 ("python2-nose" ,python2-nose)
6169 ("python2-pytest" ,python2-pytest)
6170 ("python2-pytest-cov" ,python2-pytest-cov)))
6171 (home-page "https://ipython.org")
6172 (synopsis "IPython Kernel for Jupyter")
6173 (description
6174 "This package provides the IPython kernel for Jupyter.")
6175 (license license:bsd-3)))
6176
6177 (define-public python-pari-jupyter
6178 (package
6179 (name "python-pari-jupyter")
6180 (version "1.3.2")
6181 (source
6182 (origin
6183 (method url-fetch)
6184 (uri (pypi-uri "pari_jupyter" version))
6185 (sha256
6186 (base32
6187 "1yash0p422nnin7z58b99d0p23nx79f5m0mainc9hsjg72jhdhr6"))))
6188 (build-system python-build-system)
6189 (propagated-inputs
6190 `(("python-ipykernel" ,python-ipykernel)))
6191 (inputs
6192 `(("pari-gp" ,pari-gp)
6193 ("readline" ,readline)))
6194 (arguments
6195 `(#:tests? #f)) ; no test suite
6196 (home-page
6197 "https://github.com/jdemeyer/pari_jupyter")
6198 (synopsis "A Jupyter kernel for PARI/GP")
6199 (description "The package provides a PARI/GP kernel for Jupyter.")
6200 (license license:gpl3+)))
6201
6202 (define-public python-backcall
6203 (package
6204 (name "python-backcall")
6205 (version "0.1.0")
6206 (source
6207 (origin
6208 (method url-fetch)
6209 (uri (pypi-uri "backcall" version))
6210 (sha256
6211 (base32
6212 "1r01dqch3f8fdj3n6fviw8hxqrs6w5v0qw4izmvqzry1w9dxiv1q"))))
6213 (build-system python-build-system)
6214 (home-page "https://github.com/takluyver/backcall/")
6215 (synopsis "Specifications for callback functions passed in to an API")
6216 (description
6217 "If your code lets other people supply callback functions, it's important
6218 to specify the function signature you expect, and check that functions support
6219 that. Adding extra parameters later would break other peoples code unless
6220 you're careful. The @code{backcall} package provides a way of specifying the
6221 callback signature using a prototype function.")
6222 (license license:bsd-3)))
6223
6224 (define-public python-ipython
6225 (package
6226 (name "python-ipython")
6227 (version "7.9.0")
6228 (source
6229 (origin
6230 (method url-fetch)
6231 (uri (pypi-uri "ipython" version ".tar.gz"))
6232 (sha256
6233 (base32 "103jkw18z7fnwdal1mdbijjxi1fndzn31g887lmj7ddpf2r07lyz"))))
6234 (build-system python-build-system)
6235 (propagated-inputs
6236 `(("python-backcall" ,python-backcall)
6237 ("python-pyzmq" ,python-pyzmq)
6238 ("python-prompt-toolkit" ,python-prompt-toolkit)
6239 ("python-terminado" ,python-terminado)
6240 ("python-matplotlib" ,python-matplotlib)
6241 ("python-numpy" ,python-numpy)
6242 ("python-numpydoc" ,python-numpydoc)
6243 ("python-jedi" ,python-jedi)
6244 ("python-jinja2" ,python-jinja2)
6245 ("python-mistune" ,python-mistune)
6246 ("python-pexpect" ,python-pexpect)
6247 ("python-pickleshare" ,python-pickleshare)
6248 ("python-simplegeneric" ,python-simplegeneric)
6249 ("python-jsonschema" ,python-jsonschema)
6250 ("python-traitlets" ,python-traitlets)
6251 ("python-nbformat" ,python-nbformat)
6252 ("python-pygments" ,python-pygments)))
6253 (inputs
6254 `(("readline" ,readline)
6255 ("which" ,which)))
6256 (native-inputs
6257 `(("graphviz" ,graphviz)
6258 ("pkg-config" ,pkg-config)
6259 ("python-requests" ,python-requests) ;; for tests
6260 ("python-testpath" ,python-testpath)
6261 ("python-nose" ,python-nose)))
6262 (arguments
6263 `(#:phases
6264 (modify-phases %standard-phases
6265 (add-after 'unpack 'make-docs-reproducible
6266 (lambda _
6267 (substitute* "IPython/sphinxext/ipython_directive.py"
6268 ((".*import datetime") "")
6269 ((".*datetime.datetime.now\\(\\)") "")
6270 (("%timeit") "# %timeit"))
6271 #t))
6272 ;; Tests can only be run after the library has been installed and not
6273 ;; within the source directory.
6274 (delete 'check)
6275 (add-after 'install 'check
6276 (lambda* (#:key inputs outputs tests? #:allow-other-keys)
6277 (if tests?
6278 (begin
6279 ;; Make installed package available for running the tests
6280 (add-installed-pythonpath inputs outputs)
6281 (setenv "HOME" "/tmp/") ;; required by a test
6282 ;; We only test the core because one of the other tests
6283 ;; tries to import ipykernel.
6284 (invoke "python" "IPython/testing/iptest.py"
6285 "-v" "IPython/core/tests"))
6286 #t)))
6287 (add-before 'check 'fix-tests
6288 (lambda* (#:key inputs #:allow-other-keys)
6289 (substitute* "./IPython/utils/_process_posix.py"
6290 (("/usr/bin/env', 'which") (which "which")))
6291 (substitute* "./IPython/core/tests/test_inputtransformer.py"
6292 (("#!/usr/bin/env python")
6293 (string-append "#!" (which "python"))))
6294 ;; This test introduces a circular dependency on ipykernel
6295 ;; (which depends on ipython).
6296 (delete-file "IPython/core/tests/test_display.py")
6297 ;; AttributeError: module 'IPython.core' has no attribute 'formatters'
6298 (delete-file "IPython/core/tests/test_interactiveshell.py")
6299 #t)))))
6300 (home-page "https://ipython.org")
6301 (synopsis "IPython is a tool for interactive computing in Python")
6302 (description
6303 "IPython provides a rich architecture for interactive computing with:
6304 Powerful interactive shells, a browser-based notebook, support for interactive
6305 data visualization, embeddable interpreters and tools for parallel
6306 computing.")
6307 (properties `((python2-variant . ,(delay python2-ipython))))
6308 (license license:bsd-3)))
6309
6310 ;; This is the latest release of the LTS version of ipython with support for
6311 ;; Python 2.7 and Python 3.x. Later non-LTS versions starting from 6.0 have
6312 ;; dropped support for Python 2.7.
6313 (define-public python2-ipython
6314 (package
6315 (name "python2-ipython")
6316 (version "5.8.0")
6317 (source
6318 (origin
6319 (method url-fetch)
6320 (uri (pypi-uri "ipython" version ".tar.gz"))
6321 (sha256
6322 (base32 "01l93i4hspf0lvhmycvc8j378bslm9rw30mwfspsl6v1ayc69b2b"))))
6323 (build-system python-build-system)
6324 (propagated-inputs
6325 `(("python2-backports-shutil-get-terminal-size"
6326 ,python2-backports-shutil-get-terminal-size)
6327 ("python2-pathlib2" ,python2-pathlib2)
6328 ("python2-pyzmq" ,python2-pyzmq)
6329 ("python2-prompt-toolkit" ,python2-prompt-toolkit-1)
6330 ("python2-terminado" ,python2-terminado)
6331 ("python2-matplotlib" ,python2-matplotlib)
6332 ("python2-numpy" ,python2-numpy)
6333 ("python2-numpydoc" ,python2-numpydoc)
6334 ("python2-jinja2" ,python2-jinja2)
6335 ("python2-mistune" ,python2-mistune)
6336 ("python2-pexpect" ,python2-pexpect)
6337 ("python2-pickleshare" ,python2-pickleshare)
6338 ("python2-simplegeneric" ,python2-simplegeneric)
6339 ("python2-jsonschema" ,python2-jsonschema)
6340 ("python2-traitlets" ,python2-traitlets)
6341 ("python2-nbformat" ,python2-nbformat)
6342 ("python2-pygments" ,python2-pygments)))
6343 (inputs
6344 `(("readline" ,readline)
6345 ("which" ,which)))
6346 (native-inputs
6347 `(("graphviz" ,graphviz)
6348 ("pkg-config" ,pkg-config)
6349 ("python2-requests" ,python2-requests) ;; for tests
6350 ("python2-testpath" ,python2-testpath)
6351 ("python2-mock" ,python2-mock)
6352 ("python2-nose" ,python2-nose)))
6353 (arguments
6354 `(#:python ,python-2
6355 #:phases
6356 (modify-phases %standard-phases
6357 (add-before 'check 'delete-broken-tests
6358 (lambda* (#:key inputs #:allow-other-keys)
6359 ;; These tests throw errors for unknown reasons.
6360 (delete-file "IPython/core/tests/test_displayhook.py")
6361 (delete-file "IPython/core/tests/test_magic_terminal.py")
6362 (delete-file "IPython/core/tests/test_profile.py")
6363 #t)))))
6364 (home-page "https://ipython.org")
6365 (synopsis "IPython is a tool for interactive computing in Python")
6366 (description
6367 "IPython provides a rich architecture for interactive computing with:
6368 Powerful interactive shells, a browser-based notebook, support for interactive
6369 data visualization, embeddable interpreters and tools for parallel
6370 computing.")
6371 (license license:bsd-3)))
6372
6373 (define-public python-ipython-documentation
6374 (package
6375 (inherit python-ipython)
6376 (name "python-ipython-documentation")
6377 (version (package-version python-ipython))
6378 (arguments
6379 `(#:phases
6380 (modify-phases %standard-phases
6381 (delete 'build)
6382 (delete 'check)
6383 (replace 'install
6384 (lambda* (#:key outputs #:allow-other-keys)
6385 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
6386 (doc (string-append data "/doc/" ,name "-" ,version))
6387 (html (string-append doc "/html"))
6388 (man1 (string-append data "/man/man1"))
6389 (info (string-append data "/info"))
6390 (examples (string-append doc "/examples"))
6391 (python-arg (string-append "PYTHON=" (which "python"))))
6392 (setenv "LANG" "en_US.utf8")
6393 (with-directory-excursion "docs"
6394 ;; FIXME: pdf fails to build
6395 ;;(system* "make" "pdf" "PAPER=a4")
6396 (system* "make" python-arg "html")
6397 ;; FIXME: the generated texi file contains ^@^@, which trips
6398 ;; up the parser.
6399 ;; (system* "make" python-arg "info")
6400 )
6401 (copy-recursively "docs/man" man1)
6402 (copy-recursively "examples" examples)
6403 (copy-recursively "docs/build/html" html)
6404 ;; (copy-file "docs/build/latex/ipython.pdf"
6405 ;; (string-append doc "/ipython.pdf"))
6406 (mkdir-p info)
6407 ;; (copy-file "docs/build/texinfo/ipython.info"
6408 ;; (string-append info "/ipython.info"))
6409 (copy-file "COPYING.rst" (string-append doc "/COPYING.rst")))
6410 #t)))))
6411 (inputs
6412 `(("python-ipython" ,python-ipython)
6413 ("python-ipykernel" ,python-ipykernel)))
6414 (native-inputs
6415 `(("python-sphinx" ,python-sphinx)
6416 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)
6417 ;; FIXME: It's possible that a smaller union would work just as well.
6418 ("texlive" ,(texlive-union (list texlive-amsfonts
6419 texlive-fonts-ec
6420 texlive-generic-ifxetex
6421 texlive-generic-pdftex
6422 texlive-latex-capt-of
6423 texlive-latex-cmap
6424 texlive-latex-environ
6425 texlive-latex-eqparbox
6426 texlive-latex-etoolbox
6427 texlive-latex-expdlist
6428 texlive-latex-fancyhdr
6429 texlive-latex-fancyvrb
6430 texlive-latex-fncychap
6431 texlive-latex-float
6432 texlive-latex-framed
6433 texlive-latex-geometry
6434 texlive-latex-graphics
6435 texlive-latex-hyperref
6436 texlive-latex-mdwtools
6437 texlive-latex-multirow
6438 texlive-latex-needspace
6439 texlive-latex-oberdiek
6440 texlive-latex-parskip
6441 texlive-latex-preview
6442 texlive-latex-tabulary
6443 texlive-latex-threeparttable
6444 texlive-latex-titlesec
6445 texlive-latex-trimspaces
6446 texlive-latex-ucs
6447 texlive-latex-upquote
6448 texlive-latex-url
6449 texlive-latex-varwidth
6450 texlive-latex-wrapfig)))
6451 ("texinfo" ,texinfo)))))
6452
6453 (define-public python-urwid
6454 (package
6455 (name "python-urwid")
6456 (version "2.1.0")
6457 (source
6458 (origin
6459 (method url-fetch)
6460 (uri (pypi-uri "urwid" version))
6461 (sha256
6462 (base32
6463 "11ndnhxd41m13darf5s0c6bafdpkzq1l6mfb04wbzdmyc1hg75h8"))))
6464 (build-system python-build-system)
6465 (home-page "http://urwid.org")
6466 (synopsis "Console user interface library for Python")
6467 (description
6468 "Urwid is a curses-based UI/widget library for Python. It includes many
6469 features useful for text console applications.")
6470 (license license:lgpl2.1+)))
6471
6472 (define-public python2-urwid
6473 (package-with-python2 python-urwid))
6474
6475 (define-public python-urwidtrees
6476 (package
6477 (name "python-urwidtrees")
6478 (version "1.0.2")
6479 (source
6480 (origin
6481 (method git-fetch)
6482 ;; package author intends on distributing via github rather than pypi:
6483 ;; https://github.com/pazz/alot/issues/877#issuecomment-230173331
6484 (uri (git-reference
6485 (url "https://github.com/pazz/urwidtrees")
6486 (commit version)))
6487 (file-name (git-file-name name version))
6488 (sha256
6489 (base32
6490 "1n1kpidvkdnsqyb82vlvk78gmly96kh8351lqxn2pzgwwns6fml2"))))
6491 (build-system python-build-system)
6492 (arguments
6493 '(#:use-setuptools? #f
6494 #:tests? #f)) ; no tests
6495 (propagated-inputs `(("python-urwid" ,python-urwid)))
6496 (home-page "https://github.com/pazz/urwidtrees")
6497 (synopsis "Tree widgets for urwid")
6498 (description "Urwidtrees is a Widget Container API for the @code{urwid}
6499 toolkit. Use it to build trees of widgets.")
6500 (license license:gpl3+)))
6501
6502 (define-public python2-urwidtrees
6503 (package-with-python2 python-urwidtrees))
6504
6505 (define-public python-ua-parser
6506 (package
6507 (name "python-ua-parser")
6508 (version "0.8.0")
6509 (source
6510 (origin
6511 (method url-fetch)
6512 (uri (pypi-uri "ua-parser" version))
6513 (sha256
6514 (base32
6515 "1jwdf58rhchjzzrad405pviv0iq24xa2xmmmdgcm2c8s6b4wzfwp"))))
6516 (build-system python-build-system)
6517 (arguments
6518 `(#:tests? #f)) ;no test suite in release
6519 (native-inputs
6520 `(("python-pyyaml" ,python-pyyaml)))
6521 (home-page "https://github.com/ua-parser/uap-python")
6522 (synopsis "User agent parser")
6523 (description
6524 "@code{ua-parser} is a Python port of Browserscope's user agent parser.")
6525 (license license:asl2.0)))
6526
6527 (define-public python2-ua-parser
6528 (package-with-python2 python-ua-parser))
6529
6530 (define-public python-user-agents
6531 (package
6532 (name "python-user-agents")
6533 (version "1.1.0")
6534 (source
6535 (origin
6536 (method url-fetch)
6537 (uri (pypi-uri "user-agents" version))
6538 (sha256
6539 (base32
6540 "0fc00cd3j8dahq1zzn8pkgfgd7lq37bp2scmdma2n1c049vicgb4"))))
6541 (build-system python-build-system)
6542 (arguments
6543 `(#:tests? #f)) ;missing devices.json test file in release
6544 (propagated-inputs
6545 `(("python-ua-parser" ,python-ua-parser)))
6546 (home-page "https://github.com/selwin/python-user-agents")
6547 (synopsis "User Agent strings parsing library")
6548 (description
6549 "A library to identify devices (phones, tablets) and their capabilities by
6550 parsing (browser/HTTP) user agent strings.")
6551 (license license:expat)))
6552
6553 (define-public python2-user-agents
6554 (package-with-python2 python-user-agents))
6555
6556 (define-public python-dbus
6557 (package
6558 (name "python-dbus")
6559 (version "1.2.14")
6560 (source
6561 (origin
6562 (method url-fetch)
6563 (uri (string-append "https://dbus.freedesktop.org/releases/dbus-python/"
6564 "dbus-python-" version ".tar.gz"))
6565 (sha256
6566 (base32 "0cdchkgnivlka4lf8q4qfk0yxq483i3r3aqickjf8hfn7nx0c0mi"))))
6567 (build-system gnu-build-system)
6568 (native-inputs
6569 `(("pkg-config" ,pkg-config)))
6570 (inputs
6571 `(("python" ,python-wrapper)
6572 ("dbus-glib" ,dbus-glib)))
6573 (synopsis "Python bindings for D-bus")
6574 (description "python-dbus provides bindings for libdbus, the reference
6575 implementation of D-Bus.")
6576 (home-page "https://www.freedesktop.org/wiki/Software/DBusBindings/")
6577 (license license:expat)))
6578
6579 (define-public python2-dbus
6580 (package (inherit python-dbus)
6581 (name "python2-dbus")
6582 (inputs `(("python" ,python-2)
6583 ,@(alist-delete "python"
6584 (package-inputs python-dbus)
6585 equal?)))))
6586
6587 (define-public python-notify2
6588 (package
6589 (name "python-notify2")
6590 (version "0.3.1")
6591 (source
6592 (origin
6593 (method url-fetch)
6594 (uri (pypi-uri "notify2" version))
6595 (sha256
6596 (base32
6597 "0z8rrv9rsg1r2qgh2dxj3dfj5xnki98kgi3w839kqby4a26i1yik"))))
6598 (build-system python-build-system)
6599 (arguments `(#:tests? #f)) ; tests depend on system state
6600 (native-inputs
6601 `(("python-dbus" ,python-dbus)))
6602 (home-page "https://bitbucket.org/takluyver/pynotify2")
6603 (synopsis "Python interface to D-Bus notifications")
6604 (description
6605 "Pynotify2 provides a Python interface for sending D-Bus notifications.
6606 It is a reimplementation of pynotify in pure Python, and an alternative to
6607 the GObject Introspection bindings to libnotify for non-GTK applications.")
6608 (license (list license:bsd-2
6609 license:lgpl2.1+))))
6610
6611 (define-public python2-notify2
6612 (package-with-python2 python-notify2))
6613
6614 ;; beautifulsoup4 has a totally different namespace than 3.x,
6615 ;; and pypi seems to put it under its own name, so I guess we should too
6616 (define-public python-beautifulsoup4
6617 (package
6618 (name "python-beautifulsoup4")
6619 (version "4.7.1")
6620 (source
6621 (origin
6622 (method url-fetch)
6623 (uri (pypi-uri "beautifulsoup4" version))
6624 (sha256
6625 (base32
6626 "0j2kycz2dxgx68xzjm7rxg5xn6v61gq5ifvxyg99slmqkybnal4l"))))
6627 (build-system python-build-system)
6628 (arguments
6629 `(#:phases
6630 (modify-phases %standard-phases
6631 ;; The Python 2 source is the definitive source of beautifulsoup4. We
6632 ;; must use this conversion script when building with Python 3. The
6633 ;; conversion script also runs the tests.
6634 ;; For more information, see the file 'convert-py3k' in the source
6635 ;; distribution.
6636 (replace 'check
6637 (lambda _ (invoke "./convert-py3k"))))))
6638 (propagated-inputs
6639 `(("python-soupsieve" ,python-soupsieve)))
6640 (home-page
6641 "https://www.crummy.com/software/BeautifulSoup/bs4/")
6642 (synopsis
6643 "Python screen-scraping library")
6644 (description
6645 "Beautiful Soup is a Python library designed for rapidly setting up
6646 screen-scraping projects. It offers Pythonic idioms for navigating,
6647 searching, and modifying a parse tree, providing a toolkit for
6648 dissecting a document and extracting what you need. It automatically
6649 converts incoming documents to Unicode and outgoing documents to UTF-8.")
6650 (license license:expat)
6651 (properties `((python2-variant . ,(delay python2-beautifulsoup4))))))
6652
6653 (define-public python2-beautifulsoup4
6654 (package
6655 (inherit (package-with-python2
6656 (strip-python2-variant python-beautifulsoup4)))
6657 (arguments `(#:python ,python-2))))
6658
6659 (define-public python-soupsieve
6660 (package
6661 (name "python-soupsieve")
6662 (version "1.9.5")
6663 (source
6664 (origin
6665 (method url-fetch)
6666 (uri (pypi-uri "soupsieve" version))
6667 (sha256
6668 (base32
6669 "1nhd0q0ifwva9wn645s6pn74p1rd97asn3qfg75nphx1wkgcbhg2"))))
6670 (build-system python-build-system)
6671 (arguments `(#:tests? #f))
6672 ;;XXX: 2 tests fail currently despite claming they were to be
6673 ;;skipped. Also, beautifulsoup4 may depend on this in the future, so we
6674 ;;don't want to create a circular dependency.
6675 (home-page "https://github.com/facelessuser/soupsieve")
6676 (synopsis "CSS selector library")
6677 (description
6678 "Soup Sieve is a CSS selector library designed to be used with Beautiful
6679 Soup 4. It aims to provide selecting, matching, and filtering using modern
6680 CSS selectors. Soup Sieve currently provides selectors from the CSS level 1
6681 specifications up through the latest CSS level 4 drafts and beyond (though
6682 some are not yet implemented).")
6683 (properties `((python2-variant . ,(delay python2-soupsieve))))
6684 (license license:expat)))
6685
6686 (define-public python2-soupsieve
6687 (let ((base (package-with-python2 (strip-python2-variant python-soupsieve))))
6688 (package
6689 (inherit base)
6690 (propagated-inputs
6691 `(("python2-backports-functools-lru-cache"
6692 ,python2-backports-functools-lru-cache)
6693 ,@(package-propagated-inputs base))))))
6694
6695 (define-public python-netifaces
6696 (package
6697 (name "python-netifaces")
6698 (version "0.10.7")
6699 (source
6700 (origin
6701 (method url-fetch)
6702 (uri (pypi-uri "netifaces" version))
6703 (sha256
6704 (base32
6705 "1gccklrcplbbqh81g1mdgpa5y8na7kkf29cq2ka3f5a2fp5hyndx"))))
6706 (build-system python-build-system)
6707 (home-page "https://github.com/al45tair/netifaces")
6708 (synopsis
6709 "Python module for portable network interface information")
6710 (description
6711 "Netifaces is a Python module providing information on network
6712 interfaces in an easy and portable manner.")
6713 (license license:expat)))
6714
6715 (define-public python2-netifaces
6716 (package-with-python2 python-netifaces))
6717
6718 (define-public python-networkx
6719 (package
6720 (name "python-networkx")
6721 (version "2.4")
6722 (source
6723 (origin
6724 (method url-fetch)
6725 (uri (pypi-uri "networkx" version))
6726 (sha256
6727 (base32 "0r2wr7aqay9fwjrgk35fkjzk8lvvb4i4df7ndaqzkr4ndw5zzx7q"))))
6728 (build-system python-build-system)
6729 (arguments
6730 '(#:phases (modify-phases %standard-phases
6731 (replace 'check
6732 (lambda* (#:key tests? #:allow-other-keys)
6733 (if tests?
6734 (invoke "pytest" "-vv" "--pyargs" "networkx")
6735 (format #t "test suite not run~%"))
6736 #t)))))
6737 ;; python-decorator is needed at runtime.
6738 (propagated-inputs
6739 `(("python-decorator" ,python-decorator)))
6740 (native-inputs
6741 `(("python-pytest" ,python-pytest)))
6742 (home-page "https://networkx.github.io/")
6743 (synopsis "Python module for creating and manipulating graphs and networks")
6744 (description
6745 "NetworkX is a Python package for the creation, manipulation, and study
6746 of the structure, dynamics, and functions of complex networks.")
6747 (properties `((python2-variant . ,(delay python2-networkx))))
6748 (license license:bsd-3)))
6749
6750 ;; NetworkX 2.2 is the last version with support for Python 2.
6751 (define-public python2-networkx
6752 (let ((base (package-with-python2 (strip-python2-variant python-networkx))))
6753 (package
6754 (inherit base)
6755 (version "2.2")
6756 (source (origin
6757 (method url-fetch)
6758 (uri (pypi-uri "networkx" version ".zip"))
6759 (sha256
6760 (base32
6761 "12swxb15299v9vqjsq4z8rgh5sdhvpx497xwnhpnb0gynrx6zra5"))))
6762 (arguments
6763 `(#:python ,python-2))
6764 (native-inputs
6765 `(("python-nose" ,python2-nose)
6766 ("unzip" ,unzip))))))
6767
6768 (define-public python-datrie
6769 (package
6770 (name "python-datrie")
6771 (version "0.8.2")
6772 (source
6773 (origin
6774 (method url-fetch)
6775 (uri (pypi-uri "datrie" version))
6776 (sha256
6777 (base32
6778 "0pbn32flkrpjiwfcknmj6398qa81ba783kbcvwan3kym73v0hnsj"))))
6779 (build-system python-build-system)
6780 (native-inputs
6781 `(("python-cython" ,python-cython)
6782 ("python-hypothesis" ,python-hypothesis)
6783 ("python-pytest" ,python-pytest)
6784 ("python-pytest-runner" ,python-pytest-runner)))
6785 (home-page "https://github.com/kmike/datrie")
6786 (synopsis "Fast, efficiently stored trie for Python")
6787 (description
6788 "This package provides a fast, efficiently stored trie implementation for
6789 Python.")
6790 (license license:lgpl2.1+)))
6791
6792 (define-public snakemake
6793 (package
6794 (name "snakemake")
6795 (version "5.7.1")
6796 (source
6797 (origin
6798 (method url-fetch)
6799 (uri (pypi-uri "snakemake" version))
6800 (sha256
6801 (base32 "1pnpvvn8n2a78cg360wz3ldmpqrsm2wzi0c0dmvki9fnsw6fxdas"))))
6802 (build-system python-build-system)
6803 (arguments
6804 ;; TODO: Package missing test dependencies.
6805 '(#:tests? #f
6806 #:phases
6807 (modify-phases %standard-phases
6808 ;; For cluster execution Snakemake will call Python. Since there is
6809 ;; no suitable PYTHONPATH set, cluster execution will fail. We fix
6810 ;; this by calling the snakemake wrapper instead.
6811 (add-after 'unpack 'call-wrapper-not-wrapped-snakemake
6812 (lambda* (#:key outputs #:allow-other-keys)
6813 (substitute* "snakemake/executors.py"
6814 (("\\{sys.executable\\} -m snakemake")
6815 (string-append (assoc-ref outputs "out")
6816 "/bin/snakemake")))
6817 #t)))))
6818 (propagated-inputs
6819 `(("python-appdirs" ,python-appdirs)
6820 ("python-configargparse" ,python-configargparse)
6821 ("python-datrie" ,python-datrie)
6822 ("python-docutils" ,python-docutils)
6823 ("python-gitpython" ,python-gitpython)
6824 ("python-jinja2" ,python-jinja2)
6825 ("python-jsonschema" ,python-jsonschema)
6826 ("python-networkx" ,python-networkx)
6827 ("python-psutil" ,python-psutil)
6828 ("python-pyyaml" ,python-pyyaml)
6829 ("python-ratelimiter" ,python-ratelimiter)
6830 ("python-requests" ,python-requests)
6831 ("python-wrapt" ,python-wrapt)))
6832 (home-page "https://snakemake.readthedocs.io")
6833 (synopsis "Python-based execution environment for make-like workflows")
6834 (description
6835 "Snakemake aims to reduce the complexity of creating workflows by
6836 providing a clean and modern domain specific specification language (DSL) in
6837 Python style, together with a fast and comfortable execution environment.")
6838 (license license:expat)))
6839
6840 (define-public python-pyqrcode
6841 (package
6842 (name "python-pyqrcode")
6843 (version "1.2.1")
6844 (source
6845 (origin
6846 (method url-fetch)
6847 (uri (pypi-uri "PyQRCode" version))
6848 (sha256
6849 (base32
6850 "1m9ln8k9v7dfbh1i81225hx5mdsh8mpf9g7r4wpbfmiyfcs7dgzx"))))
6851 (build-system python-build-system)
6852 (home-page
6853 "https://github.com/mnooner256/pyqrcode")
6854 (synopsis "QR code generator")
6855 (description
6856 "Pyqrcode is a QR code generator written purely in Python with
6857 SVG, EPS, PNG and terminal output.")
6858 (license license:bsd-3)))
6859
6860 (define-public python-seaborn
6861 (package
6862 (name "python-seaborn")
6863 (version "0.10.0")
6864 (source
6865 (origin
6866 (method url-fetch)
6867 (uri (pypi-uri "seaborn" version))
6868 (sha256
6869 (base32 "1ffbms4kllihfycf6j57dziq4imgdjw03sqgifh5wzcd2d743zjr"))))
6870 (build-system python-build-system)
6871 (arguments
6872 `(#:phases
6873 (modify-phases %standard-phases
6874 (add-before 'check 'start-xserver
6875 (lambda* (#:key inputs #:allow-other-keys)
6876 (let ((xorg-server (assoc-ref inputs "xorg-server")))
6877 ;; There must be a running X server and make check doesn't
6878 ;; start one. Therefore we must do it.
6879 (system (format #f "~a/bin/Xvfb :1 &" xorg-server))
6880 (setenv "DISPLAY" ":1")
6881 #t)))
6882 (replace 'check (lambda _ (invoke "pytest" "seaborn") #t)))))
6883 (propagated-inputs
6884 `(("python-pandas" ,python-pandas)
6885 ("python-matplotlib" ,python-matplotlib)
6886 ("python-numpy" ,python-numpy)
6887 ("python-scipy" ,python-scipy)))
6888 (native-inputs
6889 `(("python-pytest" ,python-pytest)
6890 ("xorg-server" ,xorg-server-for-tests)))
6891 (home-page "https://seaborn.pydata.org/")
6892 (synopsis "Statistical data visualization")
6893 (description
6894 "Seaborn is a library for making attractive and informative statistical
6895 graphics in Python. It is built on top of matplotlib and tightly integrated
6896 with the PyData stack, including support for numpy and pandas data structures
6897 and statistical routines from scipy and statsmodels.")
6898 (properties `((python2-variant . ,(delay python2-seaborn))))
6899 (license license:bsd-3)))
6900
6901 ;; 0.9.1 is the last release with support for Python 2.
6902 (define-public python2-seaborn
6903 (let ((base (package-with-python2 (strip-python2-variant python-seaborn))))
6904 (package
6905 (inherit base)
6906 (version "0.9.1")
6907 (source (origin
6908 (method url-fetch)
6909 (uri (pypi-uri "seaborn" version))
6910 (sha256
6911 (base32
6912 "1bjnshjz4d6z3vrwfwall1a3yh8h3a1h47c3fg7458x9426alcys")))))))
6913
6914 (define-public python-mpmath
6915 (package
6916 (name "python-mpmath")
6917 (version "0.19")
6918 (source (origin
6919 (method url-fetch)
6920 (uri (string-append "http://mpmath.org/files/mpmath-"
6921 version ".tar.gz"))
6922 (sha256
6923 (base32
6924 "08ijsr4ifrqv3cjc26mkw0dbvyygsa99in376hr4b96ddm1gdpb8"))))
6925 (build-system python-build-system)
6926 (arguments
6927 '(#:phases
6928 (modify-phases %standard-phases
6929 (replace 'check
6930 (lambda _
6931 (invoke "python" "mpmath/tests/runtests.py" "-local"))))))
6932 (home-page "http://mpmath.org")
6933 (synopsis "Arbitrary-precision floating-point arithmetic in python")
6934 (description
6935 "@code{mpmath} can be used as an arbitrary-precision substitute for
6936 Python's float/complex types and math/cmath modules, but also does much
6937 more advanced mathematics.")
6938 (license license:bsd-3)))
6939
6940 (define-public python2-mpmath
6941 (package-with-python2 python-mpmath))
6942
6943 (define-public python-bigfloat
6944 (package
6945 (name "python-bigfloat")
6946 (version "0.3.0")
6947 (source
6948 (origin
6949 (method url-fetch)
6950 (uri (pypi-uri "bigfloat" version))
6951 (sha256
6952 (base32 "0xd7q4l7v0f463diznjv4k9wlaks80pn9drdqmfifi7zx8qvybi6"))))
6953 (build-system python-build-system)
6954 (inputs
6955 `(("mpfr" ,mpfr)))
6956 (home-page "https://github.com/mdickinson/bigfloat")
6957 (synopsis "Arbitrary precision floating-point arithmetic for Python")
6958 (description
6959 "This package provides a Python interface to the MPFR library for
6960 multiprecision arithmetic.")
6961 (license license:lgpl3+)))
6962
6963 (define-public python2-bigfloat
6964 (package-with-python2 python-bigfloat))
6965
6966 (define-public python-sympy
6967 (package
6968 (name "python-sympy")
6969 (version "1.1.1")
6970 (source
6971 (origin
6972 (method url-fetch)
6973 (uri (string-append
6974 "https://github.com/sympy/sympy/releases/download/sympy-"
6975 version "/sympy-" version ".tar.gz"))
6976 (sha256
6977 (base32 "190n29sppw7g8ihilc5451y7jlfcaw56crqiqbf1jff43dlmfnxc"))))
6978 (build-system python-build-system)
6979 (arguments
6980 `(#:phases
6981 (modify-phases %standard-phases
6982 ;; Run the core tests after installation. By default it would run
6983 ;; *all* tests, which take a very long time to complete and are known
6984 ;; to be flaky.
6985 (delete 'check)
6986 (add-after 'install 'check
6987 (lambda* (#:key outputs #:allow-other-keys)
6988 (invoke "python3" "-c" "import sympy; sympy.test(\"/core\")")
6989 #t)))))
6990 (propagated-inputs
6991 `(("python-mpmath" ,python-mpmath)))
6992 (home-page "https://www.sympy.org/")
6993 (synopsis "Python library for symbolic mathematics")
6994 (description
6995 "SymPy is a Python library for symbolic mathematics. It aims to become a
6996 full-featured computer algebra system (CAS) while keeping the code as simple
6997 as possible in order to be comprehensible and easily extensible.")
6998 (license license:bsd-3)))
6999
7000 (define-public python2-sympy
7001 (package
7002 (inherit (package-with-python2 python-sympy))
7003 (arguments
7004 `(#:phases
7005 (modify-phases %standard-phases
7006 ;; Run the core tests after installation. By default it would run
7007 ;; *all* tests, which take a very long time to complete and are known
7008 ;; to be flaky.
7009 (delete 'check)
7010 (add-after 'install 'check
7011 (lambda* (#:key outputs #:allow-other-keys)
7012 (invoke "python" "-c" "import sympy; sympy.test(\"/core\")")
7013 #t)))))))
7014
7015 (define-public python-q
7016 (package
7017 (name "python-q")
7018 (version "2.6")
7019 (source
7020 (origin
7021 (method url-fetch)
7022 (uri (pypi-uri "q" version))
7023 (sha256
7024 (base32
7025 "1mgfazh8fkizh6walra2zv885f3lcgr3nb02v1frfm4p8ddcy3yy"))))
7026 (build-system python-build-system)
7027 (home-page "https://github.com/zestyping/q")
7028 (synopsis "Quick-and-dirty debugging output for tired programmers")
7029 (description
7030 "q is a Python module for \"print\" style of debugging Python code. It
7031 provides convenient short API for print out of values, tracebacks, and
7032 falling into the Python interpreter.")
7033 (license license:asl2.0)))
7034
7035 (define-public python2-q
7036 (package-with-python2 python-q))
7037
7038 (define-public python2-xlib
7039 (package
7040 (name "python2-xlib")
7041 (version "0.14")
7042 (source (origin
7043 (method url-fetch)
7044 (uri (string-append "mirror://sourceforge/python-xlib/python-xlib"
7045 "/" version "/"
7046 "python-xlib-" version ".tar.gz"))
7047 (sha256
7048 (base32
7049 "1sv0447j0rx8cgs3jhjl695p5pv13ihglcjlrrz1kq05lsvb0wa7"))))
7050 (build-system python-build-system)
7051 (arguments
7052 `(#:python ,python-2 ;Python 2 only
7053 #:tests? #f)) ;no tests
7054 (home-page "http://python-xlib.sourceforge.net/")
7055 (synopsis "Python X11 client library")
7056 (description
7057 "The Python X Library is intended to be a fully functional X client
7058 library for Python programs. It is useful to implement low-level X clients.
7059 It is written entirely in Python.")
7060 (license license:gpl2+)))
7061
7062 (define-public python-singledispatch
7063 (package
7064 (name "python-singledispatch")
7065 (version "3.4.0.3")
7066 (source
7067 (origin
7068 (method url-fetch)
7069 (uri (pypi-uri "singledispatch" version))
7070 (sha256
7071 (base32
7072 "171b7ip0hsq5qm83np40h3phlr36ym18w0lay0a8v08kvy3sy1jv"))))
7073 (build-system python-build-system)
7074 (native-inputs
7075 `(("python-six" ,python-six))) ; required for conversion, not at run-time
7076 (home-page
7077 "https://docs.python.org/3/library/functools.html#functools.singledispatch")
7078 (synopsis "Backport of singledispatch feature from Python 3.4")
7079 (description
7080 "This library brings functools.singledispatch from Python 3.4 to Python
7081 2.6-3.3.")
7082 (license license:expat)))
7083
7084 (define-public python2-singledispatch
7085 (package-with-python2 python-singledispatch))
7086
7087 ;; the python- version can be removed with python-3.5
7088 (define-public python-backports-abc
7089 (package
7090 (name "python-backports-abc")
7091 (version "0.5")
7092 (source
7093 (origin
7094 (method url-fetch)
7095 (uri (pypi-uri "backports_abc" version))
7096 (sha256
7097 (base32
7098 "1pkv8d1zxj5f9i227dxbjczncbv7ks7ywnjwyxfjagm02i2yafq3"))))
7099 (build-system python-build-system)
7100 (home-page "https://github.com/cython/backports_abc")
7101 (synopsis "Backport of additions to the 'collections.abc' module")
7102 (description
7103 "Python-backports-abc provides a backport of additions to the
7104 @code{collections.abc} module in Python-3.5.")
7105 (license license:psfl)))
7106
7107 (define-public python2-backports-abc
7108 (package-with-python2 python-backports-abc))
7109
7110 (define-public python-backports-csv
7111 (package
7112 (name "python-backports-csv")
7113 (version "1.0.5")
7114 (source
7115 (origin
7116 (method url-fetch)
7117 (uri (pypi-uri "backports.csv" version))
7118 (sha256
7119 (base32
7120 "1imzbrradkfn8s2m1qcimyn74dn1mz2p3j381jljn166rf2i6hlc"))))
7121 (build-system python-build-system)
7122 (home-page "https://github.com/ryanhiebert/backports.csv")
7123 (synopsis "Backport of Python 3's csv module for Python 2")
7124 (description
7125 "Provides a backport of Python 3's @code{csv} module for parsing
7126 comma separated values. The API of the @code{csv} module in Python 2
7127 is drastically different from the @code{csv} module in Python 3.
7128 This is due, for the most part, to the difference between str in
7129 Python 2 and Python 3.")
7130 (license license:psfl)))
7131
7132 (define-public python2-backports-csv
7133 (package-with-python2 python-backports-csv))
7134
7135 (define-public python2-backports-shutil-get-terminal-size
7136 (package
7137 (name "python2-backports-shutil-get-terminal-size")
7138 (version "1.0.0")
7139 (source
7140 (origin
7141 (method url-fetch)
7142 (uri (pypi-uri "backports.shutil_get_terminal_size" version))
7143 (sha256
7144 (base32
7145 "107cmn7g3jnbkp826zlj8rrj19fam301qvaqf0f3905f5217lgki"))))
7146 (build-system python-build-system)
7147 (arguments
7148 `(#:python ,python-2
7149 #:phases
7150 (modify-phases %standard-phases
7151 (replace 'check
7152 (lambda _
7153 (invoke "py.test" "-v"))))))
7154 (native-inputs
7155 `(("python2-pytest" ,python2-pytest)))
7156 (home-page "https://github.com/chrippa/backports.shutil_get_terminal_size")
7157 (synopsis "Backport of Python 3.3's @code{shutil.get_terminal_size}")
7158 (description
7159 "This package provides a backport of the @code{get_terminal_size
7160 function} from Python 3.3's @code{shutil}.
7161 Unlike the original version it is written in pure Python rather than C,
7162 so it might be a tiny bit slower.")
7163 (license license:expat)))
7164
7165 (define-public python-waf
7166 (package
7167 (name "python-waf")
7168 (version "2.0.19")
7169 (source (origin
7170 (method url-fetch)
7171 (uri (string-append "https://waf.io/"
7172 "waf-" version ".tar.bz2"))
7173 (sha256
7174 (base32
7175 "19dvqbsvxz7ch03dh1v0znklrwxlz6yzddc3k9smzrrgny4jch6q"))))
7176 (build-system python-build-system)
7177 (arguments
7178 '(#:phases
7179 (modify-phases %standard-phases
7180 (replace 'build
7181 (lambda _
7182 ;; XXX: Find a way to add all extra tools.
7183 (let ((tools '("gccdeps"
7184 "clang_compilation_database")))
7185 (invoke "python" "waf-light" "configure" "build"
7186 (string-append "--tools="
7187 (string-join tools ","))))))
7188 (replace 'check
7189 (lambda _
7190 (invoke "python" "waf" "--version")))
7191 (replace 'install
7192 (lambda* (#:key outputs #:allow-other-keys)
7193 (let ((out (assoc-ref outputs "out")))
7194 (install-file "waf" (string-append out "/bin")))
7195 #t))
7196 ;; waf breaks when it is wrapped.
7197 (delete 'wrap))))
7198 (home-page "https://waf.io/")
7199 (synopsis "Python-based build system")
7200 (description
7201 "Waf is a Python-based framework for configuring, compiling and installing
7202 applications.")
7203 (license license:bsd-3)))
7204
7205 (define-public python2-waf
7206 (package-with-python2 python-waf))
7207
7208 (define-public python-pyzmq
7209 (package
7210 (name "python-pyzmq")
7211 (version "17.1.2")
7212 (source
7213 (origin
7214 (method url-fetch)
7215 (uri (pypi-uri "pyzmq" version))
7216 (sha256
7217 (base32 "1pyxxrz60f88ffm0y6vpbx3q8jcr9ybz8fcilihwzwhh36n84ax7"))))
7218 (build-system python-build-system)
7219 (arguments
7220 `(#:configure-flags
7221 (list (string-append "--zmq=" (assoc-ref %build-inputs "zeromq")))
7222 ;; FIXME: You must build pyzmq with 'python setup.py build_ext
7223 ;; --inplace' for 'python setup.py test' to work.
7224 #:tests? #f))
7225 (inputs
7226 `(("zeromq" ,zeromq)))
7227 (native-inputs
7228 `(("pkg-config" ,pkg-config)
7229 ("python-nose" ,python-nose)))
7230 (home-page "https://github.com/zeromq/pyzmq")
7231 (synopsis "Python bindings for 0MQ")
7232 (description
7233 "PyZMQ is the official Python binding for the ZeroMQ messaging library.")
7234 (license license:bsd-4)))
7235
7236 (define-public python2-pyzmq
7237 (package-with-python2 python-pyzmq))
7238
7239 (define-public python-pep8
7240 ;; This package has been renamed to ‘pycodestyle’ and is no longer updated.
7241 ;; Its last release (1.7.1) adds only a scary warning to this effect, breaking
7242 ;; some dependents' test suites, and nothing more.
7243 (package
7244 (name "python-pep8")
7245 (version "1.7.0")
7246 (source
7247 (origin
7248 (method url-fetch)
7249 (uri (pypi-uri "pep8" version))
7250 (sha256
7251 (base32
7252 "002rkl4lsn6x2mxmf8ar00l0m8i3mzrc6pnzz77blyksmpsxa4x1"))
7253 (patches (search-patches "python-pep8-stdlib-tokenize-compat.patch"))))
7254 (build-system python-build-system)
7255 (home-page "https://pep8.readthedocs.org/")
7256 (synopsis "Python style guide checker")
7257 (description
7258 "This tools checks Python code against some of the style conventions in
7259 PEP 8.")
7260 (license license:expat)))
7261
7262 (define-public python2-pep8
7263 (package-with-python2 python-pep8))
7264
7265 (define-public python-pyflakes
7266 (package
7267 (name "python-pyflakes")
7268 (version "2.1.1")
7269 (source
7270 (origin
7271 (method url-fetch)
7272 (uri (pypi-uri "pyflakes" version))
7273 (sha256
7274 (base32
7275 "18pq95a1xj2dgdd0m85gyfsn40jajj4xc3lp8wfv7igqhrc86xnr"))))
7276 (build-system python-build-system)
7277 (home-page
7278 "https://github.com/pyflakes/pyflakes")
7279 (synopsis "Passive checker of Python programs")
7280 (description
7281 "Pyflakes statically checks Python source code for common errors.")
7282 (license license:expat)))
7283
7284 (define-public python2-pyflakes
7285 (package-with-python2 python-pyflakes))
7286
7287 (define-public python-mccabe
7288 (package
7289 (name "python-mccabe")
7290 (version "0.6.1")
7291 (source
7292 (origin
7293 (method url-fetch)
7294 (uri (pypi-uri "mccabe" version))
7295 (sha256
7296 (base32
7297 "07w3p1qm44hgxf3vvwz84kswpsx6s7kvaibzrsx5dzm0hli1i3fx"))))
7298 (build-system python-build-system)
7299 (native-inputs
7300 `(("python-pytest" ,python-pytest-bootstrap)
7301 ("python-pytest-runner" ,python-pytest-runner)))
7302 (home-page "https://github.com/flintwork/mccabe")
7303 (synopsis "McCabe checker, plugin for flake8")
7304 (description
7305 "This package provides a Flake8 plug-in to compute the McCabe cyclomatic
7306 complexity of Python source code.")
7307 (license license:expat)))
7308
7309 (define-public python2-mccabe
7310 (package-with-python2 python-mccabe))
7311
7312 (define-public python-mccabe-0.2.1
7313 (package (inherit python-mccabe)
7314 (version "0.2.1")
7315 (source
7316 (origin
7317 (method url-fetch)
7318 (uri (pypi-uri "mccabe" version))
7319 (sha256
7320 (base32
7321 "0fi4a81kr5bcv5p4xgibqr595hyj5dafkqgsmfk96mfy8w71fajs"))))))
7322
7323 (define-public python2-mccabe-0.2.1
7324 (package-with-python2 python-mccabe-0.2.1))
7325
7326 ;; Flake8 2.4.1 requires an older version of pep8.
7327 ;; This should be removed ASAP.
7328 (define-public python-pep8-1.5.7
7329 (package (inherit python-pep8)
7330 (version "1.5.7")
7331 (source
7332 (origin
7333 (method url-fetch)
7334 (uri (pypi-uri "pep8" version))
7335 (sha256
7336 (base32
7337 "12b9bbdbwnspxgak14xg58c130x2n0blxzlms5jn2dszn8qj3d0m"))))
7338 (arguments
7339 ;; XXX Tests not compatible with Python 3.5.
7340 '(#:tests? #f))))
7341
7342 (define-public python2-pep8-1.5.7
7343 (package-with-python2 python-pep8-1.5.7))
7344
7345 ;; Flake8 2.4.1 requires an older version of pyflakes.
7346 ;; This should be removed ASAP.
7347 (define-public python-pyflakes-0.8.1
7348 (package (inherit python-pyflakes)
7349 (version "0.8.1")
7350 (source
7351 (origin
7352 (method url-fetch)
7353 (uri (pypi-uri "pyflakes" version))
7354 (sha256
7355 (base32
7356 "0sbpq6pqm1i9wqi41mlfrsc5rk92jv4mskvlyxmnhlbdnc80ma1z"))))
7357 (arguments
7358 ;; XXX Tests not compatible with Python 3.5.
7359 '(#:tests? #f))))
7360
7361 (define-public python2-pyflakes-0.8.1
7362 (package-with-python2 python-pyflakes-0.8.1))
7363
7364 (define-public python-flake8
7365 (package
7366 (name "python-flake8")
7367 (version "3.7.7")
7368 (source (origin
7369 (method url-fetch)
7370 (uri (pypi-uri "flake8" version))
7371 (sha256
7372 (base32
7373 "0qg6zggqigrd4k3gv88shd1a27d0cwgfql8vfiq2c7rl7w3rd6c5"))))
7374 (build-system python-build-system)
7375 (arguments
7376 `(#:phases
7377 (modify-phases %standard-phases
7378 (delete 'check)
7379 (add-after 'install 'check
7380 (lambda* (#:key inputs outputs #:allow-other-keys)
7381 (add-installed-pythonpath inputs outputs)
7382 (invoke "pytest" "-v")
7383 #t)))))
7384 (propagated-inputs
7385 `(("python-pycodestyle" ,python-pycodestyle)
7386 ("python-entrypoints" ,python-entrypoints)
7387 ("python-pyflakes" ,python-pyflakes)
7388 ("python-mccabe" ,python-mccabe)))
7389 (native-inputs
7390 `(("python-mock" ,python-mock)
7391 ("python-pytest" ,python-pytest-bootstrap)
7392 ("python-pytest-runner" ,python-pytest-runner)))
7393 (home-page "https://gitlab.com/pycqa/flake8")
7394 (synopsis
7395 "The modular source code checker: pep8, pyflakes and co")
7396 (description
7397 "Flake8 is a wrapper around PyFlakes, pep8 and python-mccabe.")
7398 (properties `((python2-variant . ,(delay python2-flake8))))
7399 (license license:expat)))
7400
7401 (define-public python2-flake8
7402 (let ((base (package-with-python2 (strip-python2-variant python-flake8))))
7403 (package (inherit base)
7404 (propagated-inputs
7405 `(("python2-configparser" ,python2-configparser)
7406 ("python2-enum34" ,python2-enum34)
7407 ("python2-functools32" ,python2-functools32)
7408 ("python2-typing" ,python2-typing)
7409 ,@(package-propagated-inputs base))))))
7410
7411 ;; python-hacking requires flake8 <2.6.0.
7412 (define-public python-flake8-2.5
7413 (package
7414 (inherit python-flake8)
7415 (version "2.5.5")
7416 (source (origin
7417 (method url-fetch)
7418 (uri (pypi-uri "flake8" version))
7419 (sha256
7420 (base32
7421 "1snylqwbmrylbx3r1wpz8ggk98f6bcag4441ag8mm2l7wyn58sij"))))
7422 (propagated-inputs
7423 `(("python-pep8" ,python-pep8)
7424 ,@(package-propagated-inputs python-flake8)))
7425 (properties `((python2-variant . ,(delay python2-flake8-2.5))))))
7426
7427 (define-public python2-flake8-2.5
7428 (package
7429 (inherit python2-flake8)
7430 (version (package-version python-flake8-2.5))
7431 (source (origin
7432 (inherit (package-source python-flake8-2.5))))
7433 (propagated-inputs
7434 `(("python2-pep8" ,python2-pep8)
7435 ,@(package-propagated-inputs python2-flake8)))))
7436
7437 (define-public python-flake8-polyfill
7438 (package
7439 (name "python-flake8-polyfill")
7440 (version "1.0.2")
7441 (source
7442 (origin
7443 (method url-fetch)
7444 (uri (pypi-uri "flake8-polyfill" version))
7445 (sha256
7446 (base32
7447 "1nlf1mkqw856vi6782qcglqhaacb23khk9wkcgn55npnjxshhjz4"))))
7448 (build-system python-build-system)
7449 (arguments
7450 '(#:phases
7451 (modify-phases %standard-phases
7452 (replace 'check
7453 (lambda _
7454 ;; Be compatible with Pytest 4:
7455 ;; https://gitlab.com/pycqa/flake8-polyfill/merge_requests/7
7456 (substitute* "setup.cfg"
7457 (("\\[pytest\\]")
7458 "[tool:pytest]"))
7459
7460 (setenv "PYTHONPATH"
7461 (string-append (getcwd) "/build/lib:"
7462 (getenv "PYTHONPATH")))
7463 (invoke "py.test" "-v"))))))
7464 (native-inputs
7465 `(("python-flake8" ,python-flake8)
7466 ("python-mock" ,python-mock)
7467 ("python-pep8" ,python-pep8)
7468 ("python-pycodestyle" ,python-pycodestyle)
7469 ("python-pytest" ,python-pytest)))
7470 (home-page "https://gitlab.com/pycqa/flake8-polyfill")
7471 (synopsis "Polyfill package for Flake8 plugins")
7472 (description
7473 "This package that provides some compatibility helpers for Flake8
7474 plugins that intend to support Flake8 2.x and 3.x simultaneously.")
7475 (license license:expat)))
7476
7477 (define-public python2-flake8-polyfill
7478 (package-with-python2 python-flake8-polyfill))
7479
7480 (define-public python-mistune
7481 (package
7482 (name "python-mistune")
7483 (version "0.8.4")
7484 (source
7485 (origin
7486 (method url-fetch)
7487 (uri (pypi-uri "mistune" version))
7488 (sha256
7489 (base32
7490 "0vkmsh0x480rni51lhyvigfdf06b9247z868pk3bal1wnnfl58sr"))))
7491 (build-system python-build-system)
7492 (native-inputs
7493 `(("python-nose" ,python-nose)
7494 ("python-cython" ,python-cython)))
7495 (home-page "https://github.com/lepture/mistune")
7496 (synopsis "Markdown parser in pure Python")
7497 (description "This package provides a fast markdown parser in pure
7498 Python.")
7499 (license license:bsd-3)))
7500
7501 (define-public python2-mistune
7502 (package-with-python2 python-mistune))
7503
7504 (define-public python-markdown
7505 (package
7506 (name "python-markdown")
7507 (version "3.2.1")
7508 (source
7509 (origin
7510 (method url-fetch)
7511 (uri (pypi-uri "Markdown" version))
7512 (sha256
7513 (base32
7514 "00k91gwhxnm8jdnm2v5xjz9irj6dbi7afywz2hpakqdbxs1ydzlh"))))
7515 (build-system python-build-system)
7516 (native-inputs
7517 `(("python-nose" ,python-nose)
7518 ("python-pyyaml" ,python-pyyaml)))
7519 (home-page "https://python-markdown.github.io/")
7520 (synopsis "Python implementation of Markdown")
7521 (description
7522 "This package provides a Python implementation of John Gruber's
7523 Markdown. The library features international input, various Markdown
7524 extensions, and several HTML output formats. A command line wrapper
7525 markdown_py is also provided to convert Markdown files to HTML.")
7526 (properties `((python2-variant . ,(delay python2-markdown))))
7527 (license license:bsd-3)))
7528
7529 ;; Markdown 3.2 dropped support for Python 2.
7530 (define-public python2-markdown
7531 (let ((base (package-with-python2 (strip-python2-variant python-markdown))))
7532 (package/inherit
7533 base
7534 (version "3.1.1")
7535 (source (origin
7536 (method url-fetch)
7537 (uri (pypi-uri "Markdown" version))
7538 (sha256
7539 (base32
7540 "0yhylk4ffqqs7x086fav4pnfsl1021v7lghznzkififprmmqfl1f")))))))
7541
7542 (define-public python-ptyprocess
7543 (package
7544 (name "python-ptyprocess")
7545 (version "0.5.2")
7546 (source
7547 (origin
7548 (method url-fetch)
7549 (uri (pypi-uri "ptyprocess" version))
7550 (sha256
7551 (base32
7552 "0ra31k10v3629xq0kdn8lwmfbi97anmk48r03yvh7mks0kq96hg6"))))
7553 (build-system python-build-system)
7554 (native-inputs
7555 `(("python-nose" ,python-nose)))
7556 (arguments
7557 `(#:phases
7558 (modify-phases %standard-phases
7559 (replace 'check
7560 (lambda _ (invoke "nosetests"))))))
7561 (home-page "https://github.com/pexpect/ptyprocess")
7562 (synopsis "Run a subprocess in a pseudo terminal")
7563 (description
7564 "This package provides a Python library used to launch a subprocess in a
7565 pseudo terminal (pty), and interact with both the process and its pty.")
7566 (license license:isc)))
7567
7568 (define-public python2-ptyprocess
7569 (package-with-python2 python-ptyprocess))
7570
7571 (define-public python-cram
7572 (package
7573 (name "python-cram")
7574 (version "0.7")
7575 (home-page "https://bitheap.org/cram/")
7576 (source (origin
7577 (method url-fetch)
7578 (uri (list (string-append home-page "cram-"
7579 version ".tar.gz")
7580 (pypi-uri "cram" version)))
7581 (sha256
7582 (base32
7583 "0bvz6fwdi55rkrz3f50zsy35gvvwhlppki2yml5bj5ffy9d499vx"))))
7584 (arguments
7585 '(#:phases
7586 (modify-phases %standard-phases
7587 (add-after 'unpack 'patch-source
7588 (lambda _
7589 (substitute* (find-files "cram" ".*\\.py$")
7590 ;; Replace default shell path.
7591 (("/bin/sh") (which "sh")))
7592 (substitute* (find-files "tests" ".*\\.t$")
7593 (("md5") "md5sum")
7594 (("/bin/bash") (which "bash"))
7595 (("/bin/sh") (which "sh")))
7596 (substitute* "cram/_test.py"
7597 ;; This hack works around a bug triggered by substituting
7598 ;; the /bin/sh paths. "tests/usage.t" compares the output of
7599 ;; "cram -h", which breaks the output at 80 characters. This
7600 ;; causes the line showing the default shell to break into two
7601 ;; lines, but the test expects a single line...
7602 (("env\\['COLUMNS'\\] = '80'")
7603 "env['COLUMNS'] = '160'"))
7604
7605 (substitute* "Makefile"
7606 ;; Recent versions of python-coverage have caused the test
7607 ;; coverage to decrease (as of version 0.7). Allow that.
7608 (("--fail-under=100")
7609 "--fail-under=90"))
7610
7611 #t))
7612 (replace 'check
7613 ;; The test phase uses the built library and executable.
7614 (lambda* (#:key inputs outputs #:allow-other-keys)
7615 (add-installed-pythonpath inputs outputs)
7616 (setenv "PATH" (string-append (getenv "PATH") ":"
7617 (assoc-ref outputs "out") "/bin"))
7618 (invoke "make" "test"))))))
7619 (build-system python-build-system)
7620 (native-inputs
7621 `(("python-coverage" ,python-coverage)
7622 ("which" ,which)))
7623 (synopsis "Simple testing framework for command line applications")
7624 (description
7625 "Cram is a functional testing framework for command line applications.
7626 Cram tests look like snippets of interactive shell sessions. Cram runs each
7627 command and compares the command output in the test with the command’s actual
7628 output.")
7629 (license license:gpl2+)))
7630
7631 (define-public python2-cram
7632 (package-with-python2 python-cram))
7633
7634 (define-public python-straight-plugin
7635 (package
7636 (name "python-straight-plugin")
7637 (version "1.4.1")
7638 (source
7639 (origin
7640 (method url-fetch)
7641 (uri (pypi-uri "straight.plugin" version))
7642 (sha256
7643 (base32
7644 "069pjll4383p4kkgvcc40hgyvf79j2wdbpgwz77yigzxksh1gj62"))))
7645 (build-system python-build-system)
7646 (home-page "https://github.com/ironfroggy/straight.plugin")
7647 (synopsis "Simple namespaced plugin facility")
7648 (description "Straight Plugin provides a type of plugin you can create from
7649 almost any existing Python modules, and an easy way for outside developers to
7650 add functionality and customization to your projects with their own plugins.")
7651 (license license:expat)))
7652
7653 (define-public python2-straight-plugin
7654 (package-with-python2 python-straight-plugin))
7655
7656 (define-public python-fonttools
7657 (package
7658 (name "python-fonttools")
7659 (version "3.38.0")
7660 (source (origin
7661 (method url-fetch)
7662 (uri (pypi-uri "fonttools" version ".zip"))
7663 (sha256
7664 (base32
7665 "12ripk3s7skgxr1bs9r8n13r94ym3s8iir7ivfixls9fa4dabmlh"))))
7666 (build-system python-build-system)
7667 (native-inputs
7668 `(("unzip" ,unzip)
7669 ("python-pytest" ,python-pytest)
7670 ("python-pytest-runner" ,python-pytest-runner)))
7671 (home-page "https://github.com/fonttools/fonttools")
7672 (synopsis "Tools to manipulate font files")
7673 (description
7674 "FontTools/TTX is a library to manipulate font files from Python. It
7675 supports reading and writing of TrueType/OpenType fonts, reading and writing
7676 of AFM files, reading (and partially writing) of PS Type 1 fonts. The package
7677 also contains a tool called “TTX” which converts TrueType/OpenType fonts to and
7678 from an XML-based format.")
7679 (license license:expat)))
7680
7681 (define-public python2-fonttools
7682 (package-with-python2 python-fonttools))
7683
7684 (define-public python-ly
7685 (package
7686 (name "python-ly")
7687 (version "0.9.5")
7688 (source
7689 (origin
7690 (method url-fetch)
7691 (uri (pypi-uri name version))
7692 (sha256
7693 (base32
7694 "0x98dv7p8mg26p4816yy8hz4f34zf6hpnnfmr56msgh9jnsm2qfl"))))
7695 (build-system python-build-system)
7696 (arguments
7697 ;; FIXME: Some tests need network access.
7698 '(#:tests? #f))
7699 (synopsis "Tool and library for manipulating LilyPond files")
7700 (description "This package provides a Python library to parse, manipulate
7701 or create documents in LilyPond format. A command line program ly is also
7702 provided that can be used to do various manipulations with LilyPond files.")
7703 (home-page "https://pypi.org/project/python-ly/")
7704 (license license:gpl2+)))
7705
7706 (define-public python-appdirs
7707 (package
7708 (name "python-appdirs")
7709 (version "1.4.3")
7710 (source
7711 (origin
7712 (method url-fetch)
7713 (uri (pypi-uri "appdirs" version))
7714 (sha256
7715 (base32
7716 "14id6wxi12lgyw0mg3bcfnf888ad07jz9yj46gfzhn186z8rcn4y"))))
7717 (build-system python-build-system)
7718 (home-page "https://github.com/ActiveState/appdirs")
7719 (synopsis
7720 "Determine platform-specific dirs, e.g. a \"user data dir\"")
7721 (description
7722 "This module provides a portable way of finding out where user data
7723 should be stored on various operating systems.")
7724 (license license:expat)))
7725
7726 (define-public python2-appdirs
7727 (package-with-python2 python-appdirs))
7728
7729 (define-public python-llfuse
7730 (package
7731 (name "python-llfuse")
7732 (version "1.3.5")
7733 (source (origin
7734 (method url-fetch)
7735 (uri (pypi-uri "llfuse" version ".tar.bz2"))
7736 (sha256
7737 (base32
7738 "1n7a90jww3ly49fm7x27m3xw3la3qfrnykcakga654g6kcyjlhbf"))))
7739 (build-system python-build-system)
7740 (inputs
7741 `(("fuse" ,fuse)
7742 ("attr" ,attr)))
7743 (native-inputs
7744 `(("pkg-config" ,pkg-config)))
7745 (synopsis "Python bindings for FUSE")
7746 (description
7747 "Python-LLFUSE is a set of Python bindings for the low level FUSE API.")
7748 (home-page "https://bitbucket.org/nikratio/python-llfuse/")
7749 (license license:lgpl2.0+)
7750 (properties `((python2-variant . ,(delay python2-llfuse))))))
7751
7752 (define-public python2-llfuse
7753 (package (inherit (package-with-python2
7754 (strip-python2-variant python-llfuse)))
7755 (propagated-inputs `(("python2-contextlib2" ,python2-contextlib2)))))
7756
7757 ;; For attic-0.16
7758 (define-public python-llfuse-0.41
7759 (package (inherit python-llfuse)
7760 (version "0.41.1")
7761 (source (origin
7762 (method url-fetch)
7763 (uri (string-append
7764 "https://bitbucket.org/nikratio/python-llfuse/downloads/"
7765 "llfuse-" version ".tar.bz2"))
7766 (sha256
7767 (base32
7768 "1imlqw9b73086y97izr036f58pgc5akv4ihc2rrf8j5h75jbrlaa"))))
7769 ;; Python-LLFUSE < 0.42 includes underscore.js, which is MIT (expat)
7770 ;; licensed. The rest of the package is licensed under LGPL2.0 or later.
7771 (license (list license:expat license:lgpl2.0+))))
7772
7773 (define-public python-msgpack
7774 (package
7775 (name "python-msgpack")
7776 (version "1.0.0")
7777 (source (origin
7778 (method url-fetch)
7779 (uri (pypi-uri "msgpack" version))
7780 (sha256
7781 (base32
7782 "1h5mxh84rcw04dvxy1qbfn2hisavfqgilh9k09rgyjhd936dad4m"))))
7783 (build-system python-build-system)
7784 (arguments
7785 `(#:modules ((guix build utils)
7786 (guix build python-build-system)
7787 (ice-9 ftw)
7788 (srfi srfi-1)
7789 (srfi srfi-26))
7790 #:phases
7791 (modify-phases %standard-phases
7792 (replace 'check
7793 (lambda _
7794 (let ((cwd (getcwd)))
7795 (setenv "PYTHONPATH"
7796 (string-append cwd "/build/"
7797 (find (cut string-prefix? "lib" <>)
7798 (scandir (string-append cwd "/build")))
7799 ":"
7800 (getenv "PYTHONPATH")))
7801 (invoke "pytest" "-v" "test")))))))
7802 (native-inputs
7803 `(("python-pytest" ,python-pytest)))
7804 (synopsis "MessagePack (de)serializer")
7805 (description "MessagePack is a fast, compact binary serialization format,
7806 suitable for similar data to JSON. This package provides CPython bindings for
7807 reading and writing MessagePack data.")
7808 (home-page "https://pypi.org/project/msgpack/")
7809 (license license:asl2.0)))
7810
7811 ;; This msgpack library's name changed from "python-msgpack" to "msgpack" with
7812 ;; release 0.5. Some packages like borg still call it by the old name for now.
7813 ;; <https://bugs.gnu.org/30662>
7814 (define-public python-msgpack-transitional
7815 (package
7816 (inherit python-msgpack)
7817 (name "python-msgpack-transitional")
7818 (version "0.5.6")
7819 (source (origin
7820 (method url-fetch)
7821 (uri (pypi-uri "msgpack" version))
7822 (sha256
7823 (base32
7824 "1hz2dba1nvvn52afg34liijsm7kn65cmn06dl0xbwld6bb4cis0f"))))
7825 (arguments
7826 (substitute-keyword-arguments (package-arguments python-msgpack)
7827 ((#:phases phases)
7828 `(modify-phases ,phases
7829 (add-after 'unpack 'configure-transitional
7830 (lambda _
7831 ;; Keep using the old name.
7832 (substitute* "setup.py"
7833 (("TRANSITIONAL = False")
7834 "TRANSITIONAL = 1"))
7835 #t))))))))
7836
7837 (define-public python2-msgpack
7838 (package-with-python2 python-msgpack))
7839
7840 (define-public python-netaddr
7841 (package
7842 (name "python-netaddr")
7843 (version "0.7.19")
7844 (source
7845 (origin
7846 (method url-fetch)
7847 (uri (pypi-uri "netaddr" version))
7848 (sha256
7849 (base32
7850 "1zdfadvpq4lmcqzr383gywxn4xyn355kj1n3lk9q2l03vmyfrbiq"))))
7851 (build-system python-build-system)
7852 (arguments `(#:tests? #f)) ;; No tests.
7853 (home-page "https://github.com/drkjam/netaddr/")
7854 (synopsis "Pythonic manipulation of network addresses")
7855 (description
7856 "A Python library for representing and manipulating IPv4, IPv6, CIDR, EUI
7857 and MAC network addresses.")
7858 (license license:bsd-3)))
7859
7860 (define-public python2-netaddr
7861 (package-with-python2 python-netaddr))
7862
7863 (define-public python2-pyroute2
7864 (package
7865 (name "python2-pyroute2")
7866 (version "0.5.6")
7867 (source
7868 (origin
7869 (method url-fetch)
7870 (uri (pypi-uri "pyroute2" version))
7871 (sha256
7872 (base32
7873 "1gmz4r1w0yzj6fjjypnalmfyy0lnfznydyn62gi3wk50j5hhxbny"))))
7874 (build-system python-build-system)
7875 (arguments
7876 `(#:python ,python-2)) ;Python 3.x is not supported
7877 (home-page "https://github.com/svinota/pyroute2")
7878 (synopsis "Python netlink library")
7879 (description
7880 "Pyroute2 is a pure Python netlink library with minimal dependencies.
7881 Supported netlink families and protocols include:
7882 @itemize
7883 @item rtnl, network settings - addresses, routes, traffic controls
7884 @item nfnetlink - netfilter API: ipset, nftables, ...
7885 @item ipq - simplest userspace packet filtering, iptables QUEUE target
7886 @item devlink - manage and monitor devlink-enabled hardware
7887 @item generic - generic netlink families
7888 @itemize
7889 @item nl80211 - wireless functions API (basic support)
7890 @item taskstats - extended process statistics
7891 @item acpi_events - ACPI events monitoring
7892 @item thermal_events - thermal events monitoring
7893 @item VFS_DQUOT - disk quota events monitoring
7894 @end itemize
7895 @end itemize")
7896 (license license:gpl2+)))
7897
7898 (define-public python-wrapt
7899 (package
7900 (name "python-wrapt")
7901 (version "1.11.2")
7902 (source
7903 (origin
7904 (method url-fetch)
7905 (uri (pypi-uri "wrapt" version))
7906 (sha256
7907 (base32
7908 "1q81762dgsgrd12f8qc39zk8s5wll3m5xc32jdmlf6cls4gh4njn"))))
7909 (build-system python-build-system)
7910 (arguments
7911 ;; Tests are not included in the tarball, they are only available in the
7912 ;; git repository.
7913 `(#:tests? #f))
7914 (home-page "https://github.com/GrahamDumpleton/wrapt")
7915 (synopsis "Module for decorators, wrappers and monkey patching")
7916 (description
7917 "The aim of the wrapt module is to provide a transparent object proxy for
7918 Python, which can be used as the basis for the construction of function
7919 wrappers and decorator functions.")
7920 (license license:bsd-2)))
7921
7922 (define-public python2-wrapt
7923 (package-with-python2 python-wrapt))
7924
7925 (define-public python-xlrd
7926 (package
7927 (name "python-xlrd")
7928 (version "1.2.0")
7929 (source (origin
7930 (method url-fetch)
7931 (uri (pypi-uri "xlrd" version))
7932 (sha256
7933 (base32
7934 "1ci93fda4n67qhdvfl16zasyxrpygzk53hs6m8z0rd4dxrnb6vjl"))))
7935 (build-system python-build-system)
7936 (arguments
7937 `(#:phases
7938 (modify-phases %standard-phases
7939 ;; Some tests depend on writing a temporary file to the user's home
7940 ;; directory.
7941 (add-after 'unpack 'fix-tests
7942 (lambda _
7943 (delete-file "tests/test_open_workbook.py")
7944 #t)))))
7945 (home-page "http://www.python-excel.org/")
7946 (synopsis "Library for extracting data from Excel files")
7947 (description "This package provides a library to extract data from
7948 spreadsheets using Microsoft Excel proprietary file formats @samp{.xls} and
7949 @samp{.xlsx} (versions 2.0 onwards). It has support for Excel dates and is
7950 Unicode-aware. It is not intended as an end-user tool.")
7951 (license license:bsd-3)))
7952
7953 (define-public python2-xlrd
7954 (package-with-python2 python-xlrd))
7955
7956 (define-public python-prettytable
7957 (package
7958 (name "python-prettytable")
7959 (version "0.7.2")
7960 (source
7961 (origin
7962 (method url-fetch)
7963 (uri (pypi-uri "prettytable" version ".tar.bz2"))
7964 (sha256
7965 (base32
7966 "0diwsicwmiq2cpzpxri7cyl5fmsvicafw6nfqf6p6p322dji2g45"))))
7967 (build-system python-build-system)
7968 (home-page "https://code.google.com/archive/p/prettytable/")
7969 (synopsis "Display tabular data in an ASCII table format")
7970 (description
7971 "A library designed to represent tabular data in visually appealing ASCII
7972 tables. PrettyTable allows for selection of which columns are to be printed,
7973 independent alignment of columns (left or right justified or centred) and
7974 printing of sub-tables by specifying a row range.")
7975 (license license:bsd-3)))
7976
7977 (define-public python2-prettytable
7978 (package-with-python2 python-prettytable))
7979
7980 (define-public python-tables
7981 (package
7982 (name "python-tables")
7983 (version "3.6.1")
7984 (source
7985 (origin
7986 (method url-fetch)
7987 (uri (pypi-uri "tables" version))
7988 (sha256
7989 (base32
7990 "0j8vnxh2m5n0cyk9z3ndcj5n1zj5rdxgc1gb78bqlyn2lyw75aa9"))
7991 (modules '((guix build utils)))
7992 (snippet
7993 '(begin
7994 ;; Remove pre-compiled .pyc files from source.
7995 (for-each delete-file-recursively
7996 (find-files "." "__pycache__" #:directories? #t))
7997 (for-each delete-file (find-files "." "\\.pyc$"))
7998 #t))))
7999 (build-system python-build-system)
8000 (arguments
8001 `(;; FIXME: python-build-system does not pass configure-flags to "build"
8002 ;; or "check", so we must override the build and check phases.
8003 #:phases
8004 (modify-phases %standard-phases
8005 (add-after 'unpack 'use-gcc
8006 (lambda _
8007 (substitute* "setup.py"
8008 (("^( +)compiler = new_compiler\\(\\)" line indent)
8009 (string-append line
8010 "\n"
8011 indent
8012 "compiler.set_executables(compiler='gcc',"
8013 "compiler_so='gcc',"
8014 "linker_exe='gcc',"
8015 "linker_so='gcc -shared')")))
8016 #t))
8017 (add-after 'unpack 'disable-tuning
8018 (lambda _
8019 (substitute* "setup.py"
8020 (("cpu_flags = .*")
8021 "cpu_flags = ['sse2']\n"))
8022 #t))
8023 (replace 'build
8024 (lambda* (#:key inputs #:allow-other-keys)
8025 (invoke "python" "setup.py" "build"
8026 (string-append "--hdf5="
8027 (assoc-ref inputs "hdf5")))))
8028 (replace 'check
8029 (lambda* (#:key inputs #:allow-other-keys)
8030 (invoke "python" "setup.py" "check"
8031 (string-append "--hdf5="
8032 (assoc-ref inputs "hdf5"))))))))
8033 (propagated-inputs
8034 `(("python-numexpr" ,python-numexpr)
8035 ("python-numpy" ,python-numpy)))
8036 (native-inputs
8037 `(("python-cython" ,python-cython)
8038 ("pkg-config" ,pkg-config)))
8039 (inputs
8040 `(("hdf5" ,hdf5-1.10)
8041 ("bzip2" ,bzip2)
8042 ("zlib" ,zlib)))
8043 (home-page "https://www.pytables.org/")
8044 (synopsis "Hierarchical datasets for Python")
8045 (description "PyTables is a package for managing hierarchical datasets and
8046 designed to efficiently cope with extremely large amounts of data.")
8047 (license license:bsd-3)))
8048
8049 (define-public python2-tables
8050 (package-with-python2 python-tables))
8051
8052 (define-public python-pytest-black
8053 (package
8054 (name "python-pytest-black")
8055 (version "0.3.8")
8056 (source
8057 (origin
8058 (method url-fetch)
8059 (uri (pypi-uri "pytest-black" version))
8060 (sha256
8061 (base32
8062 "04lppqydxm0f3f3x0l8hj7v0j6d8syj34jc37yzqwqcyqsnaga81"))))
8063 (build-system python-build-system)
8064 (propagated-inputs
8065 `(("python-pytest" ,python-pytest)
8066 ("python-black" ,python-black)
8067 ("python-toml" ,python-toml)))
8068 (native-inputs
8069 `(("python-setuptools-scm" ,python-setuptools-scm)))
8070 (home-page "https://github.com/shopkeep/pytest-black")
8071 (synopsis "Pytest plugin to enable format checking with black")
8072 (description
8073 "This package provides a pytest plugin to enable format checking with the
8074 Python code formatter \"black\".")
8075 (license license:expat)))
8076
8077 (define-public python-get-version
8078 (package
8079 (name "python-get-version")
8080 (version "2.1")
8081 (source
8082 (origin
8083 (method url-fetch)
8084 (uri (pypi-uri "get_version" version))
8085 (sha256
8086 (base32
8087 "1g15jyx33vkxavv9hwv275cs4g9bp2i1y942raw3fxamq8kbaml1"))))
8088 (build-system python-build-system)
8089 (propagated-inputs
8090 `(("python-pygments" ,python-pygments)
8091 ("python-pytest" ,python-pytest)
8092 ("python-pytest-black" ,python-pytest-black)
8093 ("python-pytest-cov" ,python-pytest-cov)
8094 ("python-setuptools" ,python-setuptools)
8095 ("python-testpath" ,python-testpath)))
8096 (home-page "https://github.com/flying-sheep/get_version")
8097 (synopsis "Version helper in the spirit of versioneer")
8098 (description
8099 "This package provides a version helper that lets you automatically use
8100 the latest @code{vX.X.X} Git tag as the version in your Python package. It
8101 also supports getting the version from Python source distributions or, once
8102 your package is installed, via @code{pkg_resources} (part of
8103 @code{setuptools}).")
8104 (license license:gpl3+)))
8105
8106 (define-public python-legacy-api-wrap
8107 (package
8108 (name "python-legacy-api-wrap")
8109 (version "1.2")
8110 (source
8111 (origin
8112 (method url-fetch)
8113 (uri (pypi-uri "legacy-api-wrap" version))
8114 (sha256
8115 (base32
8116 "06qhp0g543dy98vpa41hwdalvdbsjfc3ldk474yr9sd75mhl8jh3"))))
8117 (build-system python-build-system)
8118 (propagated-inputs
8119 `(("python-get-version" ,python-get-version)
8120 ("python-pytest" ,python-pytest)
8121 ("python-pytest-black" ,python-pytest-black)
8122 ("python-pytest-cov" ,python-pytest-cov)
8123 ("python-setuptools" ,python-setuptools)))
8124 (home-page "https://github.com/flying-sheep/legacy-api-wrap")
8125 (synopsis "Legacy API wrapper")
8126 (description "This module defines a decorator to wrap legacy APIs. The
8127 primary use case is APIs defined before keyword-only parameters existed.")
8128 (license license:gpl3+)))
8129
8130 (define-public python-pyasn1
8131 (package
8132 (name "python-pyasn1")
8133 (version "0.4.8")
8134 (source
8135 (origin
8136 (method url-fetch)
8137 (uri (pypi-uri "pyasn1" version))
8138 (sha256
8139 (base32
8140 "1fnhbi3rmk47l9851gbik0flfr64vs5j0hbqx24cafjap6gprxxf"))))
8141 (build-system python-build-system)
8142 (home-page "http://pyasn1.sourceforge.net/")
8143 (synopsis "ASN.1 types and codecs")
8144 (description
8145 "This is an implementation of ASN.1 types and codecs in Python. It is
8146 suitable for a wide range of protocols based on the ASN.1 specification.")
8147 (license license:bsd-2)))
8148
8149 (define-public python2-pyasn1
8150 (package-with-python2 python-pyasn1))
8151
8152 (define-public python-pyasn1-modules
8153 (package
8154 (name "python-pyasn1-modules")
8155 (version "0.2.2")
8156 (source
8157 (origin
8158 (method url-fetch)
8159 (uri (pypi-uri "pyasn1-modules" version))
8160 (sha256
8161 (base32
8162 "0ivm850yi7ajjbi8j115qpsj95bgxdsx48nbjzg0zip788c3xkx0"))))
8163 (build-system python-build-system)
8164 (propagated-inputs
8165 `(("python-pyasn1" ,python-pyasn1)))
8166 (home-page "https://sourceforge.net/projects/pyasn1/")
8167 (synopsis "ASN.1 codec implementations")
8168 (description
8169 "Pyasn1-modules is a collection of Python modules providing ASN.1 types and
8170 implementations of ASN.1-based codecs and protocols.")
8171 (license license:bsd-3)))
8172
8173 (define-public python2-pyasn1-modules
8174 (package-with-python2 python-pyasn1-modules))
8175
8176 (define-public python-ipaddress
8177 (package
8178 (name "python-ipaddress")
8179 (version "1.0.22")
8180 (source (origin
8181 (method url-fetch)
8182 (uri (pypi-uri "ipaddress" version))
8183 (sha256
8184 (base32
8185 "0b570bm6xqpjwqis15pvdy6lyvvzfndjvkynilcddjj5x98wfimi"))))
8186 (build-system python-build-system)
8187 (home-page "https://github.com/phihag/ipaddress")
8188 (synopsis "IP address manipulation library")
8189 (description
8190 "This package provides a fast, lightweight IPv4/IPv6 manipulation library
8191 in Python. This library is used to create, poke at, and manipulate IPv4 and
8192 IPv6 addresses and networks. This is a port of the Python 3.3 ipaddress
8193 module to older versions of Python.")
8194 (license license:psfl)))
8195
8196 (define-public python2-ipaddress
8197 (package-with-python2 python-ipaddress))
8198
8199 (define-public python2-ipaddr
8200 (package
8201 (name "python2-ipaddr")
8202 (version "2.1.11")
8203 (source
8204 (origin
8205 (method url-fetch)
8206 (uri (pypi-uri "ipaddr" version))
8207 (sha256
8208 (base32 "1dwq3ngsapjc93fw61rp17fvzggmab5x1drjzvd4y4q0i255nm8v"))))
8209 (build-system python-build-system)
8210 (arguments
8211 `(#:python ,python-2 ;version 2 only
8212 #:phases
8213 (modify-phases %standard-phases
8214 (replace 'check
8215 (lambda _ (invoke "python" "ipaddr_test.py"))))))
8216 (home-page "https://github.com/google/ipaddr-py")
8217 (synopsis "IP address manipulation library")
8218 (description
8219 "Ipaddr is a Python@tie{}2 library for creating and manupilating IPv4 and
8220 IPv6 addresses and networks.
8221
8222 For new implementations you may prefer to use the standard module
8223 @code{ipaddress}, which was introduced in Python 3.3 and backported to older
8224 versions of Python.")
8225 (license license:asl2.0)))
8226
8227 (define-public python-idna
8228 (package
8229 (name "python-idna")
8230 (version "2.8")
8231 (source
8232 (origin
8233 (method url-fetch)
8234 (uri (pypi-uri "idna" version))
8235 (sha256
8236 (base32
8237 "01rlkigdxg17sf9yar1jl8n18ls59367wqh59hnawlyg53vb6my3"))))
8238 (build-system python-build-system)
8239 (home-page "https://github.com/kjd/idna")
8240 (synopsis "Internationalized domain names in applications")
8241 (description
8242 "This is a library to support the Internationalised Domain Names in
8243 Applications (IDNA) protocol as specified in RFC 5891. This version of the
8244 protocol is often referred to as “IDNA2008” and can produce different results
8245 from the earlier standard from 2003. The library is also intended to act as a
8246 suitable drop-in replacement for the “encodings.idna” module that comes with
8247 the Python standard library but currently only supports the older 2003
8248 specification.")
8249 (license license:bsd-4)))
8250
8251 (define-public python-idna-2.7
8252 (package (inherit python-idna)
8253 (version "2.7")
8254 (source (origin
8255 (method url-fetch)
8256 (uri (pypi-uri "idna" version))
8257 (sha256
8258 (base32
8259 "05jam7d31767dr12x0rbvvs8lxnpb1mhdb2zdlfxgh83z6k3hjk8"))))))
8260
8261
8262 (define-public python2-idna
8263 (package-with-python2 python-idna))
8264
8265 (define-public python-idna-ssl
8266 (package
8267 (name "python-idna-ssl")
8268 (version "1.0.1")
8269 (source
8270 (origin
8271 (method url-fetch)
8272 (uri (pypi-uri "idna-ssl" version))
8273 (sha256
8274 (base32
8275 "0ydrc8hpg9mdr5hqq1lqfsfbn6sjq69slwpfrnlrm3k0phqg14qj"))))
8276 (build-system python-build-system)
8277 (arguments
8278 `(#:tests? #f)) ;circular dependency with python-aiohttp
8279 (home-page "https://github.com/aio-libs/idna-ssl")
8280 (synopsis "Patch @code{ssl.match_hostname} for Unicode(idna) domains support")
8281 (description "Patch @code{ssl.match_hostname} for Unicode(idna)
8282 domains support.")
8283 (license license:expat)))
8284
8285 (define-public python-pretend
8286 (package
8287 (name "python-pretend")
8288 (version "1.0.9")
8289 (source
8290 (origin
8291 (method url-fetch)
8292 (uri (pypi-uri "pretend" version))
8293 (sha256
8294 (base32
8295 "040vm94lcbscg5p81g1icmwwwa2jm7wrd1ybmxnv1sz8rl8bh3n9"))))
8296 (build-system python-build-system)
8297 (home-page "https://github.com/alex/pretend")
8298 (synopsis "Library for stubbing in Python")
8299 (description
8300 "Pretend is a library to make stubbing with Python easier. Stubbing is a
8301 technique for writing tests. You may hear the term mixed up with mocks,
8302 fakes, or doubles. Basically, a stub is an object that returns pre-canned
8303 responses, rather than doing any computation.")
8304 (license license:bsd-3)))
8305
8306 (define-public python2-pretend
8307 (package-with-python2 python-pretend))
8308
8309 (define-public python-pip
8310 (package
8311 (name "python-pip")
8312 (version "20.0.2")
8313 (source
8314 (origin
8315 (method url-fetch)
8316 (uri (pypi-uri "pip" version))
8317 (sha256
8318 (base32
8319 "0zwnlsjn6mb742cr995zfbk9v56ygxp8w3k49601r9by9kmcic3x"))))
8320 (build-system python-build-system)
8321 (arguments
8322 '(#:tests? #f)) ; there are no tests in the pypi archive.
8323 (home-page "https://pip.pypa.io/")
8324 (synopsis "Package manager for Python software")
8325 (description
8326 "Pip is a package manager for Python software, that finds packages on the
8327 Python Package Index (PyPI).")
8328 (license license:expat)))
8329
8330 (define-public python2-pip
8331 (package-with-python2 python-pip))
8332
8333 (define-public python-tlsh
8334 (package
8335 (name "python-tlsh")
8336 (version "3.4.5")
8337 (home-page "https://github.com/trendmicro/tlsh")
8338 (source
8339 (origin
8340 (method git-fetch)
8341 (uri (git-reference
8342 (url "https://github.com/trendmicro/tlsh.git")
8343 (commit (string-append "v" version))))
8344 (file-name (git-file-name name version))
8345 (sha256
8346 (base32 "1ydliir308xn4ywy705mmsh7863ldlixdvpqwdhbipzq9vfpmvll"))))
8347 (build-system cmake-build-system)
8348 (arguments
8349 '(#:out-of-source? #f
8350 #:phases (modify-phases %standard-phases
8351 (replace
8352 'install
8353 (lambda* (#:key outputs #:allow-other-keys)
8354 ;; Build and install the Python bindings. The underlying
8355 ;; C++ library is apparently not meant to be installed.
8356 (let ((out (assoc-ref outputs "out")))
8357 (with-directory-excursion "py_ext"
8358 (and (system* "python" "setup.py" "build")
8359 (system* "python" "setup.py" "install"
8360 (string-append "--prefix=" out))))))))))
8361 (inputs `(("python" ,python-wrapper))) ;for the bindings
8362 (synopsis "Fuzzy matching library for Python")
8363 (description
8364 "Trend Micro Locality Sensitive Hash (TLSH) is a fuzzy matching library.
8365 Given a byte stream with a minimum length of 256 bytes, TLSH generates a hash
8366 value which can be used for similarity comparisons. Similar objects have
8367 similar hash values, which allows for the detection of similar objects by
8368 comparing their hash values. The byte stream should have a sufficient amount
8369 of complexity; for example, a byte stream of identical bytes will not generate
8370 a hash value.")
8371 (license license:asl2.0)))
8372
8373 (define-public python2-tlsh
8374 (package
8375 (inherit python-tlsh)
8376 (name "python2-tlsh")
8377 (inputs `(("python" ,python-2)))))
8378
8379 (define-public python-termcolor
8380 (package
8381 (name "python-termcolor")
8382 (version "1.1.0")
8383 (source
8384 (origin
8385 (method url-fetch)
8386 (uri (pypi-uri "termcolor" version))
8387 (sha256
8388 (base32
8389 "0fv1vq14rpqwgazxg4981904lfyp84mnammw7y046491cv76jv8x"))))
8390 (build-system python-build-system)
8391 (arguments
8392 ;; There are no tests.
8393 `(#:tests? #f))
8394 (home-page "https://pypi.org/project/termcolor/")
8395 (synopsis "ANSII Color formatting for terminal output")
8396 (description
8397 "This package provides ANSII Color formatting for output in terminals.")
8398 (license license:expat)))
8399
8400 (define-public python2-termcolor
8401 (package-with-python2 python-termcolor))
8402
8403 (define-public python-libarchive-c
8404 (package
8405 (name "python-libarchive-c")
8406 (version "2.9")
8407 (source (origin
8408 (method url-fetch)
8409 (uri (pypi-uri "libarchive-c" version))
8410 (sha256
8411 (base32
8412 "0q7g6a97110bk0j5x81555kajyxh4sybaabab6v5sgr0xi6386cr"))))
8413 (build-system python-build-system)
8414 (arguments
8415 '(#:phases (modify-phases %standard-phases
8416 (add-before
8417 'build 'reference-libarchive
8418 (lambda* (#:key inputs #:allow-other-keys)
8419 ;; Retain the absolute file name of libarchive.so.
8420 (let ((libarchive (assoc-ref inputs "libarchive")))
8421 (substitute* "libarchive/ffi.py"
8422 (("find_library\\('archive'\\)")
8423 (string-append "'" libarchive
8424 "/lib/libarchive.so'"))))))
8425 (replace 'check
8426 (lambda _ (invoke "pytest" "-vv"))))))
8427 (native-inputs
8428 `(("python-mock" ,python-mock)
8429 ("python-pytest" ,python-pytest)))
8430 (inputs
8431 `(("libarchive" ,libarchive)))
8432 (home-page "https://github.com/Changaco/python-libarchive-c")
8433 (synopsis "Python interface to libarchive")
8434 (description
8435 "This package provides Python bindings to libarchive, a C library to
8436 access possibly compressed archives in many different formats. It uses
8437 Python's @code{ctypes} foreign function interface (FFI).")
8438 (license license:lgpl2.0+)))
8439
8440 (define-public python2-libarchive-c
8441 (package-with-python2 python-libarchive-c))
8442
8443 (define-public python-file
8444 (package
8445 (inherit file)
8446 (name "python-file")
8447 (build-system python-build-system)
8448 (arguments
8449 '(#:tests? #f ;no tests
8450 #:configure-flags '("--single-version-externally-managed" "--root=/")
8451 #:phases (modify-phases %standard-phases
8452 (add-before 'build 'change-directory
8453 (lambda _
8454 (chdir "python")
8455 #t))
8456 (add-before 'build 'set-library-file-name
8457 (lambda* (#:key inputs #:allow-other-keys)
8458 (let ((file (assoc-ref inputs "file")))
8459 (substitute* "magic.py"
8460 (("find_library\\('magic'\\)")
8461 (string-append "'" file "/lib/libmagic.so'")))
8462 #t))))))
8463 (inputs `(("file" ,file)))
8464 (native-inputs (if (%current-target-system)
8465 `(("self" ,this-package))
8466 '()))
8467 (synopsis "Python bindings to the libmagic file type guesser. Note that
8468 this module and the python-magic module both provide a \"magic.py\" file;
8469 these two modules, which are different and were developed separately, both
8470 serve the same purpose: provide Python bindings for libmagic.")))
8471
8472 (define-public python2-file
8473 (package-with-python2 python-file))
8474
8475 (define-public python-debian
8476 (package
8477 (name "python-debian")
8478 (home-page "https://salsa.debian.org/python-debian-team/python-debian")
8479 (version "0.1.36")
8480 (source
8481 (origin
8482 ;; Use git-fetch, as pypi doesn't include test suite.
8483 (method git-fetch)
8484 (uri (git-reference
8485 (url home-page)
8486 (commit version)))
8487 (file-name (git-file-name name version))
8488 (sha256
8489 (base32
8490 "0qy6x28bj6yfikhjww932v5xq4mf5bm1iczl7acy4c7zm6mwhqfa"))))
8491 (build-system python-build-system)
8492 (arguments
8493 `(#:phases (modify-phases %standard-phases
8494 (add-after 'unpack 'remove-debian-specific-tests
8495 ;; python-apt, apt and dpkg are not yet available in guix,
8496 ;; and these tests heavily depend on them.
8497 (lambda _
8498 (delete-file "lib/debian/tests/test_deb822.py")
8499 (delete-file "lib/debian/tests/test_debfile.py")
8500 #t)))))
8501 (propagated-inputs
8502 `(("python-six" ,python-six)
8503 ("python-chardet" ,python-chardet)))
8504 (synopsis "Debian package related modules")
8505 (description
8506 ;; XXX: Use @enumerate instead of @itemize to work around
8507 ;; <http://bugs.gnu.org/21772>.
8508 "This package provides Python modules that abstract many formats of
8509 Debian-related files, such as:
8510
8511 @enumerate
8512 @item Debtags information;
8513 @item @file{debian/changelog} files;
8514 @item packages files, pdiffs;
8515 @item control files of single or multiple RFC822-style paragraphs---e.g.
8516 @file{debian/control}, @file{.changes}, @file{.dsc};
8517 @item Raw @file{.deb} and @file{.ar} files, with (read-only) access to
8518 contained files and meta-information.
8519 @end enumerate\n")
8520
8521 ;; Modules are either GPLv2+ or GPLv3+.
8522 (license license:gpl3+)))
8523
8524 (define-public python-nbformat
8525 (package
8526 (name "python-nbformat")
8527 (version "4.4.0")
8528 (source
8529 (origin
8530 (method url-fetch)
8531 (uri (pypi-uri "nbformat" version))
8532 (sha256
8533 (base32
8534 "00nlf08h8yc4q73nphfvfhxrcnilaqanb8z0mdy6nxk0vzq4wjgp"))))
8535 (build-system python-build-system)
8536 (arguments `(#:tests? #f)) ; no test target
8537 (propagated-inputs
8538 `(("python-ipython-genutils" ,python-ipython-genutils)
8539 ("python-jsonschema" ,python-jsonschema)
8540 ("python-jupyter-core" ,python-jupyter-core)
8541 ("python-traitlets" ,python-traitlets)))
8542 (home-page "http://jupyter.org")
8543 (synopsis "Jupyter Notebook format")
8544 (description "This package provides the reference implementation of the
8545 Jupyter Notebook format and Python APIs for working with notebooks.")
8546 (license license:bsd-3)))
8547
8548 (define-public python2-nbformat
8549 (package-with-python2 python-nbformat))
8550
8551 (define-public python-bleach
8552 (package
8553 (name "python-bleach")
8554 (version "3.1.3")
8555 (source
8556 (origin
8557 (method url-fetch)
8558 (uri (pypi-uri "bleach" version))
8559 (sha256
8560 (base32
8561 "0al437aw4p2xp83az5hhlrp913nsf0cg6kg4qj3fjhv4wakxipzq"))))
8562 (build-system python-build-system)
8563 (propagated-inputs
8564 `(("python-webencodings" ,python-webencodings)
8565 ("python-six" ,python-six)))
8566 (native-inputs
8567 `(("python-datrie" ,python-datrie)
8568 ("python-genshi" ,python-genshi)
8569 ("python-lxml" ,python-lxml)
8570 ("python-pytest" ,python-pytest)))
8571 (home-page "https://github.com/mozilla/bleach")
8572 (synopsis "Whitelist-based HTML-sanitizing tool")
8573 (description "Bleach is an easy whitelist-based HTML-sanitizing tool.")
8574 (license license:asl2.0)))
8575
8576 (define-public python2-bleach
8577 (package-with-python2 python-bleach))
8578
8579 (define-public python-entrypoints
8580 (package
8581 (name "python-entrypoints")
8582 (version "0.3")
8583 (source
8584 (origin
8585 (method url-fetch)
8586 (uri (pypi-uri "entrypoints" version))
8587 (sha256
8588 (base32
8589 "0lc4si3xb7hza424414rdqdc3vng3kcrph8jbvjqb32spqddf3f7"))))
8590 (build-system python-build-system)
8591 ;; The package does not come with a setup.py file, so we have to generate
8592 ;; one ourselves.
8593 (arguments
8594 `(#:tests? #f
8595 #:phases
8596 (modify-phases %standard-phases
8597 (add-after 'unpack 'create-setup.py
8598 (lambda _
8599 (call-with-output-file "setup.py"
8600 (lambda (port)
8601 (format port "\
8602 from setuptools import setup
8603 setup(name='entrypoints', version='~a', py_modules=['entrypoints'])
8604 " ,version))))))))
8605 (home-page "https://github.com/takluyver/entrypoints")
8606 (synopsis "Discover and load entry points from installed Python packages")
8607 (description "Entry points are a way for Python packages to advertise
8608 objects with some common interface. The most common examples are
8609 @code{console_scripts} entry points, which define shell commands by
8610 identifying a Python function to run. The @code{entrypoints} module contains
8611 functions to find and load entry points.")
8612 (license license:expat)))
8613
8614 (define-public python2-entrypoints
8615 (package-with-python2 python-entrypoints))
8616
8617 (define-public python-nbconvert
8618 (package
8619 (name "python-nbconvert")
8620 (version "5.0.0b1")
8621 (source
8622 (origin
8623 (method url-fetch)
8624 (uri (pypi-uri "nbconvert" version))
8625 (sha256
8626 (base32
8627 "0brclbb18l4nmd5qy3dl9wn05rjdh1fz4rmzdlfqacj12rcdvdgp"))))
8628 (build-system python-build-system)
8629 (arguments
8630 `(;; The "bdist_egg" target is disabled by default, causing the installation
8631 ;; to fail.
8632 #:configure-flags (list "bdist_egg")
8633 ;; FIXME: 5 failures, 40 errors.
8634 #:tests? #f))
8635 ;; #:phases
8636 ;; (modify-phases %standard-phases
8637 ;; (replace 'check
8638 ;; (lambda _
8639 ;; (zero? (system* "py.test" "-v")))))
8640 (native-inputs
8641 `(("python-pytest" ,python-pytest)))
8642 (propagated-inputs
8643 `(("python-bleach" ,python-bleach)
8644 ("python-entrypoints" ,python-entrypoints)
8645 ("python-jinja2" ,python-jinja2)
8646 ("python-jupyter-core" ,python-jupyter-core)
8647 ("python-mistune" ,python-mistune)
8648 ("python-nbformat" ,python-nbformat)
8649 ("python-pygments" ,python-pygments)
8650 ("python-traitlets" ,python-traitlets)))
8651 (home-page "http://jupyter.org")
8652 (synopsis "Converting Jupyter Notebooks")
8653 (description "The @code{nbconvert} tool, @{jupyter nbconvert}, converts
8654 notebooks to various other formats via Jinja templates. It allows you to
8655 convert an @code{.ipynb} notebook file into various static formats including:
8656
8657 @enumerate
8658 @item HTML
8659 @item LaTeX
8660 @item PDF
8661 @item Reveal JS
8662 @item Markdown (md)
8663 @item ReStructured Text (rst)
8664 @item executable script
8665 @end enumerate\n")
8666 (license license:bsd-3)))
8667
8668 (define-public python2-nbconvert
8669 (package-with-python2 python-nbconvert))
8670
8671 (define-public python-notebook
8672 (package
8673 (name "python-notebook")
8674 (version "5.7.4")
8675 (source (origin
8676 (method url-fetch)
8677 (uri (pypi-uri "notebook" version))
8678 (sha256
8679 (base32
8680 "0jm7324mbxljmn9hgapj66q7swyz5ai92blmr0jpcy0h80x6f26r"))))
8681 (build-system python-build-system)
8682 (arguments
8683 `(#:phases
8684 (modify-phases %standard-phases
8685 (replace 'check
8686 (lambda _
8687 ;; These tests require a browser
8688 (delete-file-recursively "notebook/tests/selenium")
8689 ;; Some tests need HOME
8690 (setenv "HOME" "/tmp")
8691 ;; This file contains "warningfilters", which are not supported
8692 ;; by this version of nose.
8693 (delete-file "setup.cfg")
8694 (with-directory-excursion "/tmp"
8695 (invoke "nosetests" "-v"))
8696 #t)))))
8697 (propagated-inputs
8698 `(("python-jupyter-core" ,python-jupyter-core)
8699 ("python-nbformat" ,python-nbformat)
8700 ("python-nbconvert" ,python-nbconvert)
8701 ("python-prometheus-client" ,python-prometheus-client)
8702 ("python-send2trash" ,python-send2trash)
8703 ("python-terminado" ,python-terminado)))
8704 (native-inputs
8705 `(("python-nose" ,python-nose)
8706 ("python-sphinx" ,python-sphinx)
8707 ("python-requests" ,python-requests)))
8708 (home-page "http://jupyter.org/")
8709 (synopsis "Web-based notebook environment for interactive computing")
8710 (description
8711 "The Jupyter HTML notebook is a web-based notebook environment for
8712 interactive computing.")
8713 (properties `((python2-variant . ,(delay python2-notebook))))
8714 (license license:bsd-3)))
8715
8716 (define-public python2-notebook
8717 (let ((base (package-with-python2
8718 (strip-python2-variant python-notebook))))
8719 (package (inherit base)
8720 (native-inputs
8721 `(("python2-mock" ,python2-mock)
8722 ,@(package-native-inputs base)))
8723 (arguments
8724 (substitute-keyword-arguments (package-arguments base)
8725 ((#:phases phases)
8726 `(modify-phases ,phases
8727 (add-before 'check 'disable-test-case
8728 ;; The test requires network access to localhost. Curiously it
8729 ;; fails with Python 2 only. Simply make the test-case return
8730 ;; immediately.
8731 (lambda _
8732 (substitute*
8733 "notebook/services/nbconvert/tests/test_nbconvert_api.py"
8734 (("formats = self.nbconvert_api") "return #")))))))))))
8735
8736 (define-public python-widgetsnbextension
8737 (package
8738 (name "python-widgetsnbextension")
8739 (version "3.4.2")
8740 (source
8741 (origin
8742 (method url-fetch)
8743 (uri (pypi-uri "widgetsnbextension" version))
8744 (sha256
8745 (base32
8746 "0rc2nivdy7k4m3vljx7wdh2jh11djapcgwhvzlbs0isl8gl8nqgs"))))
8747 (build-system python-build-system)
8748 (propagated-inputs
8749 `(("python-ipykernel" ,python-ipykernel)
8750 ("python-notebook" ,python-notebook)))
8751 (native-inputs
8752 `(("python-certifi" ,python-certifi)
8753 ("python-nose" ,python-nose)))
8754 (home-page "https://ipython.org")
8755 (synopsis "IPython HTML widgets for Jupyter")
8756 (description "This package provides interactive HTML widgets for Jupyter
8757 notebooks.")
8758 (license license:bsd-3)))
8759
8760 (define-public python2-widgetsnbextension
8761 (package-with-python2 python-widgetsnbextension))
8762
8763 (define-public python-ipywidgets
8764 (package
8765 (name "python-ipywidgets")
8766 (version "5.2.2")
8767 (source
8768 (origin
8769 (method url-fetch)
8770 (uri (pypi-uri "ipywidgets" version))
8771 (sha256
8772 (base32
8773 "1lk0qrr5l9a0z7qkkn30hv5832whxwxymf1l576fmmad0n7hkxms"))))
8774 (build-system python-build-system)
8775 (propagated-inputs
8776 `(("python-ipython" ,python-ipython)
8777 ("python-traitlets" ,python-traitlets)
8778 ("python-widgetsnbextension" ,python-widgetsnbextension)))
8779 (native-inputs
8780 `(("python-nose" ,python-nose)
8781 ("python-pytest" ,python-pytest)))
8782 (home-page "https://ipython.org")
8783 (synopsis "IPython HTML widgets for Jupyter")
8784 (description "Ipywidgets are interactive HTML widgets for Jupyter
8785 notebooks and the IPython kernel. Notebooks come alive when interactive
8786 widgets are used. Users gain control of their data and can visualize changes
8787 in the data.")
8788 (license license:bsd-3)))
8789
8790 (define-public python2-ipywidgets
8791 (package-with-python2 python-ipywidgets))
8792
8793 (define-public python-jupyter-console
8794 (package
8795 (name "python-jupyter-console")
8796 (version "6.0.0")
8797 (source
8798 (origin
8799 (method url-fetch)
8800 (uri (pypi-uri "jupyter_console" version))
8801 (sha256
8802 (base32
8803 "1xdjw11cppf1fxvwkw2bk13ckkwas3bdah8baingn9296mvfi31h"))))
8804 (build-system python-build-system)
8805 (propagated-inputs
8806 `(("python-ipykernel" ,python-ipykernel)
8807 ("python-jupyter-client" ,python-jupyter-client)
8808 ("python-prompt-toolkit" ,python-prompt-toolkit)
8809 ("python-pygments" ,python-pygments)))
8810 (native-inputs
8811 `(("python-nose" ,python-nose)))
8812 (home-page "https://jupyter.org")
8813 (synopsis "Jupyter terminal console")
8814 (description "This package provides a terminal-based console frontend for
8815 Jupyter kernels. It also allows for console-based interaction with non-Python
8816 Jupyter kernels such as IJulia and IRKernel.")
8817 (properties `((python2-variant . ,(delay python2-jupyter-console))))
8818 (license license:bsd-3)))
8819
8820 (define-public python2-jupyter-console
8821 (package
8822 (name "python2-jupyter-console")
8823 (version "5.2.0")
8824 (source
8825 (origin
8826 (method url-fetch)
8827 (uri (pypi-uri "jupyter_console" version))
8828 (sha256
8829 (base32
8830 "1kam1qzgwr7srhm5r6aj90di5sws4bq0jmiw15452ddamb9yspal"))))
8831 (build-system python-build-system)
8832 (arguments
8833 `(#:python ,python-2
8834 #:tests? #f)) ; Tests only run in a TTY.
8835 (propagated-inputs
8836 `(("python2-ipykernel" ,python2-ipykernel)
8837 ("python2-jupyter-client" ,python2-jupyter-client)
8838 ("python2-prompt-toolkit" ,python2-prompt-toolkit-1)
8839 ("python2-pygments" ,python2-pygments)))
8840 (native-inputs
8841 `(("python2-nose" ,python2-nose)))
8842 (home-page "https://jupyter.org")
8843 (synopsis "Jupyter terminal console")
8844 (description "This package provides a terminal-based console frontend for
8845 Jupyter kernels. It also allows for console-based interaction with non-Python
8846 Jupyter kernels such as IJulia and IRKernel.")
8847 (license license:bsd-3)))
8848
8849 ;; The python-ipython and python-jupyter-console require each other. To get
8850 ;; the functionality in both packages working, strip down the
8851 ;; python-jupyter-console package when using it as an input to python-ipython.
8852 (define python-jupyter-console-minimal
8853 (package
8854 (inherit python-jupyter-console)
8855 (name "python-jupyter-console-minimal")
8856 (arguments
8857 (substitute-keyword-arguments
8858 (package-arguments python-jupyter-console)
8859 ((#:phases phases)
8860 `(modify-phases ,phases
8861 (add-after 'install 'delete-bin
8862 (lambda* (#:key outputs #:allow-other-keys)
8863 ;; Delete the bin files, to avoid conflicts in profiles
8864 ;; where python-ipython and python-jupyter-console are
8865 ;; both present.
8866 (delete-file-recursively
8867 (string-append
8868 (assoc-ref outputs "out") "/bin"))))))))
8869 ;; Remove the python-ipython propagated input, to avoid the cycle
8870 (propagated-inputs
8871 (alist-delete
8872 "python-ipython"
8873 (package-propagated-inputs python-jupyter-console)))))
8874
8875 (define-public python-qtconsole
8876 (package
8877 (name "python-qtconsole")
8878 (version "4.4.3")
8879 (source
8880 (origin
8881 (method url-fetch)
8882 (uri (pypi-uri "qtconsole" version))
8883 (sha256
8884 (base32
8885 "1b03n1ixzscm0jw97l4dq5iy4fslnqxq5bb8287xb7n2a1gs26xw"))))
8886 (build-system python-build-system)
8887 (arguments
8888 ;; XXX: Tests are disabled, because this package needs python-ipython 7,
8889 ;; but we only have the LTS version 5.x. This means that there might be
8890 ;; runtime errors, but since this is a dependency of the Jupyter package,
8891 ;; and Jupyter can be used without the qtconsole we can overlook this for
8892 ;; now.
8893 `(#:tests? #f
8894 #:phases
8895 (modify-phases %standard-phases
8896 (add-before 'check 'pre-check
8897 (lambda _
8898 (setenv "QT_QPA_PLATFORM" "offscreen")
8899 #t)))))
8900 (propagated-inputs
8901 `(("python-ipykernel" ,python-ipykernel)
8902 ("python-ipython" ,python-ipython)))
8903 (native-inputs
8904 `(("python-pytest" ,python-pytest)))
8905 (home-page "http://jupyter.org")
8906 (synopsis "Jupyter Qt console")
8907 (description "This package provides a Qt-based console for Jupyter with
8908 support for rich media output.")
8909 (license license:bsd-3)))
8910
8911 (define-public python-jsbeautifier
8912 (package
8913 (name "python-jsbeautifier")
8914 (version "1.10.2")
8915 (home-page "https://github.com/beautify-web/js-beautify")
8916 (source (origin
8917 (method git-fetch)
8918 (uri (git-reference
8919 (url home-page)
8920 (commit (string-append "v" version))))
8921 (file-name (git-file-name name version))
8922 (sha256
8923 (base32
8924 "0wawb070ki1axb3jc9xvsrgpji52vcfif3zmjzc3z4g98m5xw4kg"))))
8925 (build-system python-build-system)
8926 (arguments
8927 `(#:phases (modify-phases %standard-phases
8928 (add-after 'unpack 'chdir
8929 (lambda _
8930 ;; The upstream Git repository contains all the code,
8931 ;; but this package only builds the python code.
8932 (chdir "python")
8933 #t))
8934 (add-after 'unpack 'patch-python-six-requirements
8935 (lambda _
8936 (substitute* "python/setup.py"
8937 (("six>=1.12.0")
8938 "six>=1.11.0"))
8939 #t)))))
8940 (propagated-inputs
8941 `(("python-editorconfig" ,python-editorconfig)
8942 ("python-six" ,python-six)))
8943 (native-inputs
8944 `(("python-pytest" ,python-pytest)))
8945 (synopsis "JavaScript unobfuscator and beautifier")
8946 (description "Beautify, unpack or deobfuscate JavaScript, leveraging
8947 popular online obfuscators.")
8948 (license license:expat)))
8949
8950 (define-public jupyter
8951 (package
8952 (name "jupyter")
8953 (version "1.0.0")
8954 (source
8955 (origin
8956 (method url-fetch)
8957 (uri (pypi-uri "jupyter" version))
8958 (sha256
8959 (base32
8960 "0pwf3pminkzyzgx5kcplvvbvwrrzd3baa7lmh96f647k30rlpp6r"))))
8961 (build-system python-build-system)
8962 (arguments '(#:tests? #f)) ; there are none.
8963 (propagated-inputs
8964 `(("python-ipykernel" ,python-ipykernel)
8965 ("python-ipywidgets" ,python-ipywidgets)
8966 ("python-jupyter-console" ,python-jupyter-console)
8967 ("python-nbconvert" ,python-nbconvert)
8968 ("python-notebook" ,python-notebook)
8969 ("python-qtconsole" ,python-qtconsole)))
8970 (native-search-paths
8971 (list (search-path-specification
8972 (variable "JUPYTER_PATH")
8973 (files '("share/jupyter")))))
8974 (home-page "https://jupyter.org")
8975 (synopsis "Web application for interactive documents")
8976 (description
8977 "The Jupyter Notebook is a web application that allows you to create and
8978 share documents that contain live code, equations, visualizations and
8979 explanatory text. Uses include: data cleaning and transformation, numerical
8980 simulation, statistical modeling, machine learning and much more.")
8981 (license license:bsd-3)))
8982
8983 (define-public python-chardet
8984 (package
8985 (name "python-chardet")
8986 (version "3.0.4")
8987 (source
8988 (origin
8989 (method url-fetch)
8990 (uri (pypi-uri "chardet" version))
8991 (sha256
8992 (base32
8993 "1bpalpia6r5x1kknbk11p1fzph56fmmnp405ds8icksd3knr5aw4"))))
8994 (native-inputs
8995 `(("python-hypothesis" ,python-hypothesis)
8996 ("python-pytest" ,python-pytest)
8997 ("python-pytest-runner" ,python-pytest-runner)))
8998 (build-system python-build-system)
8999 ;; XXX: Incompatible with Pytest 4: <https://github.com/chardet/chardet/issues/173>.
9000 (arguments `(#:tests? #f))
9001 (home-page "https://github.com/chardet/chardet")
9002 (synopsis "Universal encoding detector for Python 2 and 3")
9003 (description
9004 "This package provides @code{chardet}, a Python module that can
9005 automatically detect a wide range of file encodings.")
9006 (license license:lgpl2.1+)))
9007
9008 (define-public python2-chardet
9009 (package-with-python2 python-chardet))
9010
9011 (define-public python-docopt
9012 (package
9013 (name "python-docopt")
9014 (version "0.6.2")
9015 (source
9016 (origin
9017 (method git-fetch)
9018 ;; The release on PyPI does not include tests.
9019 (uri (git-reference
9020 (url "https://github.com/docopt/docopt")
9021 (commit version)))
9022 (file-name (git-file-name name version))
9023 (sha256
9024 (base32
9025 "0aad9gbswnnhssin2q0m5lmpm0ahyf80ahs2zjigbn5y7fvljnd0"))))
9026 (build-system python-build-system)
9027 (native-inputs
9028 `(("python-pytest" ,python-pytest)))
9029 (arguments
9030 `(#:phases
9031 (modify-phases %standard-phases
9032 (replace 'check
9033 (lambda _ (invoke "py.test"))))))
9034 (home-page "http://docopt.org")
9035 (synopsis "Command-line interface description language for Python")
9036 (description "This library allows the user to define a command-line
9037 interface from a program's help message rather than specifying it
9038 programmatically with command-line parsers like @code{getopt} and
9039 @code{argparse}.")
9040 (license license:expat)))
9041
9042 (define-public python2-docopt
9043 (package-with-python2 python-docopt))
9044
9045 (define-public python-pythondialog
9046 (package
9047 (name "python-pythondialog")
9048 (version "3.4.0")
9049 (source
9050 (origin
9051 (method url-fetch)
9052 (uri (pypi-uri "pythondialog" version))
9053 (sha256
9054 (base32
9055 "1728ghsran47jczn9bhlnkvk5bvqmmbihabgif5h705b84r1272c"))))
9056 (build-system python-build-system)
9057 (arguments
9058 `(#:phases
9059 (modify-phases %standard-phases
9060 (add-after 'unpack 'patch-path
9061 (lambda* (#:key inputs #:allow-other-keys)
9062 (let* ((dialog (assoc-ref inputs "dialog")))
9063 ;; Since this library really wants to grovel the search path, we
9064 ;; must hardcode dialog's store path into it.
9065 (substitute* "dialog.py"
9066 (("os.getenv\\(\"PATH\", \":/bin:/usr/bin\"\\)")
9067 (string-append "os.getenv(\"PATH\") + \":" dialog "/bin\"")))
9068 #t))))
9069 #:tests? #f)) ; no test suite
9070 (propagated-inputs
9071 `(("dialog" ,dialog)))
9072 (home-page "http://pythondialog.sourceforge.net/")
9073 (synopsis "Python interface to the UNIX dialog utility")
9074 (description "A Python wrapper for the dialog utility. Its purpose is to
9075 provide an easy to use, pythonic and comprehensive Python interface to dialog.
9076 This allows one to make simple text-mode user interfaces on Unix-like systems")
9077 (license license:lgpl2.1)
9078 (properties `((python2-variant . ,(delay python2-pythondialog))))))
9079
9080 (define-public python2-pythondialog
9081 (let ((base (package-with-python2 (strip-python2-variant python-pythondialog))))
9082 (package
9083 (inherit base)
9084 (version (package-version python-pythondialog))
9085 (source (origin
9086 (method url-fetch)
9087 (uri (pypi-uri "python2-pythondialog" version))
9088 (sha256
9089 (base32
9090 "0d8k7lxk50imdyx85lv8j98i4c93a71iwpapnl1506rpkbm9qvd9")))))))
9091
9092 (define-public python-configobj
9093 (package
9094 (name "python-configobj")
9095 (version "5.0.6")
9096 (source (origin
9097 (method url-fetch)
9098 (uri (pypi-uri "configobj" version))
9099 (sha256
9100 (base32
9101 "00h9rcmws03xvdlfni11yb60bz3kxfvsj6dg6nrpzj71f03nbxd2"))
9102 ;; Patch setup.py so it looks for python-setuptools, which is
9103 ;; required to parse the keyword 'install_requires' in setup.py.
9104 (patches (search-patches "python-configobj-setuptools.patch"))))
9105 (build-system python-build-system)
9106 (propagated-inputs
9107 `(("python-six" ,python-six)))
9108 (synopsis "Config file reading, writing and validation")
9109 (description "ConfigObj is a simple but powerful config file reader and
9110 writer: an ini file round tripper. Its main feature is that it is very easy to
9111 use, with a straightforward programmer’s interface and a simple syntax for
9112 config files.")
9113 (home-page "https://github.com/DiffSK/configobj")
9114 (license license:bsd-3)))
9115
9116 (define-public python2-configobj
9117 (package-with-python2 python-configobj))
9118
9119 (define-public python-configargparse
9120 (package
9121 (name "python-configargparse")
9122 (version "0.14.0")
9123 (source (origin
9124 (method url-fetch)
9125 (uri (pypi-uri "ConfigArgParse" version))
9126 (sha256
9127 (base32
9128 "149fy4zya0rsnlkvxbbq43cyr8lscb5k4pj1m6n7f1grwcmzwbif"))))
9129 (build-system python-build-system)
9130 (native-inputs
9131 `(("python-pyyaml" ,python-pyyaml)))
9132 (arguments
9133 `(#:phases
9134 (modify-phases %standard-phases
9135 (replace 'check
9136 (lambda _
9137 ;; Bypass setuptools-shim because one test relies on "setup.py"
9138 ;; being the first argument passed to the python call.
9139 ;;
9140 ;; NOTE: Many tests do not run because they rely on Python's
9141 ;; built-in test.test_argparse, but we remove the unit tests from
9142 ;; our Python installation.
9143 (invoke "python" "setup.py" "test"))))))
9144 (synopsis "Replacement for argparse")
9145 (description "A drop-in replacement for argparse that allows options to also
9146 be set via config files and/or environment variables.")
9147 (home-page "https://github.com/bw2/ConfigArgParse")
9148 (license license:expat)))
9149
9150 (define-public python2-configargparse
9151 (package-with-python2 python-configargparse))
9152
9153 (define-public python-argparse-manpage
9154 (package
9155 (name "python-argparse-manpage")
9156 (version "1.1")
9157 (source
9158 (origin
9159 (method url-fetch)
9160 (uri (pypi-uri "argparse-manpage" version))
9161 (sha256
9162 (base32
9163 "0blh31zns68anina9lba5wh81d1414s97p60zw5l0d0shhh0wj5p"))))
9164 (build-system python-build-system)
9165 (home-page "https://github.com/praiskup/argparse-manpage")
9166 (synopsis "Build manual page from Python's ArgumentParser object")
9167 (description
9168 "This package provides tools to build manual pages from Python's
9169 @code{ArgumentParser} object.")
9170 (license license:asl2.0)))
9171
9172 (define-public python-contextlib2
9173 (package
9174 (name "python-contextlib2")
9175 (version "0.6.0.post1")
9176 (source
9177 (origin
9178 (method url-fetch)
9179 (uri (pypi-uri "contextlib2" version))
9180 (sha256
9181 (base32
9182 "0bhnr2ac7wy5l85ji909gyljyk85n92w8pdvslmrvc8qih4r1x01"))))
9183 (build-system python-build-system)
9184 (home-page "https://contextlib2.readthedocs.org/")
9185 (synopsis "Tools for decorators and context managers")
9186 (description "This module is primarily a backport of the Python
9187 3.2 contextlib to earlier Python versions. Like contextlib, it
9188 provides utilities for common tasks involving decorators and context
9189 managers. It also contains additional features that are not part of
9190 the standard library.")
9191 (properties `((python2-variant . ,(delay python2-contextlib2))))
9192 (license license:psfl)))
9193
9194 (define-public python2-contextlib2
9195 (let ((base (package-with-python2
9196 (strip-python2-variant python-contextlib2))))
9197 (package
9198 (inherit base)
9199 (arguments
9200 (substitute-keyword-arguments (package-arguments base)
9201 ((#:phases phases)
9202 `(modify-phases ,phases
9203 (replace 'check
9204 (lambda _ (invoke "python" "test_contextlib2.py" "-v")))))))
9205 (native-inputs
9206 `(("python2-unittest2" ,python2-unittest2))))))
9207
9208 (define-public python-texttable
9209 (package
9210 (name "python-texttable")
9211 (version "1.6.2")
9212 (source
9213 (origin
9214 (method url-fetch)
9215 (uri (pypi-uri "texttable" version))
9216 (sha256
9217 (base32
9218 "1x5l77akfc20x52jma9573qp8l8r07q103pm4l0pbizvh4vp1wzg"))))
9219 (build-system python-build-system)
9220 (arguments
9221 `(#:phases
9222 (modify-phases %standard-phases
9223 (replace 'check
9224 (lambda _ (invoke "pytest" "tests.py"))))))
9225 (native-inputs
9226 `(("python-pytest" ,python-pytest)))
9227 (home-page "https://github.com/foutaise/texttable/")
9228 (synopsis "Python module for creating simple ASCII tables")
9229 (description "Texttable is a Python module for creating simple ASCII
9230 tables.")
9231 (license license:expat)))
9232
9233 (define-public python2-texttable
9234 (package-with-python2 python-texttable))
9235
9236 (define-public python-atomicwrites
9237 (package
9238 (name "python-atomicwrites")
9239 (version "1.3.0")
9240 (source (origin
9241 (method url-fetch)
9242 (uri (pypi-uri "atomicwrites" version))
9243 (sha256
9244 (base32
9245 "19ngcscdf3jsqmpcxn6zl5b6anmsajb6izp1smcd1n02midl9abm"))))
9246 (build-system python-build-system)
9247 (synopsis "Atomic file writes in Python")
9248 (description "Library for atomic file writes using platform dependent tools
9249 for atomic file system operations.")
9250 (home-page "https://github.com/untitaker/python-atomicwrites")
9251 (license license:expat)))
9252
9253 (define-public python2-atomicwrites
9254 (package-with-python2 python-atomicwrites))
9255
9256 (define-public python-click-threading
9257 (package
9258 (name "python-click-threading")
9259 (version "0.4.4")
9260 (source (origin
9261 (method url-fetch)
9262 (uri (pypi-uri "click-threading" version))
9263 (sha256
9264 (base32
9265 "1rsxc2fbkxlhwhlmxsdjzq3spn284l6rvjfcz9mbb17ibgdgmc5j"))))
9266 (build-system python-build-system)
9267 (propagated-inputs
9268 `(("python-click" ,python-click)))
9269 (synopsis "Utilities for multithreading in Click")
9270 (description "This package provides utilities for multithreading in Click
9271 applications.")
9272 (home-page "https://github.com/click-contrib/click-threading")
9273 (license license:expat)))
9274
9275 (define-public python-click-log
9276 (package
9277 (name "python-click-log")
9278 (version "0.3.2")
9279 (source (origin
9280 (method url-fetch)
9281 (uri (pypi-uri "click-log" version))
9282 (sha256
9283 (base32
9284 "091i03bhxyzsdbc6kilxhivfda2f8ymz3b33xa6cj5kbzjiirz8n"))))
9285 (build-system python-build-system)
9286 (propagated-inputs
9287 `(("python-click" ,python-click)))
9288 (synopsis "Logging for click applications")
9289 (description "This package provides a Python library for logging Click
9290 applications.")
9291 (home-page "https://github.com/click-contrib/click-log")
9292 (license license:expat)))
9293
9294 (define-public python-apipkg
9295 (package
9296 (name "python-apipkg")
9297 (version "1.4")
9298 (source (origin
9299 (method url-fetch)
9300 (uri (pypi-uri "apipkg" version))
9301 (sha256
9302 (base32
9303 "1iks5701qnp3dlr3q1d9qm68y2plp2m029irhpz92a44psfkjf1f"))))
9304 (build-system python-build-system)
9305 (native-inputs
9306 `(("python-pytest" ,python-pytest)))
9307 (synopsis "Namespace control and lazy-import mechanism")
9308 (description "With apipkg you can control the exported namespace of a Python
9309 package and greatly reduce the number of imports for your users. It is a small
9310 pure Python module that works on virtually all Python versions.")
9311 (home-page "https://github.com/pytest-dev/apipkg")
9312 (license license:expat)))
9313
9314 (define-public python2-apipkg
9315 (package-with-python2 python-apipkg))
9316
9317 (define-public python-execnet
9318 (package
9319 (name "python-execnet")
9320 (version "1.4.1")
9321 (source (origin
9322 (method url-fetch)
9323 (uri (pypi-uri "execnet" version))
9324 (sha256
9325 (base32
9326 "1rpk1vyclhg911p3hql0m0nrpq7q7mysxnaaw6vs29cpa6kx8vgn"))))
9327 (build-system python-build-system)
9328 (arguments
9329 `(;; 2 failed, 275 passed, 670 skipped, 4 xfailed
9330 ;; The two test failures are caused by the lack of an `ssh` executable.
9331 ;; The test suite can be run with pytest after the 'install' phase.
9332 #:tests? #f))
9333 (native-inputs
9334 `(("python-pytest" ,python-pytest)
9335 ("python-setuptools-scm" ,python-setuptools-scm)))
9336 (propagated-inputs
9337 `(("python-apipkg" ,python-apipkg)))
9338 (synopsis "Rapid multi-Python deployment")
9339 (description "Execnet provides a share-nothing model with
9340 channel-send/receive communication for distributing execution across many
9341 Python interpreters across version, platform and network barriers. It has a
9342 minimal and fast API targeting the following uses:
9343 @enumerate
9344 @item distribute tasks to (many) local or remote CPUs
9345 @item write and deploy hybrid multi-process applications
9346 @item write scripts to administer multiple environments
9347 @end enumerate")
9348 (home-page "https://codespeak.net/execnet/")
9349 (license license:expat)))
9350
9351 (define-public python2-execnet
9352 (package-with-python2 python-execnet))
9353
9354 (define-public python-icalendar
9355 (package
9356 (name "python-icalendar")
9357 (version "4.0.5")
9358 (source (origin
9359 (method url-fetch)
9360 (uri (pypi-uri "icalendar" version))
9361 (sha256
9362 (base32
9363 "14ynjj65kfmlcvpb7k097w789wvxncd3cr3xz5m1jz9yl9v6vv5q"))))
9364 (build-system python-build-system)
9365 (propagated-inputs
9366 `(("python-dateutil" ,python-dateutil)
9367 ("python-pytz" ,python-pytz)))
9368 (synopsis "Python library for parsing iCalendar files")
9369 (description "The icalendar package is a parser/generator of iCalendar
9370 files for use with Python.")
9371 (home-page "https://github.com/collective/icalendar")
9372 (license license:bsd-2)))
9373
9374 (define-public python-args
9375 (package
9376 (name "python-args")
9377 (version "0.1.0")
9378 (source (origin
9379 (method url-fetch)
9380 (uri (pypi-uri "args" version))
9381 (sha256
9382 (base32
9383 "057qzi46h5dmxdqknsbrssn78lmqjlnm624iqdhrnpk26zcbi1d7"))))
9384 (build-system python-build-system)
9385 (home-page "https://github.com/kennethreitz/args")
9386 (synopsis "Command-line argument parser")
9387 (description
9388 "This library provides a Python module to parse command-line arguments.")
9389 (license license:bsd-3)))
9390
9391 (define-public python2-args
9392 (package-with-python2 python-args))
9393
9394 (define-public python-clint
9395 (package
9396 (name "python-clint")
9397 (version "0.5.1")
9398 (source (origin
9399 (method url-fetch)
9400 (uri (pypi-uri "clint" version))
9401 (sha256
9402 (base32
9403 "1an5lkkqk1zha47198p42ji3m94xmzx1a03dn7866m87n4r4q8h5"))))
9404 (build-system python-build-system)
9405 (arguments
9406 '(#:phases
9407 (modify-phases %standard-phases
9408 (replace 'check
9409 (lambda _ (invoke "py.test" "-v"))))))
9410 (native-inputs
9411 `(("python-pytest" ,python-pytest)))
9412 (propagated-inputs
9413 `(("python-args" ,python-args)))
9414 (home-page "https://github.com/kennethreitz/clint")
9415 (synopsis "Command-line interface tools")
9416 (description
9417 "Clint is a Python module filled with a set of tools for developing
9418 command-line applications, including tools for colored and indented
9419 output, progress bar display, and pipes.")
9420 (license license:isc)))
9421
9422 (define-public python2-clint
9423 (package-with-python2 python-clint))
9424
9425 (define-public python-rply
9426 (package
9427 (name "python-rply")
9428 (version "0.7.5")
9429 (source (origin
9430 (method url-fetch)
9431 (uri (pypi-uri "rply" version))
9432 (sha256
9433 (base32
9434 "0lv428895zxsz43968qx0q9bimwqnfykndz4dpjbq515w2gvzhjh"))))
9435 (build-system python-build-system)
9436 (propagated-inputs
9437 `(("python-appdirs" ,python-appdirs)))
9438 (home-page "https://github.com/alex/rply")
9439 (synopsis "Parser generator for Python")
9440 (description
9441 "This package provides a pure Python based parser generator, that also
9442 works with RPython. It is a more-or-less direct port of David Bazzley's PLY,
9443 with a new public API, and RPython support.")
9444 (license license:bsd-3)))
9445
9446 (define-public python2-rply
9447 (package-with-python2 python-rply))
9448
9449 (define-public python-hy
9450 (package
9451 (name "python-hy")
9452 (version "0.18.0")
9453 (source (origin
9454 (method url-fetch)
9455 (uri (pypi-uri "hy" version))
9456 (sha256
9457 (base32
9458 "04dfwm336gw61fmgwikvh0cnxk682p19b4w555wl5d7mlym4rwj2"))))
9459 (build-system python-build-system)
9460 (arguments
9461 '(#:phases
9462 (modify-phases %standard-phases
9463 (add-before 'install 'set-HOME
9464 (lambda _
9465 (setenv "HOME" "/tmp") #t))
9466 (replace 'check
9467 (lambda _
9468 ;; Tests require write access to HOME.
9469 (setenv "HOME" "/tmp")
9470 (invoke "nosetests"))))))
9471 (native-inputs
9472 `(("python-coverage" ,python-coverage)
9473 ("python-nose" ,python-nose)))
9474 (propagated-inputs
9475 `(("python-astor" ,python-astor)
9476 ("python-colorama" ,python-colorama)
9477 ("python-rply" ,python-rply)
9478 ("python-funcparserlib"
9479 ,python-funcparserlib)))
9480 (home-page "http://hylang.org/")
9481 (synopsis "Lisp frontend to Python")
9482 (description
9483 "Hy is a dialect of Lisp that's embedded in Python. Since Hy transforms
9484 its Lisp code into the Python Abstract Syntax Tree, you have the whole world of
9485 Python at your fingertips, in Lisp form.")
9486 (license license:expat)))
9487
9488 (define-public python2-functools32
9489 (package
9490 (name "python2-functools32")
9491 (version "3.2.3-2")
9492 (source
9493 (origin
9494 (method url-fetch)
9495 (uri (pypi-uri "functools32" version))
9496 (sha256
9497 (base32
9498 "0v8ya0b58x47wp216n1zamimv4iw57cxz3xxhzix52jkw3xks9gn"))))
9499 (build-system python-build-system)
9500 (arguments
9501 `(#:python ,python-2
9502 #:tests? #f)) ; no test target
9503 (home-page "https://github.com/MiCHiLU/python-functools32")
9504 (synopsis
9505 "Backport of the functools module from Python 3.2.3")
9506 (description
9507 "This package is a backport of the @code{functools} module from Python
9508 3.2.3 for use with older versions of Python and PyPy.")
9509 (license license:expat)))
9510
9511 (define-public python2-subprocess32
9512 (package
9513 (name "python2-subprocess32")
9514 (version "3.2.7")
9515 (source (origin
9516 (method url-fetch)
9517 (uri (pypi-uri "subprocess32" version))
9518 (sha256
9519 (base32
9520 "14350dhhlhyz5gqzi3lihn9m6lvskx5mcb20srx1kgsk9i50li8y"))
9521 (patches
9522 (search-patches "python2-subprocess32-disable-input-test.patch"))))
9523 (build-system python-build-system)
9524 (arguments
9525 `(#:python ,python-2
9526 ;; The test suite fails with Python > 2.7.13:
9527 ;; import test.support
9528 ;; ImportError: No module named support
9529 #:tests? #f
9530 #:phases
9531 (modify-phases %standard-phases
9532 (add-after 'unpack 'patch-/bin/sh
9533 (lambda _
9534 (substitute* '("subprocess32.py"
9535 "test_subprocess32.py")
9536 (("/bin/sh") (which "sh")))
9537 #t)))))
9538 (home-page "https://github.com/google/python-subprocess32")
9539 (synopsis "Backport of the subprocess module from Python 3.2")
9540 (description
9541 "This is a backport of the @code{subprocess} standard library module
9542 from Python 3.2 and 3.3 for use on Python 2. It includes bugfixes and some
9543 new features. On POSIX systems it is guaranteed to be reliable when used
9544 in threaded applications. It includes timeout support from Python 3.3 but
9545 otherwise matches 3.2’s API.")
9546 (license license:psfl)))
9547
9548 (define-public python2-futures
9549 (package
9550 (name "python2-futures")
9551 (version "3.2.0")
9552 (source
9553 (origin
9554 (method url-fetch)
9555 (uri (pypi-uri "futures" version))
9556 (sha256
9557 (base32
9558 "0rdjmmsab550kxsssdq49jcniz77zlkpw4pvi9hvib3lsskjmh4y"))))
9559 (build-system python-build-system)
9560 (arguments
9561 `(#:python ,python-2
9562 #:phases
9563 (modify-phases %standard-phases
9564 (replace 'check
9565 (lambda _
9566 (invoke "python" "test_futures.py")
9567 #t)))))
9568 (home-page "https://github.com/agronholm/pythonfutures")
9569 (synopsis
9570 "Backport of the concurrent.futures package from Python 3.2")
9571 (description
9572 "The concurrent.futures module provides a high-level interface for
9573 asynchronously executing callables. This package backports the
9574 concurrent.futures package from Python 3.2")
9575 (license license:bsd-3)))
9576
9577 (define-public python-promise
9578 (package
9579 (name "python-promise")
9580 (version "0.4.2")
9581 (source
9582 (origin
9583 (method url-fetch)
9584 (uri (pypi-uri "promise" version))
9585 (sha256
9586 (base32
9587 "1k19ms8l3d5jzjh557rgkxb5sg4mqgfc315rn4hx1z3n8qq6lr3h"))))
9588 (build-system python-build-system)
9589 ;; Tests wants python-futures, which is a python2 only program, and
9590 ;; can't be found by python-promise at test time.
9591 (arguments `(#:tests? #f))
9592 (home-page "https://github.com/syrusakbary/promise")
9593 (synopsis "Promises/A+ implementation for Python")
9594 (description
9595 "Promises/A+ implementation for Python")
9596 (properties `((python2-variant . ,(delay python2-promise))))
9597 (license license:expat)))
9598
9599 (define-public python2-promise
9600 (let ((promise (package-with-python2
9601 (strip-python2-variant python-promise))))
9602 (package (inherit promise)
9603 (arguments (substitute-keyword-arguments (package-arguments promise)
9604 ((#:tests? _) #t)))
9605 (native-inputs
9606 `(("python2-futures" ,python2-futures)
9607 ("python2-pytest" ,python2-pytest)
9608 ,@(package-native-inputs promise))))))
9609
9610 (define-public python-progressbar33
9611 (package
9612 (name "python-progressbar33")
9613 (version "2.4")
9614 (source
9615 (origin
9616 (method url-fetch)
9617 (uri (pypi-uri "progressbar33" version))
9618 (sha256
9619 (base32
9620 "1zvf6zs5hzrc03p9nfs4p16vhilqikycvv1yk0pxn8s07fdhvzji"))))
9621 (build-system python-build-system)
9622 (home-page "http://github.com/germangh/python-progressbar")
9623 (synopsis "Text progress bar library for Python")
9624 (description
9625 "This package provides a text progress bar library for Python. This
9626 version only differs from the original @code{progressbar} package in that it
9627 uses relative package imports instead of absolute imports, which is necessary
9628 for the module to work under Python 3.3.")
9629 ;; Either or both of these licenses may be selected.
9630 (license (list license:lgpl2.1+ license:bsd-3))))
9631
9632 (define-public python-colorama
9633 (package
9634 (name "python-colorama")
9635 (version "0.4.3")
9636 (source
9637 (origin
9638 (method url-fetch)
9639 (uri (pypi-uri "colorama" version))
9640 (sha256
9641 (base32
9642 "189n8hpijy14jfan4ha9f5n06mnl33cxz7ay92wjqgkr639s0vg9"))))
9643 (build-system python-build-system)
9644 (synopsis "Colored terminal text rendering for Python")
9645 (description "Colorama is a Python library for rendering colored terminal
9646 text.")
9647 (home-page "https://pypi.org/project/colorama/")
9648 (license license:bsd-3)))
9649
9650 (define-public python2-colorama
9651 (package-with-python2 python-colorama))
9652
9653 (define-public python-rsa
9654 (package
9655 (name "python-rsa")
9656 (version "3.4.2")
9657 (source
9658 (origin
9659 (method url-fetch)
9660 (uri (pypi-uri "rsa" version))
9661 (sha256
9662 (base32
9663 "1dcxvszbikgzh99ybdc7jq0zb9wspy2ds8z9mjsqiyv3q884xpr5"))))
9664 (build-system python-build-system)
9665 (propagated-inputs
9666 `(("python-pyasn1" ,python-pyasn1)))
9667 (synopsis "Pure-Python RSA implementation")
9668 (description "Python-RSA is a pure-Python RSA implementation. It supports
9669 encryption and decryption, signing and verifying signatures, and key
9670 generation according to PKCS#1 version 1.5. It can be used as a Python
9671 library as well as on the command line.")
9672 (home-page "https://stuvel.eu/rsa")
9673 (license license:asl2.0)))
9674
9675 (define-public python2-rsa
9676 (package-with-python2 python-rsa))
9677
9678 (define-public python-pluggy
9679 (package
9680 (name "python-pluggy")
9681 (version "0.11.0")
9682 (source
9683 (origin
9684 (method url-fetch)
9685 (uri (pypi-uri "pluggy" version))
9686 (sha256
9687 (base32
9688 "10511a54dvafw1jrk75mrhml53c7b7w4yaw7241696lc2hfvr895"))))
9689 (build-system python-build-system)
9690 (native-inputs
9691 `(("python-setuptools-scm" ,python-setuptools-scm)))
9692 (synopsis "Plugin and hook calling mechanism for Python")
9693 (description "Pluggy is an extraction of the plugin manager as used by
9694 Pytest but stripped of Pytest specific details.")
9695 (home-page "https://pypi.org/project/pluggy/")
9696 (license license:expat)))
9697
9698 (define-public python2-pluggy
9699 (package-with-python2 python-pluggy))
9700
9701 (define-public python-tox
9702 (package
9703 (name "python-tox")
9704 (version "2.8.1")
9705 (source
9706 (origin
9707 (method url-fetch)
9708 (uri (pypi-uri "tox" version))
9709 (sha256
9710 (base32
9711 "1drp6mwm8wdypjym15ia8lwjxbhcksb9vzxg4ay5dh4ji57by2ny"))))
9712 (build-system python-build-system)
9713 (arguments
9714 ;; FIXME: Tests require pytest-timeout, which itself requires
9715 ;; pytest>=2.8.0 for installation.
9716 '(#:tests? #f))
9717 (propagated-inputs
9718 `(("python-pluggy" ,python-pluggy) ; >=0.3.0,<0.4.0
9719 ("python-py" ,python-py)
9720 ("python-virtualenv" ,python-virtualenv)))
9721 (native-inputs
9722 `(; FIXME: Missing: ("python-pytest-timeout" ,python-pytest-timeout)
9723 ("python-pytest" ,python-pytest) ; >= 2.3.5
9724 ("python-setuptools-scm" ,python-setuptools-scm)))
9725 (home-page "https://tox.readthedocs.io")
9726 (synopsis "Virtualenv-based automation of test activities")
9727 (description "Tox is a generic virtualenv management and test command line
9728 tool. It can be used to check that a package installs correctly with
9729 different Python versions and interpreters, or run tests in each type of
9730 supported environment, or act as a frontend to continuous integration
9731 servers.")
9732 (license license:expat)))
9733
9734 (define-public python2-tox
9735 (package-with-python2 python-tox))
9736
9737 (define-public python-jmespath
9738 (package
9739 (name "python-jmespath")
9740 (version "0.9.4")
9741 (source
9742 (origin
9743 (method url-fetch)
9744 (uri (pypi-uri "jmespath" version))
9745 (sha256
9746 (base32
9747 "0k0765x1mybcrzajh3hiqkl8sy9hs0bmn4900frxy0j3ykvaxqmx"))))
9748 (build-system python-build-system)
9749 (native-inputs
9750 `(("python-nose" ,python-nose)))
9751 (synopsis "JSON Matching Expressions")
9752 (description "JMESPath (pronounced “james path”) is a Python library that
9753 allows one to declaratively specify how to extract elements from a JSON
9754 document.")
9755 (home-page "https://github.com/jmespath/jmespath.py")
9756 (license license:expat)))
9757
9758 (define-public python2-jmespath
9759 (package-with-python2 python-jmespath))
9760
9761 (define-public python-botocore
9762 (package
9763 (name "python-botocore")
9764 (version "1.15.26")
9765 (source
9766 (origin
9767 (method url-fetch)
9768 (uri (pypi-uri "botocore" version))
9769 (sha256
9770 (base32
9771 "1a87pbwkk5vlwz92hy1wizfnpiwn11bhaicr6bmji1i5ybwdhnr8"))))
9772 (build-system python-build-system)
9773 (arguments
9774 ;; FIXME: Many tests are failing.
9775 '(#:tests? #f))
9776 (propagated-inputs
9777 `(("python-dateutil" ,python-dateutil)
9778 ("python-docutils" ,python-docutils)
9779 ("python-jmespath" ,python-jmespath)))
9780 (native-inputs
9781 `(("python-mock" ,python-mock)
9782 ("python-nose" ,python-nose)
9783 ("behave" ,behave)
9784 ("python-tox" ,python-tox)
9785 ("python-urllib3" ,python-urllib3)
9786 ("python-wheel" ,python-wheel)))
9787 (home-page "https://github.com/boto/botocore")
9788 (synopsis "Low-level interface to AWS")
9789 (description "Botocore is a Python library that provides a low-level
9790 interface to the Amazon Web Services (AWS) API.")
9791 (license license:asl2.0)))
9792
9793 (define-public python2-botocore
9794 (package-with-python2 python-botocore))
9795
9796 (define-public python-xdo
9797 (package
9798 (name "python-xdo")
9799 (version "0.3")
9800 (source (origin
9801 (method url-fetch)
9802 (uri (string-append
9803 "http://http.debian.net/debian/pool/main/p/python-xdo/"
9804 "python-xdo_" version ".orig.tar.gz"))
9805 (sha256
9806 (base32
9807 "1vqh1n5yy5dhnq312kwrl90fnck4v26is3lq3lxdvcn60vv19da0"))))
9808 (build-system python-build-system)
9809 (arguments
9810 '(#:phases
9811 (modify-phases %standard-phases
9812 (add-before 'install 'patch-libxdo-path
9813 ;; Hardcode the path of dynamically loaded libxdo library.
9814 (lambda* (#:key inputs #:allow-other-keys)
9815 (let ((libxdo (string-append
9816 (assoc-ref inputs "xdotool")
9817 "/lib/libxdo.so")))
9818 (substitute* "xdo/_xdo.py"
9819 (("find_library\\(\"xdo\"\\)")
9820 (simple-format #f "\"~a\"" libxdo)))
9821 #t))))
9822 #:tests? #f)) ; no tests provided
9823 (propagated-inputs
9824 `(("python-six" ,python-six)))
9825 (inputs
9826 `(("xdotool" ,xdotool)
9827 ("libX11" ,libx11)))
9828 (home-page "https://tracker.debian.org/pkg/python-xdo")
9829 (synopsis "Python library for simulating X11 keyboard/mouse input")
9830 (description "Provides bindings to libxdo for manipulating X11 via simulated
9831 input. (Note that this is mostly a legacy library; you may wish to look at
9832 python-xdo for newer bindings.)")
9833 (license license:bsd-3)))
9834
9835 (define-public python2-xdo
9836 (package-with-python2 python-xdo))
9837
9838 (define-public python-mako
9839 (package
9840 (name "python-mako")
9841 (version "1.1.1")
9842 (source
9843 (origin
9844 (method url-fetch)
9845 (uri (pypi-uri "Mako" version))
9846 (sha256
9847 (base32
9848 "193mds7lv91pphnvn6c1n55rhjkgq94asdzgrsb2fiqx7rrsd119"))))
9849 (build-system python-build-system)
9850 (arguments
9851 `(#:phases (modify-phases %standard-phases
9852 (replace 'check
9853 (lambda _
9854 (invoke "pytest" "-vv"))))))
9855 (propagated-inputs
9856 `(("python-markupsafe" ,python-markupsafe)))
9857 (native-inputs
9858 `(("python-mock" ,python-mock)
9859 ("python-pytest" ,python-pytest)))
9860 (home-page "https://www.makotemplates.org/")
9861 (synopsis "Templating language for Python")
9862 (description "Mako is a templating language for Python that compiles
9863 templates into Python modules.")
9864 (license license:expat)))
9865
9866 (define-public python2-mako
9867 (package-with-python2 python-mako))
9868
9869 (define-public python-waitress
9870 (package
9871 (name "python-waitress")
9872 (version "1.1.0")
9873 (source
9874 (origin
9875 (method url-fetch)
9876 (uri (pypi-uri "waitress" version))
9877 (patches (search-patches "python-waitress-fix-tests.patch"))
9878 (sha256
9879 (base32
9880 "1a85gyji0kajc3p0s1pwwfm06w4wfxjkvvl4rnrz3h164kbd6g6k"))))
9881 (build-system python-build-system)
9882 (home-page "https://github.com/Pylons/waitress")
9883 (synopsis "Waitress WSGI server")
9884 (description "Waitress is meant to be a production-quality pure-Python WSGI
9885 server with very acceptable performance.")
9886 (license license:zpl2.1)))
9887
9888 (define-public python2-waitress
9889 (package-with-python2 python-waitress))
9890
9891 (define-public python-whichcraft
9892 (package
9893 (name "python-whichcraft")
9894 (version "0.6.1")
9895 (source
9896 (origin
9897 (method url-fetch)
9898 (uri (pypi-uri "whichcraft" version))
9899 (sha256
9900 (base32
9901 "11yfkzyplizdgndy34vyd5qlmr1n5mxis3a3svxmx8fnccdvknxc"))))
9902 (build-system python-build-system)
9903 (native-inputs
9904 `(("python-pytest" ,python-pytest)))
9905 (home-page "https://github.com/pydanny/whichcraft")
9906 (synopsis "Cross-platform cross-python shutil.which functionality")
9907 (description
9908 "This package provides a shim of the shutil.which function that's
9909 designed to work across multiple versions of Python.")
9910 (license license:bsd-3)))
9911
9912 (define-public python-cookiecutter
9913 (package
9914 (name "python-cookiecutter")
9915 (version "1.6.0")
9916 (source
9917 (origin
9918 (method url-fetch)
9919 (uri (pypi-uri "cookiecutter" version))
9920 (sha256
9921 (base32
9922 "0glsvaz8igi2wy1hsnhm9fkn6560vdvdixzvkq6dn20z3hpaa5hk"))))
9923 (build-system python-build-system)
9924 (native-inputs
9925 `(("python-freezegun" ,python-freezegun)
9926 ("python-pytest" ,python-pytest)
9927 ("python-pytest-catchlog" ,python-pytest-catchlog)
9928 ("python-pytest-cov" ,python-pytest-cov)
9929 ("python-pytest-mock" ,python-pytest-mock)))
9930 (propagated-inputs
9931 `(("python-binaryornot" ,python-binaryornot)
9932 ("python-click" ,python-click)
9933 ("python-future" ,python-future)
9934 ("python-jinja2" ,python-jinja2)
9935 ("python-jinja2-time" ,python-jinja2-time)
9936 ("python-poyo" ,python-poyo)
9937 ("python-requests" ,python-requests)
9938 ("python-whichcraft" ,python-whichcraft)))
9939 (home-page "https://github.com/audreyr/cookiecutter")
9940 (synopsis
9941 "Command-line utility that creates projects from project templates")
9942 (description
9943 "This package provides a command-line utility that creates projects from
9944 project templates, e.g. creating a Python package project from a Python package
9945 project template.")
9946 (license license:bsd-3)))
9947
9948 (define-public python-pyquery
9949 (package
9950 (name "python-pyquery")
9951 (version "1.2.17")
9952 (source
9953 (origin
9954 (method url-fetch)
9955 (uri (pypi-uri "pyquery" version))
9956 (sha256
9957 (base32
9958 "1xia20wm0vx5dk85kcwgh13bylz8qh47ffjxssd2586r60xi783a"))))
9959 (build-system python-build-system)
9960 (native-inputs
9961 `(("python-webob" ,python-webob)
9962 ("python-webtest" ,python-webtest)))
9963 (propagated-inputs
9964 `(("python-lxml" ,python-lxml)
9965 ("python-cssselect" ,python-cssselect)))
9966 (home-page "https://github.com/gawel/pyquery")
9967 (synopsis "Make jQuery-like queries on xml documents")
9968 (description "pyquery allows you to make jQuery queries on xml documents.
9969 The API is as much as possible the similar to jQuery. pyquery uses lxml for
9970 fast xml and html manipulation.")
9971 (license license:bsd-3)))
9972
9973 (define-public python-anyjson
9974 (package
9975 (name "python-anyjson")
9976 (version "0.3.3")
9977 (source
9978 (origin
9979 (method url-fetch)
9980 (uri (pypi-uri "anyjson" version))
9981 (sha256
9982 (base32
9983 "1fjph4alvcscsl5d4b6qpv1yh31jy05jxi1l0xff7lws7j32v09p"))))
9984 (build-system python-build-system)
9985 (arguments
9986 `(;; We could possibly get tests working, but on Python 3 it's not so easy.
9987 ;; Very strangely, 2to3 is run *during setup.py install* (or bdist, or
9988 ;; whatever) so this transformation needs to be done before the tests
9989 ;; can be run. Maybe we could add a build step to transform beforehand
9990 ;; but it could be annoying/difficult.
9991 ;; We can enable tests for the Python 2 version, though, and do below.
9992 #:tests? #f))
9993 (home-page "https://bitbucket.org/runeh/anyjson/")
9994 (synopsis
9995 "Wraps best available JSON implementation in a common interface")
9996 (description
9997 "Anyjson loads whichever is the fastest JSON module installed
9998 and provides a uniform API regardless of which JSON implementation is used.")
9999 (license license:bsd-3)
10000 (properties `((python2-variant . ,(delay python2-anyjson))))))
10001
10002 (define-public python2-anyjson
10003 (let ((anyjson (package-with-python2
10004 (strip-python2-variant python-anyjson))))
10005 (package
10006 (inherit anyjson)
10007 (arguments `(;; Unlike the python 3 variant, we do run tests. See above!
10008 #:tests? #t
10009 ,@(package-arguments anyjson)))
10010 (native-inputs `(("python2-nose" ,python2-nose))))))
10011
10012 (define-public python-amqp
10013 (package
10014 (name "python-amqp")
10015 (version "2.3.2")
10016 (source
10017 (origin
10018 (method url-fetch)
10019 (uri (pypi-uri "amqp" version))
10020 (sha256
10021 (base32
10022 "1sv600dgqwpimr6i1g59y9hpn50mc236gdqkr7zin13kvlpx0g87"))))
10023 (build-system python-build-system)
10024 (native-inputs
10025 `(("python-case" ,python-case)
10026 ("python-pytest-sugar" ,python-pytest-sugar)
10027 ("python-mock" ,python-mock)))
10028 (propagated-inputs
10029 `(("python-vine" ,python-vine)))
10030 (home-page "https://github.com/celery/py-amqp")
10031 (synopsis
10032 "Low-level AMQP client for Python (fork of amqplib)")
10033 (description
10034 "This is a fork of amqplib which was originally written by Barry Pederson.
10035 It is maintained by the Celery project, and used by kombu as a pure python
10036 alternative when librabbitmq is not available.")
10037 (license license:lgpl2.1+)
10038 (properties `((python2-variant . ,(delay python2-amqp))))))
10039
10040 (define-public python2-amqp
10041 (let ((amqp (package-with-python2
10042 (strip-python2-variant python-amqp))))
10043 (package
10044 (inherit amqp)
10045 (arguments `(;; Tries to run coverage tests with nose-cover3, which seems
10046 ;; unmaintained. Weirdly, does not do this on the python 3
10047 ;; version?
10048 #:tests? #f
10049 ,@(package-arguments amqp))))))
10050
10051 (define-public python-txamqp
10052 (package
10053 (name "python-txamqp")
10054 (version "0.8.2")
10055 (source
10056 (origin
10057 (method url-fetch)
10058 (uri (pypi-uri "txAMQP" version))
10059 (sha256
10060 (base32
10061 "0jd9864k3csc06kipiwzjlk9mq4054s8kzk5q1cfnxj8572s4iv4"))))
10062 (build-system python-build-system)
10063 (propagated-inputs
10064 `(("python-six" ,python-six)
10065 ("python-twisted" ,python-twisted)))
10066 (home-page "https://github.com/txamqp/txamqp")
10067 (synopsis "Communicate with AMQP peers and brokers using Twisted")
10068 (description
10069 "This package provides a Python library for communicating with AMQP peers
10070 and brokers using the asynchronous networking framework Twisted. It contains
10071 all the necessary code to connect, send and receive messages to/from an
10072 AMQP-compliant peer or broker (Qpid, OpenAMQ, RabbitMQ) using Twisted. It
10073 also includes support for using Thrift RPC over AMQP in Twisted
10074 applications.")
10075 (license license:asl2.0)))
10076
10077 (define-public python2-txamqp
10078 (package-with-python2 python-txamqp))
10079
10080 (define-public python-kombu
10081 (package
10082 (name "python-kombu")
10083 (version "4.2.2")
10084 (source
10085 (origin
10086 (method url-fetch)
10087 (uri (pypi-uri "kombu" version))
10088 (sha256
10089 (base32
10090 "15k8f7mzqr049sg9vi48m19vjykviafk3f0p5xzgw9by0x0kyxjj"))))
10091 (build-system python-build-system)
10092 (native-inputs
10093 `(("python-mock" ,python-mock)
10094 ("python-case" ,python-case)
10095 ("python-pyro4" ,python-pyro4)
10096 ("python-pytest-sugar" ,python-pytest-sugar)
10097 ("python-pytz" ,python-pytz)))
10098 (propagated-inputs
10099 `(("python-anyjson" ,python-anyjson)
10100 ("python-amqp" ,python-amqp)
10101 ("python-redis" ,python-redis)))
10102 (home-page "https://kombu.readthedocs.io")
10103 (synopsis "Message passing library for Python")
10104 (description "The aim of Kombu is to make messaging in Python as easy as
10105 possible by providing an idiomatic high-level interface for the AMQ protocol,
10106 and also provide proven and tested solutions to common messaging problems.
10107 AMQP is the Advanced Message Queuing Protocol, an open standard protocol for
10108 message orientation, queuing, routing, reliability and security, for which the
10109 RabbitMQ messaging server is the most popular implementation.")
10110 (license license:bsd-3)
10111 (properties `((python2-variant . ,(delay python2-kombu))))))
10112
10113 (define-public python2-kombu
10114 (let ((kombu (package-with-python2
10115 (strip-python2-variant python-kombu))))
10116 (package
10117 (inherit kombu)
10118 (arguments `(;; FIXME: 'TestTransport.test_del_sync' fails on python2.
10119 ;; It works fine on the python3 variant.
10120 #:tests? #f
10121 ,@(package-arguments kombu)))
10122 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10123 ,@(package-native-inputs kombu))))))
10124
10125 (define-public python-billiard
10126 (package
10127 (name "python-billiard")
10128 (version "3.5.0.5")
10129 (source
10130 (origin
10131 (method url-fetch)
10132 (uri (pypi-uri "billiard" version))
10133 (sha256
10134 (base32
10135 "03msmapj3s5zgqk87d646mafz7a01h5bm2wijalgpi0s80ks5na2"))))
10136 (build-system python-build-system)
10137 (native-inputs
10138 `(("python-case" ,python-case)
10139 ("python-pytest" ,python-pytest)))
10140 (home-page "https://github.com/celery/billiard")
10141 (synopsis
10142 "Python multiprocessing fork with improvements and bugfixes")
10143 (description
10144 "Billiard is a fork of the Python 2.7 multiprocessing package. The
10145 multiprocessing package itself is a renamed and updated version of R Oudkerk's
10146 pyprocessing package. This standalone variant is intended to be compatible with
10147 Python 2.4 and 2.5, and will draw its fixes/improvements from python-trunk.")
10148 (license license:bsd-3)
10149 (properties `((python2-variant . ,(delay python2-billiard))))))
10150
10151 (define-public python2-billiard
10152 (let ((billiard (package-with-python2
10153 (strip-python2-variant python-billiard))))
10154 (package
10155 (inherit billiard)
10156 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10157 ("python2-mock" ,python2-mock)
10158 ,@(package-native-inputs billiard))))))
10159
10160 (define-public python-celery
10161 (package
10162 (name "python-celery")
10163 (version "4.2.1")
10164 (source
10165 (origin
10166 (method url-fetch)
10167 (uri (pypi-uri "celery" version))
10168 (sha256
10169 (base32
10170 "0y66rz7z8dfcgs3s0qxmdddlaq57bzbgxgfz896nbp14grkv9nkp"))))
10171 (build-system python-build-system)
10172 (arguments
10173 '(;; TODO The tests fail with Python 3.7
10174 ;; https://github.com/celery/celery/issues/4849
10175 #:tests? #f
10176 #:phases
10177 (modify-phases %standard-phases
10178 (add-after 'unpack 'patch-requirements
10179 (lambda _
10180 (substitute* "requirements/test.txt"
10181 (("pytest>=3\\.0,<3\\.3")
10182 "pytest>=3.0"))
10183 #t)))))
10184 (native-inputs
10185 `(("python-case" ,python-case)
10186 ("python-pytest" ,python-pytest)))
10187 (propagated-inputs
10188 `(("python-pytz" ,python-pytz)
10189 ("python-billiard" ,python-billiard)
10190 ("python-kombu" ,python-kombu)))
10191 (home-page "https://celeryproject.org")
10192 (synopsis "Distributed Task Queue")
10193 (description "Celery is an asynchronous task queue/job queue based on
10194 distributed message passing. It is focused on real-time operation, but
10195 supports scheduling as well. The execution units, called tasks, are executed
10196 concurrently on a single or more worker servers using multiprocessing,
10197 Eventlet, or gevent. Tasks can execute asynchronously (in the background) or
10198 synchronously (wait until ready).")
10199 (license license:bsd-3)
10200 (properties `((python2-variant . ,(delay python2-celery))))))
10201
10202 (define-public python2-celery
10203 (let ((celery (package-with-python2
10204 (strip-python2-variant python-celery))))
10205 (package
10206 (inherit celery)
10207 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10208 ("python2-mock" ,python2-mock)
10209 ,@(package-native-inputs celery))))))
10210
10211 (define-public python-translitcodec
10212 (package
10213 (name "python-translitcodec")
10214 (version "0.4.0")
10215 (source
10216 (origin
10217 (method url-fetch)
10218 (uri (pypi-uri "translitcodec" version))
10219 (sha256
10220 (base32
10221 "10x6pvblkzky1zhjs8nmx64nb9jdzxad4bxhq4iwv0j4z2aqjnki"))))
10222 (build-system python-build-system)
10223 (arguments
10224 `(#:tests? #f)) ; no tests provided
10225 (home-page
10226 "https://github.com/claudep/translitcodec")
10227 (synopsis
10228 "Unicode to 8-bit charset transliteration codec")
10229 (description
10230 "This package contains codecs for transliterating ISO 10646 texts into
10231 best-effort representations using smaller coded character sets (ASCII,
10232 ISO 8859, etc.).")
10233 (license license:expat)))
10234
10235 (define-public python2-translitcodec
10236 (package-with-python2 python-translitcodec))
10237
10238 (define-public python-editor
10239 (package
10240 (name "python-editor")
10241 (version "1.0.4")
10242 (source
10243 (origin
10244 (method url-fetch)
10245 (uri (pypi-uri "python-editor" version))
10246 (sha256
10247 (base32
10248 "0yrjh8w72ivqxi4i7xsg5b1vz15x8fg51xra7c3bgfyxqnyadzai"))))
10249 (build-system python-build-system)
10250 (arguments
10251 '(#:tests? #f)) ;XXX: needs a TTY and an editor
10252 (home-page "https://github.com/fmoo/python-editor")
10253 (synopsis "Programmatically open an editor, capture the result")
10254 (description
10255 "python-editor is a library that provides the editor module for
10256 programmatically interfacing with your system's $EDITOR.")
10257 (license license:asl2.0)))
10258
10259 (define-public python2-editor
10260 (package-with-python2 python-editor))
10261
10262 (define-public python-vobject
10263 (package
10264 (name "python-vobject")
10265 (version "0.9.6.1")
10266 (source (origin
10267 (method url-fetch)
10268 (uri (pypi-uri "vobject" version))
10269 (sha256
10270 (base32
10271 "0081g4gngw28j7vw8101jk600wz4gzfrhf5myrqvn2mrfkn2llcn"))))
10272 (build-system python-build-system)
10273 (arguments
10274 '(;; The test suite relies on some non-portable Windows interfaces.
10275 #:tests? #f))
10276 (propagated-inputs
10277 `(("python-dateutil" ,python-dateutil)
10278 ("python-pyicu" ,python-pyicu)))
10279 (synopsis "Parse and generate vCard and vCalendar files")
10280 (description "Vobject is intended to be a full featured Python package for
10281 parsing and generating vCard and vCalendar files. Currently, iCalendar files
10282 are supported and well tested. vCard 3.0 files are supported, and all data
10283 should be imported, but only a few components are understood in a sophisticated
10284 way.")
10285 (home-page "https://eventable.github.io/vobject/")
10286 (license license:asl2.0)))
10287
10288 (define-public python2-vobject
10289 (package-with-python2 python-vobject))
10290
10291 (define-public python-munkres
10292 (package
10293 (name "python-munkres")
10294 (version "1.0.8")
10295 (source (origin
10296 (method url-fetch)
10297 (uri (pypi-uri "munkres" version))
10298 (sha256
10299 (base32
10300 "0mbspx4zv8id4x6pim6ybsa1xh96qwpbqj7skbqz4c9c9nf1lpqq"))))
10301 (build-system python-build-system)
10302 (arguments
10303 '(#:tests? #f)) ; no test suite
10304 (home-page "https://software.clapper.org/munkres/")
10305 (synopsis "Implementation of the Munkres algorithm")
10306 (description "The Munkres module provides an implementation of the Munkres
10307 algorithm (also called the Hungarian algorithm or the Kuhn-Munkres algorithm),
10308 useful for solving the Assignment Problem.")
10309 (license license:bsd-3)))
10310
10311 (define-public python2-munkres
10312 (package-with-python2 python-munkres))
10313
10314 (define-public python-whoosh
10315 (package
10316 (name "python-whoosh")
10317 (version "2.7.4")
10318 (source
10319 (origin
10320 (method url-fetch)
10321 (uri (pypi-uri "Whoosh" version))
10322 (sha256
10323 (base32
10324 "10qsqdjpbc85fykc1vgcs8xwbgn4l2l52c8d83xf1q59pwyn79bw"))))
10325 (build-system python-build-system)
10326 (arguments '(#:tests? #f)) ; Test invocation is no longer supported by Python.
10327 (native-inputs
10328 `(("python-pytest" ,python-pytest)))
10329 (home-page "https://bitbucket.org/mchaput/whoosh")
10330 (synopsis "Full text indexing, search, and spell checking library")
10331 (description
10332 "Whoosh is a fast, pure-Python full text indexing, search, and spell
10333 checking library.")
10334 (license license:bsd-2)))
10335
10336 (define-public python2-whoosh
10337 (let ((whoosh (package-with-python2 (strip-python2-variant python-whoosh))))
10338 (package (inherit whoosh)
10339 (propagated-inputs
10340 `(("python2-backport-ssl-match-hostname"
10341 ,python2-backport-ssl-match-hostname)
10342 ,@(package-propagated-inputs whoosh))))))
10343
10344 (define-public python-pathlib
10345 (package
10346 (name "python-pathlib")
10347 (version "1.0.1")
10348 (source (origin
10349 (method url-fetch)
10350 (uri (pypi-uri "pathlib" version))
10351 (sha256
10352 (base32
10353 "17zajiw4mjbkkv6ahp3xf025qglkj0805m9s41c45zryzj6p2h39"))))
10354 (build-system python-build-system)
10355 ;; The tests depend on the internal "test" module, which does not provide
10356 ;; a stable interface.
10357 (arguments `(#:tests? #f))
10358 (home-page "https://pathlib.readthedocs.org/")
10359 (synopsis "Object-oriented file system paths")
10360 (description "Pathlib offers a set of classes to handle file system paths.
10361 It offers the following advantages over using string objects:
10362
10363 @enumerate
10364 @item No more cumbersome use of os and os.path functions. Everything can
10365 be done easily through operators, attribute accesses, and method calls.
10366 @item Embodies the semantics of different path types. For example,
10367 comparing Windows paths ignores casing.
10368 @item Well-defined semantics, eliminating any inconsistencies or
10369 ambiguities (forward vs. backward slashes, etc.).
10370 @end enumerate
10371
10372 Note: In Python 3.4, pathlib is now part of the standard library. For other
10373 Python versions please consider python-pathlib2 instead, which tracks the
10374 standard library module. This module (python-pathlib) isn't maintained
10375 anymore.")
10376 (license license:expat)))
10377
10378 (define-public python2-pathlib
10379 (package-with-python2 python-pathlib))
10380
10381 (define-public python2-pathlib2
10382 (package
10383 (name "python2-pathlib2")
10384 (version "2.3.3")
10385 (source (origin
10386 (method url-fetch)
10387 (uri (pypi-uri "pathlib2" version))
10388 (sha256
10389 (base32
10390 "0hpp92vqqgcd8h92msm9slv161b1q160igjwnkf2ag6cx0c96695"))))
10391 (build-system python-build-system)
10392 ;; We only need the the Python 2 variant, since for Python 3 our minimum
10393 ;; version is 3.4 which already includes this package as part of the
10394 ;; standard library.
10395 (arguments
10396 `(#:python ,python-2))
10397 (propagated-inputs
10398 `(("python2-scandir" ,python2-scandir)
10399 ("python2-six" ,python2-six)))
10400 (home-page "https://pypi.org/project/pathlib2/")
10401 (synopsis "Object-oriented file system paths - backport of standard
10402 pathlib module")
10403 (description "The goal of pathlib2 is to provide a backport of standard
10404 pathlib module which tracks the standard library module, so all the newest
10405 features of the standard pathlib can be used also on older Python versions.
10406
10407 Pathlib offers a set of classes to handle file system paths. It offers the
10408 following advantages over using string objects:
10409
10410 @enumerate
10411 @item No more cumbersome use of os and os.path functions. Everything can
10412 be done easily through operators, attribute accesses, and method calls.
10413 @item Embodies the semantics of different path types. For example,
10414 comparing Windows paths ignores casing.
10415 @item Well-defined semantics, eliminating any inconsistencies or
10416 ambiguities (forward vs. backward slashes, etc.).
10417 @end enumerate")
10418 (license license:expat)))
10419
10420 (define-public python2-pathlib2-bootstrap
10421 (hidden-package
10422 (package
10423 (inherit python2-pathlib2)
10424 (name "python2-pathlib2-bootstrap")
10425 (propagated-inputs
10426 `(("python2-scandir" ,python2-scandir)
10427 ("python2-six" ,python2-six-bootstrap))))))
10428
10429 (define-public python-jellyfish
10430 (package
10431 (name "python-jellyfish")
10432 (version "0.5.6")
10433 (source (origin
10434 (method url-fetch)
10435 (uri (pypi-uri "jellyfish" version))
10436 (sha256
10437 (base32
10438 "1j9rplb16ba2prjj6mip46z0w9pnhnqpwgiwi0x93vnas14rlyl8"))))
10439 (build-system python-build-system)
10440 (native-inputs
10441 `(("python-pytest" ,python-pytest)))
10442 (home-page "https://github.com/jamesturk/jellyfish")
10443 (synopsis "Approximate and phonetic matching of strings")
10444 (description "Jellyfish uses a variety of string comparison and phonetic
10445 encoding algorithms to do fuzzy string matching.")
10446 (license license:bsd-2)
10447 (properties `((python2-variant . ,(delay python2-jellyfish))))))
10448
10449 (define-public python2-jellyfish
10450 (let ((jellyfish (package-with-python2
10451 (strip-python2-variant python-jellyfish))))
10452 (package (inherit jellyfish)
10453 (native-inputs `(("python2-unicodecsv" ,python2-unicodecsv)
10454 ,@(package-native-inputs jellyfish))))))
10455
10456 (define-public python2-unicodecsv
10457 (package
10458 (name "python2-unicodecsv")
10459 (version "0.14.1")
10460 (source (origin
10461 (method git-fetch)
10462 ;; The test suite is not included in the PyPi release.
10463 ;; https://github.com/jdunck/python-unicodecsv/issues/19
10464 (uri (git-reference
10465 (url "https://github.com/jdunck/python-unicodecsv")
10466 (commit version)))
10467 (file-name (git-file-name name version))
10468 (sha256
10469 (base32
10470 "15hx2k41a2lpv4hcml9zp4cvlx1171mnb5s4s13xc1pxkq3vgdjy"))))
10471 (build-system python-build-system)
10472 (arguments
10473 `(;; It supports Python 3, but Python 3 can already do Unicode CSV.
10474 #:python ,python-2))
10475 (native-inputs
10476 `(("python2-unittest2" ,python2-unittest2)))
10477 (home-page "https://github.com/jdunck/python-unicodecsv")
10478 (synopsis "Unicode CSV module for Python 2")
10479 (description "Unicodecsv is a drop-in replacement for Python 2.7's CSV
10480 module, adding support for Unicode strings.")
10481 (license license:bsd-2)))
10482
10483 (define-public python-rarfile
10484 (package
10485 (name "python-rarfile")
10486 (version "2.8")
10487 (source (origin
10488 (method url-fetch)
10489 (uri (pypi-uri "rarfile" version))
10490 (sha256
10491 (base32
10492 "0qfad483kcbga0bn4qmcz953xjk16r52fahiy46zzn56v80y89ra"))))
10493 (build-system python-build-system)
10494 (arguments
10495 '(#:phases
10496 (modify-phases %standard-phases
10497 (replace 'check
10498 ;; Many tests fail, but the installation proceeds.
10499 (lambda _ (invoke "make" "-C" "test" "test"))))))
10500 (native-inputs
10501 `(("which" ,which))) ; required for tests
10502 (propagated-inputs
10503 `(("libarchive" ,libarchive)))
10504 (home-page "https://github.com/markokr/rarfile")
10505 (synopsis "RAR archive reader for Python")
10506 (description "This is Python module for RAR archive reading. The interface
10507 is made as zipfile like as possible.")
10508 (license license:isc)))
10509
10510 (define-public python2-rarfile
10511 (package-with-python2 python-rarfile))
10512
10513 (define-public python-magic
10514 (package
10515 (name "python-magic")
10516 (version "0.4.15")
10517 (source
10518 (origin
10519 (method url-fetch)
10520 (uri (pypi-uri "python-magic" version))
10521 (sha256
10522 (base32
10523 "1mgwig9pnzgkf86q9ji9pnc99bngms15lfszq5rgqb9db07mqxpk"))
10524 (file-name (string-append name "-" version "-checkout"))))
10525 (build-system python-build-system)
10526 (arguments
10527 ;; The tests are unreliable, so don't run them. The tests fail
10528 ;; under Python3 because they were written for Python2 and
10529 ;; contain import statements that do not work in Python3. One of
10530 ;; the tests fails under Python2 because its assertions are
10531 ;; overly stringent; it relies on comparing output strings which
10532 ;; are brittle and can change depending on the version of
10533 ;; libmagic being used and the system on which the test is
10534 ;; running. In my case, under GuixSD 0.10.0, only one test
10535 ;; failed, and it seems to have failed only because the version
10536 ;; of libmagic that is packaged in Guix outputs a slightly
10537 ;; different (but not wrong) string than the one that the test
10538 ;; expected.
10539 '(#:tests? #f
10540 #:phases (modify-phases %standard-phases
10541 ;; Replace a specific method call with a hard-coded
10542 ;; path to the necessary libmagic.so file in the
10543 ;; store. If we don't do this, then the method call
10544 ;; will fail to find the libmagic.so file, which in
10545 ;; turn will cause any application using
10546 ;; python-magic to fail.
10547 (add-before 'build 'hard-code-path-to-libmagic
10548 (lambda* (#:key inputs #:allow-other-keys)
10549 (let ((file (assoc-ref inputs "file")))
10550 (substitute* "magic.py"
10551 (("ctypes.util.find_library\\('magic'\\)")
10552 (string-append "'" file "/lib/libmagic.so'")))
10553 #t)))
10554 (add-before 'install 'disable-egg-compression
10555 (lambda _
10556 (let ((port (open-file "setup.cfg" "a")))
10557 (display "\n[easy_install]\nzip_ok = 0\n"
10558 port)
10559 (close-port port)
10560 #t))))))
10561 (inputs
10562 ;; python-magic needs to be able to find libmagic.so.
10563 `(("file" ,file)))
10564 (home-page
10565 "https://github.com/ahupp/python-magic")
10566 (synopsis
10567 "File type identification using libmagic")
10568 (description
10569 "This module uses ctypes to access the libmagic file type
10570 identification library. It makes use of the local magic database and
10571 supports both textual and MIME-type output. Note that this module and
10572 the python-file module both provide a \"magic.py\" file; these two
10573 modules, which are different and were developed separately, both serve
10574 the same purpose: to provide Python bindings for libmagic.")
10575 (license license:expat)))
10576
10577 (define-public python2-magic
10578 (package-with-python2 python-magic))
10579
10580 (define-public python2-s3cmd
10581 (package
10582 (name "python2-s3cmd")
10583 (version "1.6.1")
10584 (source
10585 (origin
10586 (method url-fetch)
10587 (uri (string-append "mirror://sourceforge/s3tools/s3cmd/" version "/"
10588 "s3cmd-" version ".tar.gz"))
10589 (sha256
10590 (base32
10591 "0ki1rzhm5icvi9ry5jswi4b22yqwyj0d2wsqsgilwx6qhi7pjxa6"))))
10592 (build-system python-build-system)
10593 (arguments
10594 ;; s3cmd is written for python2 only and contains no tests.
10595 `(#:python ,python-2
10596 #:tests? #f))
10597 (propagated-inputs
10598 `(("python2-dateutil" ,python2-dateutil)
10599 ;; The python-file package also provides a magic.py module.
10600 ;; This is an unfortunate state of affairs; however, s3cmd
10601 ;; fails to install if it cannot find specifically the
10602 ;; python-magic package. Thus we include it, instead of using
10603 ;; python-file. Ironically, s3cmd sometimes works better
10604 ;; without libmagic bindings at all:
10605 ;; https://github.com/s3tools/s3cmd/issues/198
10606 ("python2-magic" ,python2-magic)))
10607 (home-page "https://s3tools.org/s3cmd")
10608 (synopsis "Command line tool for S3-compatible storage services")
10609 (description
10610 "S3cmd is a command line tool for uploading, retrieving and managing data
10611 in storage services that are compatible with the Amazon Simple Storage
10612 Service (S3) protocol, including S3 itself. It supports rsync-like backup,
10613 GnuPG encryption, and more. It also supports management of Amazon's
10614 CloudFront content delivery network.")
10615 (license license:gpl2+)))
10616
10617 (define-public python-pkgconfig
10618 (package
10619 (name "python-pkgconfig")
10620 (version "1.3.1")
10621 (source
10622 (origin
10623 (method url-fetch)
10624 (uri (pypi-uri "pkgconfig" version))
10625 (sha256
10626 (base32
10627 "107x2wmchlch8saixb488cgjz9n6inl38wi7nxkb942rbaapxiqb"))))
10628 (build-system python-build-system)
10629 (native-inputs
10630 `(("python-nose" ,python-nose)))
10631 (inputs
10632 `(("pkg-config" ,pkg-config)))
10633 (arguments
10634 `(#:phases
10635 (modify-phases %standard-phases
10636 (add-before 'build 'patch
10637 ;; Hard-code the path to pkg-config.
10638 (lambda _
10639 (substitute* "pkgconfig/pkgconfig.py"
10640 (("cmd = 'pkg-config")
10641 (string-append "cmd = '" (which "pkg-config"))))
10642 #t))
10643 (replace 'check
10644 (lambda _
10645 (invoke "nosetests" "test.py"))))))
10646 (home-page "https://github.com/matze/pkgconfig")
10647 (synopsis "Python interface for pkg-config")
10648 (description "This module provides a Python interface to pkg-config. It
10649 can be used to find all pkg-config packages, check if a package exists,
10650 check if a package meets certain version requirements, query CFLAGS and
10651 LDFLAGS and parse the output to build extensions with setup.py.")
10652 (license license:expat)))
10653
10654 (define-public python2-pkgconfig
10655 (package-with-python2 python-pkgconfig))
10656
10657 (define-public python-bz2file
10658 (package
10659 (name "python-bz2file")
10660 (version "0.98")
10661 (source
10662 (origin
10663 (method url-fetch)
10664 (uri (pypi-uri "bz2file" version))
10665 (sha256
10666 (base32
10667 "126s53fkpx04f33a829yqqk8fj4png3qwg4m66cvlmhmwc8zihb4"))))
10668 (build-system python-build-system)
10669 (arguments
10670 `(#:tests? #f)) ; Tests use deprecated python modules.
10671 (home-page "https://github.com/nvawda/bz2file")
10672 (synopsis "Read and write bzip2-compressed files")
10673 (description
10674 "Bz2file is a Python library for reading and writing bzip2-compressed
10675 files. It contains a drop-in replacement for the I/O interface in the
10676 standard library's @code{bz2} module, including features from the latest
10677 development version of CPython that are not available in older releases.")
10678 (license license:asl2.0)))
10679
10680 (define-public python2-bz2file
10681 (package-with-python2 python-bz2file))
10682
10683 (define-public python-future
10684 (package
10685 (name "python-future")
10686 (version "0.17.1")
10687 (source
10688 (origin
10689 (method url-fetch)
10690 (uri (pypi-uri "future" version))
10691 (sha256
10692 (base32
10693 "1f2rlqn9rh7adgir52dlbqz69gsab44x0mlm8gf1cs7xvhv54137"))))
10694 (build-system python-build-system)
10695 ;; Many tests connect to the network or are otherwise flawed.
10696 ;; https://github.com/PythonCharmers/python-future/issues/210
10697 (arguments
10698 `(#:tests? #f))
10699 (home-page "https://python-future.org")
10700 (synopsis "Single-source support for Python 3 and 2")
10701 (description
10702 "@code{python-future} is the missing compatibility layer between Python 2 and
10703 Python 3. It allows you to use a single, clean Python 3.x-compatible codebase
10704 to support both Python 2 and Python 3 with minimal overhead.")
10705 (license license:expat)))
10706
10707 (define-public python2-future
10708 (package-with-python2 python-future))
10709
10710 (define-public python-cysignals
10711 (package
10712 (name "python-cysignals")
10713 (version "1.9.0")
10714 (source
10715 (origin
10716 (method url-fetch)
10717 (uri (pypi-uri "cysignals" version))
10718 (sha256
10719 (base32
10720 "15ix8crpad26cfl1skyg7qajqqfdrm8q5ahhmlfmqi1aw0jqj2g2"))))
10721 (build-system python-build-system)
10722 (native-inputs
10723 `(("python-cython" ,python-cython)
10724 ("python-sphinx" ,python-sphinx)))
10725 (inputs
10726 `(("pari-gp" ,pari-gp)))
10727 (arguments
10728 `(#:modules ((guix build python-build-system)
10729 ((guix build gnu-build-system) #:prefix gnu:)
10730 (guix build utils))
10731 ;; FIXME: Tests are executed after installation and currently fail
10732 ;; when not installing into standard locations; the author is working
10733 ;; on a fix.
10734 #:tests? #f
10735 #:phases
10736 (modify-phases %standard-phases
10737 (add-before
10738 'build 'configure
10739 (assoc-ref gnu:%standard-phases 'configure)))))
10740 (home-page
10741 "https://github.com/sagemath/cysignals")
10742 (synopsis
10743 "Handling of interrupts and signals for Cython")
10744 (description
10745 "The cysignals package provides mechanisms to handle interrupts (and
10746 other signals and errors) in Cython code, using two related approaches,
10747 for mixed Cython/Python code or external C libraries and pure Cython code,
10748 respectively.")
10749 (license license:lgpl3+)))
10750
10751 (define-public python2-cysignals
10752 (package-with-python2 python-cysignals))
10753
10754 (define-public python2-shedskin
10755 (package
10756 (name "python2-shedskin")
10757 (version "0.9.4")
10758 (source
10759 (origin
10760 (method url-fetch)
10761 (uri (string-append "https://github.com/shedskin/shedskin/"
10762 "releases/download/v" version
10763 "/shedskin-" version ".tgz"))
10764 (sha256
10765 (base32
10766 "0nzwrzgw1ga8rw6f0ryq7zr9kkiavd1cqz5hzxkcbicl1dk7kz41"))))
10767 (build-system python-build-system)
10768 (arguments
10769 `(#:python ,python-2
10770 #:phases (modify-phases %standard-phases
10771 (add-after 'unpack 'fix-resulting-include-libs
10772 (lambda* (#:key inputs #:allow-other-keys)
10773 (let ((libgc (assoc-ref inputs "libgc"))
10774 (pcre (assoc-ref inputs "pcre")))
10775 (substitute* "shedskin/makefile.py"
10776 (("variable == 'CCFLAGS':[ ]*")
10777 (string-append "variable == 'CCFLAGS':\n"
10778 " line += ' -I " pcre "/include"
10779 " -I " libgc "/include'"))
10780 (("variable == 'LFLAGS':[ ]*")
10781 (string-append "variable == 'LFLAGS':\n"
10782 " line += ' -L" pcre "/lib"
10783 " -L " libgc "/lib'")))
10784 #t))))))
10785 (inputs `(("pcre" ,pcre)
10786 ("libgc" ,libgc)))
10787 (home-page "https://shedskin.github.io/")
10788 (synopsis "Experimental Python-2 to C++ Compiler")
10789 (description (string-append "This is an experimental compiler for a subset of
10790 Python. It generates C++ code and a Makefile."))
10791 (license (list license:gpl3 license:bsd-3 license:expat))))
10792
10793 (define-public python2-rope
10794 (package
10795 (name "python2-rope")
10796 (version "0.11.0")
10797 (source
10798 (origin
10799 (method url-fetch)
10800 (uri (pypi-uri "rope" version))
10801 (sha256
10802 (base32
10803 "1cppm0pa9aqgsbkq130lskrzmrvjs5vpiavjjbhpz2fdw52w8251"))))
10804 (arguments
10805 ;; Rope has only partial python3 support, see `python-rope'
10806 `(#:python ,python-2))
10807 (build-system python-build-system)
10808 (native-inputs
10809 `(("python2-unittest2" ,python2-unittest2)))
10810 (home-page "https://github.com/python-rope/rope")
10811 (synopsis "Refactoring library for Python")
10812 (description "Rope is a refactoring library for Python. It facilitates
10813 the renaming, moving and extracting of attributes, functions, modules, fields
10814 and parameters in Python 2 source code. These refactorings can also be applied
10815 to occurrences in strings and comments.")
10816 (license license:gpl2)))
10817
10818 (define-public python-rope
10819 (package
10820 (inherit python2-rope)
10821 (name "python-rope")
10822 (arguments `(#:python ,python-wrapper
10823 ;; XXX: Only partial python3 support, results in some failing
10824 ;; tests: <https://github.com/python-rope/rope/issues/247>.
10825 #:tests? #f))
10826 (properties `((python2-variant . ,(delay python2-rope))))))
10827
10828 (define-public python-py3status
10829 (package
10830 (name "python-py3status")
10831 (version "3.21")
10832 (source
10833 (origin
10834 (method url-fetch)
10835 (uri (pypi-uri "py3status" version))
10836 (sha256
10837 (base32 "16z8zq83hxy48g6hh4xczbdz50qvxv9k1aahr4fqq7jis60cc262"))))
10838 (build-system python-build-system)
10839 (inputs
10840 `(("file" ,file)))
10841 (arguments
10842 '(#:phases
10843 (modify-phases %standard-phases
10844 ;; 'file' is used for detection of configuration file encoding
10845 ;; let's make link the dependency to particular input
10846 (add-before 'build 'patch-file-path
10847 (lambda* (#:key inputs #:allow-other-keys)
10848 (let ((file-path (assoc-ref inputs "file")))
10849 (substitute* "py3status/parse_config.py"
10850 (("\\[\"file\", \"-b\"")
10851 (string-append "['" file-path "/bin/file', '-b'")))
10852 #t))))
10853 #:tests? #f)) ; TODO: Requires many libraries not in Guix.
10854 (home-page "https://github.com/ultrabug/py3status")
10855 (synopsis "Extensible i3status wrapper written in Python")
10856 (description "py3status is an i3status wrapper which extends i3status
10857 functionality in a modular way, allowing you to extend your panel with your
10858 own code, responding to click events and updating clock every second.")
10859 (license license:bsd-3)))
10860
10861 (define-public python-tblib
10862 (package
10863 (name "python-tblib")
10864 (version "1.6.0")
10865 (source (origin
10866 (method url-fetch)
10867 (uri (pypi-uri "tblib" version))
10868 (sha256
10869 (base32
10870 "0i136n5pydmd202254wzrdbspkw0br0c9mbxhfs9hpfbahvyx6r2"))))
10871 (build-system python-build-system)
10872 (arguments
10873 `(#:phases
10874 (modify-phases %standard-phases
10875 (replace 'check
10876 (lambda _
10877 ;; Upstream runs tests after installation and the package itself
10878 ;; resides in a subdirectory. Extend PYTHONPATH so it will be
10879 ;; found.
10880 (setenv "PYTHONPATH"
10881 (string-append (getcwd) "/build/lib:"
10882 (getenv "PYTHONPATH")))
10883 (invoke "py.test" "-vv" "tests" "README.rst"))))))
10884 (native-inputs
10885 `(("python-pytest" ,python-pytest)
10886 ("python-six" ,python-six)))
10887 (home-page "https://github.com/ionelmc/python-tblib")
10888 (synopsis "Traceback serialization library")
10889 (description
10890 "Traceback serialization allows you to:
10891
10892 @enumerate
10893 @item Pickle tracebacks and raise exceptions with pickled tracebacks in
10894 different processes. This allows better error handling when running code over
10895 multiple processes (imagine multiprocessing, billiard, futures, celery etc).
10896
10897 @item Parse traceback strings and raise with the parsed tracebacks.
10898 @end enumerate\n")
10899 (license license:bsd-3)))
10900
10901 (define-public python2-tblib
10902 (package-with-python2 python-tblib))
10903
10904 (define-public python-greenlet
10905 (package
10906 (name "python-greenlet")
10907 (version "0.4.15")
10908 (source (origin
10909 (method url-fetch)
10910 (uri (pypi-uri "greenlet" version))
10911 (sha256
10912 (base32
10913 "1g4g1wwc472ds89zmqlpyan3fbnzpa8qm48z3z1y6mlk44z485ll"))))
10914 (build-system python-build-system)
10915 (home-page "https://greenlet.readthedocs.io/")
10916 (synopsis "Lightweight in-process concurrent programming")
10917 (description
10918 "Greenlet package is a spin-off of Stackless, a version of CPython
10919 that supports micro-threads called \"tasklets\". Tasklets run
10920 pseudo-concurrently (typically in a single or a few OS-level threads) and
10921 are synchronized with data exchanges on \"channels\".")
10922 (license (list license:psfl license:expat))))
10923
10924 (define-public python2-greenlet
10925 (package-with-python2 python-greenlet))
10926
10927 (define-public python-objgraph
10928 (package
10929 (name "python-objgraph")
10930 (version "3.4.1")
10931 (source
10932 (origin
10933 (method url-fetch)
10934 (uri (pypi-uri "objgraph" version))
10935 (sha256
10936 (base32
10937 "19qmqsh984zq1rzzjy4vqnmviaqnymcyl8h7z99pnicbgwnm2adz"))))
10938 (build-system python-build-system)
10939 (propagated-inputs
10940 `(("python-graphviz" ,python-graphviz)))
10941 (native-inputs
10942 `(("python-mock" ,python-mock)
10943 ("graphviz" ,graphviz)))
10944 (home-page "https://mg.pov.lt/objgraph/")
10945 (synopsis "Draw Python object reference graphs with graphviz")
10946 (description
10947 "This package provides tools to draw Python object reference graphs with
10948 graphviz.")
10949 (license license:expat)))
10950
10951 (define-public python2-objgraph
10952 (package-with-python2 python-objgraph))
10953
10954 (define-public python-gevent
10955 (package
10956 (name "python-gevent")
10957 (version "1.4.0")
10958 (source (origin
10959 (method url-fetch)
10960 (uri (pypi-uri "gevent" version))
10961 (sha256
10962 (base32
10963 "1lchr4akw2jkm5v4kz7bdm4wv3knkfhbfn9vkkz4s5yrkcxzmdqy"))
10964 (modules '((guix build utils)))
10965 (snippet
10966 '(begin
10967 ;; unbunding libev and c-ares
10968 (delete-file-recursively "deps")
10969 #t))))
10970 (build-system python-build-system)
10971 (arguments
10972 `(#:modules ((ice-9 ftw)
10973 (ice-9 match)
10974 (srfi srfi-26)
10975 (guix build utils)
10976 (guix build python-build-system))
10977 #:phases (modify-phases %standard-phases
10978 (add-before 'patch-source-shebangs 'patch-hard-coded-paths
10979 (lambda _
10980 (substitute* "src/gevent/subprocess.py"
10981 (("/bin/sh") (which "sh")))
10982 (for-each (lambda (file)
10983 (substitute* file
10984 (("/bin/sh") (which "sh"))
10985 (("/bin/true") (which "true"))))
10986 (find-files "src/greentest" "\\.py$"))
10987 #t))
10988 (add-before 'build 'do-not-use-bundled-sources
10989 (lambda* (#:key inputs #:allow-other-keys)
10990 (setenv "GEVENTSETUP_EMBED" "0")
10991
10992 ;; Prevent building bundled libev.
10993 (substitute* "setup.py"
10994 (("run_make=_BUILDING")
10995 "run_make=False"))
10996
10997 (let ((greenlet (string-append
10998 (assoc-ref inputs "python-greenlet")
10999 "/include")))
11000 (match (scandir greenlet
11001 (lambda (item)
11002 (string-prefix? "python" item)))
11003 ((python)
11004 (setenv "C_INCLUDE_PATH"
11005 (string-append greenlet "/" python ":"
11006 (or (getenv "C_INCLUDE_PATH")
11007 ""))))))
11008 #t))
11009 (add-before 'check 'pretend-to-be-CI
11010 (lambda _
11011 ;; A few tests are skipped due to network constraints or
11012 ;; get longer timeouts when running in a CI environment.
11013 ;; Piggy-back on that, as we need the same adjustments.
11014 (setenv "TRAVIS" "1")
11015 (setenv "APPVEYOR" "1")
11016 #t))
11017 (add-before 'check 'adjust-tests
11018 (lambda _
11019 (let ((disabled-tests
11020 '(;; These tests rely on networking which is not
11021 ;; available in the build container.
11022 "test_urllib2net.py"
11023 "test__server.py"
11024 "test__server_pywsgi.py"
11025 "test_socket.py"
11026 "test__socket.py"
11027 "test__socket_ssl.py"
11028 "test__socket_dns.py"
11029 "test__socket_dns6.py"
11030 "test___example_servers.py"
11031 "test__getaddrinfo_import.py"
11032 "test__examples.py"
11033 "test_httplib.py"
11034 "test_https.py"
11035 "test_urllib2_localnet.py"
11036 "test_ssl.py"
11037 "test__ssl.py"
11038 ;; XXX: These tests borrow functionality from the
11039 ;; Python builtin 'test' module, but it is not
11040 ;; installed with the Guix Python distribution.
11041 "test_smtpd.py"
11042 "test_wsgiref.py"
11043 "test_urllib2.py"
11044 "test_thread.py"
11045 "test_threading.py"
11046 "test__threading_2.py"
11047 ;; FIXME: test_patch_twice_warning_events fails for
11048 ;; no apparent reason. Needs more investigation!
11049 "test__monkey.py"
11050 ;; These tests rely on KeyboardInterrupts which do not
11051 ;; work inside the build container for some reason
11052 ;; (lack of controlling terminal?).
11053 "test_subprocess.py"
11054 "test__issues461_471.py"
11055 ;; TODO: Patch out the tests that use getprotobyname, etc
11056 ;; instead of disabling all the tests from these files.
11057 "test__all__.py"
11058 "test___config.py"
11059 "test__execmodules.py")))
11060 (call-with-output-file "skipped_tests.txt"
11061 (lambda (port)
11062 (display (string-join disabled-tests "\n") port)))
11063 #t)))
11064 (replace 'check
11065 (lambda _
11066 ;; Make sure the build directory is on PYTHONPATH.
11067 (setenv "PYTHONPATH"
11068 (string-append
11069 (getenv "PYTHONPATH") ":"
11070 (getcwd) "/build/"
11071 (car (scandir "build" (cut string-prefix? "lib." <>)))))
11072
11073 ;; Use the build daemons configured number of workers.
11074 (setenv "NWORKERS" (number->string (parallel-job-count)))
11075
11076 (invoke "python" "-m" "gevent.tests" "--config"
11077 "known_failures.py" "--ignore" "skipped_tests.txt"))))))
11078 (propagated-inputs
11079 `(("python-greenlet" ,python-greenlet)
11080 ("python-objgraph" ,python-objgraph)))
11081 (native-inputs
11082 `(("python-six" ,python-six)
11083
11084 ;; For tests.
11085 ("python-dnspython" ,python-dnspython)
11086 ("python-psutil" ,python-psutil)
11087 ("python-zope.event" ,python-zope-event)
11088 ("python-zope.interface" ,python-zope-interface)))
11089 (inputs
11090 `(("c-ares" ,c-ares)
11091 ("libev" ,libev)))
11092 (home-page "http://www.gevent.org/")
11093 (synopsis "Coroutine-based network library")
11094 (description
11095 "gevent is a coroutine-based Python networking library that uses greenlet
11096 to provide a high-level synchronous API on top of the libev event loop.")
11097 (license license:expat)
11098 (properties `((python2-variant . ,(delay python2-gevent))))))
11099
11100 (define-public python2-gevent
11101 (let ((base (package-with-python2
11102 (strip-python2-variant python-gevent))))
11103 (package
11104 (inherit base)
11105 (native-inputs `(,@(package-native-inputs base)
11106 ("python-mock" ,python2-mock))))))
11107
11108 (define-public python-fastimport
11109 (package
11110 (name "python-fastimport")
11111 (version "0.9.6")
11112 (source
11113 (origin
11114 (method url-fetch)
11115 (uri (pypi-uri "fastimport" version))
11116 (sha256
11117 (base32 "1aqjsin4rmqm7ln4j0p73fzxifws6c6ikgyhav7r137m2ixsxl43"))))
11118 (build-system python-build-system)
11119 (home-page "https://github.com/jelmer/python-fastimport")
11120 (synopsis "VCS fastimport parser and generator in Python")
11121 (description "This package provides a parser for and generator of the Git
11122 @url{https://www.kernel.org/pub/software/scm/git/docs/git-fast-import.html,fastimport}
11123 format.")
11124 (license license:gpl2+)))
11125
11126 (define-public python2-fastimport
11127 (package-with-python2 python-fastimport))
11128
11129 (define-public python-twisted
11130 (package
11131 (name "python-twisted")
11132 (version "19.7.0")
11133 (source (origin
11134 (method url-fetch)
11135 (uri (pypi-uri "Twisted" version ".tar.bz2"))
11136 (sha256
11137 (base32
11138 "17d3hnxv9qndagzz63mdpyk99xj63p9gq586vjn0rxk8cl197nym"))))
11139 (build-system python-build-system)
11140 (arguments
11141 '(#:tests? #f)) ; FIXME: some tests fail
11142 (propagated-inputs
11143 `(("python-zope-interface" ,python-zope-interface)
11144 ("python-pyhamcrest" ,python-pyhamcrest)
11145 ("python-incremental" ,python-incremental)
11146 ("python-hyperlink" ,python-hyperlink)
11147 ("python-constantly" ,python-constantly)
11148 ("python-automat" ,python-automat)))
11149 (home-page "https://twistedmatrix.com/")
11150 (synopsis "Asynchronous networking framework written in Python")
11151 (description
11152 "Twisted is an extensible framework for Python programming, with special
11153 focus on event-based network programming and multiprotocol integration.")
11154 (license license:expat)))
11155
11156 (define-public python2-twisted
11157 (package-with-python2 python-twisted))
11158
11159 (define-public python-pika
11160 (package
11161 (name "python-pika")
11162 (version "0.12.0")
11163 (source
11164 (origin
11165 (method url-fetch)
11166 (uri (pypi-uri "pika" version))
11167 (sha256
11168 (base32
11169 "0ld7akgm93s8pfa4dsx9qlzlhj76zspbr5m9ms0ns09yd2w4aq9h"))))
11170 (build-system python-build-system)
11171 (native-inputs
11172 `(("python-pyev" ,python-pyev)
11173 ("python-tornado" ,python-tornado)
11174 ("python-twisted" ,python-twisted)))
11175 (home-page "https://pika.readthedocs.org")
11176 (synopsis "Pure Python AMQP Client Library")
11177 (description
11178 "Pika is a pure-Python implementation of the AMQP (Advanced Message Queuing
11179 Protocol) 0-9-1 protocol that tries to stay fairly independent of the underlying
11180 network support library.")
11181 (license license:bsd-3)))
11182
11183 (define-public python2-pika
11184 (package-with-python2 python-pika))
11185
11186 (define-public python-ply
11187 (package
11188 (name "python-ply")
11189 (version "3.10")
11190 (source
11191 (origin
11192 (method url-fetch)
11193 (uri (pypi-uri "ply" version))
11194 (sha256
11195 (base32
11196 "1jxsr1d2f732r6ljhvm827113dckwl6qwakfvpbdhcbhvpvlmscn"))))
11197 (build-system python-build-system)
11198 (home-page "http://www.dabeaz.com/ply/")
11199 (synopsis "Python Lex & Yacc")
11200 (description "PLY is a @code{lex}/@code{yacc} implemented purely in Python.
11201 It uses LR parsing and does extensive error checking.")
11202 (license license:bsd-3)))
11203
11204 (define-public python2-ply
11205 (package-with-python2 python-ply))
11206
11207 (define-public python-tabulate
11208 (package
11209 (name "python-tabulate")
11210 (version "0.7.7")
11211 (source (origin
11212 (method url-fetch)
11213 (uri (pypi-uri "tabulate" version))
11214 (sha256
11215 (base32
11216 "1inqhspd4frxnp08c32yndr0lc4px1xfkqah184i5w09gkhvi843"))))
11217 (build-system python-build-system)
11218 (arguments
11219 ;; FIXME: The pypi release tarball is missing a 'test/common.py'
11220 ;; and the latest release is not tagged in the upstream repository.
11221 '(#:tests? #f))
11222 (home-page "https://bitbucket.org/astanin/python-tabulate")
11223 (synopsis "Pretty-print tabular data")
11224 (description
11225 "Tabulate is a library and command-line utility to pretty-print tabular
11226 data in Python.")
11227 (license license:expat)))
11228
11229 (define-public python2-tabulate
11230 (package-with-python2 python-tabulate))
11231
11232 (define-public python-kazoo
11233 (package
11234 (name "python-kazoo")
11235 (version "2.4.0")
11236 (source
11237 (origin
11238 (method url-fetch)
11239 (uri (pypi-uri "kazoo" version))
11240 (sha256
11241 (base32
11242 "16y213k7r8shyn2zw1k6lkzjgcrvm441pqv8scvcjixhvpbx3hm7"))))
11243 (build-system python-build-system)
11244 (arguments '(#:tests? #f)) ; XXX: needs zookeeper
11245 (propagated-inputs
11246 `(("python-six" ,python-six)))
11247 (home-page "https://kazoo.readthedocs.org")
11248 (synopsis "High-level Zookeeper client library")
11249 (description
11250 "Kazoo is a Python client library for the Apache Zookeeper distributed
11251 application service. It is designed to be easy to use and to avoid common
11252 programming errors.")
11253 (license license:asl2.0)))
11254
11255 (define-public python2-kazoo
11256 (package-with-python2 python-kazoo))
11257
11258 (define-public python-pykafka
11259 (package
11260 (name "python-pykafka")
11261 (version "2.4.0")
11262 (source (origin
11263 (method url-fetch)
11264 (uri (pypi-uri "pykafka" version))
11265 (sha256
11266 (base32
11267 "1id6sr159p6aa13bxcqyr9gln8sqg1l0ddzns5iws8kk5q1p5cfv"))))
11268 (build-system python-build-system)
11269 (arguments '(#:tests? #f)) ; XXX: needs zookeeper, kafka, etc.
11270 (propagated-inputs
11271 `(("python-gevent" ,python-gevent)
11272 ("python-kazoo" ,python-kazoo)
11273 ("python-tabulate" ,python-tabulate)))
11274 (inputs
11275 `(("librdkafka" ,librdkafka)))
11276 (home-page "https://pykafka.readthedocs.io/")
11277 (synopsis "Apache Kafka client for Python")
11278 (description
11279 "PyKafka is a client for the Apache Kafka distributed messaging system.
11280 It includes Python implementations of Kafka producers and consumers, which
11281 are optionally backed by a C extension built on librdkafka.")
11282 (license license:asl2.0)))
11283
11284 (define-public python2-pykafka
11285 (package-with-python2 python-pykafka))
11286
11287 (define-public python-wcwidth
11288 (package
11289 (name "python-wcwidth")
11290 (version "0.1.8")
11291 (source (origin
11292 (method url-fetch)
11293 (uri (pypi-uri "wcwidth" version))
11294 (sha256
11295 (base32
11296 "1a1pzds3xzfylm5mnc5f6c1p8kiig0daqjc9gygd9rc3cj53x2zj"))))
11297 (build-system python-build-system)
11298 (home-page "https://github.com/jquast/wcwidth")
11299 (synopsis "Measure number of terminal column cells of wide-character codes")
11300 (description "Wcwidth measures the number of terminal column cells of
11301 wide-character codes. It is useful for those implementing a terminal emulator,
11302 or programs that carefully produce output to be interpreted by one. It is a
11303 Python implementation of the @code{wcwidth} and @code{wcswidth} C functions
11304 specified in POSIX.1-2001 and POSIX.1-2008.")
11305 (license license:expat)))
11306
11307 (define-public python2-wcwidth
11308 (package-with-python2 python-wcwidth))
11309
11310 (define-public python2-jsonrpclib
11311 (package
11312 (name "python2-jsonrpclib")
11313 (version "0.1.7")
11314 (source (origin
11315 (method url-fetch)
11316 (uri (pypi-uri "jsonrpclib" version))
11317 (sha256
11318 (base32
11319 "02vgirw2bcgvpcxhv5hf3yvvb4h5wzd1lpjx8na5psdmaffj6l3z"))))
11320 (build-system python-build-system)
11321 (arguments
11322 `(#:tests? #f
11323 #:python ,python-2))
11324 (home-page "https://github.com/joshmarshall/jsonrpclib/")
11325 (synopsis "Implementation of JSON-RPC specification for Python")
11326 (description
11327 "This library is an implementation of the JSON-RPC specification.
11328 It supports both the original 1.0 specification, as well as the
11329 new (proposed) 2.0 spec, which includes batch submission, keyword arguments,
11330 etc.")
11331 (license license:asl2.0)))
11332
11333 (define-public python-chai
11334 (package
11335 (name "python-chai")
11336 (version "1.1.2")
11337 (source (origin
11338 (method url-fetch)
11339 (uri (pypi-uri "chai" version))
11340 (sha256
11341 (base32
11342 "1k6n6zbgrrs83crp6mr3yqj9zlv40b8rpisyrliwsq7naml2p3gz"))))
11343 (build-system python-build-system)
11344 (home-page "https://github.com/agoragames/chai")
11345 (synopsis "Mocking framework for Python")
11346 (description
11347 "Chai provides an api for mocking, stubbing and spying your python
11348 objects, patterned after the Mocha library for Ruby.")
11349 (license license:bsd-3)))
11350
11351 (define-public python2-chai
11352 (package-with-python2 python-chai))
11353
11354 (define-public python-inflection
11355 (package
11356 (name "python-inflection")
11357 (version "0.3.1")
11358 (source
11359 (origin (method url-fetch)
11360 (uri (pypi-uri "inflection" version))
11361 (sha256
11362 (base32
11363 "1jhnxgnw8y3mbzjssixh6qkc7a3afc4fygajhqrqalnilyvpzshq"))))
11364 (build-system python-build-system)
11365 (native-inputs
11366 `(("python-pytest" ,python-pytest)))
11367 (home-page "https://github.com/jpvanhal/inflection")
11368 (synopsis "Python string transformation library")
11369 (description
11370 "Inflection is a string transformation library. It singularizes
11371 and pluralizes English words, and transforms strings from CamelCase to
11372 underscored string.")
11373 (license license:expat)))
11374
11375 (define-public python2-inflection
11376 (package-with-python2 python-inflection))
11377
11378 (define-public python-pylev
11379 (package
11380 (name "python-pylev")
11381 (version "1.3.0")
11382 (source (origin
11383 (method url-fetch)
11384 (uri (pypi-uri "pylev" version))
11385 (sha256
11386 (base32
11387 "1hz1x9blsbxya1y9nnhnwwdnqmakxi9mc0jkwj0rn6b1h44i0f86"))))
11388 (build-system python-build-system)
11389 (home-page "https://github.com/toastdriven/pylev")
11390 (synopsis "Levenshtein distance implementation in Python")
11391 (description "Pure Python Levenshtein implementation, based off the
11392 Wikipedia code samples at
11393 @url{http://en.wikipedia.org/wiki/Levenshtein_distance}.")
11394 (license license:bsd-3)))
11395
11396 (define-public python2-pylev
11397 (package-with-python2 python-pylev))
11398
11399 (define-public python-cleo
11400 (package
11401 (name "python-cleo")
11402 (version "0.7.6")
11403 (source (origin
11404 (method url-fetch)
11405 (uri (pypi-uri "cleo" version))
11406 (sha256
11407 (base32
11408 "02dlc0rn43zgvw0s5v4j80bca9n1jfpwy3r78gn9qjgk0qj39kwr"))))
11409 (build-system python-build-system)
11410 (native-inputs
11411 `( ;; For testing
11412 ("python-mock" ,python-mock)
11413 ("python-pytest-mock" ,python-pytest-mock)
11414 ("python-pytest" ,python-pytest)))
11415 (propagated-inputs
11416 `(("python-backpack" ,python-backpack)
11417 ("python-clikit" ,python-clikit)
11418 ("python-pastel" ,python-pastel)
11419 ("python-pylev" ,python-pylev)))
11420 (home-page "https://github.com/sdispater/cleo")
11421 (synopsis "Command-line arguments library for Python")
11422 (description
11423 "Cleo allows you to create command-line commands with signature in
11424 docstring and colored output.")
11425 (license license:expat)))
11426
11427 (define-public python2-cleo
11428 (package-with-python2 python-cleo))
11429
11430 (define-public python-tomlkit
11431 (package
11432 (name "python-tomlkit")
11433 (version "0.5.11")
11434 (source
11435 (origin
11436 (method url-fetch)
11437 (uri (pypi-uri "tomlkit" version))
11438 (sha256
11439 (base32 "1kq1663iqxgwrmb883n55ypi5axnixla2hrby9g2x227asifsi7h"))))
11440 (build-system python-build-system)
11441 (native-inputs
11442 `(("python-pytest" ,python-pytest)))
11443 (home-page "https://github.com/sdispater/tomlkit")
11444 (synopsis "Style-preserving TOML library")
11445 (description
11446 "TOML Kit is a 0.5.0-compliant TOML library. It includes a parser that
11447 preserves all comments, indentations, whitespace and internal element ordering,
11448 and makes them accessible and editable via an intuitive API. It can also
11449 create new TOML documents from scratch using the provided helpers. Part of the
11450 implementation has been adapted, improved, and fixed from Molten.")
11451 (license license:expat)))
11452
11453 (define-public python-shellingham
11454 (package
11455 (name "python-shellingham")
11456 (version "1.3.1")
11457 (source
11458 (origin
11459 (method url-fetch)
11460 (uri (pypi-uri "shellingham" version))
11461 (sha256
11462 (base32
11463 "1q7kws7w4x2hji3g7y0ni9ddk4sd676ylrb3db54gbpys6xj6nwq"))))
11464 (build-system python-build-system)
11465 (home-page
11466 "https://github.com/sarugaku/shellingham")
11467 (synopsis "Tool to detect surrounding shell")
11468 (description
11469 "Shellingham detects what shell the current Python executable is
11470 running in.")
11471 (license license:isc)))
11472
11473 (define-public python-memcached
11474 (package
11475 (name "python-memcached")
11476 (version "1.59")
11477 (source
11478 (origin
11479 (method url-fetch)
11480 (uri (pypi-uri "python-memcached" version))
11481 (sha256
11482 (base32
11483 "0kvyapavbirk2x3n1jx4yb9nyigrj1s3x15nm3qhpvhkpqvqdqm2"))))
11484 (build-system python-build-system)
11485 (propagated-inputs `(("python-six" ,python-six)))
11486 (home-page
11487 "https://github.com/linsomniac/python-memcached")
11488 (synopsis "Pure python memcached client")
11489 (description
11490 "This software is a pure Python interface to the memcached memory cache
11491 daemon. It is the client side software which allows storing values in one or
11492 more, possibly remote, memcached servers.")
11493 (license license:psfl)))
11494
11495 (define-public python-clikit
11496 (package
11497 (name "python-clikit")
11498 (version "0.4.2")
11499 (source
11500 (origin
11501 (method url-fetch)
11502 (uri (pypi-uri "clikit" version))
11503 (sha256
11504 (base32
11505 "1jnnr21hvzx4i29nbph1z96ympv0njiwyvngjq48w1q05133cwzn"))))
11506 (build-system python-build-system)
11507 (propagated-inputs
11508 `(("python-pastel" ,python-pastel)
11509 ("python-pylev" ,python-pylev)))
11510 (home-page "https://github.com/sdispater/clikit")
11511 (synopsis "Group of utilities to build command line interfaces")
11512 (description
11513 "CliKit is a group of utilities to build testable command line
11514 interfaces.")
11515 (properties `((python2-variant . ,(delay python2-clikit))))
11516 (license license:expat)))
11517
11518 (define-public python2-clikit
11519 (let ((base (package-with-python2 (strip-python2-variant python-clikit))))
11520 (package/inherit
11521 base
11522 (propagated-inputs
11523 `(("python-enum34" ,python2-enum34)
11524 ("python-typing" ,python2-typing)
11525 ,@(package-propagated-inputs base))))))
11526
11527 (define-public python-msgpack-python
11528 (package
11529 (name "python-msgpack-python")
11530 (version "0.5.6")
11531 (source
11532 (origin
11533 (method url-fetch)
11534 (uri (pypi-uri "msgpack-python" version))
11535 (sha256
11536 (base32
11537 "16wh8qgybmfh4pjp8vfv78mdlkxfmcasg78lzlnm6nslsfkci31p"))))
11538 (build-system python-build-system)
11539 (home-page "http://msgpack.org/")
11540 (synopsis "Package to deserialize messages in MessagePack binary format")
11541 (description
11542 "MessagePack is an efficient binary serialization format. It lets you
11543 exchange data among multiple languages like JSON. But it's faster and
11544 smaller. Small integers are encoded into a single byte, and typical short
11545 strings require only one extra byte in addition to the strings themselves.")
11546 (license license:asl2.0)))
11547
11548 (define-public python-cachy
11549 (package
11550 (name "python-cachy")
11551 (version "0.3.0")
11552 (source
11553 (origin
11554 (method url-fetch)
11555 (uri (pypi-uri "cachy" version))
11556 (sha256
11557 (base32
11558 "1cb9naly8ampzlky7h74n5wj628l7jkpsh0c0jz0namlrvs82r8q"))))
11559 (build-system python-build-system)
11560 (arguments
11561 '(#:phases
11562 (modify-phases %standard-phases
11563 (replace 'check
11564 (lambda _ (invoke "pifpaf" "run" "memcached" "--port" "11211" "--"
11565 "pytest"))))))
11566 (native-inputs
11567 `(("memcached" ,memcached)
11568 ("python-fakeredis" ,python-fakeredis)
11569 ("python-flexmock" ,python-flexmock)
11570 ("python-pifpaf" ,python-pifpaf)
11571 ("python-pytest" ,python-pytest)))
11572 (propagated-inputs
11573 `(("python-memcached" ,python-memcached)
11574 ("python-msgpack-python" ,python-msgpack-python)
11575 ("python-redis" ,python-redis)))
11576 (home-page "https://github.com/sdispater/cachy")
11577 (synopsis "Simple yet effective caching library")
11578 (description
11579 "Cachy provides a simple yet effective caching library. A simple but
11580 powerful API: thread-safety; decorator syntax; support for memcached, redis,
11581 database, file, dict stores. Cachy supports python versions 2.7+ and 3.2+.")
11582 (license license:expat)))
11583
11584 (define-public poetry
11585 (package
11586 (name "poetry")
11587 (version "1.0.5")
11588 ;; Poetry can only be built from source with Poetry.
11589 (source
11590 (origin
11591 (method url-fetch)
11592 (uri (pypi-uri "poetry" version))
11593 (sha256
11594 (base32
11595 "02h387k0xssvv78yy82pcpknpq4w5ym2in1zl8cg9r5wljl5w6cf"))))
11596 (build-system python-build-system)
11597 (arguments
11598 `(#:tests? #f ;; Pypi does not have tests.
11599 #:phases
11600 (modify-phases %standard-phases
11601 (add-before 'build 'patch-setup-py
11602 (lambda _
11603 (substitute* "setup.py"
11604 ;; poetry won't update version as 21.0.0 relies on python > 3.6
11605 (("keyring>=20.0.1,<21.0.0") "keyring>=21.0.0,<22.0.0")
11606 (("pyrsistent>=0.14.2,<0.15.0") "pyrsistent>=0.14.2,<0.16.0")
11607 (("importlib-metadata>=1.1.3,<1.2.0") "importlib-metadata>=1.1.3,<1.5.0"))
11608 #t)))))
11609 (propagated-inputs
11610 `(("python-cachecontrol" ,python-cachecontrol)
11611 ("python-cachy" ,python-cachy)
11612 ("python-cleo" ,python-cleo)
11613 ("python-clikit" ,python-clikit)
11614 ("python-html5lib" ,python-html5lib)
11615 ("python-importlib-metadata" ,python-importlib-metadata) ;; python < 3.8
11616 ("python-jsonschema" ,python-jsonschema)
11617 ("python-keyring" ,python-keyring)
11618 ("python-pexpect" ,python-pexpect)
11619 ("python-pkginfo" ,python-pkginfo)
11620 ("python-pyparsing" ,python-pyparsing)
11621 ("python-pyrsistent" ,python-pyrsistent)
11622 ("python-requests" ,python-requests)
11623 ("python-requests-toolbelt" ,python-requests-toolbelt)
11624 ("python-shellingham" ,python-shellingham)
11625 ("python-tomlkit" ,python-tomlkit)
11626 ("python-virtualenv" ,python-virtualenv)))
11627 (home-page "https://python-poetry.org")
11628 (synopsis "Python dependency management and packaging made easy")
11629 (description "Poetry is a tool for dependency management and packaging
11630 in Python. It allows you to declare the libraries your project depends on and
11631 it will manage (install/update) them for you.")
11632 (license license:expat)))
11633
11634 (define-public python-lazy-object-proxy
11635 (package
11636 (name "python-lazy-object-proxy")
11637 (version "1.4.3")
11638 (source (origin
11639 (method url-fetch)
11640 (uri (pypi-uri "lazy-object-proxy" version))
11641 (sha256
11642 (base32
11643 "1w1aaay424ciz8fz3fkzxb0pxzfxn184f2whpyn4fx72bn50x47k"))))
11644 (native-inputs
11645 `(("python-setuptools-scm" ,python-setuptools-scm-3.3)))
11646 (build-system python-build-system)
11647 (home-page "https://github.com/ionelmc/python-lazy-object-proxy")
11648 (synopsis "Lazy object proxy for python")
11649 (description
11650 "Lazy object proxy is an object that wraps a callable but defers the call
11651 until the object is actually required, and caches the result of said call.")
11652 (license license:bsd-2)))
11653
11654 (define-public python2-lazy-object-proxy
11655 (package-with-python2 python-lazy-object-proxy))
11656
11657 (define-public python-dnspython
11658 (package
11659 (name "python-dnspython")
11660 (version "1.16.0")
11661 (source (origin
11662 (method url-fetch)
11663 (uri (string-append "http://www.dnspython.org/kits/"
11664 version "/dnspython-" version ".tar.gz"))
11665 (sha256
11666 (base32
11667 "1yaw7irazy42n0kdhlk7wyg8ki34rxcnc5xbc1wfwy245b0wbxab"))))
11668 (build-system python-build-system)
11669 (arguments '(#:tests? #f)) ; XXX: requires internet access
11670 (home-page "http://www.dnspython.org")
11671 (synopsis "DNS toolkit for Python")
11672 (description
11673 "dnspython is a DNS toolkit for Python. It supports almost all record
11674 types. It can be used for queries, zone transfers, and dynamic updates.
11675 It supports TSIG authenticated messages and EDNS0.")
11676 (license license:expat)))
11677
11678 (define-public python2-dnspython
11679 (package-with-python2 python-dnspython))
11680
11681 (define-public python-email-validator
11682 (package
11683 (name "python-email-validator")
11684 (version "1.0.2")
11685 (source
11686 (origin (method url-fetch)
11687 (uri (pypi-uri "email_validator" version))
11688 (sha256
11689 (base32
11690 "1ja9149l9ck5n45a72h3is7v476hjny5ybxbcamx1nw6iplsm7k6"))))
11691 (build-system python-build-system)
11692 (arguments
11693 '(#:phases
11694 (modify-phases %standard-phases
11695 (add-before 'build 'use-dnspython
11696 (lambda _
11697 (substitute* "setup.py"
11698 (("dnspython3") "dnspython"))
11699 #t)))))
11700 (propagated-inputs
11701 `(("python-dnspython" ,python-dnspython)
11702 ("python-idna" ,python-idna)))
11703 (home-page "https://github.com/JoshData/python-email-validator")
11704 (synopsis "Email address validation library for Python")
11705 (description
11706 "This library validates email address syntax and deliverability.")
11707 (license license:cc0)))
11708
11709 (define-public python2-email-validator
11710 (package-with-python2 python-email-validator))
11711
11712 (define-public python-ukpostcodeparser
11713 (package
11714 (name "python-ukpostcodeparser")
11715 (version "1.0.3")
11716 (source (origin
11717 (method url-fetch)
11718 (uri (pypi-uri "UkPostcodeParser" version))
11719 (sha256
11720 (base32
11721 "1jwg9z4rz51mcka1821rwgycsd0mcicyp1kiwjfa2kvg8bm9p2qd"))))
11722 (build-system python-build-system)
11723 (home-page "https://github.com/hamstah/ukpostcodeparser")
11724 (synopsis "UK Postcode parser for Python")
11725 (description
11726 "This library provides the @code{parse_uk_postcode} function for
11727 parsing UK postcodes.")
11728 (license license:expat)))
11729
11730 (define-public python2-ukpostcodeparser
11731 (package-with-python2 python-ukpostcodeparser))
11732
11733 (define-public python-faker
11734 (package
11735 (name "python-faker")
11736 (version "4.0.2")
11737 (source (origin
11738 (method url-fetch)
11739 (uri (pypi-uri "Faker" version))
11740 (sha256
11741 (base32
11742 "13qq485ydxmdnqn3xbfv1xfyqbf9qfnfw33v1vw5l6jyy9p8cgrd"))))
11743 (build-system python-build-system)
11744 (arguments
11745 '(#:phases
11746 (modify-phases %standard-phases
11747 (replace 'check
11748 (lambda _ (invoke "python" "-m" "pytest" "-v"))))))
11749 (native-inputs
11750 `(;; For testing
11751 ("python-freezegun" ,python-freezegun)
11752 ("python-pytest" ,python-pytest)
11753 ("python-random2" ,python-random2)
11754 ("python-ukpostcodeparser" ,python-ukpostcodeparser)
11755 ("python-validators" ,python-validators)))
11756 (propagated-inputs
11757 `(("python-dateutil" ,python-dateutil)
11758 ("python-text-unidecode" ,python-text-unidecode)))
11759 (home-page "https://github.com/joke2k/faker")
11760 (synopsis "Python package that generates fake data")
11761 (description
11762 "Faker is a Python package that generates fake data such as names,
11763 addresses, and phone numbers.")
11764 (license license:expat)
11765 (properties `((python2-variant . ,(delay python2-faker))))))
11766
11767 ;; Faker 4.0 dropped Python 2 support, so we stick with this older version here.
11768 (define-public python2-faker
11769 (let ((base (package-with-python2 (strip-python2-variant
11770 python-faker))))
11771 (package
11772 (inherit base)
11773 (version "3.0.1")
11774 (source (origin
11775 (method url-fetch)
11776 (uri (pypi-uri "Faker" version))
11777 (sha256
11778 (base32
11779 "11cr0qvspkdh6198rqy56qildk7bnp6llj8kyy1dan5sp5n4dxy7"))))
11780 (native-inputs
11781 `(("python-mock" ,python2-mock)
11782 ,@(package-native-inputs base)))
11783 (propagated-inputs
11784 `(("python2-ipaddress" ,python2-ipaddress)
11785 ("python2-six" ,python2-six)
11786 ,@(package-propagated-inputs base))))))
11787
11788 (define-public python-pyaml
11789 (package
11790 (name "python-pyaml")
11791 (version "18.11.0")
11792 (source (origin
11793 (method url-fetch)
11794 (uri (pypi-uri "pyaml" version))
11795 (sha256
11796 (base32
11797 "0fi604ix8lbpj1266q7js6szm771saprdzzcdwmj43wy83694qmr"))))
11798 (build-system python-build-system)
11799 (native-inputs
11800 `(("python-unidecode" ,python-unidecode)))
11801 (propagated-inputs
11802 `(("python-pyyaml" ,python-pyyaml)))
11803 (home-page "https://github.com/mk-fg/pretty-yaml")
11804 (synopsis "YAML pretty-print library for Python")
11805 (description
11806 "pyaml is a PyYAML based python module to produce pretty and readable
11807 YAML-serialized data.")
11808 (license license:wtfpl2)))
11809
11810 (define-public python2-pyaml
11811 (package-with-python2 python-pyaml))
11812
11813 (define-public python-backpack
11814 (package
11815 (name "python-backpack")
11816 (version "0.1")
11817 (source
11818 (origin
11819 (method url-fetch)
11820 (uri (pypi-uri "backpack" version))
11821 (sha256
11822 (base32
11823 "14rq1mvm0jda90lcx9gyyby9dvq4x3js2cmxvd6vl4686ixwyqh1"))))
11824 (build-system python-build-system)
11825 (native-inputs
11826 `(("python-pytest" ,python-pytest)
11827 ("python-nose" ,python-nose)))
11828 (propagated-inputs
11829 `(("python-simplejson" ,python-simplejson)))
11830 (home-page "https://github.com/sdispater/backpack")
11831 (synopsis "Utilities for working with Python collections")
11832 (description "Backpack provides some useful utilities for working with
11833 collections of data.")
11834 (license license:expat)))
11835
11836 (define-public python2-backpack
11837 (package-with-python2 python-backpack))
11838
11839 (define-public python-prompt-toolkit
11840 (package
11841 (name "python-prompt-toolkit")
11842 (version "2.0.7")
11843 (source
11844 (origin
11845 (method url-fetch)
11846 (uri (pypi-uri "prompt_toolkit" version ".tar.gz"))
11847 (sha256
11848 (base32
11849 "0fgacqk73w7s932vy46pan2yp8rvjmlkag20xvaydh9mhf6h85zx"))))
11850 (build-system python-build-system)
11851 (arguments
11852 `(#:phases
11853 (modify-phases %standard-phases
11854 (delete 'check)
11855 (add-after 'install 'post-install-check
11856 (lambda* (#:key inputs outputs #:allow-other-keys)
11857 ;; HOME is needed for the test
11858 ;; "test_pathcompleter_can_expanduser".
11859 (setenv "HOME" "/tmp")
11860 (add-installed-pythonpath inputs outputs)
11861 (invoke "py.test"))))))
11862 (propagated-inputs
11863 `(("python-wcwidth" ,python-wcwidth)
11864 ("python-six" ,python-six)
11865 ("python-pygments" ,python-pygments)))
11866 (native-inputs
11867 `(("python-pytest" ,python-pytest)))
11868 (home-page "https://github.com/jonathanslenders/python-prompt-toolkit")
11869 (synopsis "Library for building command line interfaces in Python")
11870 (description
11871 "Prompt-Toolkit is a library for building interactive command line
11872 interfaces in Python. It's like GNU Readline but it also features syntax
11873 highlighting while typing, out-of-the-box multi-line input editing, advanced
11874 code completion, incremental search, support for Chinese double-width
11875 characters, mouse support, and auto suggestions.")
11876 (license license:bsd-3)))
11877
11878 (define-public python2-prompt-toolkit
11879 (package-with-python2 python-prompt-toolkit))
11880
11881 (define-public python-prompt-toolkit-1
11882 (package (inherit python-prompt-toolkit)
11883 (version "1.0.15")
11884 (source
11885 (origin
11886 (method url-fetch)
11887 (uri (pypi-uri "prompt_toolkit" version ".tar.gz"))
11888 (sha256
11889 (base32
11890 "05v9h5nydljwpj5nm8n804ms0glajwfy1zagrzqrg91wk3qqi1c5"))))))
11891
11892 (define-public python2-prompt-toolkit-1
11893 (package-with-python2 python-prompt-toolkit-1))
11894
11895 (define-public python-jedi
11896 (package
11897 (name "python-jedi")
11898 (version "0.17.0")
11899 (source
11900 (origin
11901 (method url-fetch)
11902 (uri (pypi-uri "jedi" version))
11903 (patches (search-patches "python-jedi-sort-project-test.patch"))
11904 (sha256
11905 (base32
11906 "0c1h9x3a9klvk2g288wl328x8xgzw7136k6vs9hkd56b85vcjh6z"))))
11907 (build-system python-build-system)
11908 (arguments
11909 `(#:phases
11910 (modify-phases %standard-phases
11911 (replace 'check
11912 (lambda _
11913 (setenv "HOME" "/tmp")
11914 (invoke "python" "-m" "pytest" "-vv"))))))
11915 (native-inputs
11916 `(("python-pytest" ,python-pytest)
11917 ("python-docopt" ,python-docopt)))
11918 (propagated-inputs
11919 `(("python-parso" ,python-parso)))
11920 (home-page "https://github.com/davidhalter/jedi")
11921 (synopsis "Autocompletion and static analysis library for Python")
11922 (description
11923 "Jedi is a static analysis tool for Python that can be used in Integrated
11924 Development Environments (@dfn{IDE}s) and text editors. It understands Python
11925 on a deeper level than many other static analysis frameworks for Python.
11926
11927 Jedi understands docstrings and you can use Jedi autocompletion in your REPL as
11928 well.")
11929 (license license:expat)))
11930
11931 (define-public python2-jedi
11932 (package-with-python2 python-jedi))
11933
11934 ;; python-language-server requires 0.15 specifically. Remove once unused.
11935 (define-public python-jedi-0.15
11936 (package
11937 (inherit python-jedi)
11938 (version "0.15.2")
11939 (source (origin
11940 (method url-fetch)
11941 (uri (pypi-uri "jedi" version))
11942 (sha256
11943 (base32
11944 "01zqasl690x1i6dq4mvh13pz0cw8i276xsivsrnn00x90iqm42g9"))))
11945 (propagated-inputs
11946 `(("python-parso" ,python-parso-0.5)))))
11947
11948 (define-public ptpython
11949 (package
11950 (name "ptpython")
11951 (version "0.34")
11952 (source (origin
11953 (method url-fetch)
11954 (uri (pypi-uri "ptpython" version))
11955 (sha256
11956 (base32
11957 "1mmbiyzf0n8hm7z2a562x7w5cbl6jc0zsk6vp40q1z4cyblv1k13"))))
11958 (build-system python-build-system)
11959 (arguments
11960 '(#:tests? #f)) ; FIXME: No tests in pypi tarball.
11961 (propagated-inputs
11962 `(("python-docopt" ,python-docopt)
11963 ("python-jedi" ,python-jedi)
11964 ("python-prompt-toolkit" ,python-prompt-toolkit)
11965 ("python-pygments" ,python-pygments)))
11966 (home-page "https://github.com/jonathanslenders/ptpython")
11967 (synopsis "Python Read-Eval-Print-Loop with nice IDE-like features")
11968 (description
11969 "ptpython is a Python read-eval-print loop with IDE-like features.
11970 It supports syntax highlighting, multiline editing, autocompletion, mouse,
11971 color schemes, bracketed paste, Vi and Emacs keybindings, Chinese characters
11972 etc.")
11973 (license license:bsd-3)
11974 (properties `((python2-variant . ,(delay ptpython-2))))))
11975
11976 (define-public ptpython-2
11977 (let ((base (package-with-python2 (strip-python2-variant ptpython))))
11978 (package
11979 (inherit base)
11980 (name "ptpython2"))))
11981
11982 (define-public python-stem
11983 (package
11984 (name "python-stem")
11985 (version "1.8.0")
11986 (source
11987 (origin
11988 (method url-fetch)
11989 (uri (pypi-uri "stem" version))
11990 (sha256
11991 (base32
11992 "1hk8alc0r4m669ggngdfvryndd0fbx0w62sclcmg55af4ak8xd50"))))
11993 (build-system python-build-system)
11994 (arguments
11995 `(#:phases
11996 (modify-phases %standard-phases
11997 (replace 'check
11998 (lambda _
11999 (invoke "./run_tests.py" "--unit")
12000 #t)))))
12001 (native-inputs
12002 `(("python-mock" ,python-mock)
12003 ("python-pycodestyle" ,python-pycodestyle)
12004 ("python-pyflakes" ,python-pyflakes)))
12005 (home-page "https://stem.torproject.org/")
12006 (synopsis
12007 "Python controller library that allows applications to interact with Tor")
12008 (description
12009 "Stem is a Python controller library for Tor. With it you can use Tor's
12010 control protocol to script against the Tor process and read descriptor data
12011 relays publish about themselves.")
12012 (license license:lgpl3)))
12013
12014 (define-public python2-stem
12015 (package-with-python2 python-stem))
12016
12017 (define-public python-pyserial
12018 (package
12019 (name "python-pyserial")
12020 (version "3.4")
12021 (source
12022 (origin
12023 (method url-fetch)
12024 (uri (pypi-uri "pyserial" version))
12025 (sha256
12026 (base32
12027 "09y68bczw324a4jb9a1cfwrbjhq179vnfkkkrybbksp0vqgl0bbf"))))
12028 (build-system python-build-system)
12029 (arguments
12030 '(#:tests? #f)) ; FIXME: 3/49 tests are failing.
12031 ;; #:phases
12032 ;; (modify-phases %standard-phases
12033 ;; (replace 'check
12034 ;; (lambda _
12035 ;; (zero? (system* "python" "test/run_all_tests.py" "loop://")))))))
12036 (home-page
12037 "https://github.com/pyserial/pyserial")
12038 (synopsis "Python Serial Port Bindings")
12039 (description "@code{pyserial} provide serial port bindings for Python. It
12040 supports different byte sizes, stop bits, parity and flow control with RTS/CTS
12041 and/or Xon/Xoff. The port is accessed in RAW mode.")
12042 (license license:bsd-3)))
12043
12044 (define-public python2-pyserial
12045 (package-with-python2 python-pyserial))
12046
12047 (define-public python-kivy
12048 (package
12049 (name "python-kivy")
12050 (version "1.10.1")
12051 (source
12052 (origin
12053 (method url-fetch)
12054 (uri (pypi-uri "Kivy" version))
12055 (file-name (string-append name "-" version ".tar.gz"))
12056 (sha256
12057 (base32
12058 "1zzxjdp78hfjjiklzr82l4zwibwcq4j6kgicspqs6iyyfn5yisbw"))))
12059 (build-system python-build-system)
12060 (arguments
12061 `(#:tests? #f ; Tests require many optional packages
12062 #:phases
12063 (modify-phases %standard-phases
12064 (add-after 'patch-generated-file-shebangs 'set-sdl-paths
12065 (lambda* (#:key inputs #:allow-other-keys)
12066 (setenv "KIVY_SDL2_PATH"
12067 (string-append (assoc-ref inputs "sdl-union")
12068 "/include/SDL2"))
12069 #t)))))
12070 (native-inputs
12071 `(("pkg-config" ,pkg-config)
12072 ("python-cython" ,python-cython)))
12073 (inputs
12074 `(("gstreamer" ,gstreamer)
12075 ("mesa" ,mesa)
12076 ("sdl-union"
12077 ,(sdl-union (list sdl2 sdl2-image sdl2-mixer sdl2-ttf)))))
12078 (home-page "https://kivy.org")
12079 (synopsis
12080 "Multitouch application framework")
12081 (description
12082 "A software library for rapid development of
12083 hardware-accelerated multitouch applications.")
12084 (license license:expat)))
12085
12086 (define-public python2-kivy
12087 (package-with-python2 python-kivy))
12088
12089 (define-public python-binaryornot
12090 (package
12091 (name "python-binaryornot")
12092 (version "0.4.4")
12093 (source (origin
12094 (method url-fetch)
12095 (uri (pypi-uri "binaryornot" version))
12096 (sha256
12097 (base32
12098 "0qc006986rb6bcbmiymwgcl1mns2jphr1j7sr7nk41nlr7gh359m"))))
12099 (build-system python-build-system)
12100 (arguments
12101 `(#:phases
12102 (modify-phases %standard-phases
12103 (add-after 'unpack 'patch-tests
12104 (lambda _
12105 ;; TypeError: binary() got an unexpected keyword argument
12106 ;; 'average_size'.
12107 (substitute* "tests/test_check.py"
12108 (("average_size=512") ""))
12109 #t)))))
12110 (propagated-inputs
12111 `(("python-chardet" ,python-chardet)
12112 ("python-hypothesis" ,python-hypothesis)))
12113 (home-page "https://github.com/audreyr/binaryornot")
12114 (synopsis "Package to check if a file is binary or text")
12115 (description "Ultra-lightweight pure Python package to check if a file is
12116 binary or text.")
12117 (license license:bsd-3)
12118 (properties `((python2-variant . ,(delay python2-binaryornot))))))
12119
12120 (define-public python2-binaryornot
12121 (let ((base (package-with-python2 (strip-python2-variant python-binaryornot))))
12122 (package (inherit base)
12123 (propagated-inputs
12124 `(("python2-enum34" ,python2-enum34)
12125 ,@(package-propagated-inputs base))))))
12126
12127 (define-public python-binwalk
12128 (package
12129 (name "python-binwalk")
12130 (version "2.2.0")
12131 (source
12132 (origin
12133 (method git-fetch)
12134 (uri (git-reference
12135 (url "https://github.com/ReFirmLabs/binwalk")
12136 (commit (string-append "v" version))))
12137 (file-name (git-file-name name version))
12138 (sha256
12139 (base32
12140 "1bxgj569fzwv6jhcbl864nmlsi9x1k1r20aywjxc8b9b1zgqrlvc"))))
12141 (build-system python-build-system)
12142 (arguments
12143 `(#:phases
12144 (modify-phases %standard-phases
12145 (add-before 'check 'set-pythonpath
12146 (lambda _
12147 (setenv "PYTHONPATH"
12148 (string-append
12149 (getcwd) "/src/"
12150 ":" (getenv "PYTHONPATH")))
12151 (setenv "HOME" "")
12152 #t)))))
12153 (native-inputs
12154 `(("python-coverage" ,python-coverage)
12155 ("python-nose" ,python-nose)))
12156 (home-page "https://github.com/ReFirmLabs/binwalk")
12157 (synopsis "Firmware analysis tool")
12158 (description "Binwalk is a tool for analyzing, reverse engineering, and
12159 extracting firmware images")
12160 (license license:expat)))
12161
12162 (define-public python-nltk
12163 (package
12164 (name "python-nltk")
12165 (version "3.2.1")
12166 (source (origin
12167 (method url-fetch)
12168 (uri (pypi-uri "nltk" version))
12169 (sha256
12170 (base32
12171 "0skxbhnymwlspjkzga0f7x1hg3y50fwpfghs8g8k7fh6f4nknlym"))))
12172 (build-system python-build-system)
12173 (arguments
12174 '(;; The tests require some extra resources to be downloaded.
12175 ;; TODO Try packaging these resources.
12176 #:tests? #f))
12177 (home-page "http://nltk.org/")
12178 (synopsis "Natural Language Toolkit")
12179 (description "It provides interfaces to over 50 corpora and lexical
12180 resources such as WordNet, along with a suite of text processing libraries
12181 for classification, tokenization, stemming, tagging, parsing, and semantic
12182 reasoning, wrappers for natural language processing libraries.")
12183 (license license:asl2.0)))
12184
12185 (define-public python2-nltk
12186 (package-with-python2 python-nltk))
12187
12188 (define-public python-pymongo
12189 (package
12190 (name "python-pymongo")
12191 (version "3.7.2")
12192 (source (origin
12193 (method url-fetch)
12194 (uri (pypi-uri "pymongo" version))
12195 (sha256
12196 (base32
12197 "0zis4707r9hdg5qgkhp3wss9camr9h56ixyfc8n9dxwlnnly4x4c"))))
12198 (build-system python-build-system)
12199 (propagated-inputs
12200 `(("python-certifi" ,python-certifi)))
12201 (home-page "https://github.com/mongodb/mongo-python-driver")
12202 (synopsis "Python driver for MongoDB")
12203 (description "Python driver for MongoDB.")
12204 (license license:asl2.0)))
12205
12206 (define-public python2-pymongo
12207 (package-with-python2 python-pymongo))
12208
12209 (define-public python-consul
12210 (package
12211 (name "python-consul")
12212 (version "0.6.1")
12213 (source
12214 (origin
12215 (method url-fetch)
12216 (uri (pypi-uri "python-consul" version))
12217 (sha256
12218 (base32
12219 "0rfyxcy4cr3x848vhx876ifalxd5ghq6l5x813m49h4vq2d4jiq8"))))
12220 (build-system python-build-system)
12221 (arguments
12222 '(#:tests? #f)) ; The tests are not distributed
12223 (propagated-inputs
12224 `(("python-requests" ,python-requests)
12225 ("python-six" ,python-six)))
12226 (home-page "https://github.com/cablehead/python-consul")
12227 (synopsis "Python client for Consul")
12228 (description
12229 "Python client for @url{http://www.consul.io/,Consul}, a tool for service
12230 discovery, monitoring and configuration.")
12231 (license license:expat)))
12232
12233 (define-public python2-consul
12234 (package-with-python2 python-consul))
12235
12236 (define-public python-schematics
12237 (package
12238 (name "python-schematics")
12239 (version "1.1.1")
12240 (source
12241 (origin
12242 (method git-fetch)
12243 (uri (git-reference
12244 (url "https://github.com/schematics/schematics.git")
12245 (commit (string-append "v" version))))
12246 (file-name (git-file-name name version))
12247 (sha256
12248 (base32 "0xdqskycznqc7mfp60bhw1zq8wx7yx1dvmbq3brnm1dx3xnqa0zd"))))
12249 (build-system python-build-system)
12250 (propagated-inputs
12251 `(("python-six" ,python-six)))
12252 (arguments
12253 ;; The tests require a bunch of not very nice packages with fixed
12254 ;; version requirements (e.g. python-coveralls).
12255 `(#:tests? #f))
12256 (home-page "https://github.com/schematics/schematics")
12257 (synopsis "Python Data Structures for Humans")
12258 (description "Python Data Structures for Humans.")
12259 (license license:bsd-3)))
12260
12261 (define-public python2-schematics
12262 (package-with-python2 python-schematics))
12263
12264 (define-public python-odfpy
12265 (package
12266 (name "python-odfpy")
12267 (version "1.3.3")
12268 (source (origin
12269 (method url-fetch)
12270 (uri (pypi-uri "odfpy" version))
12271 (sha256
12272 (base32
12273 "1a6ms0w9zfhhkqhvrnynwwbxrivw6hgjc0s5k7j06npc7rq0blxw"))))
12274 (arguments
12275 `(#:modules ((srfi srfi-1)
12276 (guix build python-build-system)
12277 (guix build utils))
12278 #:phases
12279 (modify-phases %standard-phases
12280 (replace 'check
12281 ;; The test runner invokes python2 and python3 for test*.py.
12282 ;; To avoid having both in inputs, we replicate it here.
12283 (lambda _
12284 (for-each (lambda (test-file) (invoke "python" test-file))
12285 (find-files "tests" "^test.*\\.py$"))
12286 #t)))))
12287 (build-system python-build-system)
12288 (home-page "https://github.com/eea/odfpy")
12289 (synopsis "Python API and tools to manipulate OpenDocument files")
12290 (description "Collection of libraries and utility programs written in
12291 Python to manipulate OpenDocument 1.2 files.")
12292 (license
12293 ;; The software is mainly dual GPL2+ and ASL2.0, but includes a
12294 ;; number of files with other licenses.
12295 (list license:gpl2+ license:asl2.0 license:lgpl2.1+ license:cc-by-sa3.0))))
12296
12297 (define-public python2-odfpy
12298 (package-with-python2 python-odfpy))
12299
12300 (define-public python-natsort
12301 (package
12302 (name "python-natsort")
12303 (version "7.0.1")
12304 (source (origin
12305 (method url-fetch)
12306 (uri (pypi-uri "natsort" version))
12307 (sha256
12308 (base32
12309 "1ksqfai72dbcfbwx43pxl658j59mx2rvqypjy1fk0ax2qd6lccx6"))))
12310 (build-system python-build-system)
12311 (arguments
12312 `(#:modules ((guix build utils)
12313 (guix build python-build-system)
12314 (srfi srfi-1)
12315 (srfi srfi-26)
12316 (ice-9 ftw))
12317 #:phases
12318 (modify-phases %standard-phases
12319 (add-before 'check 'set-cachedir
12320 ;; Tests require write access to $HOME by default
12321 (lambda _ (setenv "PYTHON_EGG_CACHE" "/tmp") #t))
12322 (replace 'check
12323 (lambda _
12324 (let ((cwd (getcwd)))
12325 (setenv "PYTHONPATH"
12326 (string-append
12327 cwd "/build/"
12328 (find (cut string-prefix? "lib" <>)
12329 (scandir (string-append cwd "/build")))
12330 ":"
12331 (getenv "PYTHONPATH")))
12332 (invoke "pytest" "-v")))))))
12333 (native-inputs
12334 `(("python-hypothesis" ,python-hypothesis)
12335 ("python-pytest-cov" ,python-pytest-cov)
12336 ("python-pytest-mock" ,python-pytest-mock)
12337 ("python-pytest" ,python-pytest)))
12338 (propagated-inputs ; TODO: Add python-fastnumbers.
12339 `(("python-pyicu" ,python-pyicu)))
12340 (home-page "https://github.com/SethMMorton/natsort")
12341 (synopsis "Natural sorting for python and shell")
12342 (description
12343 "Natsort lets you apply natural sorting on lists instead of
12344 lexicographical. If you use the built-in @code{sorted} method in python
12345 on a list such as @code{[@code{a20}, @code{a9}, @code{a1}, @code{a4},
12346 @code{a10}]}, it would be returned as @code{[@code{a1}, @code{a10}, @code{a20},
12347 @code{a4}, @code{a9}]}. Natsort provides a function @code{natsorted} that
12348 identifies numbers and sorts them separately from strings. It can also sort
12349 version numbers, real numbers, mixed types and more, and comes with a shell
12350 command @command{natsort} that exposes this functionality in the command line.")
12351 (license license:expat)
12352 (properties `((python2-variant . ,(delay python2-natsort))))))
12353
12354 ;; Natsort 6.x are the last versions with support for Python 2.
12355 (define-public python2-natsort
12356 (let ((base (package-with-python2 (strip-python2-variant python-natsort))))
12357 (package (inherit base)
12358 (version "6.2.1")
12359 (source (origin
12360 (method url-fetch)
12361 (uri (pypi-uri "natsort" version))
12362 (sha256
12363 (base32
12364 "1mc9hbh6fv76xyz13frm7dgi05cf74f9j5wvcyjiy5234gylz565"))))
12365 (native-inputs
12366 `(("python2-pathlib" ,python2-pathlib)
12367 ,@(package-native-inputs base))))))
12368
12369 (define-public glances
12370 (package
12371 (name "glances")
12372 (version "3.1.4")
12373 (source
12374 (origin
12375 (method url-fetch)
12376 (uri (pypi-uri "Glances" version))
12377 (sha256
12378 (base32 "0dc47gbvp9a3wxppdqihxpglxxaxbj3hcvzgcxxq8zcsciah3plq"))
12379 (modules '((guix build utils)))
12380 (snippet
12381 '(begin
12382 ;; Glances phones PyPI for weekly update checks by default.
12383 ;; Disable these. The user can re-enable them if desired.
12384 (substitute* "glances/outdated.py"
12385 (("^(.*)self\\.load_config\\(config\\)\n" line indentation)
12386 (string-append indentation
12387 "self.args.disable_check_update = True\n"
12388 line)))
12389 #t))))
12390 (build-system python-build-system)
12391 (propagated-inputs
12392 `(("python-future" ,python-future)
12393 ("python-psutil" ,python-psutil)))
12394 (home-page "https://github.com/nicolargo/glances")
12395 (synopsis "Cross-platform curses-based monitoring tool")
12396 (description
12397 "Glances is a curses-based monitoring tool for a wide variety of platforms.
12398 Glances uses the PsUtil library to get information from your system. It
12399 monitors CPU, load, memory, network bandwidth, disk I/O, disk use, and more.")
12400 (license license:lgpl3+)))
12401
12402 (define-public python-glances
12403 (deprecated-package "python-glances" glances))
12404
12405 (define-public python-graphql-core
12406 (package
12407 (name "python-graphql-core")
12408 (version "0.5.3")
12409 (source
12410 (origin
12411 (method url-fetch)
12412 (uri (pypi-uri "graphql-core" version))
12413 (sha256
12414 (base32
12415 "0rsaarx2sj4xnw9966rhh4haiqaapm4lm2mfqm48ywd51j5vh1a0"))))
12416 (build-system python-build-system)
12417 (arguments
12418 `(#:tests? #f ; Tests require the unpackaged pytest-benchmark.
12419 #:phases
12420 (modify-phases %standard-phases
12421 (add-after 'unpack 'patch-hardcoded-version
12422 (lambda _ (substitute*
12423 "setup.py"
12424 (("'gevent==1.1rc1'") "'gevent'"))
12425 #t)))))
12426 (native-inputs
12427 `(("python-gevent" ,python-gevent)
12428 ("python-mock" ,python-mock)
12429 ("python-pytest-mock" ,python-pytest-mock)))
12430 (propagated-inputs
12431 `(("python-promise" ,python-promise)
12432 ("python-six" ,python-six)))
12433 (home-page "https://github.com/graphql-python/graphql-core")
12434 (synopsis "GraphQL implementation for Python")
12435 (description
12436 "GraphQL implementation for Python. GraphQL is a data query language and
12437 runtime designed and used to request and deliver data to mobile and web apps.
12438 This library is a port of @url{https://github.com/graphql/graphql-js,graphql-js}
12439 to Python.")
12440 (license license:expat)))
12441
12442 (define-public python2-graphql-core
12443 (package-with-python2 python-graphql-core))
12444
12445 (define-public python-graphql-relay
12446 (package
12447 (name "python-graphql-relay")
12448 (version "0.4.5")
12449 (source
12450 (origin
12451 (method url-fetch)
12452 (uri (pypi-uri "graphql-relay" version))
12453 (sha256
12454 (base32
12455 "1nv5dxcj59zv31qvl8bd142njmxcmymny2dz3br1l2cpbljbf5i7"))))
12456 (build-system python-build-system)
12457 (arguments
12458 '(#:tests? #f)) ; The tests are not distributed
12459 (propagated-inputs
12460 `(("python-graphql-core" ,python-graphql-core)
12461 ("python-promise" ,python-promise)
12462 ("python-six" ,python-six)))
12463 (home-page "https://github.com/graphql-python/graphql-relay-py")
12464 (synopsis "Relay implementation for Python")
12465 (description
12466 "This is a library to allow the easy creation of Relay-compliant servers
12467 using the GraphQL Python reference implementation of a GraphQL server. It
12468 should be noted that the code is a exact port of the original
12469 @url{https://github.com/graphql/graphql-relay-js,graphql-relay js implementation}
12470 from Facebook.")
12471 (license license:expat)))
12472
12473 (define-public python2-graphql-relay
12474 (package-with-python2 python-graphql-relay))
12475
12476 (define-public python-graphene
12477 (package
12478 (name "python-graphene")
12479 (version "0.10.2")
12480 (source
12481 (origin
12482 (method url-fetch)
12483 (uri (pypi-uri "graphene" version))
12484 (sha256
12485 (base32
12486 "09zhac7igh9ixdz0ay6csy35b40l1jwbf2wrbxmgxwfhy51iy06q"))))
12487 (build-system python-build-system)
12488 (propagated-inputs
12489 `(("python-graphql-core" ,python-graphql-core)
12490 ("python-graphql-relay" ,python-graphql-relay)
12491 ("python-iso8601" ,python-iso8601)
12492 ("python-promise" ,python-promise)
12493 ("python-six" ,python-six)))
12494 (arguments
12495 `(#:tests? #f)) ; no tests/ in the PyPI tarball
12496 (home-page "https://graphene-python.org/")
12497 (synopsis "GraphQL Framework for Python")
12498 (description
12499 "Graphene is a Python library for building GraphQL schemas/types.
12500 A GraphQL schema describes your data model, and provides a GraphQL server
12501 with an associated set of resolve methods that know how to fetch data.")
12502 (properties `((python2-variant . ,(delay python2-graphene))))
12503 (license license:expat)))
12504
12505 (define-public python2-graphene
12506 (let ((base (package-with-python2
12507 (strip-python2-variant python-graphene))))
12508 (package (inherit base)
12509 (native-inputs
12510 `(("python2-sqlalchemy" ,python2-sqlalchemy)
12511 ,@(package-native-inputs base))))))
12512
12513 (define-public python-nautilus
12514 (package
12515 (name "python-nautilus")
12516 (version "0.4.9")
12517 (source
12518 (origin
12519 (method url-fetch)
12520 (uri (pypi-uri "nautilus" version))
12521 (sha256
12522 (base32
12523 "01hwzjc1zshk4vvxrcghm398fpy4jls66dyz06g07mrwqif8878p"))))
12524 (build-system python-build-system)
12525 (arguments `(#:tests? #f)) ; fails to import test modules
12526 (propagated-inputs
12527 `(("python-bcrypt" ,python-bcrypt)
12528 ("python-click" ,python-click)
12529 ("python-consul" ,python-consul)
12530 ("python-graphene" ,python-graphene)
12531 ("python-jinja2" ,python-jinja2)
12532 ("python-peewee" ,python-peewee)
12533 ("python-pika" ,python-pika)
12534 ("python-tornado" ,python-tornado)
12535 ("python-wtforms" ,python-wtforms)))
12536 (native-inputs
12537 `(("python-nose2" ,python-nose2)))
12538 (home-page "https://github.com/AlecAivazis/nautilus")
12539 (synopsis "Library for creating microservice applications")
12540 (description
12541 "Nautilus is a framework for flux based microservices that looks to
12542 provide extendible implementations of common aspects of a cloud so that you can
12543 focus on building massively scalable web applications.")
12544 (license license:expat)))
12545
12546 (define-public python-random2
12547 (package
12548 (name "python-random2")
12549 (version "1.0.1")
12550 (source (origin
12551 (method url-fetch)
12552 (uri (pypi-uri "random2" version ".zip"))
12553 (sha256
12554 (base32
12555 "01y0s4747plsx8fdnxy0nz83dp69naddz58m81r9h0s1qfm31b9l"))))
12556 (build-system python-build-system)
12557 (native-inputs `(("unzip" ,unzip)))
12558 (home-page "http://pypi.python.org/pypi/random2")
12559 (synopsis "Python 3 version of the Python 2 @code{random} module")
12560 (description
12561 "This package provides a Python 3 ported version of Python 2.7’s
12562 @code{random} module. It has also been back-ported to work in Python 2.6.
12563
12564 In Python 3, the implementation of @code{randrange()} was changed, so that
12565 even with the same seed you get different sequences in Python 2 and 3.
12566
12567 This package closes that gap, allowing stable random number generation
12568 between the different Python versions.")
12569 (license license:psfl)))
12570
12571 (define-public python2-random2
12572 (package-with-python2 python-random2))
12573
12574 (define-public python-snowballstemmer
12575 (package
12576 (name "python-snowballstemmer")
12577 (version "2.0.0")
12578 (source (origin
12579 (method url-fetch)
12580 (uri (pypi-uri "snowballstemmer" version))
12581 (sha256
12582 (base32
12583 "0ligk61idlz8kkgd5hpip5whm172riwglb6xydii7h62yhysqfyz"))))
12584 (build-system python-build-system)
12585 (arguments
12586 `(;; No tests exist
12587 #:tests? #f))
12588 (home-page "https://github.com/shibukawa/snowball_py")
12589 (synopsis "Snowball stemming library collection for Python")
12590 (description "This package provides 16 word stemmer algorithms generated
12591 from Snowball algorithms. It includes the 15 original ones plus the Poerter
12592 English stemmer.")
12593 (license license:bsd-3)))
12594
12595 (define-public python2-snowballstemmer
12596 (package-with-python2 python-snowballstemmer))
12597
12598 (define-public python-setproctitle
12599 (package
12600 (name "python-setproctitle")
12601 (version "1.1.10")
12602 (source
12603 (origin
12604 (method url-fetch)
12605 (uri (pypi-uri "setproctitle" version))
12606 (sha256
12607 (base32
12608 "163kplw9dcrw0lffq1bvli5yws3rngpnvrxrzdw89pbphjjvg0v2"))))
12609 (build-system python-build-system)
12610 (arguments
12611 '(#:phases
12612 (modify-phases %standard-phases
12613 (add-before 'check 'patch-Makefile
12614 ;; Stricly this is only required for the python2 variant.
12615 ;; But adding a phase in an inherited package seems to be
12616 ;; cumbersum. So we patch even for python3.
12617 (lambda _
12618 (let ((nose (assoc-ref %build-inputs "python2-nose")))
12619 (when nose
12620 (substitute* "Makefile"
12621 (("\\$\\(PYTHON\\) [^ ]which nosetests[^ ] ")
12622 (string-append nose "/bin/nosetests "))))
12623 #t)))
12624 (replace 'check
12625 (lambda _
12626 (setenv "PYTHON" (or (which "python3") (which "python")))
12627 (setenv "PYCONFIG" (or (which "python3-config")
12628 (which "python-config")))
12629 (setenv "CC" "gcc")
12630 ;; No need to extend PYTHONPATH to find the built package, since
12631 ;; the Makefile will build anyway
12632 (invoke "make" "check"))))))
12633 (native-inputs
12634 `(("procps" ,procps))) ; required for tests
12635 (home-page
12636 "https://github.com/dvarrazzo/py-setproctitle")
12637 (synopsis
12638 "Setproctitle implementation for Python to customize the process title")
12639 (description "The library allows a process to change its title (as displayed
12640 by system tools such as ps and top).
12641
12642 Changing the title is mostly useful in multi-process systems, for
12643 example when a master process is forked: changing the children's title
12644 allows identifying the task each process is busy with. The technique
12645 is used by PostgreSQL and the OpenSSH Server for example.")
12646 (license license:bsd-3)
12647 (properties `((python2-variant . ,(delay python2-setproctitle))))))
12648
12649 (define-public python2-setproctitle
12650 (let ((base (package-with-python2
12651 (strip-python2-variant python-setproctitle))))
12652 (package
12653 (inherit base)
12654 (native-inputs `(("python2-nose" ,python2-nose)
12655 ,@(package-native-inputs base))))))
12656
12657 (define-public python-validictory
12658 (package
12659 (name "python-validictory")
12660 (version "1.0.1")
12661 (source
12662 (origin
12663 (method url-fetch)
12664 (uri (pypi-uri "validictory" version))
12665 (sha256
12666 (base32
12667 "1zf1g9sw47xzp5f80bd94pb42j9yqv82lcrgcvdwr6nkaphfi37q"))))
12668 (build-system python-build-system)
12669 (arguments
12670 '(#:phases
12671 (modify-phases %standard-phases
12672 (add-after 'unpack 'bootstrap
12673 ;; Move the tests out of the package directory to avoid
12674 ;; packaging them.
12675 (lambda* _
12676 (rename-file "validictory/tests" "tests")
12677 (delete-file "tests/__init__.py")))
12678 (replace 'check
12679 (lambda _
12680 ;; Extend PYTHONPATH so the built package will be found.
12681 (setenv "PYTHONPATH"
12682 (string-append (getcwd) "/build/lib:"
12683 (getenv "PYTHONPATH")))
12684 (invoke "py.test" "-vv" ))))))
12685 (native-inputs
12686 `(("python-pytest" ,python-pytest)))
12687 (home-page
12688 "https://github.com/jamesturk/validictory")
12689 (synopsis "General purpose Python data validator")
12690 (description "It allows validation of arbitrary Python data structures.
12691
12692 The schema format is based on the JSON Schema
12693 proposal (http://json-schema.org), so combined with json the library is also
12694 useful as a validator for JSON data.")
12695 (license license:expat)))
12696
12697 (define-public python2-validictory
12698 (package-with-python2 python-validictory))
12699
12700 (define-public python-pyelftools
12701 (package
12702 (name "python-pyelftools")
12703 (version "0.25")
12704 (source
12705 (origin
12706 (method url-fetch)
12707 (uri (pypi-uri "pyelftools" version))
12708 (sha256
12709 (base32
12710 "090vdksbz341f7ljvr0zswblw4lspa8qaiikzyjkf318arpxmil9"))))
12711 (build-system python-build-system)
12712 (arguments
12713 `(#:phases
12714 (modify-phases %standard-phases
12715 (add-before 'check 'set-pythonpath
12716 (lambda _
12717 (setenv "PYTHONPATH"
12718 (string-append
12719 (getcwd) "/test/"
12720 ":" (getenv "PYTHONPATH")))
12721 #t)))))
12722 (home-page
12723 "https://github.com/eliben/pyelftools")
12724 (synopsis
12725 "Analyze binary and library file information")
12726 (description "This Python library provides interfaces for parsing and
12727 analyzing two binary and library file formats; the Executable and Linking
12728 Format (ELF), and debugging information in the Debugging With Attributed
12729 Record Format (DWARF).")
12730 (license license:public-domain)))
12731
12732 (define-public python-pyev
12733 (package
12734 (name "python-pyev")
12735 (version "0.9.0")
12736 (source
12737 (origin
12738 (method url-fetch)
12739 (uri (pypi-uri "pyev" version))
12740 (sha256
12741 (base32
12742 "0rf603lc0s6zpa1nb25vhd8g4y337wg2wyz56i0agsdh7jchl0sx"))))
12743 (build-system python-build-system)
12744 (arguments
12745 `(#:tests? #f ; no test suite
12746 #:phases
12747 (modify-phases %standard-phases
12748 (add-after 'unpack 'patch
12749 (lambda* (#:key inputs #:allow-other-keys)
12750 (let ((libev (string-append (assoc-ref inputs "libev")
12751 "/lib/libev.so.4")))
12752 (substitute* "setup.py"
12753 (("libev_dll_name = find_library\\(\\\"ev\\\"\\)")
12754 (string-append "libev_dll_name = \"" libev "\"")))))))))
12755 (inputs
12756 `(("libev" ,libev)))
12757 (home-page "http://pythonhosted.org/pyev/")
12758 (synopsis "Python libev interface")
12759 (description "Pyev provides a Python interface to libev.")
12760 (license license:gpl3)))
12761
12762 (define-public python2-pyev
12763 (package-with-python2 python-pyev))
12764
12765 (define-public python-imagesize
12766 (package
12767 (name "python-imagesize")
12768 (version "1.2.0")
12769 (source
12770 (origin
12771 (method url-fetch)
12772 (uri (pypi-uri "imagesize" version))
12773 (sha256
12774 (base32
12775 "1cd24x0vqbd6c8ym1n21qc0aj54mfb7rzdqglmwk9xxixajbbxmi"))))
12776 (build-system python-build-system)
12777 (home-page "https://github.com/shibukawa/imagesize_py")
12778 (synopsis "Gets image size of files in various formats in Python")
12779 (description
12780 "This package allows determination of image size from
12781 PNG, JPEG, JPEG2000 and GIF files in pure Python.")
12782 (license license:expat)))
12783
12784 (define-public python2-imagesize
12785 (package-with-python2 python-imagesize))
12786
12787 (define-public python-termstyle
12788 (package
12789 (name "python-termstyle")
12790 (version "0.1.11")
12791 (source
12792 (origin
12793 (method url-fetch)
12794 (uri (pypi-uri "termstyle" version))
12795 (sha256
12796 (base32
12797 "17wzkkcqy5zc0g68xlad3kcv66iw14d2pwqc0h9420gak0vbhx7g"))))
12798 (build-system python-build-system)
12799 (arguments
12800 '(#:phases
12801 (modify-phases %standard-phases
12802 (replace 'check
12803 (lambda _
12804 (invoke "python" "test3.py"))))))
12805 (home-page "https://github.com/gfxmonk/termstyle")
12806 (synopsis "Console text coloring for Python")
12807 (description "This package provides console text coloring for Python.")
12808 (license license:bsd-3)))
12809
12810 (define-public python-argcomplete
12811 (package
12812 (name "python-argcomplete")
12813 (version "1.10.3")
12814 (source
12815 (origin
12816 (method url-fetch)
12817 (uri (pypi-uri "argcomplete" version))
12818 (sha256
12819 (base32
12820 "02jkc44drb0yjz6x28lvg6rj607n8r2irdpdvyylm8xnycn54zx3"))))
12821 (build-system python-build-system)
12822 (arguments
12823 `(#:phases
12824 (modify-phases %standard-phases
12825 (add-after 'unpack 'embed-tool-references
12826 (lambda _
12827 (substitute* "argcomplete/bash_completion.d/python-argcomplete.sh"
12828 ((" grep")
12829 (string-append " " (which "grep")))
12830 ((" egrep")
12831 (string-append " " (which "egrep")))
12832 (("elif which")
12833 (string-append "elif " (which "which")))
12834 (("\\$\\(which")
12835 (string-append "$(" (which "which"))))
12836 #t)))))
12837 (inputs
12838 `(("grep" ,grep)
12839 ("which" ,which)))
12840 (native-inputs
12841 `(("python-coverage" ,python-coverage)
12842 ("python-flake8" ,python-flake8)
12843 ("python-pexpect" ,python-pexpect)
12844 ("python-wheel" ,python-wheel)
12845 ("tcsh" ,tcsh)
12846 ("fish" ,fish)
12847 ("bash-full" ,bash))) ;full Bash for 'test_file_completion'
12848 (home-page "https://github.com/kislyuk/argcomplete")
12849 (synopsis "Shell tab completion for Python argparse")
12850 (description "argcomplete provides extensible command line tab completion
12851 of arguments and options for Python scripts using @code{argparse}. It's
12852 particularly useful for programs with many options or sub-parsers that can
12853 dynamically suggest completions; for example, when browsing resources over the
12854 network.")
12855 (license license:asl2.0)))
12856
12857 (define-public python2-argcomplete
12858 (package-with-python2 python-argcomplete))
12859
12860 (define-public python-xopen
12861 (package
12862 (name "python-xopen")
12863 (version "0.5.0")
12864 (source
12865 (origin
12866 (method url-fetch)
12867 (uri (pypi-uri "xopen" version))
12868 (sha256
12869 (base32
12870 "17xbrgi23l87yg6h0qcknssp2q812miiy33qw6v45v5gx0jwv5xh"))))
12871 (build-system python-build-system)
12872 (propagated-inputs
12873 `(("python-setuptools-scm" ,python-setuptools-scm)))
12874 (home-page "https://github.com/marcelm/xopen/")
12875 (synopsis "Open compressed files transparently")
12876 (description "This module provides an @code{xopen} function that works like
12877 Python's built-in @code{open} function, but can also deal with compressed files.
12878 Supported compression formats are gzip, bzip2 and, xz, and are automatically
12879 recognized by their file extensions. The focus is on being as efficient as
12880 possible on all supported Python versions.")
12881 (license license:expat)))
12882
12883 (define-public python2-xopen
12884 (let ((base (package-with-python2
12885 (strip-python2-variant python-xopen))))
12886 (package
12887 (inherit base)
12888 (propagated-inputs `(("python2-bz2file" ,python2-bz2file)
12889 ,@(package-propagated-inputs base))))))
12890
12891 (define-public python-cheetah
12892 (package
12893 (name "python-cheetah")
12894 (version "3.1.0")
12895 (source
12896 (origin
12897 (method url-fetch)
12898 (uri (pypi-uri "Cheetah3" version))
12899 (sha256
12900 (base32
12901 "1ihag9cxll6b86fc8v5lkhmr3brdbi4yiz16zpgw79yylmv8fgr9"))))
12902 (build-system python-build-system)
12903 (arguments
12904 `(#:modules ((guix build utils)
12905 (guix build python-build-system)
12906 (ice-9 ftw)
12907 (srfi srfi-1)
12908 (srfi srfi-26))
12909 #:phases (modify-phases %standard-phases
12910 (add-after 'unpack 'use-absolute-python
12911 (lambda _
12912 (substitute* "Cheetah/CheetahWrapper.py"
12913 (("#!/usr/bin/env python")
12914 (string-append "#!" (which "python"))))
12915 #t))
12916 (replace 'check
12917 (lambda _
12918 (let ((cwd (getcwd)))
12919 (setenv "PYTHONPATH"
12920 (string-append
12921 cwd "/build/"
12922 (find (cut string-prefix? "lib" <>)
12923 (scandir (string-append cwd "/build")))
12924 ":" (getenv "PYTHONPATH")))
12925 (setenv "PATH"
12926 (string-append (getenv "PATH")
12927 ":" cwd "/bin"))
12928 (setenv "TMPDIR" "/tmp")
12929
12930 (substitute* "Cheetah/Tests/Test.py"
12931 (("unittest.TextTestRunner\\(\\)")
12932 "unittest.TextTestRunner(verbosity=2)"))
12933
12934 (invoke "python" "Cheetah/Tests/Test.py")))))))
12935 (propagated-inputs
12936 `(("python-markdown" ,python-markdown))) ;optional
12937 (home-page "https://cheetahtemplate.org/")
12938 (synopsis "Template engine")
12939 (description "Cheetah is a text-based template engine and Python code
12940 generator.
12941
12942 Cheetah can be used as a standalone templating utility or referenced as
12943 a library from other Python applications. It has many potential uses,
12944 but web developers looking for a viable alternative to ASP, JSP, PHP and
12945 PSP are expected to be its principle user group.
12946
12947 Features:
12948 @enumerate
12949 @item Generates HTML, SGML, XML, SQL, Postscript, form email, LaTeX, or any other
12950 text-based format.
12951 @item Cleanly separates content, graphic design, and program code.
12952 @item Blends the power and flexibility of Python with a simple template language
12953 that non-programmers can understand.
12954 @item Gives template writers full access to any Python data structure, module,
12955 function, object, or method in their templates.
12956 @item Makes code reuse easy by providing an object-orientated interface to
12957 templates that is accessible from Python code or other Cheetah templates.
12958 One template can subclass another and selectively reimplement sections of it.
12959 @item Provides a simple, yet powerful, caching mechanism that can dramatically
12960 improve the performance of a dynamic website.
12961 @item Compiles templates into optimized, yet readable, Python code.
12962 @end enumerate")
12963 (license (license:x11-style "file://LICENSE"))))
12964
12965 (define-public python2-cheetah
12966 (package-with-python2 python-cheetah))
12967
12968 (define-public python-dulwich
12969 (package
12970 (name "python-dulwich")
12971 (version "0.18.6")
12972 (source
12973 (origin
12974 (method url-fetch)
12975 (uri (list (string-append "https://www.dulwich.io/releases/"
12976 "dulwich-" version ".tar.gz")
12977 (pypi-uri "dulwich" version)))
12978 (sha256
12979 (base32
12980 "1aa1xfrxkc3j9s4xi0llhf5gndyi9ryprcxsqfa5fcb8ph34981q"))))
12981 (build-system python-build-system)
12982 (arguments
12983 `(#:phases
12984 (modify-phases %standard-phases
12985 (add-before 'check 'fix-tests
12986 (lambda* (#:key inputs #:allow-other-keys)
12987 ;; The tests use Popen with a custom environment which doesn't
12988 ;; include PATH.
12989 (substitute* "dulwich/tests/compat/utils.py"
12990 (("'git'") (string-append "'"
12991 (which "git")
12992 "'")))
12993 (substitute* '("dulwich/tests/test_repository.py"
12994 "dulwich/tests/test_hooks.py")
12995 (("#!/bin/sh") (string-append "#!" (which "sh"))))
12996 (setenv "TEST_RUNNER" "unittest")
12997 (setenv "PYTHONHASHSEED" "random")
12998 #t)))))
12999 (propagated-inputs
13000 `(("python-fastimport" ,python-fastimport)))
13001 (native-inputs
13002 `(("python-mock" ,python-mock)
13003 ("python-geventhttpclient" ,python-geventhttpclient)
13004 ("git" ,git)))
13005 (home-page "https://www.dulwich.io/")
13006 (synopsis "Git implementation in Python")
13007 (description "Dulwich is an implementation of the Git file formats and
13008 protocols written in pure Python.")
13009 ;; Can be used with either license.
13010 (license (list license:asl2.0 license:gpl2+))))
13011
13012 (define-public python2-dulwich
13013 (package-with-python2 python-dulwich))
13014
13015 (define-public python-pbkdf2
13016 (package
13017 (name "python-pbkdf2")
13018 (version "1.3")
13019 (source
13020 (origin
13021 (method url-fetch)
13022 (uri (pypi-uri "pbkdf2" version))
13023 (sha256
13024 (base32
13025 "0yb99rl2mbsaamj571s1mf6vgniqh23v98k4632150hjkwv9fqxc"))))
13026 (build-system python-build-system)
13027 (arguments
13028 '(#:phases
13029 (modify-phases %standard-phases
13030 (replace 'check
13031 (lambda _
13032 (setenv "PYTHONPATH"
13033 (string-append (getcwd) "/build/lib:"
13034 (getenv "PYTHONPATH")))
13035 (invoke "python" "test/test_pbkdf2.py"))))))
13036 (propagated-inputs
13037 `(("python-pycrypto" ,python-pycrypto))) ; optional
13038 (home-page "https://www.dlitz.net/software/python-pbkdf2/")
13039 (synopsis "Password-based key derivation")
13040 (description "This module implements the password-based key derivation
13041 function, PBKDF2, specified in RSA PKCS#5 v2.0.
13042
13043 PKCS#5 v2.0 Password-Based Key Derivation is a key derivation function which
13044 is part of the RSA Public Key Cryptography Standards series. The provided
13045 implementation takes a password or a passphrase and a salt value (and
13046 optionally a iteration count, a digest module, and a MAC module) and provides
13047 a file-like object from which an arbitrarly-sized key can be read.")
13048 (license license:expat)))
13049
13050 (define-public python2-pbkdf2
13051 (package-with-python2 python-pbkdf2))
13052
13053 (define-public python-qrcode
13054 (package
13055 (name "python-qrcode")
13056 (version "6.1")
13057 (source
13058 (origin
13059 (method url-fetch)
13060 (uri (pypi-uri "qrcode" version))
13061 (sha256
13062 (base32 "0sa3n298b9jpz6zn0birnjii3mg9sihjq28n9nzjlzv09y2m6ljh"))))
13063 (build-system python-build-system)
13064 (arguments
13065 ;; FIXME: Tests require packaging 'pymaging'.
13066 '(#:tests? #f))
13067 (propagated-inputs
13068 `(("python-lxml" ,python-lxml) ; for SVG output
13069 ("python-pillow" ,python-pillow) ; for PNG output
13070 ("python-six" ,python-six)))
13071 (home-page "https://github.com/lincolnloop/python-qrcode")
13072 (synopsis "QR Code image generator")
13073 (description "This package provides a pure Python QR Code generator
13074 module. It uses the Python Imaging Library (PIL) to allow for the generation
13075 of QR Codes.
13076
13077 In addition this package provides a command line tool to generate QR codes and
13078 either write these QR codes to a file or do the output as ascii art at the
13079 console.")
13080 (license license:bsd-3)))
13081
13082 (define-public python2-qrcode
13083 (package-with-python2 python-qrcode))
13084
13085 (define-public python-rst2ansi
13086 (package
13087 (name "python-rst2ansi")
13088 (version "0.1.5")
13089 (source
13090 (origin
13091 (method url-fetch)
13092 (uri (pypi-uri "rst2ansi" version))
13093 (sha256
13094 (base32
13095 "0vzy6gd60l79ff750scl0sz48r1laalkl6md6dwzah4dcadgn5qv"))))
13096 (build-system python-build-system)
13097 (propagated-inputs
13098 `(("python-docutils" ,python-docutils)))
13099 (home-page "https://github.com/Snaipe/python-rst-to-ansi")
13100 (synopsis "Convert RST to ANSI-decorated console output")
13101 (description
13102 "Python module dedicated to rendering RST (reStructuredText) documents
13103 to ansi-escaped strings suitable for display in a terminal.")
13104 (license license:expat)))
13105
13106 (define-public python-ansi2html
13107 (package
13108 (name "python-ansi2html")
13109 (version "1.2.0")
13110 (source
13111 (origin
13112 (method url-fetch)
13113 (uri (pypi-uri "ansi2html" version))
13114 (sha256
13115 (base32
13116 "1wa00zffprb78w1mqq90dk47czz1knanys2a40zbw2vyapd5lp9y"))))
13117 (build-system python-build-system)
13118 (native-inputs
13119 `(("python-mock" ,python-mock)
13120 ("python-nose" ,python-nose)))
13121 (propagated-inputs
13122 `(("python-six" ,python-six)))
13123 (home-page "https://github.com/ralphbean/ansi2html")
13124 (synopsis "Convert ANSI-decorated console output to HTML")
13125 (description
13126 "@command{ansi2html} is a Python library and command line utility for
13127 convering text with ANSI color codes to HTML or LaTeX.")
13128 (license license:gpl3+)))
13129
13130 (define-public python2-ansi2html
13131 (package-with-python2 python-ansi2html))
13132
13133 (define-public python-ddt
13134 (package
13135 (name "python-ddt")
13136 (version "1.1.3")
13137 (source
13138 (origin
13139 (method url-fetch)
13140 (uri (pypi-uri "ddt" version))
13141 (sha256
13142 (base32
13143 "1lw17420iimhghkgzgax85nn8d1an2d6k2cfvb7j5kwn2dqlr1vk"))))
13144 (build-system python-build-system)
13145 (native-inputs
13146 `(("python-mock" ,python-mock)
13147 ("python-nose" ,python-nose)))
13148 (propagated-inputs
13149 `(("python-six" ,python-six)
13150 ("python-pyyaml" ,python-pyyaml)))
13151 (home-page "https://github.com/txels/ddt")
13152 (synopsis "Data-Driven Tests")
13153 (description
13154 "Data-Driven Tests (@dfn{DDT}) allow you to multiply one test case by
13155 running it with different test data, and make it appear as multiple test
13156 cases.")
13157 (license license:expat)))
13158
13159 (define-public python2-ddt
13160 (package-with-python2 python-ddt))
13161
13162 (define-public python-pycountry
13163 (package
13164 (name "python-pycountry")
13165 (version "18.5.26")
13166 (source
13167 (origin
13168 (method url-fetch)
13169 (uri (pypi-uri "pycountry" version))
13170 (sha256
13171 (base32
13172 "15q9j047s3yc9cfcxq1ch8b71f81na44cr6dydd5gxk0ki9a4akz"))))
13173 (build-system python-build-system)
13174 (home-page "https://bitbucket.org/flyingcircus/pycountry")
13175 (synopsis "ISO databases for languages, countries, currencies, etc.")
13176 (description
13177 "@code{pycountry} provides the ISO databases for the standards:
13178 @enumerate
13179 @item 639-3 (Languages)
13180 @item 3166 (Countries)
13181 @item 3166-3 (Deleted Countries)
13182 @item 3166-2 (Subdivisions of countries)
13183 @item 4217 (Currencies)
13184 @item 15924 (Scripts)
13185 @end enumerate
13186 It includes a copy from Debian’s pkg-isocodes and makes the data accessible
13187 through a Python API.")
13188 (license license:lgpl2.1+)))
13189
13190 (define-public python2-pycountry
13191 (package-with-python2 python-pycountry))
13192
13193 (define-public python-pycosat
13194 (package
13195 (name "python-pycosat")
13196 (version "0.6.1")
13197 (source
13198 (origin
13199 (method url-fetch)
13200 (uri (pypi-uri "pycosat" version))
13201 (sha256
13202 (base32
13203 "1kl3wh1f47rc712n4bmwplbx3fqz3x9i1b587jrbpmvdva4c8f6l"))))
13204 ;; TODO: Unundle picosat. http://fmv.jku.at/picosat/
13205 (build-system python-build-system)
13206 (home-page "https://github.com/ContinuumIO/pycosat")
13207 (synopsis "Bindings to picosat (a SAT solver)")
13208 (description
13209 "This package provides efficient Python bindings to @code{picosat} on
13210 the C level. When importing pycosat, the @code{picosat} solver becomes part
13211 of the Python process itself. @code{picosat} is a @dfn{Boolean Satisfiability
13212 Problem} (SAT) solver.")
13213 (license license:expat)))
13214
13215 (define-public python2-pycosat
13216 (package-with-python2 python-pycosat))
13217
13218 (define-public python2-ruamel.ordereddict
13219 (package
13220 (name "python2-ruamel.ordereddict")
13221 (version "0.4.9")
13222 (source
13223 (origin
13224 (method url-fetch)
13225 (uri (pypi-uri "ruamel.ordereddict" version))
13226 (sha256
13227 (base32
13228 "1xmkl8v9l9inm2pyxgc1fm5005yxm7fkd5gv74q7lj1iy5qc8n3h"))))
13229 (build-system python-build-system)
13230 (arguments
13231 `(#:python ,python-2
13232 #:phases
13233 (modify-phases %standard-phases
13234 (delete 'check)
13235 (add-after 'install 'check
13236 (lambda* (#:key inputs outputs #:allow-other-keys)
13237 (add-installed-pythonpath inputs outputs)
13238 (invoke "python" "test/testordereddict.py"))))))
13239 (home-page "https://bitbucket.org/ruamel/ordereddict")
13240 (synopsis "Version of dict that keeps keys in insertion order")
13241 (description
13242 "This is an implementation of an ordered dictionary with @dfn{Key
13243 Insertion Order} (KIO: updates of values do not affect the position of the
13244 key), @dfn{Key Value Insertion Order} (KVIO, an existing key's position is
13245 removed and put at the back). The standard library module @code{OrderedDict},
13246 implemented later, implements a subset of @code{ordereddict} functionality.
13247 Sorted dictionaries are also provided. Currently only with @dfn{Key Sorted
13248 Order} (KSO, no sorting function can be specified, but a transform can be
13249 specified to apply on the key before comparison (e.g. @code{string.lower})).")
13250 (license license:expat)))
13251
13252 (define-public python-pypeg2
13253 (package
13254 (name "python-pypeg2")
13255 (version "2.15.2")
13256 (source
13257 (origin
13258 (method url-fetch)
13259 (uri (pypi-uri "pyPEG2" version))
13260 (sha256
13261 (base32
13262 "0v8ziaam2r637v94ra4dbjw6jzxz99gs5x4i585kgag1v204yb9b"))))
13263 (build-system python-build-system)
13264 (propagated-inputs `(("python-lxml" ,python-lxml)))
13265 (arguments
13266 ;;https://bitbucket.org/fdik/pypeg/issues/36/test-failures-on-py35
13267 '(#:tests? #f))
13268 (home-page "https://fdik.org/pyPEG/")
13269 (synopsis "Parsering Expression Grammars in Python")
13270 (description "PyPEG is an intrinsic parser interpreter framework for
13271 Python. It is based on Parsing Expression Grammars, PEG. With pyPEG you can
13272 parse many formal languages.")
13273 (license license:gpl2)))
13274
13275 (define-public python-incremental
13276 (package
13277 (name "python-incremental")
13278 (version "17.5.0")
13279 (source
13280 (origin
13281 (method url-fetch)
13282 (uri (pypi-uri "incremental" version))
13283 (sha256
13284 (base32
13285 "1cylxdz1cnkm5g3pklna3h2n0i0rks95ir1pnpxfnvpkmab1cxbv"))))
13286 (build-system python-build-system)
13287 (home-page "https://github.com/hawkowl/incremental")
13288 (synopsis "Library for versioning Python projects")
13289 (description "Incremental is a small library that versions your Python
13290 projects.")
13291 (license license:expat)))
13292
13293 (define-public python2-incremental
13294 (package-with-python2 python-incremental))
13295
13296 (define-public python-invoke
13297 (package
13298 (name "python-invoke")
13299 (home-page "https://www.pyinvoke.org/")
13300 (version "1.3.0")
13301 (source (origin
13302 (method url-fetch)
13303 (uri (pypi-uri "invoke" version))
13304 (sha256
13305 (base32
13306 "1nn7gad0rvy492acpyhkrp01zsk86acf34qhsvq4xmm6x39788n5"))))
13307 (build-system python-build-system)
13308 (arguments
13309 ;; XXX: Requires many dependencies that are not yet in Guix.
13310 `(#:tests? #f))
13311 (synopsis "Pythonic task execution")
13312 (description
13313 "Invoke is a Python task execution tool and library, drawing inspiration
13314 from various sources to arrive at a powerful and clean feature set. It is
13315 evolved from the Fabric project, but focuses on local and abstract concerns
13316 instead of servers and network commands.")
13317 (license license:bsd-3)))
13318
13319 (define-public python2-invoke
13320 (package-with-python2 python-invoke))
13321
13322 (define-public python-automat
13323 (package
13324 (name "python-automat")
13325 (version "0.7.0")
13326 (source (origin
13327 (method url-fetch)
13328 (uri (pypi-uri "Automat" version))
13329 (sha256
13330 (base32
13331 "03ivg70n3b1cbcd2zvjhk8y4kmqxcvhmili39lmgx09dza1qpmyb"))))
13332 (build-system python-build-system)
13333 ;; We disable the tests because they require python-twisted, while
13334 ;; python-twisted depends on python-automat. Twisted is optional, but the
13335 ;; tests fail if it is not available. Also see
13336 ;; <https://github.com/glyph/automat/issues/71>.
13337 (arguments '(#:tests? #f))
13338 (native-inputs
13339 `(("python-m2r" ,python-m2r)
13340 ("python-setuptools-scm" ,python-setuptools-scm)
13341 ("python-graphviz" ,python-graphviz)))
13342 (propagated-inputs
13343 `(("python-six" ,python-six)
13344 ("python-attrs" ,python-attrs)))
13345 (home-page "https://github.com/glyph/Automat")
13346 (synopsis "Self-service finite-state machines")
13347 (description "Automat is a library for concise, idiomatic Python
13348 expression of finite-state automata (particularly deterministic finite-state
13349 transducers).")
13350 (license license:expat)))
13351
13352 (define-public python2-automat
13353 (package-with-python2 python-automat))
13354
13355 (define-public python-m2r
13356 (package
13357 (name "python-m2r")
13358 (version "0.2.1")
13359 (source (origin
13360 (method url-fetch)
13361 (uri (pypi-uri "m2r" version))
13362 (sha256
13363 (base32
13364 "16gdm8i06jjmlpvckpfmlkr4693dh0vs192vgsqn84fsdkbbm45z"))))
13365 (build-system python-build-system)
13366 (propagated-inputs
13367 `(("python-docutils" ,python-docutils)
13368 ("python-mistune" ,python-mistune)))
13369 (native-inputs
13370 `(("python-pygments" ,python-pygments)
13371 ("python-mock" ,python-mock)))
13372 (home-page "https://github.com/miyakogi/m2r")
13373 (synopsis "Markdown to reStructuredText converter")
13374 (description "M2R converts a markdown file including reST markups to valid
13375 reST format.")
13376 (license license:expat)))
13377
13378 (define-public python2-m2r
13379 (package-with-python2 python-m2r))
13380
13381 (define-public python-constantly
13382 (package
13383 (name "python-constantly")
13384 (version "15.1.0")
13385 (source (origin
13386 (method url-fetch)
13387 (uri (pypi-uri "constantly" version))
13388 (sha256
13389 (base32
13390 "0dgwdla5kfpqz83hfril716inm41hgn9skxskvi77605jbmp4qsq"))))
13391 (build-system python-build-system)
13392 (home-page "https://github.com/twisted/constantly")
13393 (synopsis "Symbolic constants in Python")
13394 (description "Constantly is a Python library that provides symbolic
13395 constant support. It includes collections and constants with text, numeric,
13396 and bit flag values.")
13397 (license license:expat)))
13398
13399 (define-public python2-constantly
13400 (package-with-python2 python-constantly))
13401
13402 (define-public python-attrs
13403 (package
13404 (name "python-attrs")
13405 (version "19.1.0")
13406 (source (origin
13407 (method url-fetch)
13408 (uri (pypi-uri "attrs" version))
13409 (sha256
13410 (base32
13411 "16g33zr5f449lqc5wgvzpknxryfzrfsxcr6kpgxwn7l5fkv71f7h"))))
13412 (build-system python-build-system)
13413 (arguments
13414 `(#:modules ((guix build utils)
13415 (guix build python-build-system)
13416 (ice-9 ftw)
13417 (srfi srfi-1)
13418 (srfi srfi-26))
13419 #:phases (modify-phases %standard-phases
13420 (replace 'check
13421 (lambda _
13422 (let ((cwd (getcwd)))
13423 (setenv "PYTHONPATH"
13424 (string-append
13425 cwd "/build/"
13426 (find (cut string-prefix? "lib" <>)
13427 (scandir (string-append cwd "/build")))
13428 ":"
13429 (getenv "PYTHONPATH")))
13430 (invoke "python" "-m" "pytest")))))))
13431 (native-inputs
13432 `(("python-coverage" ,python-coverage)
13433 ("python-hypothesis" ,python-hypothesis)
13434 ("python-pympler" ,python-pympler)
13435 ("python-pytest" ,python-pytest)
13436 ("python-six" ,python-six)
13437 ("python-sphinx" ,python-sphinx)
13438 ("python-zope-interface" ,python-zope-interface)))
13439 (home-page "https://github.com/python-attrs/attrs/")
13440 (synopsis "Attributes without boilerplate")
13441 (description "@code{attrs} is a Python package with class decorators that
13442 ease the chores of implementing the most common attribute-related object
13443 protocols.")
13444 (license license:expat)))
13445
13446 (define-public python2-attrs
13447 (package-with-python2 python-attrs))
13448
13449 (define-public python-attrs-bootstrap
13450 (package
13451 (inherit python-attrs)
13452 (name "python-attrs-bootstrap")
13453 (native-inputs `())
13454 (arguments `(#:tests? #f))))
13455
13456 (define-public python2-attrs-bootstrap
13457 (package-with-python2 python-attrs-bootstrap))
13458
13459 (define-public python2-cliapp
13460 (package
13461 (name "python2-cliapp")
13462 (version "1.20180812.1")
13463 (source
13464 (origin
13465 (method url-fetch)
13466 (uri (string-append
13467 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/cliapp/snapshot/cliapp-"
13468 version ".tar.gz"))
13469 (sha256
13470 (base32
13471 "1c1jlblbns8qhiaqjpg4xi6lip8xwfc5w643p43rg543havaj45x"))))
13472 (build-system python-build-system)
13473 (arguments
13474 `(#:python ,python-2
13475 #:phases
13476 (modify-phases %standard-phases
13477 ;; check phase needs to be run before the build phase. If not,
13478 ;; coverage-test-runner looks for tests for the built source files,
13479 ;; and fails.
13480 (delete 'check)
13481 (add-before 'build 'check
13482 (lambda _
13483 ;; Disable python3 tests
13484 (substitute* "check"
13485 (("python3") "# python3"))
13486 (invoke "./check"))))))
13487 (native-inputs
13488 `(("python2-coverage-test-runner" ,python2-coverage-test-runner)
13489 ("python2-pep8" ,python2-pep8)))
13490 (propagated-inputs
13491 `(("python2-pyaml" ,python2-pyaml)))
13492 (home-page "https://liw.fi/cliapp/")
13493 (synopsis "Python framework for command line programs")
13494 (description "@code{python2-cliapp} is a python framework for
13495 command line programs. It contains the typical stuff such programs
13496 need to do, such as parsing the command line for options, and
13497 iterating over input files.")
13498 (license license:gpl2+)))
13499
13500 (define-public python2-ttystatus
13501 (package
13502 (name "python2-ttystatus")
13503 (version "0.36")
13504 (source
13505 (origin
13506 (method url-fetch)
13507 (uri (string-append
13508 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/ttystatus/snapshot/ttystatus-"
13509 version ".tar.gz"))
13510 (sha256
13511 (base32
13512 "06mdk4d19zw2j3is54gndhzl396g3xc8k52m7i86z69s9hcz71by"))))
13513 (build-system python-build-system)
13514 (native-inputs
13515 `(("python2-coverage-test-runner" ,python2-coverage-test-runner)
13516 ("python2-pep8" ,python2-pep8)))
13517 (arguments
13518 `(#:python ,python-2
13519 #:phases
13520 (modify-phases %standard-phases
13521 ;; check phase needs to be run before the build phase. If not,
13522 ;; coverage-test-runner looks for tests for the built source files,
13523 ;; and fails.
13524 (delete 'check)
13525 (add-before 'build 'check
13526 (lambda _ (invoke "make" "check"))))))
13527 (home-page "https://liw.fi/ttystatus/")
13528 (synopsis "Python library for showing progress reporting and
13529 status updates on terminals")
13530 (description "@code{python2-ttystatus} is a python library for
13531 showing progress reporting and status updates on terminals, for
13532 command line programs. Output is automatically adapted to the width
13533 of the terminal: truncated if it does not fit, and resized if the
13534 terminal size changes.")
13535 (license license:gpl3+)))
13536
13537 (define-public python2-tracing
13538 (package
13539 (name "python2-tracing")
13540 (version "0.10")
13541 (source
13542 (origin
13543 (method url-fetch)
13544 (uri (string-append
13545 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/python-tracing/snapshot/tracing-"
13546 version ".tar.gz"))
13547 (sha256
13548 (base32
13549 "06cw4zg42fsvqy372vi2whj26w56vzg5axhzwdjc2bgwf03garbw"))))
13550 (build-system python-build-system)
13551 (arguments
13552 `(#:python ,python-2))
13553 (home-page "https://liw.fi/tracing/")
13554 (synopsis "Python debug logging helper")
13555 (description "@code{python2-tracing} is a python library for
13556 logging debug messages. It provides a way to turn debugging messages
13557 on and off, based on the filename they occur in. It is much faster
13558 than using @code{logging.Filter} to accomplish the same thing, which
13559 matters when code is run in production mode. The actual logging still
13560 happens using the @code{logging} library.")
13561 (license license:gpl3+)))
13562
13563 (define-public python2-larch
13564 (package
13565 (name "python2-larch")
13566 (version "1.20151025")
13567 (source
13568 (origin
13569 (method url-fetch)
13570 (uri (string-append
13571 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/larch/snapshot/larch-"
13572 version ".tar.gz"))
13573 (patches (search-patches
13574 "python2-larch-coverage-4.0a6-compatibility.patch"))
13575 (sha256
13576 (base32
13577 "1p4knkkavlqymgciz2wbcnfrdgdbafhg14maplnk4vbw0q8xs663"))))
13578 (build-system python-build-system)
13579 (arguments
13580 `(#:python ,python-2
13581 #:phases
13582 (modify-phases %standard-phases
13583 ;; check phase needs to be run before the build phase. If not,
13584 ;; coverage-test-runner looks for tests for the built source files,
13585 ;; and fails.
13586 (delete 'check)
13587 (add-before 'build 'check
13588 (lambda _ (invoke "make" "check"))))))
13589 (native-inputs
13590 `(("cmdtest" ,cmdtest)
13591 ("python2-coverage-test-runner" ,python2-coverage-test-runner)))
13592 (propagated-inputs
13593 `(("python2-tracing" ,python2-tracing)))
13594 (home-page "https://liw.fi/larch/")
13595 (synopsis "Python copy-on-write B-tree library")
13596 (description "@code{python2-larch} is an implementation of
13597 particular kind of B-tree, based on research by Ohad Rodeh. See
13598 @url{http://liw.fi/larch/ohad-btrees-shadowing-clones.pdf} for details
13599 on the data structure.
13600
13601 The distinctive feature of this B-tree is that a node is never
13602 (conceptually) modified. Instead, all updates are done by
13603 copy-on-write. This makes it easy to clone a tree, and modify only the
13604 clone, while other processes access the original tree.")
13605 (license license:gpl3+)))
13606
13607 (define-public python-astroid
13608 (package
13609 (name "python-astroid")
13610 (version "2.3.3")
13611 (source
13612 (origin
13613 (method url-fetch)
13614 (uri (pypi-uri "astroid" version))
13615 (sha256
13616 (base32 "0fnibsl2cb5mvzbfm7sycj85smx48f8w8m7ks1sqlmpr9ps0gski"))))
13617 (build-system python-build-system)
13618 (propagated-inputs
13619 `(("python-lazy-object-proxy" ,python-lazy-object-proxy)
13620 ("python-six" ,python-six)
13621 ("python-typed-ast" ,python-typed-ast)
13622 ("python-wrapt" ,python-wrapt)))
13623 (native-inputs
13624 `(("python-dateutil" ,python-dateutil)
13625 ("python-nose" ,python-nose)
13626 ("python-pytest" ,python-pytest)
13627 ("python-pytest-runner" ,python-pytest-runner)))
13628 (arguments
13629 `(#:phases
13630 (modify-phases %standard-phases
13631 (add-after 'unpack 'remove-spurious-test
13632 (lambda _
13633 ;; This can be removed after upgrading from python-3.7
13634 ;; https://github.com/PyCQA/astroid/issues/593
13635 ;; https://bugs.python.org/issue34056
13636 (delete-file "astroid/tests/unittest_modutils.py")
13637 #t))
13638 (replace 'check
13639 (lambda _
13640 (invoke "pytest" "astroid"))))))
13641 (home-page "https://github.com/PyCQA/astroid")
13642 (synopsis "Common base representation of python source code for pylint and
13643 other projects")
13644 (description "@code{python-astroid} provides a common base representation
13645 of python source code for projects such as pychecker, pyreverse, pylint, etc.
13646
13647 It provides a compatible representation which comes from the _ast module. It
13648 rebuilds the tree generated by the builtin _ast module by recursively walking
13649 down the AST and building an extended ast. The new node classes have
13650 additional methods and attributes for different usages. They include some
13651 support for static inference and local name scopes. Furthermore, astroid
13652 builds partial trees by inspecting living objects.")
13653 (license license:lgpl2.1+)
13654 (properties `((python2-variant . ,(delay python2-astroid))))))
13655
13656 (define-public python2-astroid
13657 (let ((base (package-with-python2
13658 (strip-python2-variant python-astroid))))
13659 (package (inherit base)
13660 ;; Version 2.x removes python2 support.
13661 (version "1.6.5")
13662 (source
13663 (origin
13664 (method url-fetch)
13665 (uri (pypi-uri "astroid" version))
13666 (sha256
13667 (base32
13668 "0fir4b67sm7shcacah9n61pvq313m523jb4q80sycrh3p8nmi6zw"))))
13669 (arguments
13670 (substitute-keyword-arguments (package-arguments base)
13671 ((#:phases phases)
13672 `(modify-phases ,phases
13673 (add-after 'unpack 'remove-spurious-test
13674 (lambda _
13675 ;; https://github.com/PyCQA/astroid/issues/276
13676 (delete-file "astroid/tests/unittest_brain.py")
13677 #t))
13678 (replace 'check
13679 (lambda _
13680 (invoke"python" "-m" "unittest" "discover"
13681 "-p" "unittest*.py")))))))
13682 (native-inputs `())
13683 (propagated-inputs
13684 `(("python2-backports-functools-lru-cache"
13685 ,python2-backports-functools-lru-cache)
13686 ("python2-enum34" ,python2-enum34)
13687 ("python2-singledispatch" ,python2-singledispatch)
13688 ,@(alist-delete "python-typed-ast"
13689 (package-propagated-inputs base)))))))
13690
13691 (define-public python-isort
13692 (package
13693 (name "python-isort")
13694 (version "4.3.4")
13695 (source
13696 (origin
13697 (method git-fetch)
13698 (uri (git-reference
13699 ;; Tests pass only from the Github sources
13700 (url "https://github.com/timothycrosley/isort")
13701 (commit version)))
13702 (file-name (git-file-name name version))
13703 (sha256
13704 (base32
13705 "1q0mlrpki5vjbgwxag5rghljjcfg7mvb0pbkwid80p0sqrxlm2p6"))))
13706 (build-system python-build-system)
13707 (native-inputs
13708 `(("python-mock" ,python-mock)
13709 ("python-pytest" ,python-pytest)))
13710 (home-page "https://github.com/timothycrosley/isort")
13711 (synopsis "Python utility/library to sort python imports")
13712 (description "@code{python-isort} is a python utility/library to sort
13713 imports alphabetically, and automatically separated into sections. It
13714 provides a command line utility, a python library and plugins for various
13715 editors.")
13716 (license license:expat)
13717 (properties `((python2-variant . ,(delay python2-isort))))))
13718
13719 (define-public python2-isort
13720 (let ((base (package-with-python2
13721 (strip-python2-variant python-isort))))
13722 (package (inherit base)
13723 (native-inputs
13724 `(("python2-futures" ,python2-futures)
13725 ,@(package-native-inputs base))))))
13726
13727 (define-public python2-backports-functools-lru-cache
13728 (package
13729 (name "python2-backports-functools-lru-cache")
13730 (version "1.5")
13731 (source
13732 (origin
13733 (method url-fetch)
13734 ;; only the pypi tarballs contain the necessary metadata
13735 (uri (pypi-uri "backports.functools_lru_cache" version))
13736 (sha256
13737 (base32
13738 "06jgv8gib4fhky0p5cmxdghvsgjyzcdgk48k8pxb1ccf11znk64x"))))
13739 (build-system python-build-system)
13740 (native-inputs
13741 `(("python2-setuptools-scm" ,python2-setuptools-scm)))
13742 (arguments
13743 `(#:python ,python-2))
13744 (home-page "https://github.com/jaraco/backports.functools_lru_cache")
13745 (synopsis "Backport of functools.lru_cache from Python 3.3")
13746 (description "@code{python2-backports-functools-lru-cache} is a backport
13747 of @code{functools.lru_cache} from python 3.3.")
13748 (license license:expat)))
13749
13750 (define-public python-configparser
13751 (package
13752 (name "python-configparser")
13753 (version "3.7.1")
13754 (source
13755 (origin
13756 (method url-fetch)
13757 (uri (pypi-uri "configparser" version))
13758 (sha256
13759 (base32
13760 "0cnz213il9lhgda6x70fw7mfqr8da43s3wm343lwzhqx94mgmmav"))))
13761 (build-system python-build-system)
13762 (home-page "https://github.com/jaraco/configparser/")
13763 (synopsis "Backport of configparser from python 3.5")
13764 (description "@code{python-configparser} is a backport of
13765 @code{configparser} from Python 3.5 so that it can be used directly
13766 in other versions.")
13767 (license license:expat)))
13768
13769 (define-public python2-configparser
13770 (package-with-python2 python-configparser))
13771
13772 (define-public python-mando
13773 (package
13774 (name "python-mando")
13775 (version "0.6.4")
13776 (source (origin
13777 (method url-fetch)
13778 (uri (pypi-uri "mando" version))
13779 (sha256
13780 (base32
13781 "0q6rl085q1hw1wic52pqfndr0x3nirbxnhqj9akdm5zhq2fv3zkr"))))
13782 (build-system python-build-system)
13783 (propagated-inputs
13784 `(("python-rst2ansi" ,python-rst2ansi)
13785 ("python-six" ,python-six)))
13786 (native-inputs
13787 `(("python-pytest" ,python-pytest)))
13788 (home-page "https://mando.readthedocs.org/")
13789 (synopsis
13790 "Wrapper around argparse, allowing creation of complete CLI applications")
13791 (description
13792 "This package is a wrapper around argparse, allowing you to write complete CLI
13793 applications in seconds while maintaining all the flexibility.")
13794 (license license:expat)))
13795
13796 (define-public python2-mando
13797 (package-with-python2 python-mando))
13798
13799 (define-public python2-argparse
13800 (package
13801 (name "python2-argparse")
13802 (version "1.4.0")
13803 (source
13804 (origin
13805 (method url-fetch)
13806 (uri (pypi-uri "argparse" version))
13807 (sha256
13808 (base32
13809 "1r6nznp64j68ih1k537wms7h57nvppq0szmwsaf99n71bfjqkc32"))))
13810 (build-system python-build-system)
13811 (arguments
13812 `(#:python ,python-2))
13813 (home-page "https://github.com/ThomasWaldmann/argparse/")
13814 (synopsis "Python command-line parsing library")
13815 (description
13816 "This package is mostly for people who want to have @code{argparse} on
13817 older Pythons because it was not part of the standard library back then.")
13818 (license license:psfl)))
13819
13820 (define-public python-fudge
13821 (package
13822 (name "python-fudge")
13823 ;; 0.9.6 is the latest version suitable for testing the "fabric" Python 2
13824 ;; package, which is currently the only use of this package.
13825 (version "0.9.6")
13826 (source
13827 (origin
13828 (method url-fetch)
13829 (uri (pypi-uri "fudge" version))
13830 (sha256
13831 (base32
13832 "185ia3vr3qk4f2s1a9hdxb8ci4qc0x0xidrad96pywg8j930qs9l"))))
13833 (build-system python-build-system)
13834 (arguments
13835 `(#:tests? #f)) ;XXX: Tests require the NoseJS Python package.
13836 (home-page "https://github.com/fudge-py/fudge")
13837 (synopsis "Replace real objects with fakes/mocks/stubs while testing")
13838 (description
13839 "Fudge is a Python module for using fake objects (mocks and stubs) to
13840 test real ones.
13841
13842 In readable Python code, you declare the methods available on your fake object
13843 and how they should be called. Then you inject that into your application and
13844 start testing. This declarative approach means you don’t have to record and
13845 playback actions and you don’t have to inspect your fakes after running code.
13846 If the fake object was used incorrectly then you’ll see an informative
13847 exception message with a traceback that points to the culprit.")
13848 (license license:expat)))
13849
13850 (define-public python2-fudge
13851 (package-with-python2 python-fudge))
13852
13853 (define-public python-mwclient
13854 (package
13855 (name "python-mwclient")
13856 (version "0.10.0")
13857 (source
13858 (origin
13859 (method git-fetch)
13860 ;; The PyPI version wouldn't contain tests.
13861 (uri (git-reference
13862 (url "https://github.com/mwclient/mwclient")
13863 (commit (string-append "v" version))))
13864 (file-name (git-file-name name version))
13865 (sha256
13866 (base32
13867 "1c3q6lwmb05yqywc4ya98ca7hsl15niili8rccl4n1yqp77c103v"))))
13868 (build-system python-build-system)
13869 (propagated-inputs
13870 `(("python-requests-oauthlib" ,python-requests-oauthlib)
13871 ("python-six" ,python-six)))
13872 (native-inputs
13873 `(("python-mock" ,python-mock)
13874 ("python-pytest" ,python-pytest)
13875 ("python-pytest-cov" ,python-pytest-cov)
13876 ("python-pytest-runner" ,python-pytest-runner)
13877 ("python-responses" ,python-responses)))
13878 (home-page "https://github.com/btongminh/mwclient")
13879 (synopsis "MediaWiki API client")
13880 (description "This package provides a MediaWiki API client.")
13881 (license license:expat)))
13882
13883 (define-public python2-mwclient
13884 (package-with-python2 python-mwclient))
13885
13886 (define-public python-utils
13887 (package
13888 (name "python-utils")
13889 (version "2.1.0")
13890 (source (origin
13891 (method url-fetch)
13892 (uri (pypi-uri "python-utils" version))
13893 (sha256
13894 (base32
13895 "1mcsy6q5am4ya72rgkpb6kax6vv7c93cfkkas89xnpa4sj9zf28p"))))
13896 (build-system python-build-system)
13897 (native-inputs
13898 `(("pytest-runner" ,python-pytest-runner)
13899 ("pytest" ,python-pytest)
13900 ("six" ,python-six)))
13901 (home-page "https://github.com/WoLpH/python-utils")
13902 (synopsis "Convenient utilities not included with the standard Python install")
13903 (description
13904 "Python Utils is a collection of small Python functions and classes which
13905 make common patterns shorter and easier.")
13906 (license license:bsd-2)))
13907
13908 (define-public python2-utils
13909 (package-with-python2 python-utils))
13910
13911 (define-public python-diff-match-patch
13912 (package
13913 (name "python-diff-match-patch")
13914 (version "20121119")
13915 (source
13916 (origin
13917 (method url-fetch)
13918 (uri (pypi-uri "diff-match-patch" version))
13919 (sha256
13920 (base32
13921 "0k1f3v8nbidcmmrk65m7h8v41jqi37653za9fcs96y7jzc8mdflx"))))
13922 (build-system python-build-system)
13923 (home-page "https://code.google.com/p/google-diff-match-patch")
13924 (synopsis "Synchronize plain text")
13925 (description "Diff Match and Patch libraries offer robust algorithms to
13926 perform the operations required for synchronizing plain text.")
13927 (license license:asl2.0)))
13928
13929 (define-public python2-diff-match-patch
13930 (package-with-python2 python-diff-match-patch))
13931
13932 (define-public python-dirsync
13933 (package
13934 (name "python-dirsync")
13935 (version "2.2.3")
13936 (source
13937 (origin
13938 (method url-fetch)
13939 (uri (pypi-uri "dirsync" version))
13940 (sha256
13941 (base32
13942 "1r40fkanksagcszf1ag85mdr8w7rgc7196n6s1qlsk2abw6i7v0z"))))
13943 (build-system python-build-system)
13944 (propagated-inputs
13945 `(("six" ,python-six)))
13946 (home-page "https://bitbucket.org/tkhyn/dirsync")
13947 (synopsis "Advanced directory tree synchronisation tool")
13948 (description "Advanced directory tree synchronisation tool.")
13949 (license license:expat)))
13950
13951 (define-public python2-dirsync
13952 (package-with-python2 python-dirsync))
13953
13954 (define-public python-levenshtein
13955 (package
13956 (name "python-levenshtein")
13957 (version "0.12.0")
13958 (source
13959 (origin
13960 (method url-fetch)
13961 (uri (pypi-uri "python-Levenshtein" version))
13962 (sha256
13963 (base32
13964 "1c9ybqcja31nghfcc8xxbbz9h60s9qi12b9hr4jyl69xbvg12fh3"))))
13965 (build-system python-build-system)
13966 (home-page "https://github.com/ztane/python-Levenshtein")
13967 (synopsis "Fast computation of Levenshtein distance and string similarity")
13968 (description
13969 "The Levenshtein Python C extension module contains functions for fast computation of
13970 @enumerate
13971 @item Levenshtein (edit) distance, and edit operations
13972 @item string similarity
13973 @item approximate median strings, and generally string averaging
13974 @item string sequence and set similarity
13975 @end enumerate
13976 It supports both normal and Unicode strings.")
13977 (license license:gpl2+)))
13978
13979 (define-public python2-levenshtein
13980 (package-with-python2 python-levenshtein))
13981
13982 (define-public python-scandir
13983 (package
13984 (name "python-scandir")
13985 (version "1.9.0")
13986 (source
13987 (origin
13988 (method url-fetch)
13989 (uri (pypi-uri "scandir" version))
13990 (sha256
13991 (base32 "0r3hvf1a9jm1rkqgx40gxkmccknkaiqjavs8lccgq9s8khh5x5s4"))))
13992 (build-system python-build-system)
13993 (arguments
13994 `(#:phases (modify-phases %standard-phases
13995 (replace 'check
13996 (lambda _
13997 (invoke "python" "test/run_tests.py"))))))
13998 (home-page "https://github.com/benhoyt/scandir")
13999 (synopsis "Directory iteration function")
14000 (description
14001 "Directory iteration function like os.listdir(), except that instead of
14002 returning a list of bare filenames, it yields DirEntry objects that include
14003 file type and stat information along with the name. Using scandir() increases
14004 the speed of os.walk() by 2-20 times (depending on the platform and file
14005 system) by avoiding unnecessary calls to os.stat() in most cases.
14006
14007 This package is part of the Python standard library since version 3.5.")
14008 (license license:bsd-3)))
14009
14010 (define-public python2-scandir
14011 (package-with-python2 python-scandir))
14012
14013 (define-public python2-stemming
14014 (package
14015 (name "python2-stemming")
14016 (version "1.0.1")
14017 (source
14018 (origin
14019 (method url-fetch)
14020 (uri (pypi-uri "stemming" version))
14021 (sha256
14022 (base32 "0ldwa24gnnxhniv0fhygkpc2mwgd93q10ag8rvzayv6hw418frsr"))))
14023 (build-system python-build-system)
14024 (arguments
14025 `(#:python ,python-2))
14026 (home-page "https://bitbucket.org/mchaput/stemming/overview")
14027 (synopsis "Python implementations of various stemming algorithms")
14028 (description
14029 "Python implementations of the Porter, Porter2, Paice-Husk, and Lovins
14030 stemming algorithms for English. These implementations are straightforward and
14031 efficient, unlike some Python versions of the same algorithms available on the
14032 Web. This package is an extraction of the stemming code included in the Whoosh
14033 search engine.")
14034 (license license:public-domain)))
14035
14036 (define-public python-factory-boy
14037 (package
14038 (name "python-factory-boy")
14039 (version "2.8.1")
14040 (source
14041 (origin
14042 (method url-fetch)
14043 (uri (pypi-uri "factory_boy" version))
14044 (sha256
14045 (base32 "1fvin6san5xsjh2c4y18caj2lnmwxlylyqm8mh1yc6rp38wlwr56"))))
14046 (build-system python-build-system)
14047 (arguments
14048 ;; Tests are not included in the tarball.
14049 `(#:tests? #f))
14050 (propagated-inputs
14051 `(("faker" ,python-faker)))
14052 (home-page "https://github.com/benhoyt/scandir")
14053 (synopsis "Versatile test fixtures replacement")
14054 (description
14055 "Factory_boy is a fixtures replacement based on thoughtbot’s factory_girl.
14056
14057 As a fixtures replacement tool, it aims to replace static, hard to maintain
14058 fixtures with easy-to-use factories for complex object.
14059
14060 Instead of building an exhaustive test setup with every possible combination
14061 of corner cases, factory_boy allows you to use objects customized for the
14062 current test, while only declaring the test-specific fields")
14063 (license license:expat)))
14064
14065 (define-public python2-factory-boy
14066 (package-with-python2 python-factory-boy))
14067
14068 (define-public python-translate-toolkit
14069 (package
14070 (name "python-translate-toolkit")
14071 (version "2.1.0")
14072 (source
14073 (origin
14074 (method url-fetch)
14075 (uri (pypi-uri "translate-toolkit" version ".tar.bz2"))
14076 (sha256
14077 (base32 "1vlkwrg83vb17jc36pmwh2b7jphwf390lz0jw8hakcg16qhwypvq"))))
14078 (build-system python-build-system)
14079 (native-inputs
14080 `(("python-pytest" ,python-pytest)
14081 ("python-sphinx" ,python-sphinx)))
14082 (propagated-inputs
14083 `(("python-babel" ,python-babel)
14084 ("python-beautifulsoup4" ,python-beautifulsoup4)
14085 ("python-chardet" ,python-chardet)
14086 ("python-diff-match-patch" ,python-diff-match-patch)
14087 ("python-levenshtein" ,python-levenshtein)
14088 ("python-lxml" ,python-lxml)
14089 ("python-six" ,python-six)
14090 ("python-vobject" ,python-vobject)
14091 ("python-pyyaml" ,python-pyyaml)))
14092 (arguments
14093 ;; TODO: tests are not run, because they end with
14094 ;; TypeError: parse() missing 2 required positional arguments: 'tree' and
14095 ;; 'parse_funcs'
14096 ;; during test setup.
14097 `(#:tests? #f))
14098 (home-page "https://toolkit.translatehouse.org")
14099 (synopsis "Tools and API for translation and localization engineering")
14100 (description
14101 "Tools and API for translation and localization engineering. It contains
14102 several utilities, as well as an API for building localization tools.")
14103 (license license:gpl2+)))
14104
14105 (define-public python2-translate-toolkit
14106 (package-with-python2 python-translate-toolkit))
14107
14108 (define-public python-packaging
14109 (package
14110 (name "python-packaging")
14111 (version "20.0")
14112 (source
14113 (origin
14114 (method url-fetch)
14115 (uri (pypi-uri "packaging" version))
14116 ;; XXX: The URL in the patch file is wrong, it should be
14117 ;; <https://github.com/pypa/packaging/pull/256>.
14118 (patches (search-patches "python-packaging-test-arch.patch"))
14119 (sha256
14120 (base32
14121 "1y2ip3a4ykkpgnwgn85j6hkspcl0cg3mzms97f40mk57vwqq67gy"))))
14122 (build-system python-build-system)
14123 (arguments
14124 `(#:phases (modify-phases %standard-phases
14125 (replace 'check
14126 (lambda _ (invoke "py.test" "-vv"))))))
14127 (native-inputs
14128 `(("python-pretend" ,python-pretend)
14129 ("python-pytest" ,python-pytest)))
14130 (propagated-inputs
14131 `(("python-pyparsing" ,python-pyparsing)
14132 ("python-six" ,python-six)))
14133 (home-page "https://github.com/pypa/packaging")
14134 (synopsis "Core utilities for Python packages")
14135 (description "Packaging is a Python module for dealing with Python packages.
14136 It offers an interface for working with package versions, names, and dependency
14137 information.")
14138 ;; From 'LICENSE': This software is made available under the terms of
14139 ;; *either* of the licenses found in LICENSE.APACHE or LICENSE.BSD.
14140 ;; Contributions to this software is made under the terms of *both* these
14141 ;; licenses.
14142 (license (list license:asl2.0 license:bsd-2))))
14143
14144 (define-public python2-packaging
14145 (package-with-python2 python-packaging))
14146
14147 (define-public python-relatorio
14148 (package
14149 (name "python-relatorio")
14150 (version "0.8.0")
14151 (source
14152 (origin
14153 (method url-fetch)
14154 (uri (pypi-uri "relatorio" version))
14155 (sha256
14156 (base32
14157 "1na6hlhz1awi1hbjg1gyclq0khz42iz90wvdjw7mmj655788bpxx"))))
14158 (build-system python-build-system)
14159 (propagated-inputs
14160 `(("python-lxml" ,python-lxml)
14161 ("python-genshi" ,python-genshi)))
14162 (native-inputs
14163 `(("python-magic" ,python-magic)))
14164 (home-page "https://relatorio.tryton.org/")
14165 (synopsis "Templating library able to output ODT and PDF files")
14166 (description "Relatorio is a templating library which provides a way to
14167 easily output ODT, ODS, PNG, SVG and several other kinds of files. Support
14168 for more filetypes can be easily added by creating plugins for them.")
14169 (license license:gpl3+)))
14170
14171 (define-public python2-relatorio
14172 (package-with-python2 python-relatorio))
14173
14174 (define-public python-radon
14175 (package
14176 (name "python-radon")
14177 (version "4.1.0")
14178 (source
14179 (origin
14180 (method url-fetch)
14181 (uri (pypi-uri "radon" version))
14182 (sha256
14183 (base32
14184 "0vfxxzbnz5lxfvp0yxp35g6c8qqnnbhi4dm7shkm1d3d4192q22n"))))
14185 (build-system python-build-system)
14186 (arguments
14187 `(#:phases (modify-phases %standard-phases
14188 (replace 'check
14189 (lambda _
14190 (invoke "python" "radon/tests/run.py"))))))
14191 (propagated-inputs
14192 `(("python-colorama" ,python-colorama)
14193 ("python-flake8-polyfill" ,python-flake8-polyfill)
14194 ("python-mando" ,python-mando)))
14195 (native-inputs
14196 `(("python-pytest" ,python-pytest)
14197 ("python-pytest-mock" ,python-pytest-mock)))
14198 (home-page "https://radon.readthedocs.org/")
14199 (synopsis "Code Metrics in Python")
14200 (description "Radon is a Python tool which computes various code metrics.
14201 Supported metrics are:
14202 @itemize @bullet
14203 @item raw metrics: SLOC, comment lines, blank lines, &c.
14204 @item Cyclomatic Complexity (i.e. McCabe’s Complexity)
14205 @item Halstead metrics (all of them)
14206 @item the Maintainability Index (a Visual Studio metric)
14207 @end itemize")
14208 (properties `((python2-variant . ,(delay python2-radon))))
14209 (license license:expat)))
14210
14211 (define-public python2-radon
14212 (let ((base (package-with-python2 (strip-python2-variant python-radon))))
14213 (package
14214 (inherit base)
14215 (propagated-inputs
14216 `(("python-configparser" ,python2-configparser)
14217 ("python-future" ,python2-future)
14218 ,@(package-propagated-inputs base))))))
14219
14220 (define-public python-sure
14221 (package
14222 (name "python-sure")
14223 (version "1.4.11")
14224 (source
14225 (origin
14226 (method url-fetch)
14227 (uri (pypi-uri "sure" version))
14228 (sha256
14229 (base32
14230 "1and0drq8w9iplsic22n2h7hkpyq03a1mbqk4sgcdqhqzdqm539w"))))
14231 (build-system python-build-system)
14232 (propagated-inputs
14233 `(("python-mock" ,python-mock)
14234 ("python-six" ,python-six)))
14235 (native-inputs
14236 `(("python-nose" ,python-nose)))
14237 (home-page "https://github.com/gabrielfalcao/sure")
14238 (synopsis "Automated testing library in python for python")
14239 (description
14240 "Sure is a python library that leverages a DSL for writing assertions.
14241 Sure is heavily inspired by @code{RSpec Expectations} and @code{should.js}.")
14242 (license license:gpl3+)))
14243
14244 (define-public python2-sure
14245 (package-with-python2 python-sure))
14246
14247 (define-public python2-couleur
14248 ;; This package does not seem to support python3 at all, hence,
14249 ;; only the python2 variant definition is provided.
14250 (package
14251 (name "python2-couleur")
14252 (version "0.6.2")
14253 (source
14254 (origin
14255 (method url-fetch)
14256 (uri (pypi-uri "couleur" version))
14257 (sha256
14258 (base32
14259 "1qqaxyqz74wvid0cr119dhcwz0h0if5b5by44zl49pd5z65v58k1"))))
14260 (build-system python-build-system)
14261 (arguments
14262 `(#:python ,python-2))
14263 (home-page "https://github.com/gabrielfalcao/couleur")
14264 (synopsis
14265 "ANSI terminal tool for python, colored shell and other handy fancy features")
14266 (description
14267 "@code{Couleur} provides python programs a way to use the ANSI features in a unix
14268 terminal such as coloured output in the shell, overwriting output, indentation, etc.")
14269 ;; README.md says ASL2.0, but all source code headers are LGPL3+.
14270 ;; https://github.com/gabrielfalcao/couleur/issues/11
14271 (license license:lgpl3+)))
14272
14273 (define-public python-misaka
14274 (package
14275 (name "python-misaka")
14276 (version "2.1.1")
14277 (source
14278 (origin
14279 (method url-fetch)
14280 (uri (pypi-uri "misaka" version))
14281 (sha256
14282 (base32
14283 "1mzc29wwyhyardclj1vg2xsfdibg2lzb7f1azjcxi580ama55wv2"))))
14284 (build-system python-build-system)
14285 (arguments
14286 `(;; Line 37 of setup.py calls self.run_command('develop')
14287 ;; in the 'check' phase. This command seems to be trying
14288 ;; to write to
14289 ;; /gnu/store/...-python-<version>/lib/python<version>/site-packages/
14290 ;; for which it does not have the permission to write.
14291 #:tests? #f))
14292 (propagated-inputs
14293 `(("python-cffi" ,python-cffi)))
14294 (home-page "https://github.com/FSX/misaka")
14295 (synopsis "Python binding for Hoedown")
14296 (description
14297 "@code{Misaka} is a CFFI-based binding for @code{Hoedown}, a fast markdown processing
14298 library written in C. It features a fast HTML renderer and functionality to make custom
14299 renderers (e.g. man pages or LaTeX).")
14300 (license license:expat)))
14301
14302 (define-public python2-misaka
14303 (package-with-python2 python-misaka))
14304
14305 (define-public python2-steadymark
14306 ;; This is forced into being a python2 only variant
14307 ;; due to its dependence on couleur that has no support
14308 ;; for python3
14309 (package
14310 (name "python2-steadymark")
14311 (version "0.7.3")
14312 (source
14313 (origin
14314 (method url-fetch)
14315 (uri (pypi-uri "steadymark" version))
14316 (sha256
14317 (base32
14318 "1640i9g8dycql3cc8j0bky0jkzj0q39blfbp4lsgpkprkfgcdk8v"))))
14319 (build-system python-build-system)
14320 (native-inputs
14321 `(("python-couleur" ,python2-couleur)
14322 ("python-sure" ,python2-sure)
14323 ("python-misaka" ,python2-misaka)))
14324 (arguments
14325 `(#:python ,python-2
14326 #:phases
14327 (modify-phases %standard-phases
14328 (add-before 'build 'patch-setup-py
14329 (lambda _
14330 ;; Update requirements from dependency==version
14331 ;; to dependency>=version
14332 (substitute* "setup.py"
14333 (("==") ">="))
14334 #t)))))
14335 (home-page "https://github.com/gabrielfalcao/steadymark")
14336 (synopsis "Markdown-based test runner for python")
14337 (description
14338 "@code{Steadymark} allows documentation to be written in github-flavoured
14339 markdown. The documentation may contain snippets of code surrounded by python
14340 code blocks and @code{Steadymark} will find these snippets and run them, making
14341 sure that there are no old malfunctional examples in the documentation examples.")
14342 (license license:expat)))
14343
14344 (define-public python-jsonpointer
14345 (package
14346 (name "python-jsonpointer")
14347 (version "1.10")
14348 (source
14349 (origin
14350 (method url-fetch)
14351 (uri (pypi-uri "jsonpointer" version))
14352 (sha256
14353 (base32
14354 "1cg0gvgqjysydv6p45v4jywg1jb3v48c7m3cbpi57zgf6nndr9cz"))))
14355 (build-system python-build-system)
14356 (home-page "https://github.com/stefankoegl/python-json-pointer")
14357 (synopsis "Identify specific nodes in a JSON document")
14358 (description "@code{jsonpointer} allows you to access specific nodes
14359 by path in a JSON document (see RFC 6901).")
14360 (license license:bsd-3)))
14361
14362 (define-public python2-jsonpointer
14363 (package-with-python2 python-jsonpointer))
14364
14365 (define-public python-jsonpatch
14366 (package
14367 (name "python-jsonpatch")
14368 (version "1.16")
14369 (source
14370 (origin
14371 (method git-fetch)
14372 ;; pypi version lacks tests.js
14373 (uri (git-reference
14374 (url "https://github.com/stefankoegl/python-json-patch")
14375 (commit (string-append "v" version))))
14376 (file-name (git-file-name name version))
14377 (sha256
14378 (base32
14379 "0k9pff06lxama3nhsc7cdxbp83422bdy8ifs52i6xkas8hpyzfzr"))))
14380 (build-system python-build-system)
14381 (native-inputs
14382 `(("python-jsonpointer" ,python-jsonpointer)))
14383 (home-page "https://github.com/stefankoegl/python-json-patch")
14384 (synopsis "Applying JSON Patches in Python 2.6+ and 3.x")
14385 (description "@code{jsonpatch} is a library and program that allows
14386 applying JSON Patches according to RFC 6902.")
14387 (license license:bsd-3)))
14388
14389 (define-public python2-jsonpatch
14390 (package-with-python2 python-jsonpatch))
14391
14392 (define-public python-jsonpatch-0.4
14393 (package (inherit python-jsonpatch)
14394 (name "python-jsonpatch")
14395 (version "0.4")
14396 (source
14397 (origin
14398 (method git-fetch)
14399 (uri (git-reference
14400 (url "https://github.com/stefankoegl/python-json-patch")
14401 (commit (string-append "v" version))))
14402 (file-name (git-file-name name version))
14403 (sha256
14404 (base32
14405 "1fq02y57kinyknxjcav0slcb0k9mwdffqw2hnlhdkpj7palh2mwk"))))))
14406
14407 (define-public python2-jsonpatch-0.4
14408 (package-with-python2 python-jsonpatch-0.4))
14409
14410 (define-public python-rfc3986
14411 (package
14412 (name "python-rfc3986")
14413 (version "1.1.0")
14414 (source (origin
14415 (method url-fetch)
14416 (uri (pypi-uri "rfc3986" version))
14417 (sha256
14418 (base32
14419 "06wlmysw83f75ff84zr1yr6n0shvc2xn1n1sb4iwzqap9hf5fn44"))))
14420 (build-system python-build-system)
14421 (arguments
14422 `(#:modules ((guix build utils)
14423 (guix build python-build-system)
14424 (ice-9 ftw)
14425 (srfi srfi-1)
14426 (srfi srfi-26))
14427 #:phases
14428 (modify-phases %standard-phases
14429 (replace 'check
14430 (lambda _
14431 (let ((cwd (getcwd)))
14432 (setenv "PYTHONPATH"
14433 (string-append cwd "/build/"
14434 (find (cut string-prefix? "lib" <>)
14435 (scandir (string-append cwd "/build")))
14436 ":"
14437 (getenv "PYTHONPATH")))
14438 (invoke "pytest" "-v")))))))
14439 (native-inputs
14440 `(("python-pytest" ,python-pytest)))
14441 (home-page "https://rfc3986.readthedocs.io/")
14442 (synopsis "Parse and validate URI references")
14443 (description
14444 "@code{rfc3986} is a Python implementation of RFC@tie{}3986 including
14445 validation and authority parsing. This module also supports RFC@tie{}6874
14446 which adds support for zone identifiers to IPv6 addresses.")
14447 (license license:asl2.0)))
14448
14449 (define-public python2-rfc3986
14450 (package-with-python2 python-rfc3986))
14451
14452 (define-public python-rfc3987
14453 (package
14454 (name "python-rfc3987")
14455 (version "1.3.7")
14456 (source
14457 (origin
14458 (method url-fetch)
14459 (uri (pypi-uri "rfc3987" version))
14460 (sha256
14461 (base32
14462 "192pclzs2y0yaywqkrlvd0x73740q310kvqvm6jldhi619mq59wi"))))
14463 (build-system python-build-system)
14464 (home-page "https://pypi.org/project/rfc3987/")
14465 (synopsis "Parsing and validation of URIs (RFC 3986) and IRIs (RFC 3987)")
14466 (description "@code{rfc3987} provides routines for parsing and
14467 validation of URIs (see RFC 3986) and IRIs (see RFC 3987).")
14468 (license license:gpl3+)))
14469
14470 (define-public python2-rfc3987
14471 (package-with-python2 python-rfc3987))
14472
14473 (define-public python-validators
14474 (package
14475 (name "python-validators")
14476 (version "0.14.2")
14477 (source (origin
14478 (method url-fetch)
14479 (uri (pypi-uri "validators" version))
14480 (sha256
14481 (base32
14482 "024m15j33szd0v8k5l4ccish6n0b4knq81gmb4fq25ynwyyyd4mi"))))
14483 (build-system python-build-system)
14484 (arguments
14485 '(#:phases (modify-phases %standard-phases
14486 (replace 'check
14487 (lambda _
14488 (invoke "pytest" "-vv"))))))
14489 (propagated-inputs
14490 `(("python-decorator" ,python-decorator)
14491 ("python-six" ,python-six)))
14492 (native-inputs
14493 `(("python-flake8" ,python-flake8)
14494 ("python-isort" ,python-isort)
14495 ("python-pytest" ,python-pytest)))
14496 (home-page "https://github.com/kvesteri/validators")
14497 (synopsis "Data validation library")
14498 (description
14499 "This package contains validators for different things such as email
14500 addresses, IP addresses, URLs, hashes and more. It has been designed to
14501 be easy to use and not require defining a schema or form just to validate
14502 some input.")
14503 (license license:expat)))
14504
14505 (define-public python2-validators
14506 (package-with-python2 python-validators))
14507
14508 (define-public python-validate-email
14509 (package
14510 (name "python-validate-email")
14511 (version "1.3")
14512 (source
14513 (origin
14514 (method url-fetch)
14515 (uri (pypi-uri "validate_email" version))
14516 (sha256
14517 (base32
14518 "1bxffaf5yz2cph8ki55vdvdypbwkvn2xr1firlcy62vqbzf1jivq"))))
14519 (build-system python-build-system)
14520 (home-page "https://github.com/syrusakbary/validate_email")
14521 (synopsis "Verifies if an email address is valid and really exists")
14522 (description "@code{validate_email} can be used to verify if an email
14523 address is valid and really exists.")
14524 (license license:lgpl3+)))
14525
14526 (define-public python2-validate-email
14527 (package-with-python2 python-validate-email))
14528
14529 (define-public python-flex
14530 (package
14531 (name "python-flex")
14532 (version "6.10.0")
14533 (source
14534 (origin
14535 (method url-fetch)
14536 (uri (pypi-uri "flex" version))
14537 (sha256
14538 (base32
14539 "00pamnwla3khk8nyla7y28dq9jnh69swd7f4jfsl7sn1izs8n8zk"))))
14540 (build-system python-build-system)
14541 (propagated-inputs
14542 `(("python-click" ,python-click)
14543 ("python-iso8601" ,python-iso8601)
14544 ("python-jsonpointer" ,python-jsonpointer)
14545 ("python-pyyaml" ,python-pyyaml)
14546 ("python-requests" ,python-requests)
14547 ("python-rfc3987" ,python-rfc3987)
14548 ("python-six" ,python-six)
14549 ("python-validate-email" ,python-validate-email)))
14550 (home-page "https://github.com/pipermerriam/flex")
14551 (synopsis "Validates Swagger schemata")
14552 (description "@code{flex} can be used to validate Swagger schemata.")
14553 (license license:bsd-3)))
14554
14555 (define-public python2-flex
14556 (package-with-python2 python-flex))
14557
14558 (define-public python-marshmallow
14559 (package
14560 (name "python-marshmallow")
14561 (version "3.0.0b14")
14562 (source
14563 (origin
14564 (method url-fetch)
14565 (uri (pypi-uri "marshmallow" version))
14566 (sha256
14567 (base32
14568 "1digk3f5cfk7wmlka65mc7bzsd96pbsgcsvp6pimd5b4ff9zb5p3"))))
14569 (build-system python-build-system)
14570 (propagated-inputs
14571 `(("python-dateutil" ,python-dateutil)
14572 ("python-simplejson" ,python-simplejson)))
14573 (native-inputs
14574 `(("python-pytest" ,python-pytest)
14575 ("python-pytz" ,python-pytz)))
14576 (home-page "https://github.com/marshmallow-code/marshmallow")
14577 (synopsis "Convert complex datatypes to and from native
14578 Python datatypes.")
14579 (description "@code{marshmallow} provides a library for converting
14580 complex datatypes to and from native Python datatypes.")
14581 (license license:expat)))
14582
14583 (define-public python2-marshmallow
14584 (package-with-python2 python-marshmallow))
14585
14586 (define-public python-apispec
14587 (package
14588 (name "python-apispec")
14589 (version "0.25.3")
14590 (source
14591 (origin
14592 (method url-fetch)
14593 (uri (pypi-uri "apispec" version))
14594 (sha256
14595 (base32
14596 "0kxa8723zbisx10363yh4mmmn4higxrspymbjfz5zq8f644zagm9"))))
14597 (build-system python-build-system)
14598 (propagated-inputs
14599 `(("python-pyyaml" ,python-pyyaml)))
14600 (native-inputs
14601 `(("python-pytest" ,python-pytest)
14602 ("python-flask" ,python-flask)
14603 ("python-marshmallow" ,python-marshmallow)
14604 ("python-tornado" ,python-tornado)
14605 ("python-bottle" ,python-bottle)
14606 ("python-mock" ,python-mock)))
14607 (home-page "https://github.com/marshmallow-code/apispec")
14608 (synopsis "Swagger 2.0 API specification generator")
14609 (description "@code{python-apispec} is a pluggable API specification
14610 generator. Currently supports the OpenAPI specification (f.k.a.
14611 Swagger 2.0).")
14612 (license license:expat)))
14613
14614 (define-public python2-apispec
14615 (package-with-python2 python-apispec))
14616
14617 (define-public python-flasgger
14618 (package
14619 (name "python-flasgger")
14620 (version "0.6.3")
14621 (source
14622 (origin
14623 (method git-fetch)
14624 (uri (git-reference
14625 (url "https://github.com/rochacbruno/flasgger.git")
14626 (commit version)))
14627 (file-name (git-file-name name version))
14628 (sha256
14629 (base32 "0yydxsyjnc0clbrjqb1n7587l6cdqvwdagwxk5hkx01qwdfbkvpn"))))
14630 (build-system python-build-system)
14631 (arguments
14632 `(#:phases
14633 (modify-phases %standard-phases
14634 (replace 'check
14635 (lambda* (#:key inputs outputs #:allow-other-keys)
14636 (substitute* "Makefile"
14637 (("flake8 flasgger --ignore=F403")
14638 "flake8 flasgger --ignore=E731,F403"))
14639 (setenv "PYTHONPATH" (string-append (getcwd)
14640 ":"
14641 (getenv "PYTHONPATH")))
14642 (invoke "py.test"))))))
14643 (propagated-inputs
14644 `(("python-flask" ,python-flask)
14645 ("python-pyyaml" ,python-pyyaml)
14646 ("python-jsonschema" ,python-jsonschema)
14647 ("python-mistune" ,python-mistune)
14648 ("python-six" ,python-six)))
14649 (native-inputs
14650 `(("python-decorator" ,python-decorator)
14651 ("python-flake8" ,python-flake8)
14652 ("python-flask-restful" ,python-flask-restful)
14653 ("python-flex" ,python-flex)
14654 ("python-pytest" ,python-pytest)
14655 ("python-pytest-cov" ,python-pytest-cov)
14656 ("python-marshmallow" ,python-marshmallow)
14657 ("python-apispec" ,python-apispec)))
14658 (home-page "https://github.com/rochacbruno/flasgger/")
14659 (synopsis "Extract Swagger specs from your Flask project")
14660 (description "@code{python-flasgger} allows extracting Swagger specs
14661 from your Flask project. It is a fork of Flask-Swagger.")
14662 (license license:expat)))
14663
14664 (define-public python2-flasgger
14665 (package-with-python2 python-flasgger))
14666
14667 (define-public python-swagger-spec-validator
14668 (package
14669 (name "python-swagger-spec-validator")
14670 (version "2.4.3")
14671 (source
14672 (origin
14673 (method url-fetch)
14674 (uri (pypi-uri "swagger-spec-validator" version))
14675 (sha256
14676 (base32
14677 "11g627icrsqwazsncwi0sdvprcj6hwaayw5xk3xsj8d97bmrzqjp"))))
14678 (build-system python-build-system)
14679 (propagated-inputs
14680 `(("python-jsonschema" ,python-jsonschema)
14681 ("python-pyyaml" ,python-pyyaml)
14682 ("python-six" ,python-six)))
14683 (home-page
14684 "https://github.com/Yelp/swagger_spec_validator")
14685 (synopsis "Validation of Swagger specifications")
14686 (description "@code{swagger_spec_validator} provides a library for
14687 validating Swagger API specifications.")
14688 (license license:asl2.0)))
14689
14690 (define-public python2-swagger-spec-validator
14691 (package-with-python2 python-swagger-spec-validator))
14692
14693 (define-public python-apache-libcloud
14694 (package
14695 (name "python-apache-libcloud")
14696 (version "2.4.0")
14697 (source
14698 (origin
14699 (method url-fetch)
14700 (uri (pypi-uri "apache-libcloud" version))
14701 (sha256
14702 (base32
14703 "0daj3mkzw79v5zin2r1s2wkrz1hplfc16bwj4ss68i5qjq4l2p0j"))))
14704 (build-system python-build-system)
14705 (arguments
14706 `(#:phases
14707 (modify-phases %standard-phases
14708 (add-after 'unpack 'patch-ssh
14709 (lambda* (#:key inputs #:allow-other-keys)
14710 (substitute* "libcloud/compute/ssh.py"
14711 (("'ssh'") (string-append "'" (assoc-ref inputs "openssh")
14712 "/bin/ssh" "'")))
14713 #t))
14714 (add-after 'unpack 'patch-tests
14715 (lambda _
14716 (substitute* "./libcloud/test/test_file_fixtures.py"
14717 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-923>.
14718 (("def _ascii") "def _raw_data(self, method, url, body, headers):
14719 return (httplib.OK,
14720 \"1234abcd\",
14721 {\"test\": \"value\"},
14722 httplib.responses[httplib.OK])
14723 def _ascii"))
14724 (substitute* "libcloud/test/compute/test_ssh_client.py"
14725 (("class ShellOutSSHClientTests")
14726 "@unittest.skip(\"Guix container doesn't have ssh service\")
14727 class ShellOutSSHClientTests")
14728 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-924>.
14729 (("'.xf0.x90.x8d.x88'") "b'\\xF0\\x90\\x8D\\x88'")
14730 (("'.xF0', '.x90', '.x8D', '.x88'")
14731 "b'\\xF0', b'\\x90', b'\\x8D', b'\\x88'"))
14732 #t))
14733 (add-before 'check 'copy-secret
14734 (lambda _
14735 (copy-file "libcloud/test/secrets.py-dist"
14736 "libcloud/test/secrets.py")
14737 #t)))))
14738 (inputs
14739 `(("openssh" ,openssh)))
14740 (propagated-inputs
14741 `(("python-paramiko" ,python-paramiko)
14742 ("python-requests" ,python-requests)))
14743 (native-inputs
14744 `(("python-lockfile" ,python-lockfile)
14745 ("python-mock" ,python-mock)
14746 ("python-pytest" ,python-pytest)
14747 ("python-pytest-runner" ,python-pytest-runner)
14748 ("python-requests-mock" ,python-requests-mock)))
14749 (home-page "https://libcloud.apache.org/")
14750 (synopsis "Unified Cloud API")
14751 (description "@code{libcloud} is a Python library for interacting with
14752 many of the popular cloud service providers using a unified API.")
14753 (license license:asl2.0)))
14754
14755 (define-public python2-apache-libcloud
14756 (package-with-python2 python-apache-libcloud))
14757
14758 (define-public python-smmap
14759 (package
14760 (name "python-smmap")
14761 (version "3.0.1")
14762 (source
14763 (origin
14764 (method url-fetch)
14765 (uri (pypi-uri "smmap" version))
14766 (sha256
14767 (base32 "0ijlnv60y8f41py1wnn5n1a1i81cxd9dfpdhr0k3cgkrcbz8850p"))))
14768 (build-system python-build-system)
14769 (native-inputs
14770 `(("python-nosexcover" ,python-nosexcover)))
14771 (home-page "https://github.com/Byron/smmap")
14772 (synopsis "Python sliding window memory map manager")
14773 (description "@code{smmap} is a pure Python implementation of a sliding
14774 window memory map manager.")
14775 (license license:bsd-3)))
14776
14777 (define-public python-smmap2
14778 (deprecated-package "python-smmap2" python-smmap))
14779
14780 (define-public python2-smmap
14781 (package-with-python2 python-smmap))
14782
14783 (define-public python2-smmap2
14784 (deprecated-package "python2-smmap2" python2-smmap))
14785
14786 (define-public python-regex
14787 (package
14788 (name "python-regex")
14789 (version "2019.04.14")
14790 (source (origin
14791 (method url-fetch)
14792 (uri (pypi-uri "regex" version))
14793 (sha256
14794 (base32
14795 "1a6hhfs6l6snr1z654ay6wzbmwdkmv282fzfkd5hk2d1n73y8v6m"))))
14796 ;; TODO: Fix and enable regex_test.py tests that complain about the
14797 ;; test.support module not existing.
14798 (build-system python-build-system)
14799 (home-page "https://bitbucket.org/mrabarnett/mrab-regex")
14800 (synopsis "Alternative regular expression module")
14801 (description "This regular expression implementation is backwards-
14802 compatible with the standard @code{re} module, but offers additional
14803 functionality like full case-folding for case-insensitive matches in Unicode.")
14804 (license license:psfl)))
14805
14806 (define-public python2-regex
14807 (package-with-python2 python-regex))
14808
14809 (define-public python2-pyopengl
14810 (package
14811 (name "python2-pyopengl")
14812 (version "3.1.0")
14813 (source
14814 (origin
14815 (method url-fetch)
14816 (uri (pypi-uri "PyOpenGL" version))
14817 (sha256
14818 (base32
14819 "1byxjj6a8rwzhxhjqlc588zdad2qwxdd7vlam2653ylll31waiwv"))))
14820 (arguments
14821 `(#:python ,python-2))
14822 (build-system python-build-system)
14823 (home-page "http://pyopengl.sourceforge.net")
14824 (synopsis "Standard OpenGL bindings for Python")
14825 (description
14826 "PyOpenGL is the most common cross platform Python binding to OpenGL and
14827 related APIs. The binding is created using the standard @code{ctypes}
14828 library.")
14829 (license license:bsd-3)))
14830
14831 (define-public python2-pyopengl-accelerate
14832 (package
14833 (inherit python2-pyopengl)
14834 (name "python2-pyopengl-accelerate")
14835 (version "3.1.0")
14836 (source
14837 (origin
14838 (method url-fetch)
14839 (uri (pypi-uri "PyOpenGL-accelerate" version))
14840 (sha256
14841 (base32
14842 "0464c1ifzk0k92lyndikmvzjgnx1y25r7bkkc8pnxm4kp1q4czwj"))))
14843 (synopsis "Acceleration code for PyOpenGL")
14844 (description
14845 "This is the Cython-coded accelerator module for PyOpenGL.")))
14846
14847 (define-public python-rencode
14848 (package
14849 (name "python-rencode")
14850 (version "1.0.5")
14851 (source
14852 (origin
14853 (method url-fetch)
14854 (uri (pypi-uri "rencode" version))
14855 (sha256
14856 (base32
14857 "0mzwdq1is7kyyr32i5k4iz6g5xxdvmiyc132jnc60p9m6lnwjrpv"))))
14858 (build-system python-build-system)
14859 (arguments
14860 `(#:phases
14861 (modify-phases %standard-phases
14862 (add-before 'check 'delete-bogus-test
14863 ;; This test requires /home/aresch/Downloads, which is not provided by
14864 ;; the build environment.
14865 (lambda _
14866 (delete-file "rencode/t.py")
14867 #t)))))
14868 (native-inputs `(("pkg-config" ,pkg-config)
14869 ("python-cython" ,python-cython)))
14870 (home-page "https://github.com/aresch/rencode")
14871 (synopsis "Serialization of heterogeneous data structures")
14872 (description
14873 "The @code{rencode} module is a data structure serialization library,
14874 similar to @code{bencode} from the BitTorrent project. For complex,
14875 heterogeneous data structures with many small elements, r-encoding stake up
14876 significantly less space than b-encodings. This version of rencode is a
14877 complete rewrite in Cython to attempt to increase the performance over the
14878 pure Python module.")
14879 (license license:bsd-3)))
14880
14881 (define-public python2-rencode
14882 (package-with-python2 python-rencode))
14883
14884 (define-public python-xenon
14885 (package
14886 (name "python-xenon")
14887 (version "0.7.0")
14888 (source
14889 (origin
14890 (method url-fetch)
14891 (uri (pypi-uri "xenon" version))
14892 (sha256
14893 (base32
14894 "0nv207ql2wmh9q62503np056c4vf1c1hlsi5cvv5p5kx574k6r2y"))))
14895 (build-system python-build-system)
14896 (native-inputs
14897 `(("python-pyyaml" ,python-pyyaml)
14898 ("python-radon" ,python-radon)
14899 ("python-requests" ,python-requests)
14900 ("python-flake8" ,python-flake8)
14901 ("python-tox" ,python-tox)))
14902 (arguments
14903 `(#:tests? #f ;test suite not shipped with the PyPI archive
14904 #:phases
14905 (modify-phases %standard-phases
14906 (add-before 'build 'patch-test-requirements
14907 (lambda _
14908 ;; Remove httpretty dependency for tests.
14909 (substitute* "setup.py"
14910 (("httpretty") ""))
14911 #t)))))
14912 (home-page "https://xenon.readthedocs.org/")
14913 (synopsis "Monitor code metrics for Python on your CI server")
14914 (description
14915 "Xenon is a monitoring tool based on Radon. It monitors code complexity.
14916 Ideally, @code{xenon} is run every time code is committed. Through command
14917 line options, various thresholds can be set for the complexity of code. It
14918 will fail (i.e. it will exit with a non-zero exit code) when any of these
14919 requirements is not met.")
14920 (license license:expat)))
14921
14922 (define-public python2-xenon
14923 (package-with-python2 python-xenon))
14924
14925 (define-public python-pysocks
14926 (package
14927 (name "python-pysocks")
14928 (version "1.7.0")
14929 (source
14930 (origin
14931 (method url-fetch)
14932 (uri (pypi-uri "PySocks" version))
14933 (sha256
14934 (base32
14935 "0z4p31bpqm893cf87qqgb30k7nwd8kqfjwwjm5cvxb6zbyj1w0yr"))))
14936 (build-system python-build-system)
14937 (arguments `(#:tests? #f))
14938 (home-page "https://github.com/Anorov/PySocks")
14939 (synopsis "SOCKS client module")
14940 (description "@code{pysocks} is an updated and semi-actively maintained
14941 version of @code{SocksiPy} with bug fixes and extra features.")
14942 (license license:bsd-3)))
14943
14944 (define-public python2-pysocks
14945 (package-with-python2 python-pysocks))
14946
14947 (define-public python-pydiff
14948 (package
14949 (name "python-pydiff")
14950 (version "0.2")
14951 (source
14952 (origin
14953 (method url-fetch)
14954 (uri (pypi-uri "pydiff" version))
14955 (sha256
14956 (base32
14957 "1als83h9w0gab24ipyna6khm390qmpnpkc5jksmdbs2xc8hp2z44"))))
14958 (build-system python-build-system)
14959 (home-page "https://github.com/myint/pydiff")
14960 (synopsis "Library to diff two Python files at the bytecode level")
14961 (description
14962 "@code{pydiff} makes it easy to look for actual code changes while
14963 ignoring formatting changes.")
14964 (license license:expat)))
14965
14966 (define-public python2-pydiff
14967 (package-with-python2 python-pydiff))
14968
14969 (define-public python-tqdm
14970 (package
14971 (name "python-tqdm")
14972 (version "4.43.0")
14973 (source
14974 (origin
14975 (method url-fetch)
14976 (uri (pypi-uri "tqdm" version))
14977 (sha256
14978 (base32
14979 "093v4c2x5hpigv47zvyxl8wh10y2yd2gvz3l9vchn0zsp8hv2pzk"))))
14980 (build-system python-build-system)
14981 (arguments
14982 '(#:phases (modify-phases %standard-phases
14983 (replace 'check
14984 (lambda* (#:key inputs outputs #:allow-other-keys)
14985 (add-installed-pythonpath inputs outputs)
14986 ;; This invokation is taken from tox.ini.
14987 (invoke "nosetests" "--ignore-files=\"test_perf.py\""
14988 "-d" "-v" "tqdm/"))))))
14989 (native-inputs
14990 `(("python-nose" ,python-nose)))
14991 (home-page "https://github.com/tqdm/tqdm")
14992 (synopsis "Fast, extensible progress meter")
14993 (description
14994 "Make loops show a progress bar on the console by just wrapping any
14995 iterable with @code{|tqdm(iterable)|}. Offers many options to define
14996 design and layout.")
14997 (license (list license:mpl2.0 license:expat))))
14998
14999 (define-public python2-tqdm
15000 (package-with-python2 python-tqdm))
15001
15002 (define-public python-pkginfo
15003 (package
15004 (name "python-pkginfo")
15005 (version "1.4.2")
15006 (source
15007 (origin
15008 (method url-fetch)
15009 (uri (pypi-uri "pkginfo" version))
15010 (sha256
15011 (base32
15012 "0x6lm17p1ks031mj6pajyp4rkq74vpqq8qwjb7ikgwmkli1day2q"))))
15013 (build-system python-build-system)
15014 (arguments
15015 ;; The tests are broken upstream.
15016 '(#:tests? #f))
15017 (home-page
15018 "https://code.launchpad.net/~tseaver/pkginfo/trunk")
15019 (synopsis
15020 "Query metadatdata from sdists, bdists, and installed packages")
15021 (description
15022 "API to query the distutils metadata written in @file{PKG-INFO} inside a
15023 source distriubtion (an sdist) or a binary distribution (e.g., created by
15024 running bdist_egg). It can also query the EGG-INFO directory of an installed
15025 distribution, and the *.egg-info stored in a \"development checkout\" (e.g,
15026 created by running @code{python setup.py develop}).")
15027 (license license:expat)))
15028
15029 (define-public python2-pkginfo
15030 (package-with-python2 python-pkginfo))
15031
15032 (define-public python-twine
15033 (package
15034 (name "python-twine")
15035 (version "1.9.1")
15036 (source
15037 (origin
15038 (method url-fetch)
15039 (uri (pypi-uri "twine" version))
15040 (sha256
15041 (base32
15042 "1ay1b6kdq6k4bfbjsvf6ymj41wrgpvinhxndb09355pwhxwmp96a"))))
15043 (build-system python-build-system)
15044 (propagated-inputs
15045 `(("python-tqdm" ,python-tqdm)
15046 ("python-pkginfo" ,python-pkginfo)
15047 ("python-requests" ,python-requests)
15048 ("python-requests-toolbelt" ,python-requests-toolbelt)))
15049 (home-page "https://github.com/pypa/twine")
15050 (synopsis "Collection of utilities for interacting with PyPI")
15051 (description
15052 "@code{twine} currently supports registering projects and uploading
15053 distributions. It authenticates the user over HTTPS, allows them to pre-sign
15054 their files and supports any packaging format (including wheels).")
15055 (license license:asl2.0)))
15056
15057 (define-public python2-twine
15058 (package-with-python2 python-twine))
15059
15060 (define-public python-linecache2
15061 (package
15062 (name "python-linecache2")
15063 (version "1.0.0")
15064 (source
15065 (origin
15066 (method url-fetch)
15067 (uri (pypi-uri "linecache2" version))
15068 (sha256
15069 (base32
15070 "0z79g3ds5wk2lvnqw0y2jpakjf32h95bd9zmnvp7dnqhf57gy9jb"))))
15071 (build-system python-build-system)
15072 (arguments
15073 `(;; The tests depend on unittest2, and our version is a bit too old.
15074 #:tests? #f))
15075 (native-inputs
15076 `(("python-pbr" ,python-pbr-minimal)))
15077 (home-page
15078 "https://github.com/testing-cabal/linecache2")
15079 (synopsis "Backports of the linecache module")
15080 (description
15081 "The linecache module allows one to get any line from any file, while
15082 attempting to optimize internally, using a cache, the common case where many
15083 lines are read from a single file.")
15084 (license license:psfl)))
15085
15086 (define-public python2-linecache2
15087 (package-with-python2 python-linecache2))
15088
15089 (define-public python-traceback2
15090 (package
15091 (name "python-traceback2")
15092 (version "1.4.0")
15093 (source
15094 (origin
15095 (method url-fetch)
15096 (uri (pypi-uri "traceback2" version))
15097 (sha256
15098 (base32
15099 "0c1h3jas1jp1fdbn9z2mrgn3jj0hw1x3yhnkxp7jw34q15xcdb05"))))
15100 (build-system python-build-system)
15101 (arguments
15102 `(;; python-traceback2 and python-unittest2 depend on one another.
15103 #:tests? #f))
15104 (native-inputs
15105 `(("python-pbr" ,python-pbr-minimal)))
15106 (propagated-inputs
15107 `(("python-linecache2" ,python-linecache2)))
15108 (home-page
15109 "https://github.com/testing-cabal/traceback2")
15110 (synopsis "Backports of the traceback module")
15111 (description
15112 "This module provides a standard interface to extract, format and print
15113 stack traces of Python programs. It exactly mimics the behavior of the Python
15114 interpreter when it prints a stack trace.")
15115 (license license:psfl)))
15116
15117 (define-public python2-traceback2
15118 (package-with-python2 python-traceback2))
15119
15120 (define-public python-ratelimiter
15121 (package
15122 (name "python-ratelimiter")
15123 (version "1.2.0")
15124 (source
15125 (origin
15126 (method url-fetch)
15127 (uri (pypi-uri "ratelimiter" version))
15128 (sha256
15129 (base32
15130 "1dhz85mj5bqd2mij84ncs6pz32hgidr79hay4aqfmzaa4rbb497p"))))
15131 (build-system python-build-system)
15132 (arguments
15133 '(#:tests? #f)) ; There are no tests in the pypi archive.
15134 (home-page "https://github.com/RazerM/ratelimiter")
15135 (synopsis "Simple rate limiting object")
15136 (description
15137 "The @code{ratelimiter} module ensures that an operation will not be
15138 executed more than a given number of times during a given period.")
15139 (license license:asl2.0)))
15140
15141 (define-public python2-ratelimiter
15142 (package-with-python2 python-ratelimiter))
15143
15144 (define-public python-dukpy
15145 (package
15146 (name "python-dukpy")
15147 (version "0.3")
15148 (source
15149 (origin
15150 (method git-fetch)
15151 (uri (git-reference
15152 (url "https://github.com/kovidgoyal/dukpy.git")
15153 (commit (string-append "v" version))))
15154 (file-name (git-file-name name version))
15155 (sha256
15156 (base32 "13h21nqzasv4zj32xs61brmc106pr2cx243672crcmwxxnjgaxls"))))
15157 (build-system python-build-system)
15158 (home-page "https://github.com/kovidgoyal/dukpy")
15159 (synopsis "Run JavaScript in python")
15160 (description
15161 "dukpy is a JavaScript runtime environment for Python using the duktape
15162 embeddable JavaScript engine.")
15163 ;; Dukpy is licensed under MIT like the embedded duktape library,
15164 ;; with 'errors.c' as GPL3.
15165 (license (list license:expat license:gpl3))))
15166
15167 (define-public python2-dukpy
15168 (package-with-python2 python-dukpy))
15169
15170 (define-public python-jsonrpclib-pelix
15171 (package
15172 (name "python-jsonrpclib-pelix")
15173 (version "0.3.2")
15174 (source
15175 (origin
15176 (method url-fetch)
15177 (uri (pypi-uri "jsonrpclib-pelix" version))
15178 (sha256
15179 (base32
15180 "0f83z5zi7w32vprhk1dyc94ir1bh4hdd57bjdbwkq9ykng8qilhl"))))
15181 (build-system python-build-system)
15182 (arguments
15183 `(#:tests? #f)) ; no tests in PyPI tarball
15184 (home-page "https://github.com/tcalmant/jsonrpclib/")
15185 (synopsis "JSON-RPC 2.0 client library for Python")
15186 (description
15187 "This library implements the JSON-RPC v2.0
15188 specification (backwards-compatible) as a client library for Python. This
15189 version is a fork of jsonrpclib by Josh Marshall, usable with Pelix remote
15190 services.")
15191 (license license:asl2.0)))
15192
15193 (define-public python2-jsonrpclib-pelix
15194 (package-with-python2 python-jsonrpclib-pelix))
15195
15196 (define-public python-setuptools-scm-git-archive
15197 (package
15198 (name "python-setuptools-scm-git-archive")
15199 (version "1.0")
15200 (source
15201 (origin
15202 (method url-fetch)
15203 (uri (pypi-uri "setuptools_scm_git_archive" version))
15204 (sha256
15205 (base32
15206 "1nii1sz5jq75ilf18bjnr11l9rz1lvdmyk66bxl7q90qan85yhjj"))))
15207 (build-system python-build-system)
15208 (native-inputs
15209 `(("python-pytest" ,python-pytest)))
15210 (propagated-inputs
15211 `(("python-setuptools-scm" ,python-setuptools-scm)))
15212 (home-page "https://github.com/Changaco/setuptools_scm_git_archive/")
15213 (synopsis "Setuptools_scm plugin for git archives")
15214 (description
15215 "The setuptools_scm_git_archive package is a plugin to
15216 setuptools_scm, which supports obtaining versions from git archives that
15217 belong to tagged versions.")
15218 (license license:expat)))
15219
15220 (define-public python2-setuptools-scm-git-archive
15221 (package-with-python2 python-setuptools-scm-git-archive))
15222
15223 (define-public python-setuptools-git
15224 (package
15225 (name "python-setuptools-git")
15226 (version "1.2")
15227 (source
15228 (origin
15229 (method url-fetch)
15230 (uri (pypi-uri "setuptools-git" version))
15231 (sha256
15232 (base32
15233 "0i84qjwp5m0l9qagdjww2frdh63r37km1c48mrvbmaqsl1ni6r7z"))))
15234 (build-system python-build-system)
15235 (arguments
15236 `(#:phases
15237 (modify-phases %standard-phases
15238 ;; This is needed for tests.
15239 (add-after 'unpack 'configure-git
15240 (lambda _
15241 (setenv "HOME" "/tmp")
15242 (invoke "git" "config" "--global" "user.email" "guix")
15243 (invoke "git" "config" "--global" "user.name" "guix")
15244 #t)))))
15245 (native-inputs
15246 `(("git" ,git-minimal)))
15247 (home-page "https://github.com/msabramo/setuptools-git")
15248 (synopsis "Setuptools revision control system plugin for Git")
15249 (description
15250 "This package provides a plugin for Setuptools for revision control with
15251 Git.")
15252 (license license:bsd-3)))
15253
15254 (define-public python-pyclipper
15255 (package
15256 (name "python-pyclipper")
15257 (version "1.1.0.post3")
15258 (source
15259 (origin
15260 (method url-fetch)
15261 (uri (pypi-uri "pyclipper" version ".zip"))
15262 (sha256
15263 (base32 "164yksvqwqvwzh8f8lq92asg87hd8rvcy2xb5vm4y4ccvd5xgb7i"))
15264 (modules '((guix build utils)))
15265 (snippet
15266 '(begin
15267 ;; This file is generated by Cython.
15268 (delete-file "pyclipper/pyclipper.cpp") #t))))
15269 (build-system python-build-system)
15270 (arguments
15271 `(#:phases
15272 (modify-phases %standard-phases
15273 (add-before 'build 'cythonize-sources
15274 (lambda _
15275 (with-directory-excursion "pyclipper"
15276 (invoke "cython" "--cplus" "pyclipper.pyx")))))))
15277 (propagated-inputs
15278 `(("python-setuptools-scm-git-archive" ,python-setuptools-scm-git-archive)))
15279 (native-inputs
15280 `(("python-cython" ,python-cython)
15281 ("python-pytest" ,python-pytest)
15282 ("python-pytest-runner" ,python-pytest-runner)
15283 ("python-unittest2" ,python-unittest2)
15284 ("unzip" ,unzip)))
15285 (home-page "https://github.com/greginvm/pyclipper")
15286 (synopsis "Wrapper for Angus Johnson's Clipper library")
15287 (description
15288 "Pyclipper is a Cython wrapper for the C++ translation of the
15289 Angus Johnson's polygon clipping Clipper library (ver. 6.4.2).")
15290 (license license:expat)))
15291
15292 (define-public python2-pyclipper
15293 (package-with-python2 python-pyclipper))
15294
15295 (define-public python2-booleanoperations
15296 (package
15297 (name "python2-booleanoperations")
15298 (version "0.7.1")
15299 (source
15300 (origin
15301 (method url-fetch)
15302 (uri (pypi-uri "booleanOperations" version ".zip"))
15303 (sha256
15304 (base32
15305 "1hw42fazdpvsn77glx96hwsj9l17mvx37sc5707s08y5w6fx16mn"))))
15306 (build-system python-build-system)
15307 (arguments
15308 `(#:python ,python-2))
15309 (native-inputs
15310 `(("unzip" ,unzip)
15311 ("python2-pytest" ,python2-pytest)
15312 ("python2-pytest-runner" ,python2-pytest-runner)))
15313 (propagated-inputs
15314 `(("python-fonttools" ,python2-fonttools)
15315 ("python-pyclipper" ,python2-pyclipper)
15316 ("python-ufolib" ,python2-ufolib)))
15317 (home-page "https://github.com/typemytype/booleanOperations")
15318 (synopsis "Boolean operations on paths")
15319 (description
15320 "BooleanOperations provides a Python library that enables
15321 boolean operations on paths.")
15322 (license license:expat)))
15323
15324 (define-public python-tempdir
15325 (package
15326 (name "python-tempdir")
15327 (version "0.7.1")
15328 (source
15329 (origin
15330 (method url-fetch)
15331 (uri (pypi-uri "tempdir" version))
15332 (sha256
15333 (base32
15334 "13msyyxqbicr111a294x7fsqbkl6a31fyrqflx3q7k547gnq15k8"))))
15335 (build-system python-build-system)
15336 (home-page "https://pypi.org/project/tempdir/")
15337 (arguments
15338 ;; the package has no tests
15339 '(#:tests? #f))
15340 (synopsis "Python library for managing temporary directories")
15341 (description
15342 "This library manages temporary directories that are automatically
15343 deleted with all their contents when they are no longer needed. It is
15344 particularly convenient for use in tests.")
15345 (license license:expat)))
15346
15347 (define-public python2-tempdir
15348 (package-with-python2 python-tempdir))
15349
15350 (define-public python-activepapers
15351 (package
15352 (name "python-activepapers")
15353 (version "0.2.2")
15354 (source
15355 (origin
15356 (method url-fetch)
15357 (uri (pypi-uri "ActivePapers.Py" version))
15358 (sha256
15359 (base32
15360 "12wkhjh90ffipjzv10swndp2xv9hd7xrxvg6v0n4n3i411pj4xb8"))))
15361 (build-system python-build-system)
15362 (arguments
15363 `(#:modules ((ice-9 ftw)
15364 (srfi srfi-1)
15365 (guix build utils)
15366 (guix build python-build-system))
15367
15368 #:phases
15369 (modify-phases %standard-phases
15370 (add-after 'unpack 'delete-python2-code
15371 (lambda _
15372 (for-each delete-file
15373 '("lib/activepapers/builtins2.py"
15374 "lib/activepapers/standardlib2.py"
15375 "lib/activepapers/utility2.py"))))
15376 (replace 'check
15377 (lambda _
15378 ;; Deactivate the test cases that download files
15379 (setenv "NO_NETWORK_ACCESS" "1")
15380 ;; For some strange reason, some tests fail if nosetests runs all
15381 ;; test modules in a single execution. They pass if each test
15382 ;; module is run individually.
15383 (for-each (lambda (filename)
15384 (invoke "nosetests"
15385 (string-append "tests/" filename)))
15386 (scandir "tests"
15387 (lambda (filename)
15388 (string-suffix? ".py" filename)))))))))
15389 (native-inputs
15390 `(("python-tempdir" ,python-tempdir)
15391 ("python-nose" ,python-nose)))
15392 (propagated-inputs
15393 `(("python-h5py" ,python-h5py)))
15394 (home-page "https://www.activepapers.org/")
15395 (synopsis "Executable papers for scientific computing")
15396 (description
15397 "ActivePapers is a tool for working with executable papers, which
15398 combine data, code, and documentation in single-file packages,
15399 suitable for publication as supplementary material or on repositories
15400 such as figshare or Zenodo.")
15401 (properties `((python2-variant . ,(delay python2-activepapers))))
15402 (license license:bsd-3)))
15403
15404 (define-public python2-activepapers
15405 (let ((base (package-with-python2
15406 (strip-python2-variant python-activepapers))))
15407 (package
15408 (inherit base)
15409 (arguments
15410 (substitute-keyword-arguments (package-arguments base)
15411 ((#:phases phases)
15412 `(modify-phases ,phases
15413 (delete 'delete-python2-code)
15414 (add-after 'unpack 'delete-python3-code
15415 (lambda _
15416 (for-each delete-file
15417 '("lib/activepapers/builtins3.py"
15418 "lib/activepapers/standardlib3.py"
15419 "lib/activepapers/utility3.py")))))))))))
15420
15421 (define-public python-semver
15422 (package
15423 (name "python-semver")
15424 (version "2.9.0")
15425 (source
15426 (origin
15427 (method url-fetch)
15428 (uri (pypi-uri "semver" version))
15429 (sha256
15430 (base32
15431 "183kg1rhzz3hqizvphkd8hlbf1zxfx8737zhfkmqzxi71jmdw7pd"))))
15432 (build-system python-build-system)
15433 (native-inputs
15434 `(("python-appdirs" ,python-appdirs)
15435 ("python-distlib" ,python-distlib)
15436 ("python-importlib-metadata" ,python-importlib-metadata)
15437 ("python-filelock" ,python-filelock)
15438 ("python-six" ,python-six)
15439 ("python-tox" ,python-tox)
15440 ("python-virtualenv" ,python-virtualenv)))
15441 (home-page "https://github.com/k-bx/python-semver")
15442 (synopsis "Python helper for Semantic Versioning")
15443 (description "This package provides a Python library for
15444 @url{Semantic Versioning, http://semver.org/}.")
15445 (license license:bsd-3)))
15446
15447 (define-public python2-semver
15448 (package-with-python2 python-semver))
15449
15450 (define-public python-pyro4
15451 (package
15452 (name "python-pyro4")
15453 (version "4.77")
15454 (source
15455 (origin
15456 (method url-fetch)
15457 (uri (pypi-uri "Pyro4" version))
15458 (sha256
15459 (base32 "0gsjg869y4gpy265s1gj1f2qy6jn5iz8r2bwwnq78r1r5yi15zib"))))
15460 (build-system python-build-system)
15461 (arguments
15462 '(#:tests? #f)) ;FIXME: Some tests require network access.
15463 (native-inputs
15464 `(("python-cloudpickle" ,python-cloudpickle)
15465 ("python-dill" ,python-dill)
15466 ("python-msgpack" ,python-msgpack)))
15467 (propagated-inputs
15468 `(("python-serpent" ,python-serpent)))
15469 (home-page "https://pyro4.readthedocs.io")
15470 (synopsis "Distributed object middleware for Python")
15471 (description
15472 "Pyro enables you to build applications in which objects can talk to each
15473 other over the network. You can just use normal Python method calls to call
15474 objects on other machines, also known as remote procedure calls (RPC).")
15475 (license license:expat)))
15476
15477 (define-public python2-pyro
15478 (package
15479 (name "python2-pyro")
15480 (version "3.16")
15481 (source
15482 (origin
15483 (method url-fetch)
15484 (uri (pypi-uri "Pyro" version))
15485 (file-name (string-append "Pyro-" version ".tar.gz"))
15486 (sha256
15487 (base32
15488 "0y75wzdqbjy565rpxaxscav4j8xg060sa90lnmb7aypgaf251v8v"))))
15489 (build-system python-build-system)
15490 (arguments
15491 ;; Pyro is not compatible with Python 3
15492 `(#:python ,python-2
15493 ;; Pyro has no test cases for automatic execution
15494 #:tests? #f))
15495 (home-page "https://pythonhosted.org/Pyro/")
15496 (synopsis "Distributed object manager for Python")
15497 (description "Pyro is a Distributed Object Technology system
15498 written in Python that is designed to be easy to use. It resembles
15499 Java's Remote Method Invocation (RMI). It has less similarity to CORBA,
15500 which is a system and language independent Distributed Object Technology
15501 and has much more to offer than Pyro or RMI. Pyro 3.x is no
15502 longer maintained. New projects should use Pyro4 instead, which
15503 is the new Pyro version that is actively developed.")
15504 (license license:expat)))
15505
15506 (define-public python2-scientific
15507 (package
15508 (name "python2-scientific")
15509 (version "2.9.4")
15510 (source
15511 (origin
15512 (method git-fetch)
15513 (uri (git-reference
15514 (url "https://github.com/khinsen/ScientificPython")
15515 (commit (string-append "rel" version))))
15516 (file-name (git-file-name name version))
15517 (sha256
15518 (base32
15519 "16l48aj9fps9r7jyk8gpxppwrv0fqvlc13sayxskz28r5s6sjwbl"))))
15520 (build-system python-build-system)
15521 (inputs
15522 `(("netcdf" ,netcdf)))
15523 (propagated-inputs
15524 `(("python-numpy" ,python2-numpy-1.8)
15525 ("python-pyro" ,python2-pyro)))
15526 (arguments
15527 ;; ScientificPython is not compatible with Python 3
15528 `(#:python ,python-2
15529 #:tests? #f ; No test suite
15530 #:phases
15531 (modify-phases %standard-phases
15532 (replace 'build
15533 (lambda* (#:key inputs #:allow-other-keys)
15534 (invoke "python" "setup.py" "build"
15535 (string-append "--netcdf_prefix="
15536 (assoc-ref inputs "netcdf"))))))))
15537 (home-page "http://dirac.cnrs-orleans.fr/ScientificPython")
15538 (synopsis "Python modules for scientific computing")
15539 (description "ScientificPython is a collection of Python modules that are
15540 useful for scientific computing. Most modules are rather general (Geometry,
15541 physical units, automatic derivatives, ...) whereas others are more
15542 domain-specific (e.g. netCDF and PDB support). The library is currently
15543 not actively maintained and works only with Python 2 and NumPy < 1.9.")
15544 (license license:cecill-c)))
15545
15546 (define-public python2-mmtk
15547 (package
15548 (name "python2-mmtk")
15549 (version "2.7.12")
15550 (source
15551 (origin
15552 (method git-fetch)
15553 (uri (git-reference
15554 (url "https://github.com/khinsen/MMTK")
15555 (commit (string-append "rel" version))))
15556 (file-name (git-file-name name version))
15557 (sha256
15558 (base32
15559 "1fqwh3ba9jd42nigvn5shndgwb1zy7kh9520ncvqci7n8ffjr6p1"))))
15560 (build-system python-build-system)
15561 (native-inputs
15562 `(("netcdf" ,netcdf)))
15563 (propagated-inputs
15564 `(("python-scientific" ,python2-scientific)
15565 ("python-tkinter" ,python-2 "tk")))
15566 (arguments
15567 `(#:python ,python-2
15568 #:tests? #f
15569 #:phases
15570 (modify-phases %standard-phases
15571 (add-before 'build 'includes-from-scientific
15572 (lambda* (#:key inputs #:allow-other-keys)
15573 (mkdir-p "Include/Scientific")
15574 (copy-recursively
15575 (string-append
15576 (assoc-ref inputs "python-scientific")
15577 "/include/python2.7/Scientific")
15578 "Include/Scientific"))))))
15579 (home-page "http://dirac.cnrs-orleans.fr/MMTK")
15580 (synopsis "Python library for molecular simulation")
15581 (description "MMTK is a library for molecular simulations with an emphasis
15582 on biomolecules. It provides widely used methods such as Molecular Dynamics
15583 and normal mode analysis, but also basic routines for implementing new methods
15584 for simulation and analysis. The library is currently not actively maintained
15585 and works only with Python 2 and NumPy < 1.9.")
15586 (license license:cecill-c)))
15587
15588 (define-public python-phonenumbers
15589 (package
15590 (name "python-phonenumbers")
15591 (version "8.9.1")
15592 (source
15593 (origin
15594 (method url-fetch)
15595 (uri (pypi-uri "phonenumbers" version))
15596 (sha256
15597 (base32
15598 "03fmrgb4r8x3ykmddjs9i3zhs703in8smikj3a6447blqpimwyh1"))))
15599 (build-system python-build-system)
15600 (home-page
15601 "https://github.com/daviddrysdale/python-phonenumbers")
15602 (synopsis
15603 "Python library for dealing with international phone numbers")
15604 (description
15605 "This package provides a Python port of Google's libphonenumber library.")
15606 (license license:asl2.0)))
15607
15608 (define-public python2-phonenumbers
15609 (package-with-python2 python-phonenumbers))
15610
15611 (define-public python-send2trash
15612 (package
15613 (name "python-send2trash")
15614 (version "1.5.0")
15615 (source
15616 (origin (method git-fetch)
15617 ;; Source tarball on PyPI doesn't include tests.
15618 (uri (git-reference
15619 (url "https://github.com/hsoft/send2trash.git")
15620 (commit version)))
15621 (file-name (git-file-name name version))
15622 (sha256
15623 (base32
15624 "1c76zldhw2ay7q7r00nnzcampjz9lkqfcbzqpm0iqp5i6bmmv30v"))))
15625 (build-system python-build-system)
15626 (arguments
15627 '(#:phases
15628 (modify-phases %standard-phases
15629 (add-before 'check 'pre-check
15630 (lambda _
15631 (mkdir-p "/tmp/foo")
15632 (setenv "HOME" "/tmp/foo")
15633 #t)))))
15634 (home-page "https://github.com/hsoft/send2trash")
15635 (synopsis "Send files to the user's @file{~/Trash} directory")
15636 (description "This package provides a Python library to send files to the
15637 user's @file{~/Trash} directory.")
15638 (properties `((python2-variant . ,(delay python2-send2trash))))
15639 (license license:bsd-3)))
15640
15641 (define-public python2-send2trash
15642 (package
15643 (inherit (package-with-python2 (strip-python2-variant python-send2trash)))
15644 (arguments
15645 (substitute-keyword-arguments (package-arguments python-send2trash)
15646 ((#:phases phases)
15647 `(modify-phases ,phases
15648 (add-before 'check 'setenv
15649 (lambda _
15650 (setenv "PYTHONPATH"
15651 (string-append (getcwd) ":" (getenv "PYTHONPATH")))
15652 #t))))))))
15653
15654 (define-public python-yapf
15655 (package
15656 (name "python-yapf")
15657 (version "0.29.0")
15658 (source
15659 (origin
15660 (method url-fetch)
15661 (uri (pypi-uri "yapf" version))
15662 (sha256
15663 (base32
15664 "1pj3xzblmbssshi889b6n9hwqbjpabw6j0fimlng2sshd3226bki"))))
15665 (build-system python-build-system)
15666 (home-page "https://github.com/google/yapf")
15667 (synopsis "Formatter for Python code")
15668 (description "YAPF is a formatter for Python code. It's based off of
15669 @dfn{clang-format}, developed by Daniel Jasper. In essence, the algorithm
15670 takes the code and reformats it to the best formatting that conforms to the
15671 style guide, even if the original code didn't violate the style guide.")
15672 (license license:asl2.0)))
15673
15674 (define-public python2-yapf
15675 (package-with-python2 python-yapf))
15676
15677 (define-public python-gyp
15678 (let ((commit "5e2b3ddde7cda5eb6bc09a5546a76b00e49d888f")
15679 (revision "0"))
15680 (package
15681 (name "python-gyp")
15682 ;; Google does not release versions,
15683 ;; based on second most recent commit date.
15684 (version (git-version "0.0.0" revision commit))
15685 (source
15686 (origin
15687 ;; Google does not release tarballs,
15688 ;; git checkout is needed.
15689 (method git-fetch)
15690 (uri (git-reference
15691 (url "https://chromium.googlesource.com/external/gyp")
15692 (commit commit)))
15693 (file-name (git-file-name name version))
15694 (sha256
15695 (base32
15696 "0fr7nxcrk292djmxzpcjaphnsd123k31gp8jnd91vwknhq6snmv9"))))
15697 (build-system python-build-system)
15698 (home-page "https://gyp.gsrc.io/")
15699 (synopsis "GYP is a Meta-Build system")
15700 (description
15701 "GYP builds build systems for large, cross platform applications.
15702 It can be used to generate XCode projects, Visual Studio projects, Ninja build
15703 files, and Makefiles.")
15704 (license license:bsd-3))))
15705
15706 (define-public python2-gyp
15707 (package-with-python2 python-gyp))
15708
15709 (define-public python-whatever
15710 (package
15711 (name "python-whatever")
15712 (version "0.6")
15713 (source
15714 (origin
15715 (method git-fetch)
15716 (uri (git-reference
15717 (url "https://github.com/Suor/whatever")
15718 (commit version)))
15719 (file-name (git-file-name name version))
15720 (sha256
15721 (base32 "1q7ajgqjfivxqsqgnhp4lc4p6jxyh4zprcsdbpd6dw54inaf0av5"))))
15722 (build-system python-build-system)
15723 (arguments
15724 `(#:phases
15725 (modify-phases %standard-phases
15726 (replace 'check
15727 (lambda _
15728 (invoke "py.test"))))))
15729 (native-inputs
15730 `(("python-pytest" ,python-pytest)))
15731 (home-page "http://github.com/Suor/whatever")
15732 (synopsis "Make anonymous functions by partial application of operators")
15733 (description "@code{whatever} provides an easy way to make anonymous
15734 functions by partial application of operators.")
15735 (license license:bsd-3)))
15736
15737 (define-public python2-whatever
15738 (package-with-python2 python-whatever))
15739
15740 (define-public python-funcy
15741 (package
15742 (name "python-funcy")
15743 (version "1.11")
15744 (source
15745 (origin
15746 (method git-fetch)
15747 (uri (git-reference
15748 (url "https://github.com/Suor/funcy.git")
15749 (commit version)))
15750 (sha256
15751 (base32 "1s98vkjnq3zq71737hn8xa15kssvmy1sfzsll3vrlv53902418mw"))
15752 (file-name (git-file-name name version))))
15753 (build-system python-build-system)
15754 (arguments
15755 `(#:phases
15756 (modify-phases %standard-phases
15757 (replace 'check
15758 (lambda _
15759 (invoke "py.test"))))))
15760 (native-inputs
15761 `(("python-pytest" ,python-pytest)
15762 ("python-whatever" ,python-whatever)))
15763 (home-page "http://github.com/Suor/funcy")
15764 (synopsis "Functional tools")
15765 (description "@code{funcy} is a library that provides functional tools.
15766 Examples are:
15767 @enumerate
15768 @item merge - Merges collections of the same type
15769 @item walk - Type-preserving map
15770 @item select - Selects a part of a collection
15771 @item take - Takes the first n items of a collection
15772 @item first - Takes the first item of a collection
15773 @item remove - Predicated-removes items of a collection
15774 @item concat - Concatenates two collections
15775 @item flatten - Flattens a collection with subcollections
15776 @item distinct - Returns only distinct items
15777 @item split - Predicated-splits a collection
15778 @item split_at - Splits a collection at a given item
15779 @item group_by - Groups items by group
15780 @item pairwise - Pairs off adjacent items
15781 @item partial - Partially-applies a function
15782 @item curry - Curries a function
15783 @item compose - Composes functions
15784 @item complement - Complements a predicate
15785 @item all_fn - \"all\" with predicate
15786 @end enumerate")
15787 (license license:bsd-3)))
15788
15789 (define-public python2-funcy
15790 (package-with-python2 python-funcy))
15791
15792 (define-public python-isoweek
15793 (package
15794 (name "python-isoweek")
15795 (version "1.3.3")
15796 (source
15797 (origin
15798 (method url-fetch)
15799 (uri (pypi-uri "isoweek" version))
15800 (sha256
15801 (base32
15802 "1s7zsf0pab0l9gn6456qadnz5i5h90hafcjwnhx5mq23qjxggwvk"))))
15803 (build-system python-build-system)
15804 (home-page "https://github.com/gisle/isoweek")
15805 (synopsis "Objects representing a week")
15806 (description "The @code{isoweek} module provide the class Week that
15807 implements the week definition of ISO 8601. This standard also defines
15808 a notation for identifying weeks; yyyyWww (where the W is a literal).
15809 Week instances stringify to this form.")
15810 (license license:bsd-3)))
15811
15812 (define-public python2-isoweek
15813 (package-with-python2 python-isoweek))
15814
15815 (define-public python-tokenize-rt
15816 (package
15817 (name "python-tokenize-rt")
15818 (version "2.0.1")
15819 (source
15820 (origin
15821 (method url-fetch)
15822 (uri (pypi-uri "tokenize-rt" version))
15823 (sha256
15824 (base32
15825 "1yjvbz7rvrz31zjyax1cgy3xhf4wb3j18jwnj4bnl77ca4gliyiw"))))
15826 (build-system python-build-system)
15827 (home-page "https://github.com/asottile/tokenize-rt")
15828 (synopsis "Wrapper around the stdlib tokenize which roundtrips.")
15829 (description
15830 "This Python library is a wrapper around @code{tokenize} from the Python
15831 standard library. It provides two additional tokens @code{ESCAPED_NL} and
15832 @code{UNIMPORTANT_WS}, and a @code{Token} data type. Use @code{src_to_tokens}
15833 and @code{tokens_to_src} to roundtrip.")
15834 (license license:expat)))
15835
15836 (define-public python-future-fstrings
15837 (package
15838 (name "python-future-fstrings")
15839 (version "0.4.1")
15840 (source
15841 (origin
15842 (method url-fetch)
15843 (uri (pypi-uri "future_fstrings" version))
15844 (sha256
15845 (base32
15846 "0ydxqz2dvns44g55p8ix2x18qkfk3aaz0m0dc70f3g6n8js35h47"))))
15847 (build-system python-build-system)
15848 (propagated-inputs
15849 `(("python-tokenize-rt" ,python-tokenize-rt)))
15850 (home-page "https://github.com/asottile/future-fstrings")
15851 (synopsis "Backport of fstrings to Python < 3.6")
15852 (description
15853 "This package provides a UTF-8 compatible encoding
15854 @code{future_fstrings}, which performs source manipulation. It decodes the
15855 source bytes using the UTF-8 encoding and then rewrites Python 3.6 style
15856 @code{f} strings.")
15857 (license license:expat)))
15858
15859 (define-public python-typed-ast
15860 (package
15861 (name "python-typed-ast")
15862 (version "1.4.0")
15863 (source
15864 (origin
15865 (method git-fetch)
15866 (uri (git-reference
15867 (url "https://github.com/python/typed_ast.git")
15868 (commit version)))
15869 (sha256
15870 (base32 "0l0hz809f7i356kmqkvfsaswiidb98j9hs9rrjnfawzqcbffzgyb"))
15871 (file-name (git-file-name name version))))
15872 (build-system python-build-system)
15873 (arguments
15874 `(#:modules ((guix build utils)
15875 (guix build python-build-system)
15876 (ice-9 ftw)
15877 (srfi srfi-1)
15878 (srfi srfi-26))
15879 #:phases
15880 (modify-phases %standard-phases
15881 (replace 'check
15882 (lambda _
15883 (let ((cwd (getcwd)))
15884 (setenv "PYTHONPATH"
15885 (string-append cwd "/build/"
15886 (find (cut string-prefix? "lib" <>)
15887 (scandir (string-append cwd "/build")))
15888 ":"
15889 (getenv "PYTHONPATH"))))
15890 (invoke "pytest")
15891 #t)))))
15892 (native-inputs `(("python-pytest" ,python-pytest)))
15893 (home-page "https://github.com/python/typed_ast")
15894 (synopsis "Fork of Python @code{ast} modules with type comment support")
15895 (description "This package provides a parser similar to the standard
15896 @code{ast} library. Unlike @code{ast}, the parsers in @code{typed_ast}
15897 include PEP 484 type comments and are independent of the version of Python
15898 under which they are run. The @code{typed_ast} parsers produce the standard
15899 Python AST (plus type comments), and are both fast and correct, as they are
15900 based on the CPython 2.7 and 3.7 parsers.")
15901 ;; See the file "LICENSE" for the details.
15902 (license (list license:psfl
15903 license:asl2.0
15904 license:expat)))) ;ast27/Parser/spark.py
15905
15906 (define-public python-typing
15907 (package
15908 (name "python-typing")
15909 (version "3.6.6")
15910 (source
15911 (origin
15912 (method url-fetch)
15913 (uri (pypi-uri "typing" version))
15914 (sha256
15915 (base32
15916 "0ba9acs4awx15bf9v3nrs781msbd2nx826906nj6fqks2bvca9s0"))))
15917 (build-system python-build-system)
15918 (home-page "https://docs.python.org/3/library/typing.html")
15919 (synopsis "Type hints for Python")
15920 (description "This is a backport of the standard library @code{typing}
15921 module to Python versions older than 3.5. Typing defines a standard notation
15922 for Python function and variable type annotations. The notation can be used
15923 for documenting code in a concise, standard format, and it has been designed
15924 to also be used by static and runtime type checkers, static analyzers, IDEs
15925 and other tools.")
15926 (license license:psfl)))
15927
15928 (define-public python2-typing
15929 (package-with-python2 python-typing))
15930
15931 (define-public python-typing-extensions
15932 (package
15933 (name "python-typing-extensions")
15934 (version "3.7.4.1")
15935 (source
15936 (origin
15937 (method url-fetch)
15938 (uri (pypi-uri "typing_extensions" version))
15939 (sha256
15940 (base32
15941 "1wj1vcgbnm20aiinmphyxfrbv3qi9xdhvw89ab3qm42y9n4wq7h9"))))
15942 (build-system python-build-system)
15943 (home-page
15944 "https://github.com/python/typing/blob/master/typing_extensions/README.rst")
15945 (synopsis "Experimental type hints for Python")
15946 (description
15947 "The typing_extensions module contains additional @code{typing} hints not
15948 yet present in the of the @code{typing} standard library.
15949 Included are implementations of:
15950 @enumerate
15951 @item ClassVar
15952 @item ContextManager
15953 @item Counter
15954 @item DefaultDict
15955 @item Deque
15956 @item NewType
15957 @item NoReturn
15958 @item overload
15959 @item Protocol
15960 @item runtime
15961 @item Text
15962 @item Type
15963 @item TYPE_CHECKING
15964 @item AsyncGenerator
15965 @end enumerate\n")
15966 (license license:psfl)))
15967
15968 (define-public bpython
15969 (package
15970 (name "bpython")
15971 (version "0.18")
15972 (source
15973 (origin
15974 (method url-fetch)
15975 (uri (pypi-uri "bpython" version))
15976 (sha256
15977 (base32 "1hl6frgvr2lqaxqczl8amg9xih32b3gzv429vs0qrjb8wpdj1k2n"))))
15978 (build-system python-build-system)
15979 (arguments
15980 `(#:phases
15981 (modify-phases %standard-phases
15982 (add-after 'unpack 'remove-failing-test
15983 (lambda _
15984 ;; Remove failing test. FIXME: make it pass
15985 (delete-file "bpython/test/test_args.py")
15986 #t))
15987 (add-after 'wrap 'add-aliases
15988 ;; for symmetry to bpython2, add symlinks bypthon3, bpdb3, etc.
15989 (lambda* (#:key outputs #:allow-other-keys)
15990 (let ((out (assoc-ref outputs "out")))
15991 (for-each
15992 (lambda (old new)
15993 (symlink old (string-append out "/bin/" new)))
15994 '("bpython" "bpython-curses" "bpython-urwid" "bpdb")
15995 '("bpython3" "bpython3-curses" "bpython3-urwid" "bpdb3")))
15996 #t)))))
15997 (propagated-inputs
15998 `(("python-pygments" ,python-pygments)
15999 ("python-requests" ,python-requests)
16000 ("python-babel" ,python-babel) ; optional, for internationalization
16001 ("python-curtsies" ,python-curtsies) ; >= 0.1.18
16002 ("python-greenlet" ,python-greenlet)
16003 ("python-urwid" ,python-urwid) ; for bpython-urwid only
16004 ("python-six" ,python-six)))
16005 (native-inputs
16006 `(("python-sphinx" ,python-sphinx)
16007 ("python-mock" ,python-mock)))
16008 (home-page "https://bpython-interpreter.org/")
16009 (synopsis "Fancy interface to the Python interpreter")
16010 (description "Bpython is a fancy interface to the Python
16011 interpreter. bpython's main features are
16012
16013 @enumerate
16014 @item in-line syntax highlighting,
16015 @item readline-like autocomplete with suggestions displayed as you type,
16016 @item expected parameter list for any Python function,
16017 @item \"rewind\" function to pop the last line of code from memory and
16018 re-evaluate,
16019 @item send the code you've entered off to a pastebin,
16020 @item save the code you've entered to a file, and
16021 @item auto-indentation.
16022 @end enumerate")
16023 (license license:expat)))
16024
16025 (define-public bpython2
16026 (let ((base (package-with-python2
16027 (strip-python2-variant bpython))))
16028 (package (inherit base)
16029 (name "bpython2")
16030 (arguments
16031 `(#:python ,python-2
16032 #:phases
16033 (modify-phases %standard-phases
16034 (add-after 'unpack 'remove-failing-test
16035 (lambda _
16036 ;; Remove failing test. FIXME: make it pass
16037 (delete-file "bpython/test/test_args.py")
16038 ;; Disable failing test-cases (renaming inhibits they are
16039 ;; discovered)
16040 (substitute* "bpython/test/test_curtsies_repl.py"
16041 (("^(\\s*def )(test_get_last_word_with_prev_line\\W)" _ a b)
16042 (string-append a "xxx_off_" b))
16043 (("^(\\s*def )(test_complex\\W)" _ a b)
16044 (string-append a "xxx_off_" b)))
16045 #t))
16046 (add-before 'build 'rename-scripts
16047 ;; rename the scripts to bypthon2, bpdb2, etc.
16048 (lambda _
16049 (substitute* "setup.py"
16050 (("^(\\s+'bpdb)(\\s+=.*',?)\\s*?$" _ name rest)
16051 (string-append name "2" rest "\n"))
16052 (("^(\\s+'bpython)(-\\S+)?(\\s+=.*',?)\\s*?$" _ name sub rest)
16053 (string-append name "2" (or sub "") rest "\n")))
16054 #t))))))))
16055
16056 (define-public python-pyinotify
16057 (package
16058 (name "python-pyinotify")
16059 (version "0.9.6")
16060 (source (origin
16061 (method url-fetch)
16062 (uri (pypi-uri "pyinotify" version))
16063 (sha256
16064 (base32
16065 "1x3i9wmzw33fpkis203alygfnrkcmq9w1aydcm887jh6frfqm6cw"))))
16066 (build-system python-build-system)
16067 (arguments `(#:tests? #f)) ;no tests
16068 (home-page "https://github.com/seb-m/pyinotify")
16069 (synopsis "Python library for monitoring inotify events")
16070 (description
16071 "@code{pyinotify} provides a Python interface for monitoring
16072 file system events on Linux.")
16073 (license license:expat)))
16074
16075 (define-public python2-pyinotify
16076 (package-with-python2 python-pyinotify))
16077
16078 ;; Ada parser uses this version.
16079 (define-public python2-quex-0.67.3
16080 (package
16081 (name "python2-quex")
16082 (version "0.67.3")
16083 (source
16084 (origin
16085 (method url-fetch)
16086 (uri (string-append "mirror://sourceforge/quex/HISTORY/"
16087 (version-major+minor version)
16088 "/quex-" version ".zip"))
16089 (sha256
16090 (base32
16091 "14gv8ll3ipqv4kyc2xiy891nrmjl4ic823zfyx8hassagyclyppw"))))
16092 (build-system python-build-system)
16093 (native-inputs
16094 `(("unzip" ,unzip)))
16095 (arguments
16096 `(#:python ,python-2
16097 #:tests? #f
16098 #:phases
16099 (modify-phases %standard-phases
16100 (delete 'configure)
16101 (delete 'build)
16102 (replace 'install
16103 (lambda* (#:key outputs #:allow-other-keys)
16104 (let* ((out (assoc-ref outputs "out"))
16105 (share/quex (string-append out "/share/quex"))
16106 (bin (string-append out "/bin")))
16107 (copy-recursively "." share/quex)
16108 (mkdir-p bin)
16109 (symlink (string-append share/quex "/quex-exe.py")
16110 (string-append bin "/quex"))
16111 #t))))))
16112 (native-search-paths
16113 (list (search-path-specification
16114 (variable "QUEX_PATH")
16115 (files '("share/quex")))))
16116 (home-page "http://quex.sourceforge.net/")
16117 (synopsis "Lexical analyzer generator in Python")
16118 (description "@code{quex} is a lexical analyzer generator in Python.")
16119 (license license:lgpl2.1+))) ; Non-military
16120
16121 (define-public python2-quex
16122 (package (inherit python2-quex-0.67.3)
16123 (name "python2-quex")
16124 (version "0.68.1")
16125 (source
16126 (origin
16127 (method url-fetch)
16128 (uri (string-append "mirror://sourceforge/quex/DOWNLOAD/quex-" version ".tar.gz"))
16129 (sha256
16130 (base32
16131 "0svc9nla3b9145d6b7fb9dizx412l3difzqw0ilh9lz52nsixw8j"))
16132 (file-name (string-append name "-" version ".tar.gz"))))))
16133
16134 (define-public python-more-itertools
16135 (package
16136 (name "python-more-itertools")
16137 (version "7.1.0")
16138 (source
16139 (origin
16140 (method url-fetch)
16141 (uri (pypi-uri "more-itertools" version))
16142 (sha256
16143 (base32
16144 "16phg2f2dvm6ci5wr49ncha5lmc0m2in3bsl33c61vzca4gkvd4b"))))
16145 (build-system python-build-system)
16146 (home-page "https://github.com/erikrose/more-itertools")
16147 (synopsis "More routines for operating on iterables, beyond itertools")
16148 (description "Python's built-in @code{itertools} module implements a
16149 number of iterator building blocks inspired by constructs from APL, Haskell,
16150 and SML. @code{more-itertools} includes additional building blocks for
16151 working with iterables.")
16152 (properties `((python2-variant . ,(delay python2-more-itertools))))
16153 (license license:expat)))
16154
16155 ;; The 5.x series are the last versions supporting Python 2.7.
16156 (define-public python2-more-itertools
16157 (package
16158 (inherit python-more-itertools)
16159 (name "python2-more-itertools")
16160 (version "5.0.0")
16161 (source (origin
16162 (method url-fetch)
16163 (uri (pypi-uri "more-itertools" version))
16164 (sha256
16165 (base32
16166 "1r12cm6mcdwdzz7d47a6g4l437xsvapdlgyhqay3i2nrlv03da9q"))))
16167 (arguments
16168 `(#:python ,python2-minimal))
16169 (propagated-inputs
16170 `(("python2-six" ,python2-six-bootstrap)))))
16171
16172 (define-public python-latexcodec
16173 (package
16174 (name "python-latexcodec")
16175 (version "1.0.7")
16176 (source
16177 (origin
16178 (method url-fetch)
16179 (uri (pypi-uri "latexcodec" version))
16180 (sha256
16181 (base32 "0wnp3yqcgx0rpy8dz51vh75lbp2qif67da19zi7m3ca98n887hgb"))))
16182 (build-system python-build-system)
16183 (inputs
16184 `(("python-six" ,python-six)))
16185 (home-page "https://readthedocs.org/projects/latexcodec/")
16186 (synopsis "Work with LaTeX code in Python")
16187 (description "Lexer and codec to work with LaTeX code in Python.")
16188 (license license:expat)))
16189
16190 (define-public python-pybtex
16191 (package
16192 (name "python-pybtex")
16193 (version "0.22.2")
16194 (source
16195 (origin
16196 (method url-fetch)
16197 (uri (pypi-uri "pybtex" version))
16198 (sha256
16199 (base32 "070wfcmxrd7xg1si421mi9150gmx2qwx431nwf69sq3hhmgnx080"))))
16200 (build-system python-build-system)
16201 (native-inputs
16202 `(("python-nose" ,python-nose)))
16203 (inputs
16204 `(("python-latexcodec" ,python-latexcodec)
16205 ("python-pyyaml" ,python-pyyaml)
16206 ("python-six" ,python-six)))
16207 (arguments
16208 `(#:test-target "nosetests"))
16209 (home-page "https://pybtex.org/")
16210 (synopsis "BibTeX-compatible bibliography processor")
16211 (description "Pybtex is a BibTeX-compatible bibliography processor written
16212 in Python. You can simply type pybtex instead of bibtex.")
16213 (license license:expat)))
16214
16215 (define-public python-onetimepass
16216 (package
16217 (name "python-onetimepass")
16218 (version "1.0.1")
16219 (source
16220 (origin
16221 (method url-fetch)
16222 (uri (pypi-uri "onetimepass" version))
16223 (sha256
16224 (base32 "09vagxgbq78wvq4xbikmn2hpqqsa2i96kqsmphf7dqynfv0dlsd5"))))
16225 (build-system python-build-system)
16226 (propagated-inputs `(("python-six" ,python-six)))
16227 (home-page "https://github.com/tadeck/onetimepass/")
16228 (synopsis "One-time password library")
16229 (description "Python one-time password library for HMAC-based (HOTP) and
16230 time-based (TOTP) passwords.")
16231 (license license:expat)))
16232
16233 (define-public python-parso
16234 (package
16235 (name "python-parso")
16236 (version "0.7.0")
16237 (source
16238 (origin
16239 (method url-fetch)
16240 (uri (pypi-uri "parso" version))
16241 (sha256
16242 (base32
16243 "0b7irps2dqmzq41sxbpvxbivhh1x2hwmbqp45bbpd82446p9z3lh"))))
16244 (native-inputs
16245 `(("python-pytest" ,python-pytest)))
16246 (build-system python-build-system)
16247 (arguments
16248 `(#:phases (modify-phases %standard-phases
16249 (replace 'check
16250 (lambda _ (invoke "pytest" "-vv"))))))
16251 (home-page "https://github.com/davidhalter/parso")
16252 (synopsis "Python Parser")
16253 (description "Parso is a Python parser that supports error recovery and
16254 round-trip parsing for different Python versions (in multiple Python versions).
16255 Parso is also able to list multiple syntax errors in your Python file.")
16256 (license license:expat)))
16257
16258 (define-public python2-parso
16259 (package-with-python2 python-parso))
16260
16261 ;; This version is required for Jedi@0.15, which in turn is needed for
16262 ;; python-language-server.
16263 (define-public python-parso-0.5
16264 (package
16265 (inherit python-parso)
16266 (version "0.5.2")
16267 (source (origin
16268 (method url-fetch)
16269 (uri (pypi-uri "parso" version))
16270 (sha256
16271 (base32
16272 "1qgvrkpma7vylrk047mxxvqd66nwqk978n3ig2w8iz9m3bgjbksm"))))))
16273
16274 (define-public python-async-generator
16275 (package
16276 (name "python-async-generator")
16277 (version "1.10")
16278 (source
16279 (origin
16280 (method url-fetch)
16281 (uri (pypi-uri "async_generator" version))
16282 (sha256
16283 (base32
16284 "0i11f6z6lix8ixi3vsk6s76zvvpmgrw6zjrcwjm0m4hjdh83vfvf"))))
16285 (build-system python-build-system)
16286 (native-inputs
16287 `(("python-pytest" ,python-pytest)))
16288 (home-page "https://github.com/python-trio/async_generator")
16289 (synopsis "Async generators and context managers for Python 3.5+")
16290 (description "@code{async_generator} back-ports Python 3.6's native async
16291 generators and Python 3.7's context managers into Python 3.5.")
16292 ;; Dual licensed.
16293 (license (list license:expat license:asl2.0))))
16294
16295 (define-public python-async-timeout
16296 (package
16297 (name "python-async-timeout")
16298 (version "3.0.1")
16299 (source
16300 (origin
16301 (method url-fetch)
16302 (uri (pypi-uri "async-timeout" version))
16303 (sha256
16304 (base32
16305 "0pscbyr840m7fyfc3r8zv9kgkwdcn9f78p7zsrczciwd09m82g0c"))))
16306 (build-system python-build-system)
16307 (home-page "https://github.com/aio-libs/async_timeout/")
16308 (synopsis "Timeout context manager for asyncio programs")
16309 (description "@code{async-timeout} provides a timeout timeout context
16310 manager compatible with @code{asyncio}.")
16311 (license license:asl2.0)))
16312
16313 (define-public python-glob2
16314 (package
16315 (name "python-glob2")
16316 (version "0.7")
16317 (source
16318 (origin
16319 (method git-fetch)
16320 (uri (git-reference
16321 (url "https://github.com/miracle2k/python-glob2.git")
16322 (commit (string-append "v" version))))
16323 (file-name (git-file-name name version))
16324 (sha256
16325 (base32 "160nh2ay9lw2hi0rixpzb2k87r6ql56k0j2cm87lqz8xc8zbw919"))))
16326 (build-system python-build-system)
16327 (home-page "https://github.com/miracle2k/python-glob2/")
16328 (synopsis "Extended Version of the python buildin glob module")
16329 (description "This is an extended version of the Python
16330 @url{http://docs.python.org/library/glob.html, built-in glob module} which
16331 adds:
16332
16333 @itemize
16334 @item The ability to capture the text matched by glob patterns, and return
16335 those matches alongside the file names.
16336 @item A recursive @code{**} globbing syntax, akin for example to the
16337 @code{globstar} option of Bash.
16338 @item The ability to replace the file system functions used, in order to glob
16339 on virtual file systems.
16340 @item Compatible with Python 2 and Python 3 (tested with 3.3).
16341 @end itemize
16342
16343 Glob2 currently based on the glob code from Python 3.3.1.")
16344 (license license:bsd-2)))
16345
16346 (define-public python2-glob2
16347 (package-with-python2 python-glob2))
16348
16349 (define-public python-gipc
16350 (package
16351 (name "python-gipc")
16352 (version "0.6.0")
16353 (source
16354 (origin
16355 (method url-fetch)
16356 (uri (pypi-uri "gipc" version ".zip"))
16357 (sha256
16358 (base32
16359 "0pd9by719qh882hqs6xpby61sn1x5h98hms5p2p8yqnycrf1s0h2"))))
16360 (build-system python-build-system)
16361 (native-inputs
16362 `(("unzip" ,unzip)))
16363 (propagated-inputs
16364 `(("python-gevent" ,python-gevent)))
16365 (home-page "https://gehrcke.de/gipc/")
16366 (synopsis "Child process management in the context of gevent")
16367 (description "Usage of Python's multiprocessing package in a
16368 gevent-powered application may raise problems. With @code{gipc},
16369 process-based child processes can safely be created anywhere within a
16370 gevent-powered application.")
16371 (license license:expat)))
16372
16373 (define-public python2-gipc
16374 (package-with-python2 python-gipc))
16375
16376 (define-public python-fusepy
16377 (package
16378 (name "python-fusepy")
16379 (version "2.0.4")
16380 (source
16381 (origin
16382 (method url-fetch)
16383 (uri (pypi-uri "fusepy" version))
16384 (sha256
16385 (base32
16386 "0v5grm4zyf58hsplwsxfbihddw95lz9w8cy3rpzbyha287swgx8h"))))
16387 (build-system python-build-system)
16388 (arguments
16389 `(#:phases
16390 (modify-phases %standard-phases
16391 (add-before 'build 'set-library-file-name
16392 (lambda* (#:key inputs #:allow-other-keys)
16393 (let ((fuse (assoc-ref inputs "fuse")))
16394 (substitute* "fuse.py"
16395 (("find_library\\('fuse'\\)")
16396 (string-append "'" fuse "/lib/libfuse.so'")))
16397 #t))))))
16398 (propagated-inputs
16399 `(("fuse" ,fuse)))
16400 (home-page "https://github.com/fusepy/fusepy")
16401 (synopsis "Simple ctypes bindings for FUSE")
16402 (description "Python module that provides a simple interface to FUSE and
16403 MacFUSE. The binding is created using the standard @code{ctypes} library.")
16404 (license license:isc)))
16405
16406 (define-public python2-fusepy
16407 (package-with-python2 python-fusepy))
16408
16409 (define-public python-fusepyng
16410 (package
16411 (name "python-fusepyng")
16412 (version "1.0.7")
16413 (source
16414 (origin
16415 (method url-fetch)
16416 (uri (pypi-uri "fusepyng" version))
16417 (sha256
16418 (base32
16419 "17w9iw6m6zjbmnhs4ikd27pq4mb1nan6k4ahlwyz40463vw6wkwb"))))
16420 (build-system python-build-system)
16421 (arguments
16422 '(#:phases
16423 (modify-phases %standard-phases
16424 (add-after 'unpack 'set-libfuse-path
16425 (lambda* (#:key inputs #:allow-other-keys)
16426 (let ((fuse (assoc-ref inputs "fuse")))
16427 (substitute* "fusepyng.py"
16428 (("os.environ.get\\('FUSE_LIBRARY_PATH'\\)")
16429 (string-append "\"" fuse "/lib/libfuse.so\""))))
16430 #t)))))
16431 (inputs
16432 `(("fuse" ,fuse)))
16433 (propagated-inputs
16434 `(("python-paramiko" ,python-paramiko)))
16435 (home-page "https://github.com/rianhunter/fusepyng")
16436 (synopsis "Simple ctypes bindings for FUSE")
16437 (description "@code{fusepyng} is a Python module that provides a simple
16438 interface to FUSE on various operating systems. It's just one file and is
16439 implemented using @code{ctypes}.")
16440 (license license:isc)))
16441
16442 (define-public python2-gdrivefs
16443 (package
16444 (name "python2-gdrivefs")
16445 (version "0.14.9")
16446 (source
16447 (origin
16448 (method url-fetch)
16449 (uri (pypi-uri "gdrivefs" version))
16450 (sha256
16451 (base32
16452 "0v9sp2cfg4ki3wagkwf3rnfpjhvgf845anz3757il9z95yvvcvb7"))))
16453 (build-system python-build-system)
16454 (arguments
16455 `(#:python ,python-2
16456 #:phases
16457 (modify-phases %standard-phases
16458 (add-before 'build 'patch-setup-py
16459 (lambda _
16460 ;; Update requirements from dependency==version
16461 ;; to dependency>=version
16462 (substitute* "gdrivefs/resources/requirements.txt"
16463 (("==") ">="))
16464 #t)))))
16465 (native-inputs
16466 `(("python2-gipc" ,python2-gipc)
16467 ("python2-gevent" ,python2-gevent)
16468 ("python2-greenlet" ,python2-greenlet)
16469 ("python2-httplib2" ,python2-httplib2)
16470 ("python2-uritemplate" ,python2-uritemplate)
16471 ("python2-oauth2client" ,python2-oauth2client)
16472 ("python2-six" ,python2-six)))
16473 (propagated-inputs
16474 `(("python2-dateutil" ,python2-dateutil)
16475 ("python2-fusepy" ,python2-fusepy)
16476 ("python2-google-api-client" ,python2-google-api-client)))
16477 (home-page "https://github.com/dsoprea/GDriveFS")
16478 (synopsis "Mount Google Drive as a local file system")
16479 (description "@code{gdrivefs} provides a FUSE wrapper for Google Drive
16480 under Python 2.7.")
16481 (license license:gpl2)))
16482
16483 (define-public python-userspacefs
16484 (package
16485 (name "python-userspacefs")
16486 (version "1.0.13")
16487 (source
16488 (origin
16489 (method url-fetch)
16490 (uri (pypi-uri "userspacefs" version))
16491 (sha256
16492 (base32
16493 "0kyz52jyxw3m7hqvn5g6z0sx9cq6k0nq1wj44lvdrghdljjgyk2z"))))
16494 (build-system python-build-system)
16495 (propagated-inputs
16496 `(("python-fusepyng" ,python-fusepyng)))
16497 (home-page "https://github.com/rianhunter/userspacefs")
16498 (synopsis "User-space file systems for Python")
16499 (description
16500 "@code{userspacefs} is a library that allows you to easily write
16501 user-space file systems in Python.")
16502 (license license:gpl3+)))
16503
16504 (define-public pybind11
16505 (package
16506 (name "pybind11")
16507 (version "2.4.3")
16508 (source (origin
16509 (method git-fetch)
16510 (uri (git-reference
16511 (url "https://github.com/pybind/pybind11.git")
16512 (commit (string-append "v" version))))
16513 (sha256
16514 (base32
16515 "0k89w4bsfbpzw963ykg1cyszi3h3nk393qd31m6y46pcfxkqh4rd"))
16516 (file-name (git-file-name name version))))
16517 (build-system cmake-build-system)
16518 (native-inputs
16519 `(("python" ,python-wrapper)
16520
16521 ;; The following dependencies are used for tests.
16522 ("python-pytest" ,python-pytest)
16523 ("catch" ,catch-framework2-1)
16524 ("eigen" ,eigen)))
16525 (arguments
16526 `(#:configure-flags
16527 (list (string-append "-DCATCH_INCLUDE_DIR="
16528 (assoc-ref %build-inputs "catch")
16529 "/include/catch"))
16530
16531 #:phases (modify-phases %standard-phases
16532 (add-after 'install 'install-python
16533 (lambda* (#:key outputs #:allow-other-keys)
16534 (let ((out (assoc-ref outputs "out")))
16535 (with-directory-excursion "../source"
16536 (setenv "PYBIND11_USE_CMAKE" "yes")
16537 (invoke "python" "setup.py" "install"
16538 "--single-version-externally-managed"
16539 "--root=/"
16540 (string-append "--prefix=" out)))))))
16541
16542 #:test-target "check"))
16543 (home-page "https://github.com/pybind/pybind11/")
16544 (synopsis "Seamless operability between C++11 and Python")
16545 (description
16546 "@code{pybind11} is a lightweight header-only library that exposes C++
16547 types in Python and vice versa, mainly to create Python bindings of existing
16548 C++ code. Its goals and syntax are similar to the @code{Boost.Python}
16549 library: to minimize boilerplate code in traditional extension modules by
16550 inferring type information using compile-time introspection.")
16551 (license license:bsd-3)))
16552
16553 (define-public python-fasteners
16554 (package
16555 (name "python-fasteners")
16556 (version "0.14.1")
16557 (source
16558 (origin
16559 (method url-fetch)
16560 (uri (pypi-uri "fasteners" version))
16561 (sha256
16562 (base32
16563 "063y20kx01ihbz2mziapmjxi2cd0dq48jzg587xdsdp07xvpcz22"))))
16564 (build-system python-build-system)
16565 (propagated-inputs
16566 `(("python-monotonic" ,python-monotonic)
16567 ("python-six" ,python-six)
16568 ("python-testtools" ,python-testtools)))
16569 (home-page "https://github.com/harlowja/fasteners")
16570 (synopsis "Python package that provides useful locks")
16571 (description
16572 "This package provides a Python program that provides following locks:
16573
16574 @itemize
16575 @item Locking decorator
16576 @item Reader-writer locks
16577 @item Inter-process locks
16578 @item Generic helpers
16579 @end itemize\n")
16580 (properties `((python2-variant . ,(delay python2-fasteners))))
16581 (license license:asl2.0)))
16582
16583 (define-public python2-fasteners
16584 (let ((base (package-with-python2 (strip-python2-variant python-fasteners))))
16585 (package
16586 (inherit base)
16587 (propagated-inputs
16588 `(("python2-futures" ,python2-futures)
16589 ,@(package-propagated-inputs base))))))
16590
16591 (define-public python-requests-file
16592 (package
16593 (name "python-requests-file")
16594 (version "1.4.3")
16595 (source
16596 (origin
16597 (method url-fetch)
16598 (uri (pypi-uri "requests-file" version))
16599 (sha256
16600 (base32
16601 "1yp2jaxg3v86pia0q512dg3hz6s9y5vzdivsgrba1kds05ial14g"))))
16602 (build-system python-build-system)
16603 (propagated-inputs
16604 `(("python-requests" ,python-requests)
16605 ("python-six" ,python-six)))
16606 (home-page
16607 "https://github.com/dashea/requests-file")
16608 (synopsis "File transport adapter for Requests")
16609 (description
16610 "Requests-File is a transport adapter for use with the Requests Python
16611 library to allow local file system access via @code{file://} URLs.")
16612 (license license:asl2.0)))
16613
16614 (define-public python2-requests-file
16615 (package-with-python2 python-requests-file))
16616
16617 (define-public python-tldextract
16618 (package
16619 (name "python-tldextract")
16620 (version "2.2.0")
16621 (source
16622 (origin
16623 (method url-fetch)
16624 (uri (pypi-uri "tldextract" version))
16625 (sha256
16626 (base32
16627 "1d5s8v6kpsgazyahflhji1cfdcf89rv7l7z55v774bhzvcjp2y99"))))
16628 (build-system python-build-system)
16629 (native-inputs
16630 `(("python-pytest" ,python-pytest)
16631 ("python-responses" ,python-responses)))
16632 (propagated-inputs
16633 `(("python-idna" ,python-idna)
16634 ("python-requests" ,python-requests)
16635 ("python-requests-file" ,python-requests-file)))
16636 (home-page
16637 "https://github.com/john-kurkowski/tldextract")
16638 (synopsis
16639 "Separate the TLD from the registered domain and subdomains of a URL")
16640 (description
16641 "TLDExtract accurately separates the TLD from the registered domain and
16642 subdomains of a URL, using the Public Suffix List. By default, this includes
16643 the public ICANN TLDs and their exceptions. It can optionally support the
16644 Public Suffix List's private domains as well.")
16645 (license license:bsd-3)))
16646
16647 (define-public python2-tldextract
16648 (package-with-python2 python-tldextract))
16649
16650 (define-public python-pynamecheap
16651 (package
16652 (name "python-pynamecheap")
16653 (version "0.0.3")
16654 (source
16655 (origin
16656 (method url-fetch)
16657 (uri (pypi-uri "PyNamecheap" version))
16658 (sha256
16659 (base32
16660 "0wkbwz208j8nfrsmzmclvxg22ymknn0mlz76wbdza9k2bx2zja6l"))))
16661 (build-system python-build-system)
16662 (propagated-inputs
16663 `(("python-requests" ,python-requests)))
16664 (home-page
16665 "https://github.com/Bemmu/PyNamecheap")
16666 (synopsis
16667 "Namecheap API client in Python")
16668 (description
16669 "PyNamecheap is a Namecheap API client in Python.")
16670 (license license:expat)))
16671
16672 (define-public python2-pynamecheap
16673 (package-with-python2 python-pynamecheap))
16674
16675 (define-public python-dns-lexicon
16676 (package
16677 (name "python-dns-lexicon")
16678 (version "2.4.0")
16679 (source
16680 (origin
16681 (method url-fetch)
16682 (uri (pypi-uri "dns-lexicon" version))
16683 (sha256
16684 (base32
16685 "0jdn3ns71bsybr7njgsqr9xlxsqh7zh6phn4ld0liazqdn2l5f6m"))))
16686 (build-system python-build-system)
16687 (arguments
16688 `(#:tests? #f)) ;requires internet access
16689 (propagated-inputs
16690 `(("python-future" ,python-future)
16691 ("python-pynamecheap" ,python-pynamecheap)
16692 ("python-requests" ,python-requests)
16693 ("python-tldextract" ,python-tldextract)
16694 ("python-urllib3" ,python-urllib3)))
16695 (home-page "https://github.com/AnalogJ/lexicon")
16696 (synopsis
16697 "Manipulate DNS records on various DNS providers")
16698 (description
16699 "Lexicon provides a way to manipulate DNS records on multiple DNS
16700 providers in a standardized way. It has a CLI but it can also be used as a
16701 Python library. It was designed to be used in automation, specifically with
16702 Let's Encrypt.")
16703 (license license:expat)))
16704
16705 (define-public python2-dns-lexicon
16706 (package-with-python2 python-dns-lexicon))
16707
16708 (define-public python-commandlines
16709 (package
16710 (name "python-commandlines")
16711 (version "0.4.1")
16712 (source
16713 (origin
16714 (method url-fetch)
16715 (uri (pypi-uri "commandlines" version))
16716 (sha256
16717 (base32
16718 "0r7xcr0knv02p4mswa2bng61nn8nbhhrs6kvdnb9bb3hhjvm1dl6"))))
16719 (build-system python-build-system)
16720 (home-page "https://github.com/chrissimpkins/commandlines")
16721 (synopsis "Command line argument to object parsing library")
16722 (description
16723 "@code{Commandlines} is a Python library for command line application
16724 development that supports command line argument parsing, command string
16725 validation testing and application logic.")
16726 (license license:expat)))
16727
16728 ;; Make sure to upgrade python-llvmlite in (gnu packages llvm) together with
16729 ;; python-numba. They have a very unflexible relationship.
16730 (define-public python-numba
16731 (package
16732 (name "python-numba")
16733 (version "0.46.0")
16734 (source
16735 (origin
16736 (method url-fetch)
16737 (uri (pypi-uri "numba" version))
16738 (sha256
16739 (base32
16740 "1vnfzcq6fcnkmdms6114d49awvvj5181fl7z1wlha27qc2paxjy2"))))
16741 (build-system python-build-system)
16742 (arguments
16743 `(#:modules ((guix build utils)
16744 (guix build python-build-system)
16745 (ice-9 ftw)
16746 (srfi srfi-1)
16747 (srfi srfi-26))
16748 #:phases
16749 (modify-phases %standard-phases
16750 (add-after 'unpack 'disable-proprietary-features
16751 (lambda _
16752 (setenv "NUMBA_DISABLE_HSA" "1")
16753 (setenv "NUMBA_DISABLE_CUDA" "1")
16754 #t))
16755 (add-after 'unpack 'remove-failing-tests
16756 (lambda _
16757 ;; FIXME: These tests fail for unknown reasons:
16758 ;; test_non_writable_pycache, test_non_creatable_pycache, and
16759 ;; test_frozen (all in numba.tests.test_dispatcher.TestCache).
16760 (substitute* "numba/tests/test_dispatcher.py"
16761 (("def test(_non_writable_pycache)" _ m)
16762 (string-append "def guix_skip" m))
16763 (("def test(_non_creatable_pycache)" _ m)
16764 (string-append "def guix_skip" m))
16765 (("def test(_frozen)" _ m)
16766 (string-append "def guix_skip" m)))
16767
16768 ;; These tests fail because we don't run the tests from the build
16769 ;; directory: test_setup_py_distutils, test_setup_py_setuptools
16770 ;; They are in numba.tests.test_pycc.TestDistutilsSupport.
16771 (substitute* "numba/tests/test_pycc.py"
16772 (("def test(_setup_py_distutils|_setup_py_setuptools)" _ m)
16773 (string-append "def guix_skip" m)))
16774
16775 ;; These tests fail because our version of Python does not have
16776 ;; a recognizable front-end for the Numba distribution to use
16777 ;; to check against.
16778 (substitute* "numba/tests/test_entrypoints.py"
16779 (("def test(_init_entrypoint)" _ m)
16780 (string-append "def guix_skip" m)))
16781 (substitute* "numba/tests/test_jitclasses.py"
16782 (("def test(_jitclass_longlabel_not_truncated)" _ m)
16783 (string-append "def guix_skip" m)))
16784 #t))
16785 (replace 'check
16786 (lambda _
16787 (let ((cwd (getcwd)))
16788 (setenv "PYTHONPATH"
16789 (string-append cwd "/build/"
16790 (find (cut string-prefix? "lib" <>)
16791 (scandir (string-append cwd "/build")))
16792 ":"
16793 (getenv "PYTHONPATH")))
16794 ;; Something is wrong with the PYTHONPATH when running the
16795 ;; tests from the build directory, as it complains about not being
16796 ;; able to import certain modules.
16797 (with-directory-excursion "/tmp"
16798 (invoke "python3" "-m" "numba.runtests" "-v" "-m")))
16799 #t)))))
16800 (propagated-inputs
16801 `(("python-llvmlite" ,python-llvmlite)
16802 ("python-numpy" ,python-numpy)
16803 ("python-singledispatch" ,python-singledispatch)))
16804 ;; Needed for tests.
16805 (inputs
16806 `(("python-jinja2" ,python-jinja2)
16807 ("python-pygments" ,python-pygments)))
16808 (home-page "https://numba.pydata.org")
16809 (synopsis "Compile Python code using LLVM")
16810 (description "Numba gives you the power to speed up your applications with
16811 high performance functions written directly in Python. With a few
16812 annotations, array-oriented and math-heavy Python code can be just-in-time
16813 compiled to native machine instructions, similar in performance to C, C++ and
16814 Fortran, without having to switch languages or Python interpreters.
16815
16816 Numba works by generating optimized machine code using the LLVM compiler
16817 infrastructure at import time, runtime, or statically (using the included pycc
16818 tool).")
16819 (license license:bsd-3)))
16820
16821 (define-public python-numcodecs
16822 (package
16823 (name "python-numcodecs")
16824 (version "0.6.4")
16825 (source
16826 (origin
16827 (method url-fetch)
16828 (uri (pypi-uri "numcodecs" version))
16829 (sha256
16830 (base32
16831 "0kbfr8pl3x9glsypbq8hzim003f16ml1b1cvgrh4w1sdvgal6j7g"))))
16832 (build-system python-build-system)
16833 (propagated-inputs
16834 `(("python-numpy" ,python-numpy)
16835 ("python-msgpack" ,python-msgpack)))
16836 (native-inputs
16837 `(("python-pytest" ,python-pytest)
16838 ("python-setuptools-scm" ,python-setuptools-scm)))
16839 (home-page "https://github.com/zarr-developers/numcodecs")
16840 (synopsis "Buffer compression and transformation codecs")
16841 (description
16842 "This Python package provides buffer compression and transformation
16843 codecs for use in data storage and communication applications.")
16844 (license license:expat)))
16845
16846 (define-public python-asciitree
16847 (package
16848 (name "python-asciitree")
16849 (version "0.3.3")
16850 (source
16851 (origin
16852 (method url-fetch)
16853 (uri (pypi-uri "asciitree" version))
16854 (sha256
16855 (base32
16856 "0vhgri2m2xlnibhz4xwn4hpbc7xacisxjqrk6k5kyppq96vbk92a"))))
16857 (build-system python-build-system)
16858 (home-page "https://github.com/mbr/asciitree")
16859 (synopsis "Draws ASCII trees")
16860 (description "This package draws tree structures using characters.")
16861 (license license:expat)))
16862
16863 (define-public python-zarr
16864 (package
16865 (name "python-zarr")
16866 (version "2.4.0")
16867 (source
16868 (origin
16869 (method url-fetch)
16870 (uri (pypi-uri "zarr" version))
16871 (sha256
16872 (base32
16873 "026n3sjzjv2gmwx6y72b8ij0hk42bc8zdbvfj5gdqzd4i6wj3ajk"))))
16874 (build-system python-build-system)
16875 (arguments
16876 `(#:phases
16877 (modify-phases %standard-phases
16878 (add-after 'unpack 'disable-service-tests
16879 (lambda _
16880 (setenv "ZARR_TEST_ABS" "0")
16881 (setenv "ZARR_TEST_MONGO" "0")
16882 (setenv "ZARR_TEST_REDIS" "0")
16883 #t))
16884 (replace 'check
16885 (lambda _
16886 (invoke "pytest" "-vv" "-k" "not lmdb")
16887 #t)))))
16888 (propagated-inputs
16889 `(("python-asciitree" ,python-asciitree)
16890 ("python-fasteners" ,python-fasteners)
16891 ("python-numcodecs" ,python-numcodecs)
16892 ("python-numpy" ,python-numpy)))
16893 (native-inputs
16894 `(("python-pytest" ,python-pytest)
16895 ("python-setuptools-scm" ,python-setuptools-scm)))
16896 (home-page "https://github.com/zarr-developers/zarr-python")
16897 (synopsis "Chunked, compressed, N-dimensional arrays for Python")
16898 (description
16899 "This package provides an implementation of chunked, compressed,
16900 N-dimensional arrays for Python.")
16901 (license license:expat)))
16902
16903 (define-public python-anndata
16904 (package
16905 (name "python-anndata")
16906 (version "0.7.1")
16907 (source
16908 (origin
16909 (method url-fetch)
16910 (uri (pypi-uri "anndata" version))
16911 (sha256
16912 (base32
16913 "0rnfbpr55j1a1bi2kd4mz444741hrn74kz90h5rnjr59jmpfnh09"))))
16914 (build-system python-build-system)
16915 (arguments
16916 `(#:phases
16917 (modify-phases %standard-phases
16918 (add-after 'unpack 'delete-inconvenient-tests
16919 (lambda _
16920 ;; This test depends on python-scikit-learn.
16921 (delete-file "anndata/tests/test_inplace_subset.py")
16922 #t))
16923 (delete 'check)
16924 (add-after 'install 'check
16925 (lambda* (#:key inputs outputs #:allow-other-keys)
16926 (add-installed-pythonpath inputs outputs)
16927 (invoke "pytest" "-vv"))))))
16928 (propagated-inputs
16929 `(("python-h5py" ,python-h5py)
16930 ("python-importlib-metadata" ,python-importlib-metadata)
16931 ("python-natsort" ,python-natsort)
16932 ("python-numcodecs" ,python-numcodecs)
16933 ("python-packaging" ,python-packaging)
16934 ("python-pandas" ,python-pandas)
16935 ("python-scipy" ,python-scipy)
16936 ("python-zarr" ,python-zarr)))
16937 (native-inputs
16938 `(("python-joblib" ,python-joblib)
16939 ("python-pytest" ,python-pytest)
16940 ("python-setuptools-scm" ,python-setuptools-scm)))
16941 (home-page "https://github.com/theislab/anndata")
16942 (synopsis "Annotated data for data analysis pipelines")
16943 (description "Anndata is a package for simple (functional) high-level APIs
16944 for data analysis pipelines. In this context, it provides an efficient,
16945 scalable way of keeping track of data together with learned annotations and
16946 reduces the code overhead typically encountered when using a mostly
16947 object-oriented library such as @code{scikit-learn}.")
16948 (license license:bsd-3)))
16949
16950 (define-public python-dill
16951 (package
16952 (name "python-dill")
16953 (version "0.3.1.1")
16954 (source
16955 (origin
16956 (method url-fetch)
16957 (uri (pypi-uri "dill" version))
16958 (sha256
16959 (base32 "1704g8z70d210ksgbccs2v545v9w0wc6lx15m296alb7jf0yzn22"))))
16960 (build-system python-build-system)
16961 (arguments
16962 `(#:phases
16963 (modify-phases %standard-phases
16964 (replace 'check
16965 (lambda _
16966 (with-directory-excursion "/tmp"
16967 (invoke "nosetests" "-v"))
16968 #t)))))
16969 (native-inputs
16970 `(("python-nose" ,python-nose)))
16971 (home-page "https://pypi.org/project/dill/")
16972 (synopsis "Serialize all of Python")
16973 (description "Dill extends Python's @code{pickle} module for serializing
16974 and de-serializing Python objects to the majority of the built-in Python
16975 types. Dill provides the user the same interface as the @code{pickle} module,
16976 and also includes some additional features. In addition to pickling Python
16977 objects, @code{dill} provides the ability to save the state of an interpreter
16978 session in a single command. Hence, it would be feasible to save a
16979 interpreter session, close the interpreter, ship the pickled file to another
16980 computer, open a new interpreter, unpickle the session and thus continue from
16981 the saved state of the original interpreter session.")
16982 (license license:bsd-3)))
16983
16984 (define-public python-multiprocess
16985 (package
16986 (name "python-multiprocess")
16987 (version "0.70.9")
16988 (source
16989 (origin
16990 (method url-fetch)
16991 (uri (pypi-uri "multiprocess" version))
16992 (sha256
16993 (base32
16994 "1r882nvd44xqwbrclwqx5rhs80l6809rcvpc7pkpgnij06cvvmcz"))))
16995 (build-system python-build-system)
16996 (arguments
16997 `(#:phases
16998 (modify-phases %standard-phases
16999 (add-after 'unpack 'disable-broken-tests
17000 (lambda _
17001 ;; This test is broken as there is no keyboard interrupt.
17002 (substitute* "py3.7/multiprocess/tests/__init__.py"
17003 (("^(.*)def test_wait_result"
17004 line indent)
17005 (string-append indent
17006 "@unittest.skip(\"Disabled by Guix\")\n"
17007 line)))
17008 #t))
17009 ;; Tests must be run after installation.
17010 (delete 'check)
17011 (add-after 'install 'check
17012 (lambda* (#:key inputs outputs #:allow-other-keys)
17013 (add-installed-pythonpath inputs outputs)
17014 (invoke "python" "-m" "multiprocess.tests")
17015 #t)))))
17016 (propagated-inputs
17017 `(("python-dill" ,python-dill)))
17018 (home-page "https://pypi.org/project/multiprocess/")
17019 (synopsis "Multiprocessing and multithreading in Python")
17020 (description
17021 "This package is a fork of the multiprocessing Python package, a package
17022 which supports the spawning of processes using the API of the standard
17023 library's @code{threading} module.")
17024 (license license:bsd-3)))
17025
17026 (define-public python-toolz
17027 (package
17028 (name "python-toolz")
17029 (version "0.9.0")
17030 (source
17031 (origin
17032 (method url-fetch)
17033 (uri (pypi-uri "toolz" version))
17034 (sha256
17035 (base32
17036 "1j9i7fdjnx9dz35fdj5gvgxx6585ja9sxgaiv65if77nlxz0m7wj"))))
17037 (build-system python-build-system)
17038 ;; FIXME: tests cannot be computed: "Can't perform this operation for
17039 ;; unregistered loader type"
17040 (arguments '(#:tests? #f))
17041 (home-page "https://github.com/pytoolz/toolz/")
17042 (synopsis "List processing tools and functional utilities")
17043 (description
17044 "This package provides a set of utility functions for iterators,
17045 functions, and dictionaries.")
17046 (license license:bsd-3)))
17047
17048 (define-public python2-toolz
17049 (package-with-python2 python-toolz))
17050
17051 (define-public python-cytoolz
17052 (package
17053 (name "python-cytoolz")
17054 (version "0.9.0.1")
17055 (source
17056 (origin
17057 (method url-fetch)
17058 (uri (pypi-uri "cytoolz" version))
17059 (sha256
17060 (base32
17061 "1r80p88hm3f3r4zpixzr047y5hw4bzy41m4xywnhycda83x0dk44"))))
17062 (build-system python-build-system)
17063 ;; FIXME: tests fail with "module 'cytoolz.curried' has no attribute
17064 ;; 'exceptions'"
17065 (arguments '(#:tests? #f))
17066 (propagated-inputs
17067 `(("python-toolz" ,python-toolz)))
17068 (native-inputs
17069 `(("python-cython" ,python-cython)))
17070 (home-page "https://github.com/pytoolz/cytoolz")
17071 (synopsis "High performance functional utilities")
17072 (description
17073 "The cytoolz package implements the same API as provided by toolz. The
17074 main differences are that @code{cytoolz} is faster and cytoolz offers a C API
17075 that is accessible to other projects developed in Cython.")
17076 (license license:bsd-3)))
17077
17078 (define-public python-sortedcontainers
17079 (package
17080 (name "python-sortedcontainers")
17081 (version "2.1.0")
17082 (source
17083 (origin
17084 (method url-fetch)
17085 (uri (pypi-uri "sortedcontainers" version))
17086 (sha256
17087 (base32
17088 "0fm0w5id2yhqld95hg2m636vjgkz377rvgdfqaxc25vbylr9lklp"))))
17089 (build-system python-build-system)
17090 (native-inputs
17091 `(("python-tox" ,python-tox)))
17092 (propagated-inputs
17093 `(("python-appdirs" ,python-appdirs)
17094 ("python-distlib" ,python-distlib)
17095 ("python-filelock" ,python-filelock)
17096 ("python-importlib-metadata" ,python-importlib-metadata) ;; python < 3.8
17097 ("python-six" ,python-six)))
17098 (home-page "http://www.grantjenks.com/docs/sortedcontainers/")
17099 (synopsis "Sorted List, Sorted Dict, Sorted Set")
17100 (description
17101 "This package provides a sorted collections library, written in
17102 pure-Python.")
17103 (license license:asl2.0)))
17104
17105 (define-public python-cloudpickle
17106 (package
17107 (name "python-cloudpickle")
17108 (version "1.3.0")
17109 (source
17110 (origin
17111 (method url-fetch)
17112 (uri (pypi-uri "cloudpickle" version))
17113 (sha256
17114 (base32
17115 "0lx7gy9clp427qwcm7b23zdsldpr03gy3vxxhyi8fpbhwz859brq"))))
17116 (build-system python-build-system)
17117 (arguments
17118 '(#:phases (modify-phases %standard-phases
17119 (add-before 'check 'do-not-override-PYTHONPATH
17120 (lambda _
17121 ;; Append to PYTHONPATH instead of overriding it so
17122 ;; that dependencies from Guix can be found.
17123 (substitute* "tests/testutils.py"
17124 (("env\\['PYTHONPATH'\\] = pythonpath")
17125 "env['PYTHONPATH'] += os.pathsep + pythonpath"))
17126 #t))
17127 (replace 'check
17128 (lambda* (#:key tests? #:allow-other-keys)
17129 (if tests?
17130 (invoke "pytest" "-s" "-vv")
17131 (format #t "test suite not run~%"))
17132 #t)))))
17133 (native-inputs
17134 `(;; For tests.
17135 ("python-psutil" ,python-psutil)
17136 ("python-pytest" ,python-pytest)
17137 ("python-tornado" ,python-tornado)))
17138 (home-page "https://github.com/cloudpipe/cloudpickle")
17139 (synopsis "Extended pickling support for Python objects")
17140 (description
17141 "Cloudpickle makes it possible to serialize Python constructs not
17142 supported by the default pickle module from the Python standard library. It
17143 is especially useful for cluster computing where Python expressions are
17144 shipped over the network to execute on remote hosts, possibly close to the
17145 data.")
17146 (properties `((python2-variant . ,(delay python2-cloudpickle))))
17147 (license license:bsd-3)))
17148
17149 (define-public python2-cloudpickle
17150 (let ((base (package-with-python2 (strip-python2-variant python-cloudpickle))))
17151 (package
17152 (inherit base)
17153 (native-inputs
17154 `(("python-mock" ,python2-mock)
17155 ,@(package-native-inputs base)))
17156 (propagated-inputs
17157 `(("python-futures" ,python2-futures)
17158 ,@(package-propagated-inputs base))))))
17159
17160 (define-public python-locket
17161 (package
17162 (name "python-locket")
17163 (version "0.2.0")
17164 (source
17165 (origin
17166 (method url-fetch)
17167 (uri (pypi-uri "locket" version))
17168 (sha256
17169 (base32
17170 "1d4z2zngrpqkrfhnd4yhysh66kjn4mblys2l06sh5dix2p0n7vhz"))))
17171 (build-system python-build-system)
17172 (home-page "https://github.com/mwilliamson/locket.py")
17173 (synopsis "File-based locks for Python")
17174 (description
17175 "Locket implements a lock that can be used by multiple processes provided
17176 they use the same path.")
17177 (license license:bsd-2)))
17178
17179 (define-public python2-locket
17180 (package-with-python2 python-locket))
17181
17182 (define-public python-blosc
17183 (package
17184 (name "python-blosc")
17185 (version "1.5.1")
17186 (source
17187 (origin
17188 (method url-fetch)
17189 (uri (pypi-uri "blosc" version))
17190 (sha256
17191 (base32
17192 "1cm91c6r431yla2mbs4895bgiianjf30dfz14vvv99dslygd65jw"))))
17193 (build-system python-build-system)
17194 ;; FIXME: all tests pass, but then this error is printed:
17195 ;; TypeError: calling <function run at 0x7ffff2568d90> returned None, not a test
17196 (arguments '(#:tests? #f))
17197 (propagated-inputs
17198 `(("python-numpy" ,python-numpy)))
17199 (home-page "https://github.com/blosc/python-blosc")
17200 (synopsis "Python wrapper for the Blosc data compressor library")
17201 (description "Blosc is a high performance compressor optimized for binary
17202 data. It has been designed to transmit data to the processor cache faster
17203 than the traditional, non-compressed, direct memory fetch approach via a
17204 @code{memcpy()} system call.
17205
17206 Blosc works well for compressing numerical arrays that contains data with
17207 relatively low entropy, like sparse data, time series, grids with
17208 regular-spaced values, etc.
17209
17210 This Python package wraps the Blosc library.")
17211 (license license:bsd-3)))
17212
17213 (define-public python2-blosc
17214 (package-with-python2 python-blosc))
17215
17216 (define-public python-partd
17217 (package
17218 (name "python-partd")
17219 (version "0.3.9")
17220 (source
17221 (origin
17222 (method url-fetch)
17223 (uri (pypi-uri "partd" version))
17224 (sha256
17225 (base32
17226 "0sz6rwlnl4fqq220pyz863cnv0gjdxl4m7lscl71ishl5z0xkmhz"))))
17227 (build-system python-build-system)
17228 (propagated-inputs
17229 `(("python-blosc" ,python-blosc)
17230 ("python-locket" ,python-locket)
17231 ("python-numpy" ,python-numpy)
17232 ("python-pandas" ,python-pandas)
17233 ("python-pyzmq" ,python-pyzmq)
17234 ("python-toolz" ,python-toolz)))
17235 (home-page "https://github.com/dask/partd/")
17236 (synopsis "Appendable key-value storage")
17237 (description "Partd stores key-value pairs. Values are raw bytes. We
17238 append on old values. Partd excels at shuffling operations.")
17239 (license license:bsd-3)))
17240
17241 (define-public python2-partd
17242 (package-with-python2 python-partd))
17243
17244 (define-public python-fsspec
17245 (package
17246 (name "python-fsspec")
17247 (version "0.6.1")
17248 (source
17249 (origin
17250 (method url-fetch)
17251 (uri (pypi-uri "fsspec" version))
17252 (sha256
17253 (base32
17254 "1g9ba8v04s1nrh7pvzfm2md7ivl2mrz3hcq3y9d1a44gd62h17zj"))))
17255 (build-system python-build-system)
17256 (arguments '(#:tests? #f)) ; there are none
17257 (home-page "https://github.com/intake/filesystem_spec")
17258 (synopsis "File-system specification")
17259 (description "The purpose of this package is to produce a template or
17260 specification for a file-system interface, that specific implementations
17261 should follow, so that applications making use of them can rely on a common
17262 behavior and not have to worry about the specific internal implementation
17263 decisions with any given backend.")
17264 (license license:bsd-3)))
17265
17266 (define-public python-dask
17267 (package
17268 (name "python-dask")
17269 (version "2.14.0")
17270 (source
17271 (origin
17272 (method url-fetch)
17273 (uri (pypi-uri "dask" version))
17274 (sha256
17275 (base32 "031j0j26s0675v0isyps2dphm03330n7dy8ifdy70jgvf78d119q"))))
17276 (build-system python-build-system)
17277 (arguments
17278 `(#:phases
17279 (modify-phases %standard-phases
17280 (add-after 'unpack 'disable-broken-tests
17281 (lambda _
17282 ;; This test is marked as xfail when pytest-xdist is used.
17283 (substitute* "dask/tests/test_threaded.py"
17284 (("def test_interrupt\\(\\)" m)
17285 (string-append "@pytest.mark.skip(reason=\"Disabled by Guix\")\n"
17286 m)))
17287 ;; This one fails with a type error:
17288 ;; TypeError: Already tz-aware, use tz_convert to convert.
17289 (substitute* "dask/dataframe/tests/test_shuffle.py"
17290 (("def test_set_index_timestamp\\(\\)" m)
17291 (string-append "@pytest.mark.skip(reason=\"Disabled by Guix\")\n"
17292 m)))
17293 #t))
17294 (replace 'check
17295 (lambda _ (invoke "pytest" "-vv"))))))
17296 (propagated-inputs
17297 `(("python-cloudpickle" ,python-cloudpickle)
17298 ("python-fsspec" ,python-fsspec)
17299 ("python-numpy" ,python-numpy)
17300 ("python-packaging" ,python-packaging)
17301 ("python-pandas" ,python-pandas)
17302 ("python-partd" ,python-partd)
17303 ("python-toolz" ,python-toolz)
17304 ("python-pyyaml" ,python-pyyaml)))
17305 (native-inputs
17306 `(("python-pytest" ,python-pytest)
17307 ("python-pytest-runner" ,python-pytest-runner)))
17308 (home-page "https://github.com/dask/dask/")
17309 (synopsis "Parallel computing with task scheduling")
17310 (description
17311 "Dask is a flexible parallel computing library for analytics. It
17312 consists of two components: dynamic task scheduling optimized for computation,
17313 and large data collections like parallel arrays, dataframes, and lists that
17314 extend common interfaces like NumPy, Pandas, or Python iterators to
17315 larger-than-memory or distributed environments. These parallel collections
17316 run on top of the dynamic task schedulers. ")
17317 (license license:bsd-3)))
17318
17319 (define-public python-ilinkedlist
17320 (package
17321 (name "python-ilinkedlist")
17322 (version "0.4.0")
17323 (source
17324 (origin
17325 (method url-fetch)
17326 (uri (pypi-uri "ilinkedlist" version))
17327 (sha256
17328 (base32
17329 "0nrw4sr3afldrp7073hvc0rgdz282s0l819jdmj1i6nn05v33h0l"))))
17330 (build-system python-build-system)
17331 (native-inputs `(("python-pytest" ,python-pytest)))
17332 (inputs `(("python" ,python)))
17333 (home-page "https://github.com/luther9/ilinkedlist-py")
17334 (synopsis "Immutable linked list library")
17335 (description
17336 "This is a implementation of immutable linked lists for Python. It
17337 contains @code{nil} (the empty linked list) and a @code{Pair} class for nodes.
17338 Since a linked list is treated as immutable, it is hashable, and its length
17339 can be retrieved in constant time. Some of the terminology is inspired by
17340 LISP. It is possible to create an improper list by creating a @code{Pair}
17341 with a non-list @code{cdr}.")
17342 (license license:gpl3+)))
17343
17344 (define-public python-readlike
17345 (package
17346 (name "python-readlike")
17347 (version "0.1.3")
17348 (source
17349 (origin
17350 (method url-fetch)
17351 (uri (pypi-uri "readlike" version))
17352 (sha256
17353 (base32 "027w8fvi50ksl57q0a7kb5zvmq8jxaawnviib1jdqw0p3igvm1j4"))))
17354 (build-system python-build-system)
17355 (home-page "https://github.com/jangler/readlike")
17356 (synopsis "GNU Readline-like line editing module")
17357 (description
17358 "This Python module provides line editing functions similar to the default
17359 Emacs-style ones of GNU Readline. Unlike the Python standard library's
17360 @code{readline} package, this one allows access to those capabilties in settings
17361 outside of a standard command-line interface. It is especially well-suited to
17362 interfacing with Urwid, due to a shared syntax for describing key inputs.
17363
17364 Currently, all stateless Readline commands are implemented. Yanking and history
17365 are not supported.")
17366 (license license:expat)))
17367
17368 (define-public python2-readlike
17369 (package-with-python2 python-readlike))
17370
17371 (define-public python-reparser
17372 (package
17373 (name "python-reparser")
17374 (version "1.4.3")
17375 (source
17376 (origin
17377 (method url-fetch)
17378 (uri (pypi-uri "ReParser" version))
17379 (sha256
17380 (base32 "0nniqb69xr0fv7ydlmrr877wyyjb61nlayka7xr08vlxl9caz776"))))
17381 (build-system python-build-system)
17382 (home-page "https://github.com/xmikos/reparser")
17383 (synopsis "Simple lexer/parser for inline markup based on regular expressions")
17384 (description
17385 "This Python library provides a simple lexer/parser for inline markup based
17386 on regular expressions.")
17387 (license license:expat)))
17388
17389 (define-public python2-reparser
17390 (let ((reparser (package-with-python2
17391 (strip-python2-variant python-reparser))))
17392 (package (inherit reparser)
17393 (propagated-inputs
17394 `(("python2-enum34" ,python2-enum34)
17395 ,@(package-propagated-inputs reparser))))))
17396
17397 (define-public python-precis-i18n
17398 (package
17399 (name "python-precis-i18n")
17400 (version "1.0.0")
17401 (source
17402 (origin
17403 (method url-fetch)
17404 (uri (pypi-uri "precis_i18n" version))
17405 (sha256
17406 (base32
17407 "0gjhvwd8aifx94rl1ag08vlmndyx2q3fkyqb0c4i46x3p2bc2yi2"))))
17408 (build-system python-build-system)
17409 (home-page "https://github.com/byllyfish/precis_i18n")
17410 (synopsis "Implementation of the PRECIS framework")
17411 (description
17412 "This module implements the PRECIS Framework as described in RFC 8264,
17413 RFC 8265 and RFC 8266.")
17414 (license license:expat)))
17415
17416 (define-public python-absl-py
17417 (package
17418 (name "python-absl-py")
17419 (version "0.6.1")
17420 (source
17421 (origin
17422 (method url-fetch)
17423 (uri (pypi-uri "absl-py" version))
17424 (sha256
17425 (base32
17426 "1mp9lk0b2qa37b7y6ak4lvf6ifw2ylyy6bkf9ik77md3j4xrwlc7"))))
17427 (build-system python-build-system)
17428 (propagated-inputs
17429 `(("python-six" ,python-six)))
17430 (home-page "https://github.com/abseil/abseil-py")
17431 (synopsis "Abseil Python common libraries")
17432 (description
17433 "This package provides the Abseil Python Common Libraries, a collection
17434 of Python libraries for building Python applications.")
17435 (license license:asl2.0)))
17436
17437 (define-public python-astor
17438 (package
17439 (name "python-astor")
17440 (version "0.7.1")
17441 (source
17442 (origin
17443 (method url-fetch)
17444 (uri (pypi-uri "astor" version))
17445 (sha256
17446 (base32
17447 "13gv6f2xz9i564byp21gcpc0l3w4cs23k1wbcam8kky2ls3hvhwm"))))
17448 (build-system python-build-system)
17449 ;; FIXME: There are two errors and two test failures.
17450 (arguments `(#:tests? #f))
17451 (home-page "https://github.com/berkerpeksag/astor")
17452 (synopsis "Read and write Python ASTs")
17453 (description "Astor is designed to allow easy manipulation of Python
17454 source via the Abstract Syntax Tree.")
17455 (license license:bsd-3)))
17456
17457 (define-public python2-astor
17458 (package-with-python2 python-astor))
17459
17460 (define-public python-astunparse
17461 (package
17462 (name "python-astunparse")
17463 (version "1.6.2")
17464 (source
17465 (origin
17466 (method url-fetch)
17467 (uri (pypi-uri "astunparse" version))
17468 (sha256
17469 (base32 "0rzbc44xcvzjhhiy7wac96mgal5mcjz1mfq8rmvgswskf4kf9cys"))))
17470 (build-system python-build-system)
17471 (arguments '(#:tests? #f)) ; there are none
17472 (propagated-inputs
17473 `(("python-six" ,python-six)
17474 ("python-wheel" ,python-wheel)))
17475 (home-page "https://github.com/simonpercivall/astunparse")
17476 (synopsis "AST unparser for Python")
17477 (description "This package provides an AST unparser for Python. It is a
17478 factored out version of @code{unparse} found in the Python source
17479 distribution.")
17480 (license license:bsd-3)))
17481
17482 (define-public python-gast
17483 (package
17484 (name "python-gast")
17485 (version "0.3.3")
17486 (source
17487 (origin
17488 (method url-fetch)
17489 (uri (pypi-uri "gast" version))
17490 (sha256
17491 (base32 "0mrvvfzqafj1wzd0xxfmjf4vphnlxypbhpic1m283aj9i8lfz0dq"))))
17492 (build-system python-build-system)
17493 (propagated-inputs
17494 `(("python-astunparse" ,python-astunparse)))
17495 (home-page "https://pypi.org/project/gast/")
17496 (synopsis "Generic Python AST that abstracts the underlying Python version")
17497 (description
17498 "GAST provides a compatibility layer between the AST of various Python
17499 versions, as produced by @code{ast.parse} from the standard @code{ast}
17500 module.")
17501 (license license:bsd-3)))
17502
17503 (define-public python-wikidata
17504 (package
17505 (name "python-wikidata")
17506 (version "0.6.1")
17507 (source
17508 (origin
17509 (method url-fetch)
17510 (uri (pypi-uri "Wikidata" version))
17511 (sha256
17512 (base32
17513 "08nlnydddfp1jj0cdmshvld1irzngbp3dij928wqsg9ziklm6mw9"))))
17514 (build-system python-build-system)
17515 (propagated-inputs
17516 `(("python-babel" ,python-babel)))
17517 (home-page "https://github.com/dahlia/wikidata")
17518 (synopsis "Wikidata client library")
17519 (description
17520 "This package provides a Python interface to
17521 @url{https://www.wikidata.org/, Wikidata}.")
17522 (properties '((upstream-name . "Wikidata")))
17523 (license license:gpl3+)))
17524
17525 (define-public python-doctest-ignore-unicode
17526 (package
17527 (name "python-doctest-ignore-unicode")
17528 (version "0.1.2")
17529 (source
17530 (origin
17531 (method url-fetch)
17532 (uri (pypi-uri "doctest-ignore-unicode" version))
17533 (sha256
17534 (base32
17535 "1m9aa4qnyj21lbq4sbvmv1vcz7zksss4rz37ddf2hxv4hk8b547w"))))
17536 (build-system python-build-system)
17537 (native-inputs
17538 `(("python-nose" ,python-nose)))
17539 (home-page "https://github.com/gnublade/doctest-ignore-unicode")
17540 (synopsis "Ignore Unicode literal prefixes in doctests")
17541 (description
17542 "This package adds support for a flag to ignore Unicode literal prefixes
17543 in doctests.")
17544 (license license:asl2.0)))
17545
17546 (define-public python-attr
17547 (package
17548 (name "python-attr")
17549 (version "0.3.1")
17550 (source
17551 (origin
17552 (method url-fetch)
17553 (uri (pypi-uri "attr" version))
17554 (sha256
17555 (base32
17556 "0pbpskvxp5hzdvcaf766ljwpckshir8sf7z6jqji6zyib20594ch"))))
17557 (build-system python-build-system)
17558 (home-page "https://github.com/denis-ryzhkov/attr")
17559 (synopsis "Decorator for attributes of target function or class")
17560 (description "Simple decorator to set attributes of target function or
17561 class in a @acronym{DRY, Don't Repeat Yourself} way.")
17562 (license license:expat)))
17563
17564 (define-public python-construct
17565 (package
17566 (name "python-construct")
17567 (version "2.10.56")
17568 (source
17569 (origin
17570 (method url-fetch)
17571 (uri (pypi-uri "construct" version))
17572 (sha256
17573 (base32
17574 "0q86jjzsvy835h3c8pjj4619vbp7ihfg8njmyw86ym4qrpni7flp"))))
17575 (build-system python-build-system)
17576 (arguments
17577 `(#:tests? #f)) ; No tests exist.
17578 (propagated-inputs
17579 `(("python-extras" ,python-extras)
17580 ("python-arrow" ,python-arrow)
17581 ("python-numpy" ,python-numpy)
17582 ("python-ruamel.yaml" ,python-ruamel.yaml)))
17583 (home-page "https://construct.readthedocs.io")
17584 (synopsis "Declarative and symmetrical parser and builder for binary data")
17585 (description
17586 "This package provides both simple, atomic constructs (such as
17587 integers of various sizes), as well as composite ones which allow you
17588 form hierarchical and sequential structures of increasing complexity.
17589 It features bit and byte granularity, easy debugging and testing, an
17590 easy-to-extend subclass system, and lots of primitive constructs to
17591 make your work easier.")
17592 (license license:expat)))
17593
17594 (define-public python-humanize
17595 (package
17596 (name "python-humanize")
17597 (version "0.5.1")
17598 (source
17599 (origin
17600 (method url-fetch)
17601 (uri (pypi-uri "humanize" version))
17602 (sha256
17603 (base32
17604 "06dvhm3k8lf2rayn1gxbd46y0fy1db26m3h9vrq7rb1ib08mfgx4"))))
17605 (arguments
17606 '(#:tests? #f)) ; tests not in pypi archive
17607 (build-system python-build-system)
17608 (home-page "https://github.com/jmoiron/humanize")
17609 (synopsis "Print numerical information in a human-readable form")
17610 (description "This package provides a Python module that displays numbers
17611 and dates in \"human readable\" forms. For example, it would display
17612 \"12345591313\" as \"12.3 billion\".")
17613 (license license:expat)))
17614
17615 (define-public python-txaio
17616 (package
17617 (name "python-txaio")
17618 (version "18.8.1")
17619 (source
17620 (origin
17621 (method url-fetch)
17622 (uri (pypi-uri "txaio" version))
17623 (sha256
17624 (base32
17625 "1zmpdph6zddgrnkkcykh6qk5s46l7s5mzfqrh82m4b5iffn61qv7"))))
17626 (build-system python-build-system)
17627 (propagated-inputs
17628 `(("python-twisted" ,python-twisted)
17629 ("python-six" ,python-six)))
17630 (home-page "https://github.com/crossbario/txaio")
17631 (synopsis "Compatibility layer between Python asyncio and Twisted")
17632 (description "Txaio provides a compatibility layer between the Python
17633 @code{asyncio} module and @code{Twisted}.")
17634 (license license:expat)))
17635
17636 (define-public python-toolshed
17637 (package
17638 (name "python-toolshed")
17639 (version "0.4.6")
17640 (source
17641 (origin
17642 (method url-fetch)
17643 (uri (pypi-uri "toolshed" version))
17644 (sha256
17645 (base32
17646 "14zvz51gzf9i1i3d1sj363ba4rksl6lcf4lz1arl8hpqgcbir8r3"))))
17647 (build-system python-build-system)
17648 (native-inputs
17649 `(("python-nose" ,python-nose)))
17650 (home-page "https://github.com/brentp/toolshed/")
17651 (synopsis "Collection of modules and functions for working with data")
17652 (description "This is a collection of well-tested, simple modules and
17653 functions that aim to reduce boilerplate when working with data.")
17654 (license license:bsd-2)))
17655
17656 (define-public python-annoy
17657 (package
17658 (name "python-annoy")
17659 (version "1.15.1")
17660 (source
17661 (origin
17662 (method url-fetch)
17663 (uri (pypi-uri "annoy" version))
17664 (sha256
17665 (base32
17666 "1rxn6snn0r32r07g45hdjhh8aa1xzx6fjrm8g62d8vzp46z7rzrp"))))
17667 (build-system python-build-system)
17668 (native-inputs
17669 `(("python-nose" ,python-nose)))
17670 (home-page "https://github.com/spotify/annoy/")
17671 (synopsis "Approximate nearest neighbors library")
17672 (description
17673 "Annoy is a C++ library with Python bindings to search for points in
17674 space that are close to a given query point. It also creates large read-only
17675 file-based data structures that are @code{mmap}ped into memory so that many
17676 processes may share the same data.")
17677 (license license:asl2.0)))
17678
17679 (define-public python-pylzma
17680 (package
17681 (name "python-pylzma")
17682 (version "0.5.0")
17683 (source
17684 (origin
17685 (method url-fetch)
17686 (uri (pypi-uri "pylzma" version))
17687 (sha256
17688 (base32
17689 "074anvhyjgsv2iby2ql1ixfvjgmhnvcwjbdz8gk70xzkzcm1fx5q"))))
17690 (build-system python-build-system)
17691 (home-page "http://www.joachim-bauch.de/projects/pylzma/")
17692 (synopsis "Python bindings for the LZMA library by Igor Pavlov.")
17693 (description "This package provides Python bindings for the LZMA library
17694 by Igor Pavlov.")
17695 (license license:lgpl2.1+)))
17696
17697 (define-public python2-pylzma
17698 (package-with-python2 python-pylzma))
17699
17700 (define-public python2-zeroconf
17701 (package
17702 (name "python2-zeroconf")
17703
17704 ;; This is the last version that supports Python 2.x.
17705 (version "0.19.1")
17706 (source
17707 (origin
17708 (method url-fetch)
17709 (uri (pypi-uri "zeroconf" version))
17710 (sha256
17711 (base32
17712 "0ykzg730n915qbrq9bn5pn06bv6rb5zawal4sqjyfnjjm66snkj3"))))
17713 (build-system python-build-system)
17714 (arguments
17715 `(#:python ,python-2
17716 #:phases
17717 (modify-phases %standard-phases
17718 (add-after 'unpack 'patch-requires
17719 (lambda* (#:key inputs #:allow-other-keys)
17720 (substitute* "setup.py"
17721 (("enum-compat")
17722 "enum34"))
17723 #t)))))
17724 (native-inputs
17725 `(("python2-six" ,python2-six)
17726 ("python2-enum32" ,python2-enum34)
17727 ("python2-netifaces" ,python2-netifaces)
17728 ("python2-typing" ,python2-typing)))
17729 (home-page "https://github.com/jstasiak/python-zeroconf")
17730 (synopsis "Pure Python mDNS service discovery")
17731 (description
17732 "Pure Python multicast DNS (mDNS) service discovery library (Bonjour/Avahi
17733 compatible).")
17734 (license license:lgpl2.1+)))
17735
17736 (define-public python-bsddb3
17737 (package
17738 (name "python-bsddb3")
17739 (version "6.2.6")
17740 (source
17741 (origin
17742 (method url-fetch)
17743 (uri (pypi-uri "bsddb3" version))
17744 (sha256
17745 (base32
17746 "019db2y6bfmiqbrgg9x9f6h72qjmqh05czdn2v5sy9bl0gs23mj2"))))
17747 (build-system python-build-system)
17748 (inputs
17749 `(("bdb" ,bdb)))
17750 (arguments
17751 '(#:phases
17752 (modify-phases %standard-phases
17753 (add-after 'unpack 'configure-locations
17754 (lambda* (#:key inputs #:allow-other-keys)
17755 (setenv "BERKELEYDB_DIR" (assoc-ref inputs "bdb"))
17756 (setenv "YES_I_HAVE_THE_RIGHT_TO_USE_THIS_BERKELEY_DB_VERSION" "1")
17757 #t))
17758 (replace 'check
17759 (lambda _
17760 (invoke "python3" "test3.py" "-v"))))))
17761 (home-page "https://www.jcea.es/programacion/pybsddb.htm")
17762 (synopsis "Python bindings for Oracle Berkeley DB")
17763 (description
17764 "This module provides a nearly complete wrapping of the Oracle/Sleepycat
17765 C API for the Database Environment, Database, Cursor, Log Cursor, Sequence and
17766 Transaction objects, and each of these is exposed as a Python type in the
17767 bsddb3.db module. The database objects can use various access methods: btree,
17768 hash, recno, and queue. Complete support of Berkeley DB distributed
17769 transactions. Complete support for Berkeley DB Replication Manager.
17770 Complete support for Berkeley DB Base Replication. Support for RPC.")
17771 (license license:bsd-3)))
17772
17773 (define-public python-dbfread
17774 (package
17775 (name "python-dbfread")
17776 (version "2.0.7")
17777 (source (origin
17778 (method url-fetch)
17779 (uri (pypi-uri "dbfread" version))
17780 (sha256
17781 (base32
17782 "0gdpwdzf1fngsi6jrdyj4qdf6cr7gnnr3zp80dpkzbgz0spskj07"))))
17783 (build-system python-build-system)
17784 (native-inputs
17785 `(("python-pytest" ,python-pytest)))
17786 (home-page "https://dbfread.readthedocs.io")
17787 (synopsis "Read DBF Files with Python")
17788 (description
17789 "This library reads DBF files and returns the data as native Python data
17790 types for further processing. It is primarily intended for batch jobs and
17791 one-off scripts.")
17792 (license license:expat)))
17793
17794 (define-public python-cached-property
17795 (package
17796 (name "python-cached-property")
17797 (version "1.5.1")
17798 (source
17799 (origin
17800 (method url-fetch)
17801 (uri (pypi-uri "cached-property" version))
17802 (sha256
17803 (base32
17804 "010m1bl380l2r3vwq24r5v14l6gwvgm9v0mqqjkjss552jgsa5wj"))))
17805 (build-system python-build-system)
17806 (arguments
17807 `(#:phases
17808 (modify-phases %standard-phases
17809 ;; https://github.com/pydanny/cached-property/issues/131
17810 ;; recent versions of freezegun break one test
17811 (add-after 'unpack 'disable-broken-test
17812 (lambda _
17813 (substitute* "tests/test_cached_property.py"
17814 (("def test_threads_ttl_expiry\\(self\\)" m)
17815 (string-append "@unittest.skip(\"Disabled by Guix\")\n"
17816 " " m)))
17817 #t)))))
17818 (native-inputs
17819 `(("python-freezegun" ,python-freezegun)))
17820 (home-page
17821 "https://github.com/pydanny/cached-property")
17822 (synopsis
17823 "Decorator for caching properties in classes")
17824 (description
17825 "This package provides a decorator which makes caching
17826 time-or-computationally-expensive properties quick and easy and works in Python
17827 2 or 3.")
17828 (license license:bsd-3)))
17829
17830 (define-public python-folium
17831 (package
17832 (name "python-folium")
17833 (version "0.10.1")
17834 (source
17835 (origin
17836 (method url-fetch)
17837 (uri (pypi-uri "folium" version))
17838 (sha256
17839 (base32
17840 "0gcc267wxwxr57ry86pqpbiyfvl0g48hfvgy0f2mz9s58g87kgzd"))))
17841 (build-system python-build-system)
17842 (propagated-inputs
17843 `(("python-branca" ,python-branca)
17844 ("python-jinja2" ,python-jinja2)
17845 ("python-numpy" ,python-numpy)
17846 ("python-requests" ,python-requests)))
17847 (native-inputs
17848 `(("python-pytest" ,python-pytest)))
17849 (home-page "https://github.com/python-visualization/folium")
17850 (synopsis "Make beautiful maps with Leaflet.js & Python")
17851 (description "@code{folium} makes it easy to visualize data that’s been
17852 manipulated in Python on an interactive leaflet map. It enables both the
17853 binding of data to a map for @code{choropleth} visualizations as well as
17854 passing rich vector/raster/HTML visualizations as markers on the map.
17855
17856 The library has a number of built-in tilesets from OpenStreetMap, Mapbox, and
17857 Stamen, and supports custom tilesets with Mapbox or Cloudmade API keys. It
17858 supports Image, Video, GeoJSON and TopoJSON overlays.")
17859 (license license:expat)))
17860
17861 (define-public jube
17862 (package
17863 ;; This is a command-line tool, so no "python-" prefix.
17864 (name "jube")
17865 (version "2.2.2")
17866 (source (origin
17867 (method url-fetch)
17868 (uri (string-append
17869 "http://apps.fz-juelich.de/jsc/jube/jube2/download.php?version="
17870 version))
17871 (sha256
17872 (base32
17873 "0xq4k1q63s1p6swgyp61vahlrd1fqmgbm0gm5kpj8ikwy0yc0nqk"))
17874 (file-name (string-append "jube-" version ".tar.gz"))))
17875 (build-system python-build-system)
17876 (home-page "https://apps.fz-juelich.de/jsc/jube/jube2/docu/index.html")
17877 (synopsis "Benchmarking environment")
17878 (description
17879 "JUBE helps perform and analyze benchmarks in a systematic way. For each
17880 benchmarked application, benchmark data is stored in a format that allows JUBE
17881 to deduct the desired information. This data can be parsed by automatic pre-
17882 and post-processing scripts that draw information and store it more densely
17883 for manual interpretation.")
17884 (license license:gpl3+)))
17885
17886 (define-public python-pyroutelib3
17887 (package
17888 (name "python-pyroutelib3")
17889 (version "1.3.post1")
17890 (source
17891 (origin
17892 (method url-fetch)
17893 (uri (pypi-uri "pyroutelib3" version))
17894 (sha256
17895 (base32
17896 "1hpbydpn2alyswiajfbvhzq4c7f36vdmvxy91hgv8l1lb2g2vfrj"))))
17897 (build-system python-build-system)
17898 (propagated-inputs
17899 `(("python-dateutil" ,python-dateutil)))
17900 (home-page "https://github.com/MKuranowski/pyroutelib3")
17901 (synopsis "Library for simple routing on OSM data")
17902 (description "Library for simple routing on OSM data")
17903 (license license:gpl3+)))
17904
17905 (define-public python-bibtexparser
17906 (package
17907 (name "python-bibtexparser")
17908 (version "1.1.0")
17909 (source
17910 (origin
17911 (method url-fetch)
17912 (uri (pypi-uri "bibtexparser" version))
17913 (sha256
17914 (base32
17915 "0zwhfkrzf3n5847dbnfng92k7ak199l9v6x6ax3dgdidfpm6d2fz"))))
17916 (build-system python-build-system)
17917 (propagated-inputs
17918 `(("python-pyparsing" ,python-pyparsing)))
17919 (native-inputs
17920 `(("python-future" ,python-future)))
17921 (home-page "https://github.com/sciunto-org/python-bibtexparser")
17922 (synopsis "Python library to parse BibTeX files")
17923 (description "BibtexParser is a Python library to parse BibTeX files.")
17924 (license (list license:bsd-3 license:lgpl3))))
17925
17926 (define-public python-distro
17927 (package
17928 (name "python-distro")
17929 (version "1.4.0")
17930 (source
17931 (origin
17932 (method url-fetch)
17933 (uri (pypi-uri "distro" version))
17934 (sha256
17935 (base32
17936 "0mrg75w4ap7mdzyga75yaid9n8bgb345ih5mwjp3plj6v1jxwb9n"))))
17937 (build-system python-build-system)
17938 (native-inputs
17939 `(("python-pytest" ,python-pytest)))
17940 (home-page "https://github.com/nir0s/distro")
17941 (synopsis
17942 "OS platform information API")
17943 (description
17944 "@code{distro} provides information about the OS distribution it runs on,
17945 such as a reliable machine-readable ID, or version information.
17946
17947 It is the recommended replacement for Python's original
17948 `platform.linux_distribution` function (which will be removed in Python 3.8).
17949 @code{distro} also provides a command-line interface to output the platform
17950 information in various formats.")
17951 (license license:asl2.0)))
17952
17953 (define-public python-cairosvg
17954 (package
17955 (name "python-cairosvg")
17956 (version "2.4.2")
17957 (source
17958 (origin
17959 (method url-fetch)
17960 (uri (pypi-uri "CairoSVG" version))
17961 (sha256
17962 (base32 "1bb7irxbaxxb9ahm3z5wsx1q96mm5gzskc7b6q07h9ikcnb8yrjf"))))
17963 (build-system python-build-system)
17964 (arguments
17965 `(#:phases
17966 (modify-phases %standard-phases
17967 (replace 'check
17968 (lambda _ (invoke "pytest"))))))
17969 (propagated-inputs
17970 `(("python-cairocffi" ,python-cairocffi)
17971 ("python-cssselect2" ,python-cssselect2)
17972 ("python-defusedxml" ,python-defusedxml)
17973 ("python-pillow" ,python-pillow)
17974 ("python-tinycss2" ,python-tinycss2)))
17975 (native-inputs
17976 `(("python-pytest-flake8" ,python-pytest-flake8)
17977 ("python-pytest-isort" ,python-pytest-isort)
17978 ("python-pytest-runner" ,python-pytest-runner)))
17979 (home-page "https://cairosvg.org/")
17980 (synopsis "SVG to PDF/PS/PNG converter based on Cairo")
17981 (description "CairoSVG is a SVG converter based on Cairo. It can export
17982 SVG files to PDF, PostScript and PNG files. The main part of CairoSVG is a
17983 SVG parser, trying to follow the SVG 1.1 recommendation from the W3C. Once
17984 parsed, the result is drawn to a Cairo surface that can be exported to
17985 qvarious formats: PDF, PostScript, PNG and even SVG.")
17986 (license license:lgpl3+)))
17987
17988 (define-public python-pyphen
17989 (package
17990 (name "python-pyphen")
17991 (version "0.9.5")
17992 (source
17993 (origin
17994 (method url-fetch)
17995 (uri (pypi-uri "Pyphen" version))
17996 (sha256
17997 (base32 "08c9y69ry9d6m4zalhnalg86lsp9v2j5n1ziw5vxfmiihx83lqrv"))))
17998 (build-system python-build-system)
17999 ;; TODO: Use the Guix system hyphenation packages hyphen-* rather than the
18000 ;; embedded set provided by upstream - like Debian does.
18001 (home-page "https://github.com/Kozea/Pyphen")
18002 (synopsis "Pure Python module to hyphenate text")
18003 (description "Pyphen is a pure Python module to hyphenate text using
18004 existing Hunspell hyphenation dictionaries.")
18005 (license (list license:gpl2 license:lgpl2.1 license:mpl1.1))))
18006
18007 (define-public python-intelhex
18008 (package
18009 (name "python-intelhex")
18010 (version "2.2.1")
18011 (source
18012 (origin
18013 (method url-fetch)
18014 (uri (pypi-uri "intelhex" version))
18015 (sha256
18016 (base32
18017 "0ckqjbxd8gwcg98gfzpn4vq1qxzfvq3rdbrr1hikj1nmw08qb780"))))
18018 (build-system python-build-system)
18019 (arguments '(#:tests? #f)) ;issue with version
18020 (home-page "https://pypi.org/project/IntelHex/")
18021 (synopsis "Python library for Intel HEX files manipulations")
18022 (description "The Intel HEX file format is widely used in microprocessors
18023 and microcontrollers area (embedded systems etc.) as the de facto standard for
18024 representation of code to be programmed into microelectronic devices. This
18025 package provides an intelhex Python library to read, write, create from
18026 scratch and manipulate data from Intel HEX file format. It also includes
18027 several convenience Python scripts, including \"classic\" hex2bin and bin2hex
18028 converters and more, those based on the library itself.")
18029 (license license:bsd-3)))
18030
18031 (define-public python-pykwalify
18032 (package
18033 (name "python-pykwalify")
18034 (version "1.7.0")
18035 (source
18036 (origin
18037 (method url-fetch)
18038 (uri (pypi-uri "pykwalify" version))
18039 (sha256
18040 (base32
18041 "1cnfzkg1b01f825ikpw2fhjclf9c8akxjfrbd1vc22x1lg2kk2vy"))))
18042 (build-system python-build-system)
18043 (arguments '(#:tests? #f)) ;missing dependencies
18044 (propagated-inputs
18045 `(("python-dateutil" ,python-dateutil)
18046 ("python-docopt" ,python-docopt)
18047 ("python-pyyaml" ,python-pyyaml)))
18048 (home-page "https://github.com/grokzen/pykwalify")
18049 (synopsis
18050 "Python lib/cli for JSON/YAML schema validation")
18051 (description
18052 "This package provides a parser, schema validator, and data binding tool
18053 for YAML and JSON.")
18054 (license license:expat)))
18055
18056 (define-public python-dbusmock
18057 (package
18058 (name "python-dbusmock")
18059 (version "0.18.3")
18060 (source
18061 (origin
18062 (method url-fetch)
18063 (uri (pypi-uri "python-dbusmock" version))
18064 (sha256
18065 (base32
18066 "0hp2kyac88nh9iv6l8hlmv7s1sa1s5f1a3wc2pmlmmxnd211fjlr"))))
18067 (build-system python-build-system)
18068 (arguments
18069 '(#:phases
18070 (modify-phases %standard-phases
18071 (add-after 'unpack 'patch-shell-path
18072 (lambda _
18073 (substitute* "tests/test_code.py"
18074 (("/bin/bash") (which "bash")))
18075 #t)))))
18076 (native-inputs
18077 `(;; For tests.
18078 ("dbus" ,dbus) ; for dbus-daemon
18079 ("python-nose" ,python-nose)
18080 ("which" ,which)))
18081 (propagated-inputs
18082 `(("python-dbus" ,python-dbus)
18083 ("python-pygobject" ,python-pygobject)))
18084 (home-page "https://github.com/martinpitt/python-dbusmock")
18085 (synopsis "Python library for mock D-Bus objects")
18086 (description "python-dbusmock allows for the easy creation of mock objects on
18087 D-Bus. This is useful for writing tests for software which talks to D-Bus
18088 services such as upower, systemd, logind, gnome-session or others, and it is
18089 hard (or impossible without root privileges) to set the state of the real
18090 services to what you expect in your tests.")
18091 (license license:lgpl3+)))
18092
18093 (define-public python-ujson
18094 (package
18095 (name "python-ujson")
18096 (version "1.35")
18097 (source
18098 (origin
18099 (method url-fetch)
18100 (uri (pypi-uri "ujson" version))
18101 (sha256
18102 (base32
18103 "11jz5wi7mbgqcsz52iqhpyykiaasila4lq8cmc2d54bfa3jp6q7n"))))
18104 (build-system python-build-system)
18105 (home-page "http://www.esn.me")
18106 (synopsis
18107 "Ultra fast JSON encoder and decoder for Python")
18108 (description
18109 "UltraJSON is an ultra fast JSON encoder and decoder written in pure C with
18110 bindings for Python 2.5+ and 3.")
18111 (license license:bsd-3)))
18112
18113 (define-public python2-ujson
18114 (package-with-python2 python-ujson))
18115
18116 (define-public python-iocapture
18117 ;; The latest release is more than a year older than this commit.
18118 (let ((commit "fdc021c431d0840303908dfc3ca8769db383595c")
18119 (revision "1"))
18120 (package
18121 (name "python-iocapture")
18122 (version "0.1.2")
18123 (source
18124 (origin
18125 (method git-fetch)
18126 (uri (git-reference
18127 (url "https://github.com/oinume/iocapture.git")
18128 (commit commit)))
18129 (file-name (git-file-name name version))
18130 (sha256
18131 (base32
18132 "1mkbhqibxvgwg0p7slr8dfraa3g2s6bsayladhax2jccwj4kcndz"))))
18133 (build-system python-build-system)
18134 (arguments
18135 `(#:phases
18136 (modify-phases %standard-phases
18137 (delete 'check)
18138 (add-after 'install 'check
18139 (lambda* (#:key inputs outputs #:allow-other-keys)
18140 (add-installed-pythonpath inputs outputs)
18141 (invoke "py.test" "-v" "tests")
18142 #t)))))
18143 (propagated-inputs
18144 `(("python-flexmock" ,python-flexmock)
18145 ("python-pytest" ,python-pytest)
18146 ("python-pytest-cov" ,python-pytest-cov)
18147 ("python-six" ,python-six)))
18148 (home-page "https://github.com/oinume/iocapture")
18149 (synopsis "Python capturing tool for stdout and stderr")
18150 (description
18151 "This package helps you to capture the standard out (stdout) and the
18152 standard error channel (stderr) in your program.")
18153 (license license:expat))))
18154
18155 (define-public python-argh
18156 ;; There are 21 commits since the latest release containing important
18157 ;; improvements.
18158 (let ((commit "dcd3253f2994400a6a58a700c118c53765bc50a4")
18159 (revision "1"))
18160 (package
18161 (name "python-argh")
18162 (version (git-version "0.26.2" revision commit))
18163 (source
18164 (origin
18165 (method git-fetch)
18166 (uri (git-reference
18167 (url "https://github.com/neithere/argh.git")
18168 (commit commit)))
18169 (file-name (git-file-name name version))
18170 (sha256
18171 (base32
18172 "1p5h3dnpbsjmqrvil96s71asc6i3gpinmbrabqmwnrsxprz7r3ns"))))
18173 (build-system python-build-system)
18174 (propagated-inputs
18175 `(("python-iocapture" ,python-iocapture)
18176 ("python-mock" ,python-mock)
18177 ("python-pytest" ,python-pytest)
18178 ("python-pytest-cov" ,python-pytest-cov)
18179 ("python-pytest-xdist" ,python-pytest-xdist)
18180 ("python-tox" ,python-tox)))
18181 (home-page "https://github.com/neithere/argh/")
18182 (synopsis "Argparse wrapper with natural syntax")
18183 (description
18184 "python-argh is a small library that provides several layers of
18185 abstraction on top of @code{python-argparse}. The layers can be mixed. It is
18186 always possible to declare a command with the highest possible (and least
18187 flexible) layer and then tune the behaviour with any of the lower layers
18188 including the native API of @code{python-argparse}.")
18189 (license license:lgpl3+))))
18190
18191 (define-public python-ppft
18192 (package
18193 (name "python-ppft")
18194 (version "1.6.6.1")
18195 (source
18196 (origin
18197 (method url-fetch)
18198 (uri (pypi-uri "ppft" version))
18199 (sha256
18200 (base32
18201 "1z1invkhszc5d2mvgr221v7cszzifcc77mz0pv3wjp6x5q2768cy"))))
18202 (build-system python-build-system)
18203 (arguments '(#:tests? #f)) ; there are none
18204 (propagated-inputs
18205 `(("python-six" ,python-six)))
18206 (home-page "https://pypi.org/project/ppft/")
18207 (synopsis "Fork of Parallel Python")
18208 (description
18209 "This package is a fork of Parallel Python. The Parallel Python
18210 module (@code{pp}) provides an easy and efficient way to create
18211 parallel-enabled applications for @dfn{symmetric multiprocessing} (SMP)
18212 computers and clusters. It features cross-platform portability and dynamic
18213 load balancing.")
18214 (license license:bsd-3)))
18215
18216 (define-public python-pox
18217 (package
18218 (name "python-pox")
18219 (version "0.2.7")
18220 (source
18221 (origin
18222 (method url-fetch)
18223 (uri (pypi-uri "pox" version))
18224 (sha256
18225 (base32
18226 "0y17ckc2p6i6709s279sjdj4q459mpcc38ymg9zv9y6vl6jf3bq6"))))
18227 (build-system python-build-system)
18228 (arguments
18229 `(#:phases
18230 (modify-phases %standard-phases
18231 (replace 'check
18232 (lambda _
18233 (mkdir-p "/tmp/guix")
18234 (setenv "SHELL" "bash")
18235 (setenv "USERNAME" "guix")
18236 (setenv "HOME" "/tmp/guix") ; must end on USERNAME...
18237 (invoke "py.test" "-vv")
18238 #t)))))
18239 (native-inputs
18240 `(("python-pytest" ,python-pytest)
18241 ("which" ,which)))
18242 (home-page "https://pypi.org/project/pox/")
18243 (synopsis "Python utilities for filesystem exploration and automated builds")
18244 (description
18245 "Pox provides a collection of utilities for navigating and manipulating
18246 filesystems. This module is designed to facilitate some of the low level
18247 operating system interactions that are useful when exploring a filesystem on a
18248 remote host. Pox provides Python equivalents of several shell commands such
18249 as @command{which} and @command{find}. These commands allow automated
18250 discovery of what has been installed on an operating system, and where the
18251 essential tools are located.")
18252 (license license:bsd-3)))
18253
18254 (define-public python-pathos
18255 (package
18256 (name "python-pathos")
18257 (version "0.2.5")
18258 (source
18259 (origin
18260 (method url-fetch)
18261 (uri (pypi-uri "pathos" version))
18262 (sha256
18263 (base32
18264 "0in8hxdz7k081ijn6q94gr39ycy7363sx4zysmbwyvd7snqjrbi1"))))
18265 (build-system python-build-system)
18266 (arguments
18267 '(#:phases
18268 (modify-phases %standard-phases
18269 (replace 'check
18270 (lambda _
18271 (setenv "PYTHONPATH"
18272 (string-append (getcwd) ":" (getenv "PYTHONPATH")))
18273 (invoke "python" "./tests/__main__.py"))))))
18274 (propagated-inputs
18275 `(("python-dill" ,python-dill)
18276 ("python-multiprocess" ,python-multiprocess)
18277 ("python-pox" ,python-pox)
18278 ("python-ppft" ,python-ppft)))
18279 (native-inputs
18280 `(("python-pytest" ,python-pytest)))
18281 (home-page "https://pypi.org/project/pathos/")
18282 (synopsis
18283 "Parallel graph management and execution in heterogeneous computing")
18284 (description
18285 "Python-pathos is a framework for heterogenous computing. It provides a
18286 consistent high-level interface for configuring and launching parallel
18287 computations across heterogenous resources. Python-pathos provides configurable
18288 launchers for parallel and distributed computing, where each launcher contains
18289 the syntactic logic to configure and launch jobs in an execution environment.")
18290 (license license:bsd-3)))
18291
18292 (define-public python-flit
18293 (package
18294 (name "python-flit")
18295 (version "2.1.0")
18296 (source
18297 (origin
18298 (method url-fetch)
18299 (uri (pypi-uri "flit" version))
18300 (sha256
18301 (base32
18302 "0h5vvmqinqzn97mr3ix7zx53af9ad4fimjjwqpx88yp8qhz4r5bc"))))
18303 (build-system python-build-system)
18304 (arguments
18305 `(#:tests? #f)) ; XXX: Check requires network access.
18306 (home-page "https://flit.readthedocs.io/")
18307 (synopsis
18308 "Simple packaging tool for simple packages")
18309 (description
18310 "Flit is a simple way to put Python packages and modules on PyPI. Flit
18311 packages a single importable module or package at a time, using the import
18312 name as the name on PyPI. All subpackages and data files within a package
18313 are included automatically.")
18314 (license license:bsd-3)))
18315
18316 (define-public python-pathtools
18317 (package
18318 (name "python-pathtools")
18319 (version "0.1.2")
18320 (source
18321 (origin
18322 (method url-fetch)
18323 (uri (pypi-uri "pathtools" version))
18324 (sha256
18325 (base32
18326 "1h7iam33vwxk8bvslfj4qlsdprdnwf8bvzhqh3jq5frr391cadbw"))))
18327 (build-system python-build-system)
18328 (home-page
18329 "https://github.com/gorakhargosh/pathtools")
18330 (synopsis "Path utilities for Python")
18331 (description "Pattern matching and various utilities for file systems
18332 paths.")
18333 (license license:expat)))
18334
18335 (define-public python-fastentrypoints
18336 (package
18337 (name "python-fastentrypoints")
18338 (version "0.12")
18339 (source
18340 (origin
18341 (method url-fetch)
18342 (uri (pypi-uri "fastentrypoints" version))
18343 (sha256
18344 (base32
18345 "02s1j8i2dzbpbwgq2a3fiqwm3cnmhii2qzc0k42l0rdxd4a4ya7z"))))
18346 (build-system python-build-system)
18347 (home-page
18348 "https://github.com/ninjaaron/fast-entry_points")
18349 (synopsis
18350 "Makes entry_points specified in setup.py load more quickly")
18351 (description
18352 "Using entry_points in your setup.py makes scripts that start really
18353 slowly because it imports pkg_resources. This package allows such setup
18354 scripts to load entry points more quickly.")
18355 (license license:bsd-3)))
18356
18357 (define-public python-funcparserlib
18358 (package
18359 (name "python-funcparserlib")
18360 (version "0.3.6")
18361 (source
18362 (origin
18363 (method url-fetch)
18364 (uri (pypi-uri "funcparserlib" version))
18365 (sha256
18366 (base32
18367 "07f9cgjr3h4j2m67fhwapn8fja87vazl58zsj4yppf9y3an2x6dp"))))
18368 (native-inputs
18369 `(("python-tox" ,python-tox)))
18370 (arguments
18371 `(#:phases
18372 (modify-phases %standard-phases
18373 (replace 'check
18374 (lambda _
18375 (invoke "tox"))))))
18376 (build-system python-build-system)
18377 (home-page
18378 "https://github.com/vlasovskikh/funcparserlib")
18379 (synopsis
18380 "Recursive descent parsing library based on functional combinators")
18381 (description
18382 "This package is a recursive descent parsing library for Python based on
18383 functional combinators. Parser combinators are just higher-order functions
18384 that take parsers as their arguments and return them as result values.")
18385 (license license:expat)))
18386
18387 (define-public python-speg
18388 (package
18389 (name "python-speg")
18390 (version "0.3")
18391 (source
18392 (origin
18393 (method url-fetch)
18394 (uri (pypi-uri "speg" version ".zip"))
18395 (sha256
18396 (base32 "0w9y4jf4787dzhy6rvhwi0mpl0r8qkqmqmyv2hpwdpv8w53yzjqh"))))
18397 (arguments
18398 `(#:tests? #f)) ;FIXME: tests fail, not sure why
18399 (native-inputs
18400 `(("unzip" ,unzip)))
18401 (build-system python-build-system)
18402 (home-page "https://github.com/avakar/speg")
18403 (synopsis "PEG-based parser interpreter with memoization")
18404 (description "This package is a PEG-based parser and interpreter with
18405 memoization.")
18406 (license license:expat)))
18407
18408 (define-public python-cson
18409 (package
18410 (name "python-cson")
18411 (version "0.8")
18412 (source
18413 (origin
18414 (method url-fetch)
18415 (uri (pypi-uri "cson" version))
18416 (sha256
18417 (base32 "00cyvigg4npbph39ghkg77xbxisa6plf75vii24igxfizik0337f"))))
18418 (build-system python-build-system)
18419 (propagated-inputs
18420 `(("python-speg" ,python-speg)))
18421 (home-page "https://github.com/avakar/pycson")
18422 (synopsis "Parser for Coffeescript Object Notation (CSON)")
18423 (description "This package is a parser for Coffeescript Object
18424 Notation (CSON).")
18425 (license license:expat)))
18426
18427 (define-public python-asynctest
18428 (package
18429 (name "python-asynctest")
18430 (version "0.13.0")
18431 (source
18432 (origin
18433 (method url-fetch)
18434 (uri (pypi-uri "asynctest" version))
18435 (sha256
18436 (base32
18437 "1b3zsy7p84gag6q8ai2ylyrhx213qdk2h2zb6im3xn0m5n264y62"))))
18438 (build-system python-build-system)
18439 (arguments
18440 '(#:phases
18441 (modify-phases %standard-phases
18442 (replace 'check
18443 (lambda _
18444 (invoke "python" "-X" "dev" "-m" "unittest" "-v" "test")))
18445 (add-after 'unpack 'disable-tests
18446 (lambda* _
18447 (substitute* "test/test_selector.py"
18448 ;; XXX: This test fails for unknown reason inside the build
18449 ;; environment.
18450 (("def test_events_watched_outside_test_are_ignored")
18451 "@unittest.skip('disabled by guix')
18452 def test_events_watched_outside_test_are_ignored")))))))
18453 (home-page "https://github.com/Martiusweb/asynctest")
18454 (synopsis "Extension of unittest for testing asyncio libraries")
18455 (description
18456 "The package asynctest is built on top of the standard unittest module
18457 and cuts down boilerplate code when testing libraries for asyncio.")
18458 (license license:asl2.0)))
18459
18460 (define-public python-aionotify
18461 (package
18462 (name "python-aionotify")
18463 (version "0.2.0")
18464 (source
18465 (origin
18466 ;; Source tarball on PyPi lacks tests
18467 (method git-fetch)
18468 (uri (git-reference
18469 (url "https://github.com/rbarrois/aionotify")
18470 (commit (string-append "v" version))))
18471 (file-name (git-file-name name version))
18472 (sha256
18473 (base32 "1sk9i8czxgsbrswsf1nlb4c82vgnlzi8zrvrxdip92w2z8hqh43y"))))
18474 (build-system python-build-system)
18475 (native-inputs `(("python-asynctest" ,python-asynctest)))
18476 (home-page "https://github.com/rbarrois/aionotify")
18477 (synopsis "Asyncio-powered inotify library")
18478 (description
18479 "@code{aionotify} is a simple, asyncio-based inotify library.")
18480 (license license:bsd-3)))
18481
18482 (define-public python-forbiddenfruit
18483 (package
18484 (name "python-forbiddenfruit")
18485 (version "0.1.3")
18486 (source
18487 (origin
18488 ;; Source tarball on PyPi lacks Makefile that builds and runs tests
18489 (method git-fetch)
18490 (uri (git-reference
18491 (url "https://github.com/clarete/forbiddenfruit")
18492 (commit version)))
18493 (file-name (git-file-name name version))
18494 (sha256
18495 (base32 "1fp2xvdqpi910j9r3q68x38phpxbm700gjdi2m2j5gs91xdnyyh2"))))
18496 (build-system python-build-system)
18497 (arguments
18498 '(#:phases
18499 (modify-phases %standard-phases
18500 (replace 'check
18501 (lambda _
18502 (invoke "make" "SKIP_DEPS=1"))))))
18503 (native-inputs
18504 `(("python-nose" ,python-nose)
18505 ("python-coverage" ,python-coverage)))
18506 (home-page "https://github.com/clarete/forbiddenfruit")
18507 (synopsis "Patch python built-in objects")
18508 (description "This project allows Python code to extend built-in types.")
18509 (license (list license:gpl3+ license:expat))))
18510
18511 (define-public python-shouldbe
18512 (package
18513 (name "python-shouldbe")
18514 (version "0.1.2")
18515 (source
18516 (origin
18517 (method url-fetch)
18518 (uri (pypi-uri "shouldbe" version))
18519 (sha256
18520 (base32
18521 "16zbvjxf71dl4yfbgcr6idyim3mdrfvix1dv8b95p0s9z07372pj"))))
18522 (build-system python-build-system)
18523 (propagated-inputs
18524 `(("python-forbiddenfruit" ,python-forbiddenfruit)))
18525 (native-inputs
18526 `(("python-nose" ,python-nose)))
18527 (home-page "https://github.com/directxman12/should_be")
18528 (synopsis "Python Assertion Helpers inspired by Shouldly")
18529 (description
18530 "Python Assertion Helpers inspired by Shouldly.")
18531 (license license:isc)))
18532
18533 (define-public python-k5test
18534 (package
18535 (name "python-k5test")
18536 (version "0.9.2")
18537 (source
18538 (origin
18539 (method url-fetch)
18540 (uri (pypi-uri "k5test" version))
18541 (sha256
18542 (base32
18543 "1lqp3jgfngyhaxjgj3n230hn90wsylwilh120yjf62h7b1s02mh8"))))
18544 (build-system python-build-system)
18545 (propagated-inputs
18546 `(("python-six" ,python-six)
18547 ;; `which`, `kadmin.local` binaries called inside library
18548 ("which" ,which)
18549 ("mit-krb5" ,mit-krb5)))
18550 (native-inputs `(("mit-krb5" ,mit-krb5)))
18551 (arguments
18552 '(#:phases
18553 (modify-phases %standard-phases
18554 (add-after 'unpack 'patch-paths
18555 (lambda* _
18556 (substitute* "k5test/realm.py"
18557 (("'kadmin_local'") "'kadmin.local'")))))))
18558 (home-page "https://github.com/pythongssapi/k5test")
18559 (synopsis "Library for setting up self-contained Kerberos 5 environments")
18560 (description
18561 "@code{k5test} is a library for setting up self-contained Kerberos 5
18562 environments, and running Python unit tests inside those environments. It is
18563 based on the file of the same name found alongside the MIT Kerberos 5 unit
18564 tests.")
18565 (license license:isc)))
18566
18567 (define-public python-gssapi
18568 (package
18569 (name "python-gssapi")
18570 (version "1.6.5")
18571 (source
18572 (origin
18573 (method url-fetch)
18574 (uri (pypi-uri "gssapi" version))
18575 (sha256
18576 (base32
18577 "02i5s7998dg5kcr4m0xwamd8vjqk1816xbzldyp68l91f6bynwcr"))))
18578 (build-system python-build-system)
18579 (propagated-inputs
18580 `(("python-decorator" ,python-decorator)
18581 ("python-six" ,python-six)))
18582 (inputs
18583 `(("mit-krb5" ,mit-krb5)))
18584 ;; for tests
18585 (native-inputs
18586 `(("python-shouldbe" ,python-shouldbe)
18587 ("python-parameterized" ,python-parameterized)
18588 ("python-k5test" ,python-k5test)
18589 ("python-nose" ,python-nose)))
18590 (home-page "https://github.com/pythongssapi/python-gssapi")
18591 (synopsis "Python GSSAPI Wrapper")
18592 (description
18593 "Python-GSSAPI provides both low-level and high level wrappers around the
18594 GSSAPI C libraries. While it focuses on the Kerberos mechanism, it should
18595 also be useable with other GSSAPI mechanisms.")
18596 (license license:isc)))
18597
18598 (define-public python-check-manifest
18599 (package
18600 (name "python-check-manifest")
18601 (version "0.37")
18602 (source
18603 (origin
18604 (method url-fetch)
18605 (uri (pypi-uri "check-manifest" version))
18606 (sha256
18607 (base32
18608 "0lk45ifdv2cpkl6ayfyix7jwmnxa1rha7xvb0ih5999k115wzqs4"))))
18609 (build-system python-build-system)
18610 (native-inputs
18611 `(("python-mock" ,python-mock)
18612 ("git" ,git)))
18613 (home-page "https://github.com/mgedmin/check-manifest")
18614 (synopsis "Check MANIFEST.in in a Python source package for completeness")
18615 (description "Python package can include a MANIFEST.in file to help with
18616 sending package files to the Python Package Index. This package checks that
18617 file to ensure it completely and accurately describes your project.")
18618 (license license:expat)))
18619
18620 (define-public python-android-stringslib
18621 (package
18622 (name "python-android-stringslib")
18623 (version "0.1.2")
18624 (source
18625 (origin
18626 (method git-fetch)
18627 (uri (git-reference
18628 (url "https://framagit.org/tyreunom/python-android-strings-lib")
18629 (commit (string-append "v" version))))
18630 (file-name (git-file-name name version))
18631 (sha256
18632 (base32
18633 "0gij55qzzq1h83kfpvhai1vf78kkhyvxa6l17m2nl24454lhfin4"))))
18634 (build-system python-build-system)
18635 (arguments
18636 `(#:tests? #f))
18637 (home-page "https://framagit.org/tyreunom/python-android-strings-lib")
18638 (synopsis "Android strings.xml support")
18639 (description "Android Strings Lib provides support for android's strings.xml
18640 files. These files are used to translate strings in android apps.")
18641 (license license:expat)))
18642
18643 (define-public python-watchdog
18644 (package
18645 (name "python-watchdog")
18646 (version "0.9.0")
18647 (source
18648 (origin
18649 (method url-fetch)
18650 (uri (pypi-uri "watchdog" version))
18651 (sha256
18652 (base32
18653 "07cnvvlpif7a6cg4rav39zq8fxa5pfqawchr46433pij0y6napwn"))))
18654 (build-system python-build-system)
18655 (arguments
18656 `(#:phases
18657 (modify-phases %standard-phases
18658 (add-before 'check 'remove-failing
18659 (lambda _
18660 (delete-file "tests/test_inotify_buffer.py")
18661 (delete-file "tests/test_snapshot_diff.py")
18662 #t)))))
18663 (propagated-inputs
18664 `(("python-argh" ,python-argh)
18665 ("python-pathtools" ,python-pathtools)
18666 ("python-pyyaml" ,python-pyyaml)))
18667 (native-inputs
18668 `(("python-pytest-cov" ,python-pytest-cov)
18669 ("python-pytest-timeout" ,python-pytest-timeout)))
18670 (home-page "https://github.com/gorakhargosh/watchdog")
18671 (synopsis "Filesystem events monitoring")
18672 (description "This package provides a way to monitor filesystem events
18673 such as a file modification and trigger an action. This is similar to inotify,
18674 but portable.")
18675 (license license:asl2.0)))
18676
18677 (define-public python-wget
18678 (package
18679 (name "python-wget")
18680 (version "3.2")
18681 (source
18682 (origin
18683 (method url-fetch)
18684 (uri (pypi-uri "wget" version ".zip"))
18685 (sha256
18686 (base32
18687 "0qb0y7ipby42m4m7h0ipazpdyc3bn9xi46lvifcwwl5albn31rim"))))
18688 (build-system python-build-system)
18689 (native-inputs `(("unzip" ,unzip)))
18690 (home-page "https://bitbucket.org/techtonik/python-wget/")
18691 (synopsis "Pure Python download utility")
18692 (description "The python-wget library provides an API to download files
18693 with features similar to the @command{wget} utility.")
18694 (license license:unlicense)))
18695
18696 (define-public offlate
18697 (package
18698 (name "offlate")
18699 (version "0.5")
18700 (source
18701 (origin
18702 (method git-fetch)
18703 (uri (git-reference
18704 (url "https://framagit.org/tyreunom/offlate")
18705 (commit version)))
18706 (file-name (git-file-name name version))
18707 (sha256
18708 (base32
18709 "13pqnbl05wcyldfvl75fp89vjgwsvxyc69vhnb17kkha2rc2k1h7"))))
18710 (build-system python-build-system)
18711 (arguments
18712 ;; No tests
18713 `(#:tests? #f))
18714 (propagated-inputs
18715 `(("python-android-stringslib" ,python-android-stringslib)
18716 ("python-dateutil" ,python-dateutil)
18717 ("python-gitlab" ,python-gitlab)
18718 ("python-lxml" ,python-lxml)
18719 ("python-polib" ,python-polib)
18720 ("python-pyenchant" ,python-pyenchant)
18721 ("python-pygit2" ,python-pygit2)
18722 ("python-pygithub" ,python-pygithub)
18723 ("python-pyqt" ,python-pyqt)
18724 ("python-requests" ,python-requests)
18725 ("python-ruamel.yaml" ,python-ruamel.yaml)
18726 ("python-translation-finder" ,python-translation-finder)
18727 ("python-watchdog" ,python-watchdog)))
18728 (native-inputs
18729 `(("qttools" ,qttools)))
18730 (home-page "https://framagit.org/tyreunom/offlate")
18731 (synopsis "Offline translation interface for online translation tools")
18732 (description "Offlate offers a unified interface for different translation
18733 file formats, as well as many different online translation platforms. You can
18734 use it to get work from online platforms, specialized such as the Translation
18735 Project, or not such a gitlab instance when your upstream doesn't use any
18736 dedicated platform. The tool proposes a unified interface for any format and
18737 an upload option to send your work back to the platform.")
18738 (license license:gpl3+)))
18739
18740 (define-public python-titlecase
18741 (package
18742 (name "python-titlecase")
18743 (version "0.12.0")
18744 (source
18745 (origin
18746 (method url-fetch)
18747 (uri (pypi-uri "titlecase" version))
18748 (sha256
18749 (base32
18750 "0486i99wf8ssa7sgn81fn6fv6i4rhhq6n751bc740b3hzfbpmpl4"))))
18751 (build-system python-build-system)
18752 (native-inputs
18753 `(("python-nose" ,python-nose)))
18754 (home-page "https://github.com/ppannuto/python-titlecase")
18755 (synopsis "Capitalize strings similar to book titles")
18756 (description
18757 "Python-Titlecase is a Python port of John Gruber's titlecase.pl.
18758 It capitalizes (predominantly English) strings in a way that is similar to
18759 book titles, using the New York Times Manual of Style to leave certain words
18760 lowercase.")
18761 (license license:expat)))
18762
18763 (define-public python-pypng
18764 (package
18765 (name "python-pypng")
18766 (version "0.0.20")
18767 (source
18768 (origin
18769 (method url-fetch)
18770 (uri (pypi-uri "pypng" version))
18771 (sha256
18772 (base32 "02qpa22ls41vwsrzw9r9qhj1nhq05p03hb5473pay6y980s86chh"))))
18773 (build-system python-build-system)
18774 (home-page "https://github.com/drj11/pypng")
18775 (synopsis "Pure Python PNG image encoder/decoder")
18776 (description
18777 "The PyPNG module implements support for PNG images. It reads and writes
18778 PNG files with all allowable bit depths (1/2/4/8/16/24/32/48/64 bits per
18779 pixel) and colour combinations: greyscale (1/2/4/8/16 bit); RGB, RGBA,
18780 LA (greyscale with alpha) with 8/16 bits per channel; colour mapped
18781 images (1/2/4/8 bit). Adam7 interlacing is supported for reading and writing.
18782 A number of optional chunks can be specified (when writing) and
18783 understood (when reading): tRNS, bKGD, gAMA.
18784
18785 PyPNG is not a high level toolkit for image processing (like PIL) and does not
18786 aim at being a replacement or competitor. Its strength lies in fine-grained
18787 extensive support of PNG features. It can also read and write Netpbm PAM
18788 files, with a focus on its use as an intermediate format for implementing
18789 custom PNG processing.")
18790 (license license:expat)))
18791
18792 (define-public python-fuzzywuzzy
18793 (package
18794 (name "python-fuzzywuzzy")
18795 (version "0.18.0")
18796 (source
18797 (origin
18798 (method url-fetch)
18799 (uri (pypi-uri "fuzzywuzzy" version))
18800 (sha256
18801 (base32
18802 "1s00zn75y2dkxgnbw8kl8dw4p1mc77cv78fwfa4yb0274s96w0a5"))))
18803 (build-system python-build-system)
18804 (native-inputs
18805 `(("python-hypothesis" ,python-hypothesis)
18806 ("python-pycodestyle" ,python-pycodestyle)
18807 ("python-pytest" ,python-pytest)))
18808 (propagated-inputs
18809 `(("python-levenshtein" ,python-levenshtein)))
18810 (home-page "https://github.com/seatgeek/fuzzywuzzy")
18811 (synopsis "Fuzzy string matching in Python")
18812 (description "Approximate string matching using
18813 @emph{Levenshtein Distance} to calculate the differences between
18814 sequences.")
18815 (license license:gpl2)))
18816
18817 (define-public python2-fuzzywuzzy
18818 (package-with-python2 python-fuzzywuzzy))
18819
18820 (define-public python-block-tracing
18821 (package
18822 (name "python-block-tracing")
18823 (version "1.0.1")
18824 (source
18825 (origin
18826 (method url-fetch)
18827 (uri (pypi-uri "block_tracing" version))
18828 (sha256
18829 (base32
18830 "0s2y729qr5rs7n506qfh8cssk8m2bi6k2y5vbrh2z3raf2d01alz"))))
18831 (build-system python-build-system)
18832 (arguments '(#:tests? #f)) ; no tests
18833 (home-page "https://github.com/rianhunter/block_tracing")
18834 (synopsis "Protect process memory")
18835 (description
18836 "@code{block_tracing} is a tiny Python library that can be used to
18837 prevent debuggers and other applications from inspecting the memory within
18838 your process.")
18839 (license license:expat)))
18840
18841 (define-public python-gcovr
18842 (package
18843 (name "python-gcovr")
18844 (version "4.2")
18845 (source
18846 (origin
18847 (method url-fetch)
18848 (uri (pypi-uri "gcovr" version))
18849 (sha256
18850 (base32
18851 "0gyady7x3v3l9fm1zan0idaggqqcm31y7g5vxk7h05p5h7f39bjs"))))
18852 (build-system python-build-system)
18853 (propagated-inputs
18854 `(("python-lxml" ,python-lxml)
18855 ("python-jinja2" ,python-jinja2)))
18856 (home-page "https://gcovr.com/")
18857 (synopsis "Utility for generating code coverage results")
18858 (description
18859 "Gcovr provides a utility for managing the use of the GNU gcov
18860 utility and generating summarized code coverage results. It is inspired
18861 by the Python coverage.py package, which provides a similar utility for
18862 Python.")
18863 (license license:bsd-3)))
18864
18865 (define-public python-owslib
18866 (package
18867 (name "python-owslib")
18868 (version "0.19.2")
18869 (source
18870 (origin
18871 (method url-fetch)
18872 (uri (pypi-uri "OWSLib" version))
18873 (sha256
18874 (base32 "0v8vg0naa9rywvd31cpq65ljbdclpsrx09788v4xj7lg10np8nk0"))))
18875 (build-system python-build-system)
18876 (arguments
18877 '(#:tests? #f)) ; TODO: package dependencies required for tests.
18878 (synopsis "Interface for Open Geospatial Consortium web service")
18879 (description
18880 "OWSLib is a Python package for client programming with Open Geospatial
18881 Consortium (OGC) web service (hence OWS) interface standards, and their related
18882 content models.")
18883 (home-page "https://geopython.github.io/OWSLib/")
18884 (license license:bsd-3)))
18885
18886 (define-public python-docusign-esign
18887 (package
18888 (name "python-docusign-esign")
18889 (version "3.1.0")
18890 (source (origin
18891 (method url-fetch)
18892 (uri (pypi-uri "docusign_esign" version))
18893 (sha256
18894 (base32
18895 "01f3h03vc97syjlmqyl7xa5j90pzgmwpspc5a0gra9saynnbkx37"))))
18896 (build-system python-build-system)
18897 ;; Testing requires undocumented setup changes, and so testing is disabled here.
18898 (arguments `(#:tests? #f))
18899 (propagated-inputs
18900 `(("python-certifi", python-certifi)
18901 ("python-six", python-six)
18902 ("python-dateutil", python-dateutil)
18903 ("python-urllib3", python-urllib3)
18904 ("python-pyjwt", python-pyjwt)
18905 ("python-cryptography", python-cryptography)
18906 ("python-nose", python-nose)))
18907 (synopsis "DocuSign Python Client")
18908 (description "The Official DocuSign Python Client Library used to interact
18909 with the eSign REST API. Send, sign, and approve documents using this client.")
18910 (home-page "https://www.docusign.com/devcenter")
18911 (license license:expat)))
18912
18913 (define-public python-xattr
18914 (package
18915 (name "python-xattr")
18916 (version "0.9.7")
18917 (source
18918 (origin
18919 (method url-fetch)
18920 (uri (pypi-uri "xattr" version))
18921 (sha256
18922 (base32
18923 "0i4xyiqbhjz2g16zbim17zjdbjkw79xsw8k59942vvq4is1cmfxh"))))
18924 (build-system python-build-system)
18925 (propagated-inputs
18926 `(("python-cffi" ,python-cffi)))
18927 (home-page "https://github.com/xattr/xattr")
18928 (synopsis
18929 "Python wrapper for extended filesystem attributes")
18930 (description "This package provides a Python wrapper for using extended
18931 filesystem attributes. Extended attributes extend the basic attributes of files
18932 and directories in the file system. They are stored as name:data pairs
18933 associated with file system objects (files, directories, symlinks, etc).")
18934 (license license:expat)))
18935
18936 (define-public python-json-logger
18937 (package
18938 (name "python-json-logger")
18939 (version "0.1.11")
18940 (source
18941 (origin
18942 (method url-fetch)
18943 (uri (pypi-uri "python-json-logger" version))
18944 (sha256
18945 (base32
18946 "10g2ya6nsvn5vxzvq2wb8q4d43i3d7756i5rxyjna6d0y9i138xp"))))
18947 (build-system python-build-system)
18948 (home-page
18949 "https://github.com/madzak/python-json-logger")
18950 (synopsis "JSON log formatter in Python")
18951 (description "This library allows standard Python logging to output log data
18952 as JSON objects. With JSON we can make our logs more readable by machines and
18953 we can stop writing custom parsers for syslog-type records.")
18954 (license license:bsd-3)))
18955
18956 (define-public python-daiquiri
18957 (package
18958 (name "python-daiquiri")
18959 (version "2.1.1")
18960 (source
18961 (origin
18962 (method url-fetch)
18963 (uri (pypi-uri "daiquiri" version))
18964 (sha256
18965 (base32
18966 "1qmank3c217ddiig3xr8ps0mqaydcp0q5a62in9a9g4zf72zjnqd"))))
18967 (build-system python-build-system)
18968 (propagated-inputs
18969 `(("python-json-logger" ,python-json-logger)))
18970 (native-inputs
18971 `(("python-mock" ,python-mock)
18972 ("python-pytest" ,python-pytest)
18973 ("python-setuptools-scm" ,python-setuptools-scm)
18974 ("python-six" ,python-six)))
18975 (home-page "https://github.com/jd/daiquiri")
18976 (synopsis
18977 "Library to configure Python logging easily")
18978 (description "The daiquiri library provides an easy way to configure
18979 logging in Python. It also provides some custom formatters and handlers.")
18980 (license license:asl2.0)))
18981
18982 (define-public python-pifpaf
18983 (package
18984 (name "python-pifpaf")
18985 (version "2.4.0")
18986 (source
18987 (origin
18988 (method url-fetch)
18989 (uri (pypi-uri "pifpaf" version))
18990 (sha256
18991 (base32
18992 "150av2pylsjy8ykrpyi0vzy2q24s9rhh2ya01zvwnvj9j5dspviz"))))
18993 (build-system python-build-system)
18994 (arguments
18995 `(#:tests? #f))
18996 (propagated-inputs
18997 `(("python-click" ,python-click)
18998 ("python-daiquiri" ,python-daiquiri)
18999 ("python-fixtures" ,python-fixtures)
19000 ("python-jinja2" ,python-jinja2)
19001 ("python-pbr" ,python-pbr)
19002 ("python-psutil" ,python-psutil)
19003 ("python-six" ,python-six)
19004 ("python-xattr" ,python-xattr)))
19005 (native-inputs
19006 `(("python-mock" ,python-mock)
19007 ("python-os-testr" ,python-os-testr)
19008 ("python-requests" ,python-requests)
19009 ("python-testrepository" ,python-testrepository)
19010 ("python-testtools" ,python-testtools)))
19011 (home-page "https://github.com/jd/pifpaf")
19012 (synopsis "Tools and fixtures to manage daemons for testing in Python")
19013 (description "Pifpaf is a suite of fixtures and a command-line tool that
19014 starts and stops daemons for a quick throw-away usage. This is typically
19015 useful when needing these daemons to run integration testing. It originally
19016 evolved from its precursor @code{overtest}.")
19017 (license license:asl2.0)))
19018
19019 (define-public python-pytest-check-links
19020 (package
19021 (name "python-pytest-check-links")
19022 (version "0.3.0")
19023 (source
19024 (origin
19025 (method url-fetch)
19026 ;; URI uses underscores
19027 (uri (pypi-uri "pytest_check_links" version))
19028 (sha256
19029 (base32
19030 "12x3wmrdzm6wgk0vz02hb769h68nr49q47w5q1pj95pc89hsa34v"))))
19031 (build-system python-build-system)
19032 (propagated-inputs
19033 `(("python-docutils" ,python-docutils)
19034 ("python-html5lib" ,python-html5lib)
19035 ("python-nbconvert" ,python-nbconvert)
19036 ("python-nbformat" ,python-nbformat)
19037 ("python-pytest" ,python-pytest)
19038 ("python-six" ,python-six)))
19039 (native-inputs
19040 `(("python-pbr-minimal" ,python-pbr-minimal)))
19041 (home-page "https://github.com/minrk/pytest-check-links")
19042 (synopsis "Check links in files")
19043 (description "This package provides a pytest plugin that checks URLs for
19044 HTML-containing files.")
19045 (license license:bsd-3)))
19046
19047 (define-public python-json5
19048 (package
19049 (name "python-json5")
19050 (version "0.8.5")
19051 (source
19052 (origin
19053 ;; sample.json5 is missing from PyPi source tarball
19054 (method git-fetch)
19055 (uri (git-reference
19056 (url "https://github.com/dpranke/pyjson5.git")
19057 (commit (string-append "v" version))))
19058 (file-name (git-file-name name version))
19059 (sha256
19060 (base32 "0nyngj18jlkgvm1177lc3cj47wm4yh3dqigygvcvw7xkyryafsqn"))))
19061 (build-system python-build-system)
19062 (home-page "https://github.com/dpranke/pyjson5")
19063 (synopsis
19064 "Python implementation of the JSON5 data format")
19065 (description
19066 "JSON5 extends the JSON data interchange format to make it slightly more
19067 usable as a configuration language. This Python package implements parsing and
19068 dumping of JSON5 data structures.")
19069 (license license:asl2.0)))
19070
19071 (define-public python-frozendict
19072 (package
19073 (name "python-frozendict")
19074 (version "1.2")
19075 (source
19076 (origin
19077 (method url-fetch)
19078 (uri (pypi-uri "frozendict" version))
19079 (sha256
19080 (base32 "0ibf1wipidz57giy53dh7mh68f2hz38x8f4wdq88mvxj5pr7jhbp"))))
19081 (build-system python-build-system)
19082 (home-page "https://github.com/slezica/python-frozendict")
19083 (synopsis "Simple immutable mapping for Python")
19084 (description
19085 "@dfn{frozendict} is an immutable wrapper around dictionaries that
19086 implements the complete mapping interface. It can be used as a drop-in
19087 replacement for dictionaries where immutability is desired.")
19088 (license license:expat)))
19089
19090 (define-public python-unpaddedbase64
19091 (package
19092 (name "python-unpaddedbase64")
19093 (version "1.1.0")
19094 (source
19095 (origin
19096 (method git-fetch)
19097 (uri (git-reference
19098 (url "https://github.com/matrix-org/python-unpaddedbase64.git")
19099 (commit (string-append "v" version))))
19100 (file-name (git-file-name name version))
19101 (sha256
19102 (base32
19103 "0if3fjfxga0bwdq47v77fs9hrcqpmwdxry2i2a7pdqsp95258nxd"))))
19104 (build-system python-build-system)
19105 (home-page "https://pypi.org/project/unpaddedbase64/")
19106 (synopsis "Encode and decode Base64 without “=” padding")
19107 (description
19108 "RFC 4648 specifies that Base64 should be padded to a multiple of 4 bytes
19109 using “=” characters. However this conveys no benefit so many protocols
19110 choose to use Base64 without the “=” padding.")
19111 (license license:asl2.0)))
19112
19113 (define-public python-canonicaljson
19114 (package
19115 (name "python-canonicaljson")
19116 (version "1.1.4")
19117 (source
19118 (origin
19119 (method url-fetch)
19120 (uri (pypi-uri "canonicaljson" version))
19121 (sha256
19122 (base32 "09cpacc8yvcc74i63pdmlfaahh77dnvbyw9zf29wml2zzwqfbg25"))))
19123 (build-system python-build-system)
19124 (propagated-inputs
19125 `(("python-six" ,python-six)
19126 ("python-frozendict" ,python-frozendict)
19127 ("python-simplejson" ,python-simplejson)))
19128 (home-page "https://github.com/matrix-org/python-canonicaljson")
19129 (synopsis "Canonical JSON")
19130 (description
19131 "Deterministically encode JSON.
19132
19133 @itemize
19134 @item Encodes objects and arrays as RFC 7159 JSON.
19135 @item Sorts object keys so that you get the same result each time.
19136 @item Has no insignificant whitespace to make the output as small as possible.
19137 @item Escapes only the characters that must be escaped, U+0000 to
19138 U+0019 / U+0022 / U+0056, to keep the output as small as possible.
19139 @item Uses the shortest escape sequence for each escaped character.
19140 @item Encodes the JSON as UTF-8.
19141 @item Can encode frozendict immutable dictionaries.
19142 @end itemize")
19143 (license license:asl2.0)))
19144
19145 (define-public python-signedjson
19146 (package
19147 (name "python-signedjson")
19148 (version "1.1.1")
19149 (source
19150 (origin
19151 (method url-fetch)
19152 (uri (pypi-uri "signedjson" version))
19153 (sha256
19154 (base32 "0280f8zyycsmd7iy65bs438flm7m8ffs1kcxfbvhi8hbazkqc19m"))))
19155 (build-system python-build-system)
19156 (propagated-inputs
19157 `(("python-canonicaljson" ,python-canonicaljson)
19158 ("python-importlib-metadata" ,python-importlib-metadata)
19159 ("python-pynacl" ,python-pynacl)
19160 ("python-typing-extensions" ,python-typing-extensions)
19161 ("python-unpaddedbase64" ,python-unpaddedbase64)))
19162 (native-inputs
19163 `(("python-setuptools-scm" ,python-setuptools-scm)))
19164 (home-page "https://github.com/matrix-org/python-signedjson")
19165 (synopsis "Sign JSON objects with ED25519 signatures")
19166 (description
19167 "Sign JSON objects with ED25519 signatures.
19168
19169 @itemize
19170 @item More than one entity can sign the same object.
19171 @item Each entity can sign the object with more than one key making it easier to
19172 rotate keys
19173 @item ED25519 can be replaced with a different algorithm.
19174 @item Unprotected data can be added to the object under the @dfn{\"unsigned\"}
19175 key.
19176 @end itemize")
19177 (license license:asl2.0)))
19178
19179 (define-public python-daemonize
19180 (package
19181 (name "python-daemonize")
19182 (version "2.5.0")
19183 (source
19184 (origin
19185 (method url-fetch)
19186 (uri (pypi-uri "daemonize" version))
19187 (sha256
19188 (base32 "1hwbl3gf9fdds9sc14zgjyjisjvxidrvqc11xlbb0b6jz17nw0nx"))))
19189 (build-system python-build-system)
19190 (home-page "https://github.com/thesharp/daemonize")
19191 (synopsis "Library for writing system daemons in Python")
19192 (description "Daemonize is a library for writing system daemons in Python.")
19193 (license license:expat)))
19194
19195 (define-public python-pymacaroons
19196 (package
19197 (name "python-pymacaroons")
19198 (version "0.13.0")
19199 (source
19200 (origin
19201 (method url-fetch)
19202 (uri (pypi-uri "pymacaroons" version))
19203 (sha256
19204 (base32 "1f0357a6g1h96sk6wy030xmc1p4rd80a999qvxd28v7nlm1blsqy"))))
19205 (build-system python-build-system)
19206 (propagated-inputs
19207 `(("python-six" ,python-six)
19208 ("python-pynacl" ,python-pynacl)))
19209 (home-page "https://github.com/ecordell/pymacaroons")
19210 (synopsis "Python Macaroon Library")
19211 (description
19212 "Macaroons, like cookies, are a form of bearer credential. Unlike opaque
19213 tokens, macaroons embed caveats that define specific authorization
19214 requirements for the target service, the service that issued the root macaroon
19215 and which is capable of verifying the integrity of macaroons it receives.
19216
19217 Macaroons allow for delegation and attenuation of authorization. They are
19218 simple and fast to verify, and decouple authorization policy from the
19219 enforcement of that policy.")
19220 (license license:expat)))
19221
19222 (define-public python-ldap3
19223 (package
19224 (name "python-ldap3")
19225 (version "2.7")
19226 (home-page "https://github.com/cannatag/ldap3")
19227 (source
19228 (origin
19229 (method git-fetch)
19230 (uri (git-reference (url home-page)
19231 (commit (string-append "v" version))))
19232 (file-name (git-file-name name version))
19233 (sha256
19234 (base32 "0xw9fkqld21xsvdpaqir8ccc2l805xnn9gxahsnl70xzp3mwl0xv"))))
19235 (build-system python-build-system)
19236 (arguments
19237 '(#:tests? #f ;TODO: Tests need a real LDAP server to run
19238 #:phases (modify-phases %standard-phases
19239 (replace 'check
19240 (lambda* (#:key tests? #:allow-other-keys)
19241 (when tests?
19242 (invoke "nosetests" "-s" "test"))
19243 #t)))))
19244 (native-inputs
19245 `(("python-nose" ,python-nose)))
19246 (propagated-inputs
19247 `(("python-gssapi" ,python-gssapi)
19248 ("python-pyasn1" ,python-pyasn1)))
19249 (synopsis "Python LDAP client")
19250 (description
19251 "LDAP3 is a strictly RFC 4510 conforming LDAP V3 pure Python client
19252 library.")
19253 (license license:lgpl3+)))
19254
19255 (define-public python-boltons
19256 (package
19257 (name "python-boltons")
19258 (version "20.0.0")
19259 (source
19260 (origin
19261 (method url-fetch)
19262 (uri (pypi-uri "boltons" version))
19263 (sha256
19264 (base32
19265 "0lrr40qqj3ch8xarvyzbnbjs79pz5aywklllq53l347h1b8xnkg4"))))
19266 (build-system python-build-system)
19267 (home-page "https://github.com/mahmoud/boltons")
19268 (synopsis "Extensions to the Python standard library")
19269 (description
19270 "Boltons is a set of over 230 pure-Python utilities in the same spirit
19271 as — and yet conspicuously missing from — the standard library, including:
19272
19273 @itemize
19274 @item Atomic file saving, bolted on with fileutils
19275 @item A highly-optimized OrderedMultiDict, in dictutils
19276 @item Two types of PriorityQueue, in queueutils
19277 @item Chunked and windowed iteration, in iterutils
19278 @item Recursive data structure iteration and merging, with iterutils.remap
19279 @item Exponential backoff functionality, including jitter, through
19280 iterutils.backoff
19281 @item A full-featured TracebackInfo type, for representing stack traces, in
19282 tbutils
19283 @end itemize")
19284 (license license:bsd-3)))
19285
19286 (define-public python-eliot
19287 (package
19288 (name "python-eliot")
19289 (version "1.12.0")
19290 (source
19291 (origin
19292 (method url-fetch)
19293 (uri (pypi-uri "eliot" version))
19294 (sha256
19295 (base32 "0wabv7hk63l12881f4zw02mmj06583qsx2im0yywdjlj8f56vqdn"))))
19296 (build-system python-build-system)
19297 (arguments
19298 `(#:phases
19299 (modify-phases %standard-phases
19300 (add-after 'unpack 'remove-journald-support
19301 (lambda _
19302 (for-each delete-file
19303 '("eliot/tests/test_journald.py"
19304 "eliot/journald.py"))
19305 #t))
19306 (add-after 'remove-journald-support 'remove-eliot-prettyprint-tests
19307 ;; remove command-line tool's tests. TODO eliot-prettyprint should
19308 ;; be installed and these tests should pass.
19309 (lambda _
19310 (delete-file "eliot/tests/test_prettyprint.py")
19311 #t)))))
19312 (propagated-inputs
19313 `(("python-boltons" ,python-boltons)
19314 ("python-pyrsistent" ,python-pyrsistent)
19315 ("python-six" ,python-six)
19316 ("python-zope-interface" ,python-zope-interface)))
19317 (native-inputs
19318 `(("python-black" ,python-black)
19319 ("python-coverage" ,python-coverage)
19320 ("python-dask" ,python-dask)
19321 ("python-flake8" ,python-flake8)
19322 ("python-hypothesis" ,python-hypothesis)
19323 ("python-pytest" ,python-pytest)
19324 ("python-setuptools" ,python-setuptools)
19325 ("python-sphinx" ,python-sphinx)
19326 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)
19327 ("python-testtools" ,python-testtools)
19328 ("python-twine" ,python-twine)
19329 ("python-twisted" ,python-twisted)))
19330 (home-page "https://github.com/itamarst/eliot/")
19331 (synopsis "Eliot: the logging system that tells you why it happened")
19332 (description
19333 "@dfn{eliot} is a Python logging system that outputs causal chains of
19334 actions: actions can spawn other actions, and eventually they either succeed
19335 or fail. The resulting logs tell you the story of what your software did: what
19336 happened, and what caused it.")
19337 (license license:asl2.0)))
19338
19339 (define-public python-pem
19340 (package
19341 (name "python-pem")
19342 (version "20.1.0")
19343 (source
19344 (origin
19345 (method url-fetch)
19346 (uri (pypi-uri "pem" version))
19347 (sha256
19348 (base32
19349 "1xh88ss279fprxnzd10dczmqwjhppbyvljm33zrg2mgybwd66qr7"))))
19350 (build-system python-build-system)
19351 (native-inputs
19352 `(("python-certifi" ,python-certifi)
19353 ("python-coverage" ,python-coverage)
19354 ("python-pretend" ,python-pretend)
19355 ("python-pyopenssl" ,python-pyopenssl)
19356 ("python-pytest" ,python-pytest)
19357 ("python-sphinx" ,python-sphinx)
19358 ("python-twisted" ,python-twisted)))
19359 (home-page "https://pem.readthedocs.io/")
19360 (synopsis "Easy PEM file parsing in Python")
19361 (description
19362 "This package provides a Python module for parsing and splitting PEM files.")
19363 (license license:expat)))
19364
19365 (define-public python-txsni
19366 ;; We need a few commits on top of 0.1.9 for compatibility with newer
19367 ;; Python and OpenSSL.
19368 (let ((commit "5014c141a7acef63e20fcf6c36fa07f0cd754ce1")
19369 (revision "0"))
19370 (package
19371 (name "python-txsni")
19372 (version (git-version "0.1.9" revision commit))
19373 (home-page "https://github.com/glyph/txsni")
19374 (source
19375 (origin
19376 (method git-fetch)
19377 (uri (git-reference (url home-page) (commit commit)))
19378 (file-name (git-file-name name version))
19379 (sha256
19380 (base32
19381 "0imfxx4yjj1lbq0n5ad45al3wvv4qv96sivnc1r51i66mxi658z8"))))
19382 (build-system python-build-system)
19383 (propagated-inputs
19384 `(("python-pyopenssl" ,python-pyopenssl)
19385 ("python-service-identity" ,python-service-identity)
19386 ("python-twisted" ,python-twisted)))
19387 (synopsis "Run TLS servers with Twisted")
19388 (description
19389 "This package provides an easy-to-use SNI endpoint for use
19390 with the Twisted web framework.")
19391 (license license:expat))))
19392
19393 (define-public python-txacme
19394 (package
19395 (name "python-txacme")
19396 (version "0.9.2")
19397 (source
19398 (origin
19399 (method url-fetch)
19400 (uri (pypi-uri "txacme" version))
19401 (sha256
19402 (base32 "1cplx4llq7i508w6fgwjdv9di7rsz9k9irfmzdfbiz6q6a0ykf1d"))))
19403 (build-system python-build-system)
19404 (propagated-inputs
19405 `(("python-acme" ,python-acme)
19406 ("python-attrs" ,python-attrs)
19407 ("python-eliot" ,python-eliot)
19408 ("python-josepy" ,python-josepy)
19409 ("python-pem" ,python-pem)
19410 ("python-treq" ,python-treq)
19411 ("python-twisted" ,python-twisted)
19412 ("python-txsni" ,python-txsni)))
19413 (native-inputs
19414 `(("python-fixtures" ,python-fixtures)
19415 ("python-hypothesis" ,python-hypothesis)
19416 ("python-mock" ,python-mock)
19417 ("python-service-identity"
19418 ,python-service-identity)
19419 ("python-testrepository" ,python-testrepository)
19420 ("python-testscenarios" ,python-testscenarios)
19421 ("python-testtools" ,python-testtools)))
19422 (home-page "https://github.com/twisted/txacme")
19423 (synopsis "Twisted implexmentation of the ACME protocol")
19424 (description
19425 "ACME is Automatic Certificate Management Environment, a protocol that
19426 allows clients and certificate authorities to automate verification and
19427 certificate issuance. The ACME protocol is used by the free Let's Encrypt
19428 Certificate Authority.
19429
19430 txacme is an implementation of the protocol for Twisted, the event-driven
19431 networking engine for Python.")
19432 (license license:expat)))
19433
19434 (define-public python-pysaml2
19435 (package
19436 (name "python-pysaml2")
19437 (version "5.0.0")
19438 (source
19439 (origin
19440 (method url-fetch)
19441 (uri (pypi-uri "pysaml2" version))
19442 (sha256
19443 (base32
19444 "1h8cmxh9cvxhrdfmkh92wg6zpxmhi2fixq1cy4hxismmaar7bsny"))))
19445 (build-system python-build-system)
19446 (propagated-inputs
19447 `(("python-cryptography" ,python-cryptography)
19448 ("python-dateutil" ,python-dateutil)
19449 ("python-defusedxml" ,python-defusedxml)
19450 ("python-pyopenssl" ,python-pyopenssl)
19451 ("python-pytz" ,python-pytz)
19452 ("python-requests" ,python-requests)
19453 ("python-six" ,python-six)))
19454 (home-page "https://idpy.org")
19455 (synopsis "Python implementation of SAML Version 2 Standard")
19456 (description
19457 "PySAML2 is a pure python implementation of SAML Version 2 Standard.
19458 It contains all necessary pieces for building a SAML2 service provider or
19459 an identity provider. The distribution contains examples of both.
19460
19461 This package was originally written to work in a WSGI environment, but
19462 there are extensions that allow you to use it with other frameworks.")
19463 (license license:asl2.0)))
19464
19465 (define-public python-click-plugins
19466 (package
19467 (name "python-click-plugins")
19468 (version "1.1.1")
19469 (source
19470 (origin
19471 (method url-fetch)
19472 (uri (pypi-uri "click-plugins" version))
19473 (sha256
19474 (base32 "0jr6bxj67vg988vkm6nz8jj98v9lg46bn49lkhak3n598jbrkas6"))))
19475 (build-system python-build-system)
19476 (native-inputs
19477 `(("python-pytest" ,python-pytest)))
19478 (propagated-inputs
19479 `(("python-click" ,python-click)))
19480 (synopsis "Extension for Click to register external CLI commands")
19481 (description "This package provides n extension module for Click to
19482 register external CLI commands via setuptools entry-points.")
19483 (home-page "https://github.com/click-contrib/click-plugins")
19484 (license license:bsd-3)))
19485
19486 (define-public python-diceware
19487 (package
19488 (name "python-diceware")
19489 (version "0.9.6")
19490 (source
19491 (origin
19492 (method url-fetch)
19493 (uri (pypi-uri "diceware" version))
19494 (sha256
19495 (base32
19496 "0klb0ysybzlh2wihvir82hgq62v0jjmlcqklwajyms7c0p529yby"))))
19497 (build-system python-build-system)
19498 (native-inputs
19499 `(("python-coverage" ,python-coverage)
19500 ("python-pytest" ,python-pytest)
19501 ("python-pytest-runner" ,python-pytest-runner)))
19502 (home-page "https://github.com/ulif/diceware/")
19503 (synopsis "Generates memorable passphrases")
19504 (description "This package generates passphrases by concatenating words
19505 randomly picked from wordlists. It supports several sources of
19506 randomness (including real life dice) and different wordlists (including
19507 cryptographically signed ones).")
19508 (license license:gpl3+)))
19509
19510 (define-public pyzo
19511 (package
19512 (name "pyzo")
19513 (version "4.10.2")
19514 (source
19515 (origin
19516 (method url-fetch)
19517 (uri (pypi-uri "pyzo" version))
19518 (sha256
19519 (base32 "1zplxcb78qy8qibifmnsx5i9gnlfmw9n6nr4yflsabpxw57mx4m1"))))
19520 (build-system python-build-system)
19521 (arguments
19522 `(#:phases
19523 (modify-phases %standard-phases
19524 (add-before 'check 'fix-home-directory
19525 (lambda _
19526 ;; Tests fail with "Permission denied: '/homeless-shelter'".
19527 (setenv "HOME" "/tmp")
19528 #t)))
19529 ;; Tests fail with "Uncaught Python exception: invalid literal for
19530 ;; int() with base 10: 'test'".
19531 #:tests? #f))
19532 (propagated-inputs
19533 `(("python-pyqt" ,python-pyqt)))
19534 (home-page "https://pyzo.org")
19535 (synopsis
19536 "Python IDE for scientific computing")
19537 (description
19538 "Pyzo is a Python IDE focused on interactivity and introspection,
19539 which makes it very suitable for scientific computing. Its practical
19540 design is aimed at simplicity and efficiency.
19541
19542 It consists of two main components, the editor and the shell, and uses
19543 a set of pluggable tools to help the programmer in various ways. Some
19544 example tools are source structure, project manager, interactive help,
19545 workspace...")
19546 (license license:bsd-2)))