gnu: Add python-flaky.
[jackhill/guix/guix.git] / gnu / packages / python.scm
1 ;;; GNU Guix --- Functional package management for GNU
2 ;;; Copyright © 2013 Nikita Karetnikov <nikita@karetnikov.org>
3 ;;; Copyright © 2013, 2014, 2015, 2016, 2017 Ludovic Courtès <ludo@gnu.org>
4 ;;; Copyright © 2013, 2014, 2015, 2016 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 Ricardo Wurmus <rekado@elephly.net>
11 ;;; Copyright © 2015, 2016 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 Leo Famulari <leo@famulari.name>
15 ;;; Copyright © 2015 Ben Woodcroft <donttrustben@gmail.com>
16 ;;; Copyright © 2015, 2016 Erik Edrosa <erik.edrosa@gmail.com>
17 ;;; Copyright © 2015, 2016, 2017 Efraim Flashner <efraim@flashner.co.il>
18 ;;; Copyright © 2015 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 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 Troy Sankey <sankeytms@gmail.com>
26 ;;; Copyright © 2016, 2017 ng0 <contact.ng0@cryptolab.net>
27 ;;; Copyright © 2016 Dylan Jeffers <sapientech@sapientech@openmailbox.org>
28 ;;; Copyright © 2016 David Craven <david@craven.ch>
29 ;;; Copyright © 2016, 2017 Marius Bakke <mbakke@fastmail.com>
30 ;;; Copyright © 2016, 2017 Stefan Reichör <stefan@xsteve.at>
31 ;;; Copyright © 2016 Dylan Jeffers <sapientech@sapientech@openmailbox.org>
32 ;;; Copyright © 2016 Alex Vong <alexvong1995@gmail.com>
33 ;;; Copyright © 2016, 2017 Arun Isaac <arunisaac@systemreboot.net>
34 ;;; Copyright © 2016, 2017 Julien Lepiller <julien@lepiller.eu>
35 ;;; Copyright © 2016, 2017 Tobias Geerinckx-Rice <me@tobias.gr>
36 ;;; Copyright © 2016, 2017 Thomas Danckaert <post@thomasdanckaert.be>
37 ;;; Copyright © 2017 Carlo Zancanaro <carlo@zancanaro.id.au>
38 ;;; Copyright © 2017 Frederick M. Muriithi <fredmanglis@gmail.com>
39 ;;; Copyright © 2017 Adriano Peluso <catonano@gmail.com>
40 ;;; Copyright © 2017 Ben Sturmfels <ben@sturm.com.au>
41 ;;; Copyright © 2017 Mathieu Othacehe <m.othacehe@gmail.com>
42 ;;; Copyright © 2017 José Miguel Sánchez García <jmi2k@openmailbox.org>
43 ;;; Copyright © 2017 Roel Janssen <roel@gnu.org>
44 ;;; Copyright © 2017 Kei Kebreau <kei@openmailbox.org>
45 ;;; Copyright © 2017 Rutger Helling <rhelling@mykolab.com>
46 ;;; Copyright © 2017 Muriithi Frederick Muriuki <fredmanglis@gmail.com>
47 ;;;
48 ;;; This file is part of GNU Guix.
49 ;;;
50 ;;; GNU Guix is free software; you can redistribute it and/or modify it
51 ;;; under the terms of the GNU General Public License as published by
52 ;;; the Free Software Foundation; either version 3 of the License, or (at
53 ;;; your option) any later version.
54 ;;;
55 ;;; GNU Guix is distributed in the hope that it will be useful, but
56 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
57 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
58 ;;; GNU General Public License for more details.
59 ;;;
60 ;;; You should have received a copy of the GNU General Public License
61 ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
62
63 (define-module (gnu packages python)
64 #:use-module ((guix licenses) #:prefix license:)
65 #:use-module (gnu packages)
66 #:use-module (gnu packages algebra)
67 #:use-module (gnu packages adns)
68 #:use-module (gnu packages attr)
69 #:use-module (gnu packages backup)
70 #:use-module (gnu packages bash)
71 #:use-module (gnu packages compression)
72 #:use-module (gnu packages crypto)
73 #:use-module (gnu packages databases)
74 #:use-module (gnu packages django)
75 #:use-module (gnu packages file)
76 #:use-module (gnu packages fontutils)
77 #:use-module (gnu packages gcc)
78 #:use-module (gnu packages ghostscript)
79 #:use-module (gnu packages gl)
80 #:use-module (gnu packages glib)
81 #:use-module (gnu packages graphviz)
82 #:use-module (gnu packages gstreamer)
83 #:use-module (gnu packages gtk)
84 #:use-module (gnu packages icu4c)
85 #:use-module (gnu packages image)
86 #:use-module (gnu packages imagemagick)
87 #:use-module (gnu packages libevent)
88 #:use-module (gnu packages libffi)
89 #:use-module (gnu packages linux)
90 #:use-module (gnu packages man)
91 #:use-module (gnu packages maths)
92 #:use-module (gnu packages multiprecision)
93 #:use-module (gnu packages networking)
94 #:use-module (gnu packages ncurses)
95 #:use-module (gnu packages openstack)
96 #:use-module (gnu packages password-utils)
97 #:use-module (gnu packages pcre)
98 #:use-module (gnu packages perl)
99 #:use-module (gnu packages pkg-config)
100 #:use-module (gnu packages protobuf)
101 #:use-module (gnu packages qt)
102 #:use-module (gnu packages readline)
103 #:use-module (gnu packages sdl)
104 #:use-module (gnu packages search)
105 #:use-module (gnu packages shells)
106 #:use-module (gnu packages ssh)
107 #:use-module (gnu packages statistics)
108 #:use-module (gnu packages tex)
109 #:use-module (gnu packages texinfo)
110 #:use-module (gnu packages tls)
111 #:use-module (gnu packages version-control)
112 #:use-module (gnu packages video)
113 #:use-module (gnu packages web)
114 #:use-module (gnu packages base)
115 #:use-module (gnu packages xml)
116 #:use-module (gnu packages xorg)
117 #:use-module (gnu packages xdisorg)
118 #:use-module (gnu packages tcl)
119 #:use-module (gnu packages bdw-gc)
120 #:use-module (guix packages)
121 #:use-module (guix download)
122 #:use-module (guix git-download)
123 #:use-module (guix utils)
124 #:use-module (guix build-system gnu)
125 #:use-module (guix build-system cmake)
126 #:use-module (guix build-system python)
127 #:use-module (guix build-system trivial)
128 #:use-module (srfi srfi-1))
129
130 (define-public python-2.7
131 (package
132 (name "python")
133 (version "2.7.13")
134 (source
135 (origin
136 (method url-fetch)
137 (uri (string-append "https://www.python.org/ftp/python/"
138 version "/Python-" version ".tar.xz"))
139 (sha256
140 (base32
141 "0cgpk3zk0fgpji59pb4zy9nzljr70qzgv1vpz5hq5xw2d2c47m9m"))
142 (patches (search-patches "python-2.7-search-paths.patch"
143 "python-2-deterministic-build-info.patch"
144 "python-2.7-site-prefixes.patch"
145 "python-2.7-source-date-epoch.patch"
146 "python-2.7-getentropy-on-old-kernels.patch"))
147 (modules '((guix build utils)))
148 ;; suboptimal to delete failing tests here, but if we delete them in the
149 ;; arguments then we need to make sure to strip out that phase when it
150 ;; gets inherited by python and python-minimal.
151 (snippet
152 '(begin
153 (for-each delete-file
154 '("Lib/test/test_compileall.py"
155 "Lib/test/test_ctypes.py" ; fails on mips64el
156 "Lib/test/test_distutils.py"
157 "Lib/test/test_import.py"
158 "Lib/test/test_shutil.py"
159 "Lib/test/test_socket.py"
160 "Lib/test/test_subprocess.py"))
161 #t))))
162 (outputs '("out"
163 "tk")) ;tkinter; adds 50 MiB to the closure
164 (build-system gnu-build-system)
165 (arguments
166 `(;; 356 tests OK.
167 ;; 6 tests failed:
168 ;; test_compileall test_distutils test_import test_shutil test_socket
169 ;; test_subprocess
170 ;; 39 tests skipped:
171 ;; test_aepack test_al test_applesingle test_bsddb test_bsddb185
172 ;; test_bsddb3 test_cd test_cl test_codecmaps_cn test_codecmaps_hk
173 ;; test_codecmaps_jp test_codecmaps_kr test_codecmaps_tw test_curses
174 ;; test_dl test_gdb test_gl test_imageop test_imgfile test_ioctl
175 ;; test_kqueue test_linuxaudiodev test_macos test_macostools
176 ;; test_msilib test_ossaudiodev test_scriptpackages test_smtpnet
177 ;; test_socketserver test_startfile test_sunaudiodev test_timeout
178 ;; test_tk test_ttk_guionly test_urllib2net test_urllibnet
179 ;; test_winreg test_winsound test_zipfile64
180 ;; 4 skips unexpected on linux2:
181 ;; test_bsddb test_bsddb3 test_gdb test_ioctl
182 #:test-target "test"
183 #:configure-flags
184 (list "--enable-shared" ;allow embedding
185 "--with-system-ffi" ;build ctypes
186 "--with-ensurepip=install" ;install pip and setuptools
187 "--enable-unicode=ucs4"
188 (string-append "LDFLAGS=-Wl,-rpath="
189 (assoc-ref %outputs "out") "/lib"))
190
191 #:modules ((ice-9 ftw) (ice-9 match)
192 (guix build utils) (guix build gnu-build-system))
193 #:phases
194 (modify-phases %standard-phases
195 (add-before
196 'configure 'patch-lib-shells
197 (lambda _
198 ;; Filter for existing files, since some may not exist in all
199 ;; versions of python that are built with this recipe.
200 (substitute* (filter file-exists?
201 '("Lib/subprocess.py"
202 "Lib/popen2.py"
203 "Lib/distutils/tests/test_spawn.py"
204 "Lib/test/test_subprocess.py"))
205 (("/bin/sh") (which "sh")))
206
207 ;; Use zero as the timestamp in .pyc files so that builds are
208 ;; deterministic. TODO: Remove it when this variable is set in
209 ;; gnu-build-system.scm.
210 (setenv "SOURCE_DATE_EPOCH" "1")
211 #t))
212 (add-before 'configure 'do-not-record-configure-flags
213 (lambda* (#:key configure-flags #:allow-other-keys)
214 ;; Remove configure flags from the installed '_sysconfigdata.py'
215 ;; and 'Makefile' so we don't end up keeping references to the
216 ;; build tools.
217 ;;
218 ;; Preserve at least '--with-system-ffi' since otherwise the
219 ;; thing tries to build libffi, fails, and we end up with a
220 ;; Python that lacks ctypes.
221 (substitute* "configure"
222 (("^CONFIG_ARGS=.*$")
223 (format #f "CONFIG_ARGS='~a'\n"
224 (if (member "--with-system-ffi" configure-flags)
225 "--with-system-ffi"
226 ""))))
227 #t))
228 (add-before
229 'check 'pre-check
230 (lambda _
231 ;; 'Lib/test/test_site.py' needs a valid $HOME
232 (setenv "HOME" (getcwd))
233 #t))
234 (add-after
235 'unpack 'set-source-file-times-to-1980
236 ;; XXX One of the tests uses a ZIP library to pack up some of the
237 ;; source tree, and fails with "ZIP does not support timestamps
238 ;; before 1980". Work around this by setting the file times in the
239 ;; source tree to sometime in early 1980.
240 (lambda _
241 (let ((circa-1980 (* 10 366 24 60 60)))
242 (ftw "." (lambda (file stat flag)
243 (utime file circa-1980 circa-1980)
244 #t))
245 #t)))
246 (add-after 'install 'remove-tests
247 ;; Remove 25 MiB of unneeded unit tests. Keep test_support.*
248 ;; because these files are used by some libraries out there.
249 (lambda* (#:key outputs #:allow-other-keys)
250 (let ((out (assoc-ref outputs "out")))
251 (match (scandir (string-append out "/lib")
252 (lambda (name)
253 (string-prefix? "python" name)))
254 ((pythonX.Y)
255 (let ((testdir (string-append out "/lib/" pythonX.Y
256 "/test")))
257 (with-directory-excursion testdir
258 (for-each delete-file-recursively
259 (scandir testdir
260 (match-lambda
261 ((or "." "..") #f)
262 (file
263 (not
264 (string-prefix? "test_support."
265 file))))))
266 (call-with-output-file "__init__.py" (const #t))
267 #t)))))))
268 (add-before 'strip 'make-libraries-writable
269 (lambda* (#:key outputs #:allow-other-keys)
270 ;; Make .so files writable so they can be stripped.
271 (let ((out (assoc-ref outputs "out")))
272 (for-each (lambda (file)
273 (chmod file #o755))
274 (find-files (string-append out "/lib")
275 "\\.so"))
276 #t)))
277 (add-after 'install 'move-tk-inter
278 (lambda* (#:key outputs #:allow-other-keys)
279 ;; When Tkinter support is built move it to a separate output so
280 ;; that the main output doesn't contain a reference to Tcl/Tk.
281 (let ((out (assoc-ref outputs "out"))
282 (tk (assoc-ref outputs "tk")))
283 (when tk
284 (match (find-files out "tkinter.*\\.so")
285 ((tkinter.so)
286 ;; The .so is in OUT/lib/pythonX.Y/lib-dynload, but we
287 ;; want it under TK/lib/pythonX.Y/site-packages.
288 (let* ((len (string-length out))
289 (target (string-append
290 tk "/"
291 (string-drop
292 (dirname (dirname tkinter.so))
293 len)
294 "/site-packages")))
295 (install-file tkinter.so target)
296 (delete-file tkinter.so)))))
297 #t))))))
298 (inputs
299 `(("bzip2" ,bzip2)
300 ("gdbm" ,gdbm)
301 ("libffi" ,libffi) ; for ctypes
302 ("sqlite" ,sqlite) ; for sqlite extension
303 ("openssl" ,openssl)
304 ("readline" ,readline)
305 ("zlib" ,zlib)
306 ("tcl" ,tcl)
307 ("tk" ,tk))) ; for tkinter
308 (native-inputs
309 `(("pkg-config" ,pkg-config)))
310 (native-search-paths
311 (list (search-path-specification
312 (variable "PYTHONPATH")
313 (files '("lib/python2.7/site-packages")))))
314 (home-page "https://www.python.org")
315 (synopsis "High-level, dynamically-typed programming language")
316 (description
317 "Python is a remarkably powerful dynamic programming language that
318 is used in a wide variety of application domains. Some of its key
319 distinguishing features include: clear, readable syntax; strong
320 introspection capabilities; intuitive object orientation; natural
321 expression of procedural code; full modularity, supporting hierarchical
322 packages; exception-based error handling; and very high level dynamic
323 data types.")
324 (license license:psfl)))
325
326 ;; Current 2.x version.
327 (define-public python-2 python-2.7)
328
329 (define-public python-3.5
330 (package (inherit python-2)
331 (version "3.5.3")
332 (source (origin
333 (method url-fetch)
334 (uri (string-append "https://www.python.org/ftp/python/"
335 version "/Python-" version ".tar.xz"))
336 (patches (search-patches
337 "python-fix-tests.patch"
338 "python-3.5-fix-tests.patch"
339 "python-3.5-getentropy-on-old-kernels.patch"
340 "python-3-deterministic-build-info.patch"
341 "python-3-search-paths.patch"))
342 (patch-flags '("-p0"))
343 (sha256
344 (base32
345 "1c6v1n9nz4mlx9mw1125fxpmbrgniqdbbx9hnqx44maqazb2mzpf"))
346 (snippet
347 '(delete-file
348 "Lib/ctypes/test/test_win32.py")))) ; fails on aarch64
349 (arguments (substitute-keyword-arguments (package-arguments python-2)
350 ((#:tests? _) #t)))
351 (native-search-paths
352 (list (search-path-specification
353 (variable "PYTHONPATH")
354 (files (list (string-append "lib/python"
355 (version-major+minor version)
356 "/site-packages"))))))))
357
358 ;; Current 3.x version.
359 (define-public python-3 python-3.5)
360
361 ;; Current major version.
362 (define-public python python-3)
363
364 ;; Minimal variants of Python, mostly used to break the cycle between Tk and
365 ;; Python (Tk -> libxcb -> Python.)
366
367 (define-public python2-minimal
368 (package (inherit python-2)
369 (name "python-minimal")
370 (outputs '("out"))
371
372 ;; Keep zlib, which is used by 'pip' (via the 'zipimport' module), which
373 ;; is invoked upon 'make install'. 'pip' also expects 'ctypes' and thus
374 ;; libffi.
375 (inputs `(("libffi" ,libffi)
376 ("zlib" ,zlib)))))
377
378 (define-public python-minimal
379 (package (inherit python)
380 (name "python-minimal")
381 (outputs '("out"))
382
383 ;; Build fails due to missing ctypes without libffi.
384 ;; OpenSSL is a mandatory dependency of Python 3.x, for urllib;
385 ;; zlib is required by 'zipimport', used by pip.
386 (inputs `(("libffi" ,libffi)
387 ("openssl" ,openssl)
388 ("zlib" ,zlib)))))
389
390 (define* (wrap-python3 python
391 #:optional
392 (name (string-append (package-name python) "-wrapper")))
393 (package (inherit python)
394 (name name)
395 (source #f)
396 (build-system trivial-build-system)
397 (outputs '("out"))
398 (inputs `(("bash" ,bash)))
399 (propagated-inputs `(("python" ,python)))
400 (arguments
401 `(#:modules ((guix build utils))
402 #:builder
403 (begin
404 (use-modules (guix build utils))
405 (let ((bin (string-append (assoc-ref %outputs "out") "/bin"))
406 (python (string-append (assoc-ref %build-inputs "python") "/bin/")))
407 (mkdir-p bin)
408 (for-each
409 (lambda (old new)
410 (symlink (string-append python old)
411 (string-append bin "/" new)))
412 `("python3" ,"pydoc3" ,"idle3" ,"pip3")
413 `("python" ,"pydoc" ,"idle" ,"pip"))
414 ;; python-config outputs search paths based upon its location,
415 ;; use a bash wrapper to avoid changing its outputs.
416 (let ((bash (string-append (assoc-ref %build-inputs "bash")
417 "/bin/bash"))
418 (old (string-append python "python3-config"))
419 (new (string-append bin "/python-config")))
420 (with-output-to-file new
421 (lambda ()
422 (format #t "#!~a~%" bash)
423 (format #t "exec \"~a\" \"$@\"~%" old)
424 (chmod new #o755)
425 #t)))))))
426 (synopsis "Wrapper for the Python 3 commands")
427 (description
428 "This package provides wrappers for the commands of Python@tie{}3.x such
429 that they can be invoked under their usual name---e.g., @command{python}
430 instead of @command{python3}.")))
431
432 (define-public python-wrapper (wrap-python3 python))
433 (define-public python-minimal-wrapper (wrap-python3 python-minimal))
434
435 (define-public python-psutil
436 (package
437 (name "python-psutil")
438 (version "4.3.0")
439 (source
440 (origin
441 (method url-fetch)
442 (uri (pypi-uri "psutil" version))
443 (sha256
444 (base32
445 "1w4r09fvn6kd80m5mx4ws1wz100brkaq6hzzpwrns8cgjzjpl6c6"))))
446 (build-system python-build-system)
447 (arguments
448 ;; FIXME: some tests does not return and times out.
449 '(#:tests? #f))
450 (home-page "https://www.github.com/giampaolo/psutil")
451 (synopsis "Library for retrieving information on running processes")
452 (description
453 "psutil (Python system and process utilities) is a library for retrieving
454 information on running processes and system utilization (CPU, memory, disks,
455 network) in Python. It is useful mainly for system monitoring, profiling and
456 limiting process resources and management of running processes. It implements
457 many functionalities offered by command line tools such as: ps, top, lsof,
458 netstat, ifconfig, who, df, kill, free, nice, ionice, iostat, iotop, uptime,
459 pidof, tty, taskset, pmap.")
460 (license license:bsd-3)))
461
462 (define-public python2-psutil
463 (package-with-python2 python-psutil))
464
465 (define-public python-passlib
466 (package
467 (name "python-passlib")
468 (version "1.7.1")
469 (source
470 (origin
471 (method url-fetch)
472 (uri (pypi-uri "passlib" version))
473 (sha256
474 (base32
475 "1q2khqpj9rlcgdmkypjdq1kswvhjf72bq0zk2cv669cc2dj8z51x"))))
476 (build-system python-build-system)
477 (native-inputs
478 `(("python-nose" ,python-nose)))
479 (propagated-inputs
480 `(("python-py-bcrypt" ,python-py-bcrypt)))
481 (arguments
482 `(#:phases
483 (alist-cons-before
484 'check 'set-PYTHON_EGG_CACHE
485 ;; some tests require access to "$HOME/.cython"
486 (lambda* _ (setenv "PYTHON_EGG_CACHE" "/tmp"))
487 %standard-phases)))
488 (home-page "https://bitbucket.org/ecollins/passlib")
489 (synopsis
490 "Comprehensive password hashing framework")
491 (description
492 "Passlib is a password hashing library for Python 2 & 3, which provides
493 cross-platform implementations of over 30 password hashing algorithms, as well
494 as a framework for managing existing password hashes. It's designed to be
495 useful for a wide range of tasks, from verifying a hash found in /etc/shadow,
496 to providing full-strength password hashing for multi-user application.")
497 (license license:bsd-3)))
498
499 (define-public python2-passlib
500 (package-with-python2 python-passlib))
501
502 (define-public python-py-bcrypt
503 (package
504 (name "python-py-bcrypt")
505 (version "0.4")
506 (source
507 (origin
508 (method url-fetch)
509 (uri (string-append
510 "https://pypi.python.org/packages/source/p/py-bcrypt/py-bcrypt-"
511 version
512 ".tar.gz"))
513 (sha256
514 (base32
515 "0y6smdggwi5s72v6p1nn53dg6w05hna3d264cq6kas0lap73p8az"))))
516 (build-system python-build-system)
517 (home-page "https://code.google.com/p/py-bcrypt")
518 (synopsis
519 "Bcrypt password hashing and key derivation")
520 (description
521 "A python wrapper of OpenBSD's Blowfish password hashing code. This
522 system hashes passwords using a version of Bruce Schneier's Blowfish block
523 cipher with modifications designed to raise the cost of off-line password
524 cracking and frustrate fast hardware implementation. The computation cost of
525 the algorithm is parametised, so it can be increased as computers get faster.
526 The intent is to make a compromise of a password database less likely to
527 result in an attacker gaining knowledge of the plaintext passwords (e.g. using
528 John the Ripper).")
529 ;; "sha2.c" is under BSD-3;
530 ;; "blowfish.c" and "bcrypt.c" are under BSD-4;
531 ;; the rest is under ISC.
532 (license (list license:isc license:bsd-3 license:bsd-4))))
533
534 (define-public python2-py-bcrypt
535 (package-with-python2 python-py-bcrypt))
536
537
538 (define-public python-paramiko
539 (package
540 (name "python-paramiko")
541 (version "2.1.2")
542 (source
543 (origin
544 (method url-fetch)
545 (uri (pypi-uri "paramiko" version))
546 (sha256
547 (base32
548 "04734n0wy3hxk6rij4fr29in5jmr70nxpc7pqi2ksbjysfz4kbjz"))))
549 (build-system python-build-system)
550 (arguments
551 '(#:phases
552 (modify-phases %standard-phases
553 (replace 'check
554 (lambda _
555 (zero? (system* "python" "test.py")))))))
556 (propagated-inputs
557 `(("python-pyasn1" ,python-pyasn1)
558 ("python-cryptography" ,python-cryptography)))
559 (home-page "http://www.paramiko.org/")
560 (synopsis "SSHv2 protocol library")
561 (description "Paramiko is a python implementation of the SSHv2 protocol,
562 providing both client and server functionality. While it leverages a Python C
563 extension for low level cryptography (PyCrypto), Paramiko itself is a pure
564 Python interface around SSH networking concepts.")
565 (license license:lgpl2.1+)))
566
567 (define-public python2-paramiko
568 (package-with-python2 python-paramiko))
569
570
571 (define-public python-httplib2
572 (package
573 (name "python-httplib2")
574 (version "0.9.2")
575 (source
576 (origin
577 (method url-fetch)
578 (uri (pypi-uri "httplib2" version))
579 (sha256
580 (base32
581 "126rsryvw9vhbf3qmsfw9lf4l4xm2srmgs439lgma4cpag4s3ay3"))))
582 (build-system python-build-system)
583 (home-page "https://github.com/jcgregorio/httplib2")
584 (synopsis "Comprehensive HTTP client library")
585 (description
586 "A comprehensive HTTP client library supporting many features left out of
587 other HTTP libraries.")
588 (license license:expat)))
589
590 (define-public python2-httplib2
591 (package-with-python2 python-httplib2))
592
593 (define-public python-ecdsa
594 (package
595 (name "python-ecdsa")
596 (version "0.13")
597 (source
598 (origin
599 (method url-fetch)
600 (uri (string-append
601 "https://pypi.python.org/packages/source/e/ecdsa/ecdsa-"
602 version
603 ".tar.gz"))
604 (sha256
605 (base32
606 "1yj31j0asmrx4an9xvsaj2icdmzy6pw0glfpqrrkrphwdpi1xkv4"))))
607 (build-system python-build-system)
608 (inputs
609 `(("openssl" ,openssl)))
610 (home-page
611 "https://github.com/warner/python-ecdsa")
612 (synopsis
613 "ECDSA cryptographic signature library (pure python)")
614 (description
615 "This is an easy-to-use implementation of ECDSA cryptography (Elliptic
616 Curve Digital Signature Algorithm), implemented purely in Python. With this
617 library, you can quickly create keypairs (signing key and verifying key), sign
618 messages, and verify the signatures. The keys and signatures are very short,
619 making them easy to handle and incorporate into other protocols.")
620 (license license:expat)))
621
622 (define-public python2-ecdsa
623 (package-with-python2 python-ecdsa))
624
625 (define-public python-ccm
626 (package
627 (name "python-ccm")
628 (version "2.1.6")
629 (source
630 (origin
631 (method url-fetch)
632 (uri (pypi-uri "ccm" version))
633 (sha256
634 (base32
635 "177dfxsmk3k4cih6fh6v8d91bh4nqx7ns6pc07w7m7i3cvdx3c8n"))))
636 (build-system python-build-system)
637 (propagated-inputs
638 `(("python-pyyaml" ,python-pyyaml)
639 ;; Not listed in setup.py, but used in ccmlib/node.py for full
640 ;; functionality
641 ("python-psutil" ,python-psutil)
642 ("python-six" ,python-six)))
643 (home-page "https://github.com/pcmanus/ccm")
644 (synopsis "Cassandra Cluster Manager for Apache Cassandra clusters on
645 localhost")
646 (description "Cassandra Cluster Manager is a development tool for testing
647 local Cassandra clusters. It creates, launches and removes Cassandra clusters
648 on localhost.")
649 (license license:asl2.0)))
650
651 (define-public python2-ccm
652 (package-with-python2 python-ccm))
653
654 (define-public python-pytz
655 (package
656 (name "python-pytz")
657 (version "2017.2")
658 (source
659 (origin
660 (method url-fetch)
661 (uri (pypi-uri "pytz" version ".zip"))
662 (sha256
663 (base32
664 "12cmd3j46d2gcw08bspvp6s9icfcvx88zjz52n1bli9dyvl5dh7m"))))
665 (build-system python-build-system)
666 (native-inputs
667 `(("unzip" ,unzip)))
668 (home-page "http://pythonhosted.org/pytz")
669 (synopsis "Python timezone library")
670 (description "This library brings the Olson tz database into Python. It
671 allows accurate and cross platform timezone calculations using Python 2.4 or
672 higher. It also solves the issue of ambiguous times at the end of daylight
673 saving time. Almost all of the Olson timezones are supported.")
674 (license license:expat)))
675
676 (define-public python2-pytz
677 (package-with-python2 python-pytz))
678
679 (define-public python-clyent
680 (package
681 (name "python-clyent")
682 (version "1.2.1")
683 (source
684 (origin
685 (method url-fetch)
686 (uri (pypi-uri "clyent" version))
687 (sha256
688 (base32
689 "1r9987qmy1pz3hq54160bapqsywpq14waw4w9x3ly8hmq7kpgfbj"))))
690 (build-system python-build-system)
691 (native-inputs
692 `(("python-mock" ,python-mock)))
693 (home-page "https://github.com/binstar/clyent")
694 (synopsis "Command line client library")
695 (description "Clyent is a Python command line utiliy library. It is used
696 by @code{binstar}, @code{binstar-build} and @code{chalmers}.")
697 (license license:bsd-3)))
698
699 (define-public python2-clyent
700 (package-with-python2 python-clyent))
701
702 (define-public python-babel
703 (package
704 (name "python-babel")
705 (version "2.3.4")
706 (source
707 (origin
708 (method url-fetch)
709 (uri (pypi-uri "Babel" version))
710 (sha256
711 (base32
712 "0x98qqqw35xllpcama013a9788ly84z8dm1w2wwfpxh2710c8df5"))))
713 (build-system python-build-system)
714 (propagated-inputs
715 `(("python-pytz" ,python-pytz)))
716 (arguments `(#:tests? #f)) ; no test target
717 (home-page "http://babel.pocoo.org/")
718 (synopsis
719 "Tools for internationalizing Python applications")
720 (description
721 "Babel is composed of two major parts:
722 - tools to build and work with gettext message catalogs
723 - a Python interface to the CLDR (Common Locale Data Repository), providing
724 access to various locale display names, localized number and date formatting,
725 etc. ")
726 (license license:bsd-3)))
727
728 (define-public python2-babel
729 (package-with-python2 python-babel))
730
731 (define-public python2-backport-ssl-match-hostname
732 (package
733 (name "python2-backport-ssl-match-hostname")
734 (version "3.5.0.1")
735 (source
736 (origin
737 (method url-fetch)
738 (uri (string-append
739 "https://pypi.python.org/packages/source/b/"
740 "backports.ssl_match_hostname/backports.ssl_match_hostname-"
741 version ".tar.gz"))
742 (sha256
743 (base32
744 "1wndipik52cyqy0677zdgp90i435pmvwd89cz98lm7ri0y3xjajh"))))
745 (build-system python-build-system)
746 (arguments
747 `(#:python ,python-2
748 #:tests? #f)) ; no test target
749 (home-page "https://bitbucket.org/brandon/backports.ssl_match_hostname")
750 (synopsis "Backport of ssl.match_hostname() function from Python 3.5")
751 (description
752 "This backport brings the ssl.match_hostname() function to users of
753 earlier versions of Python. The function checks the hostname in the
754 certificate returned by the server to which a connection has been established,
755 and verifies that it matches the intended target hostname.")
756 (license license:psfl)))
757
758 (define-public python-hdf4
759 (package
760 (name "python-hdf4")
761 (version "0.9")
762 (source
763 (origin
764 (method url-fetch)
765 (uri (pypi-uri name version))
766 (sha256
767 (base32
768 "1hjiyrxvxk9817qyqky3nar4y3fs4z8wxz0n884zzb5wi6skrjks"))))
769 (build-system python-build-system)
770 (native-inputs `(("nose" ,python-nose)))
771 (propagated-inputs `(("numpy" ,python-numpy)))
772 (inputs
773 `(("hdf4" ,hdf4)
774 ("libjpeg" ,libjpeg)
775 ("zlib" ,zlib)))
776 (arguments
777 `(#:phases
778 (modify-phases %standard-phases
779 (replace 'check
780 (lambda _
781 ;; The 'runexamples' script sets PYTHONPATH to CWD, then goes
782 ;; on to import numpy. Somehow this works on their CI system.
783 ;; Let's just manage PYTHONPATH here instead.
784 (substitute* "runexamples.sh"
785 (("export PYTHONPATH=.*") ""))
786 (setenv "PYTHONPATH"
787 (string-append (getcwd) ":"
788 (getenv "PYTHONPATH")))
789 (and (zero? (system* "./runexamples.sh"))
790 (zero? (system* "nosetests" "-v"))))))))
791 (home-page "https://github.com/fhs/python-hdf4")
792 (synopsis "Python interface to the NCSA HDF4 library")
793 (description
794 "Python-HDF4 is a python wrapper around the NCSA HDF version 4 library,
795 which implements the SD (Scientific Dataset), VS (Vdata) and V (Vgroup) API’s.
796 NetCDF files can also be read and modified. Python-HDF4 is a fork of
797 @url{http://hdfeos.org/software/pyhdf.php,pyhdf}.")
798 (license license:expat)))
799
800 (define-public python2-hdf4
801 (package-with-python2 python-hdf4))
802
803 (define-public python-h5py
804 (package
805 (name "python-h5py")
806 (version "2.6.0")
807 (source
808 (origin
809 (method url-fetch)
810 (uri (pypi-uri "h5py" version))
811 (sha256
812 (base32
813 "0df46dg7i7xfking9lp221bfm8dbl974yvlrbi1w7r6m61ac7bxj"))))
814 (build-system python-build-system)
815 (arguments
816 `(#:tests? #f ; no test target
817 #:phases
818 (modify-phases %standard-phases
819 (add-after 'unpack 'fix-hdf5-paths
820 (lambda* (#:key inputs #:allow-other-keys)
821 (let ((prefix (assoc-ref inputs "hdf5")))
822 (substitute* "setup_build.py"
823 (("\\['/opt/local/lib', '/usr/local/lib'\\]")
824 (string-append "['" prefix "/lib" "']"))
825 (("'/opt/local/include', '/usr/local/include'")
826 (string-append "'" prefix "/include" "'")))
827 (substitute* "setup_configure.py"
828 (("\\['/usr/local/lib', '/opt/local/lib'\\]")
829 (string-append "['" prefix "/lib" "']")))
830 #t))))))
831 (propagated-inputs
832 `(("python-six" ,python-six)
833 ("python-numpy" ,python-numpy)))
834 (inputs
835 `(("hdf5" ,hdf5)))
836 (native-inputs
837 `(("python-cython" ,python-cython)
838 ("python-pkgconfig" ,python-pkgconfig)))
839 (home-page "http://www.h5py.org/")
840 (synopsis "Read and write HDF5 files from Python")
841 (description
842 "The h5py package provides both a high- and low-level interface to the
843 HDF5 library from Python. The low-level interface is intended to be a
844 complete wrapping of the HDF5 API, while the high-level component supports
845 access to HDF5 files, datasets and groups using established Python and NumPy
846 concepts.")
847 (license license:bsd-3)))
848
849 (define-public python2-h5py
850 (package-with-python2 python-h5py))
851
852 (define-public python-netcdf4
853 (package
854 (name "python-netcdf4")
855 (version "1.2.7")
856 (source
857 (origin
858 (method url-fetch)
859 (uri (pypi-uri "netCDF4" version))
860 (sha256
861 (base32
862 "1fllizmnpw0zkzzm4j9pgamarlzfn3kmv9zrm0w65q1y31h9ni0c"))))
863 (build-system python-build-system)
864 (native-inputs
865 `(("python-cython" ,python-cython)))
866 (propagated-inputs
867 `(("python-numpy" ,python-numpy)))
868 (inputs
869 `(("netcdf" ,netcdf)
870 ("hdf4" ,hdf4)
871 ("hdf5" ,hdf5)))
872 (arguments
873 '(#:phases
874 (modify-phases %standard-phases
875 (replace 'check
876 (lambda _
877 (setenv "NO_NET" "1") ; disable opendap tests
878 (with-directory-excursion "test"
879 (setenv "PYTHONPATH" ; find and add the library we just built
880 (string-append
881 (car (find-files "../build" "lib.*"
882 #:directories? #:t
883 #:fail-on-error? #:t))
884 ":" (getenv "PYTHONPATH")))
885 (zero? (system* "python" "run_all.py"))))))))
886 (home-page
887 "https://github.com/Unidata/netcdf4-python")
888 (synopsis "Python/numpy interface to the netCDF library")
889 (description "Netcdf4-python is a Python interface to the netCDF C
890 library. netCDF version 4 has many features not found in earlier
891 versions of the library and is implemented on top of HDF5. This module
892 can read and write files in both the new netCDF 4 and the old netCDF 3
893 format, and can create files that are readable by HDF5 clients. The
894 API is modelled after @code{Scientific.IO.NetCDF}, and should be familiar
895 to users of that module.")
896 ;; The software is mainly ISC, but includes some files covered
897 ;; by the Expat license.
898 (license (list license:isc license:expat))))
899
900 (define-public python2-netcdf4
901 (package-with-python2 python-netcdf4))
902
903 (define-public python-lockfile
904 (package
905 (name "python-lockfile")
906 (version "0.12.2")
907 (source
908 (origin
909 (method url-fetch)
910 (uri (string-append "https://pypi.python.org/packages/source/l/lockfile/"
911 "lockfile-" version ".tar.gz"))
912 (sha256
913 (base32
914 "16gpx5hm73ah5n1079ng0vy381hl802v606npkx4x8nb0gg05vba"))))
915 (build-system python-build-system)
916 (arguments '(#:test-target "check"))
917 (native-inputs
918 `(("python-pbr" ,python-pbr)))
919 (home-page "https://launchpad.net/pylockfile")
920 (synopsis "Platform-independent file locking module")
921 (description
922 "The lockfile package exports a LockFile class which provides a simple
923 API for locking files.")
924 (license license:expat)))
925
926 (define-public python2-lockfile
927 (package-with-python2 python-lockfile))
928
929 (define-public python-mock
930 (package
931 (name "python-mock")
932 (version "1.0.1")
933 (source
934 (origin
935 (method url-fetch)
936 (uri (pypi-uri "mock" version))
937 (sha256
938 (base32
939 "0kzlsbki6q0awf89rc287f3aj8x431lrajf160a70z0ikhnxsfdq"))))
940 (build-system python-build-system)
941 (arguments '(#:test-target "check"))
942 (home-page "https://github.com/testing-cabal/mock")
943 (synopsis "Python mocking and patching library for testing")
944 (description
945 "Mock is a library for testing in Python. It allows you to replace parts
946 of your system under test with mock objects and make assertions about how they
947 have been used.")
948 (license license:expat)))
949
950 (define-public python2-mock
951 (package-with-python2 python-mock))
952
953 ;;; Some packages (notably, certbot and python-acme) rely on this newer version
954 ;;; of python-mock. However, a large number of packages fail to build with
955 ;;; mock@2, so we add a new variable for now. Also, there may be a dependency
956 ;;; cycle between mock and six, so we avoid creating python2-mock@2 for now.
957 (define-public python-mock-2
958 (package
959 (inherit python-mock)
960 (version "2.0.0")
961 (source
962 (origin
963 (method url-fetch)
964 (uri (pypi-uri "mock" version))
965 (sha256
966 (base32
967 "1flbpksir5sqrvq2z0dp8sl4bzbadg21sj4d42w3klpdfvgvcn5i"))))
968 (propagated-inputs
969 `(("python-pbr" ,python-pbr-minimal)
970 ,@(package-propagated-inputs python-mock)))))
971
972 (define-public python-setuptools
973 (package
974 (name "python-setuptools")
975 (version "31.0.0")
976 (source
977 (origin
978 (method url-fetch)
979 (uri (pypi-uri "setuptools" version))
980 (sha256
981 (base32
982 "0ypybh4hx3bv4vhg2dc74xpj1g56ggnaffm87k4abhwjwq6wq608"))
983 (modules '((guix build utils)))
984 (snippet
985 '(begin
986 ;; Remove included binaries which are used to build self-extracting
987 ;; installers for Windows.
988 ;; TODO: Find some way to build them ourself so we can include them.
989 (for-each delete-file (find-files "setuptools" "^(cli|gui).*\\.exe$"))
990 #t))))
991 (build-system python-build-system)
992 ;; FIXME: Tests require pytest, which itself relies on setuptools.
993 ;; One could bootstrap with an internal untested setuptools.
994 (arguments
995 `(#:tests? #f))
996 (home-page "https://pypi.python.org/pypi/setuptools")
997 (synopsis
998 "Library designed to facilitate packaging Python projects")
999 (description
1000 "Setuptools is a fully-featured, stable library designed to facilitate
1001 packaging Python projects, where packaging includes:
1002 Python package and module definitions,
1003 distribution package metadata,
1004 test hooks,
1005 project installation,
1006 platform-specific details,
1007 Python 3 support.")
1008 ;; TODO: setuptools now bundles the following libraries:
1009 ;; packaging, pyparsing, six and appdirs. How to unbundle?
1010 (license (list license:psfl ; setuptools itself
1011 license:expat ; six, appdirs, pyparsing
1012 license:asl2.0 ; packaging is dual ASL2/BSD-2
1013 license:bsd-2))))
1014
1015 (define-public python2-setuptools
1016 (package-with-python2 python-setuptools))
1017
1018 (define-public python-uniseg
1019 (package
1020 (name "python-uniseg")
1021 (version "0.7.1")
1022 (source
1023 (origin
1024 (method url-fetch)
1025 (uri (string-append "https://bitbucket.org/emptypage/uniseg-python/"
1026 "get/rel-" version ".tar.gz"))
1027 (file-name (string-append name "-" version ".tar.gz"))
1028 (sha256
1029 (base32
1030 "1df4gddnj2a0v8z35wb2ra5vvh1f1qyxs8fgd25c8g64031mna6x"))))
1031 (build-system python-build-system)
1032 (arguments
1033 '(#:tests? #f)) ; The test suite requires network access.
1034 (home-page
1035 "https://bitbucket.org/emptypage/uniseg-python")
1036 (synopsis
1037 "Python library to determine Unicode text segmentations")
1038 (description
1039 "Uniseg is a Python package used to determine Unicode text segmentations.
1040 Supported segmentations include:
1041 @enumerate
1042 @item @dfn{Code point} (any value in the Unicode codespace)
1043 @item @dfn{Grapheme cluster} (user-perceived character made of a single or
1044 multiple Unicode code points, e.g. \"G\" + acute-accent)
1045 @item Word break
1046 @item Sentence break
1047 @item Line break
1048 @end enumerate")
1049 (license license:expat)))
1050
1051 (define-public python2-uniseg
1052 (package-with-python2 python-uniseg))
1053
1054 ;;; Pycrypto is abandoned upstream:
1055 ;;;
1056 ;;; https://github.com/dlitz/pycrypto/issues/173
1057 ;;;
1058 ;;; TODO Remove this package from GNU Guix.
1059 (define-public python-pycrypto
1060 (package
1061 (name "python-pycrypto")
1062 (version "2.6.1")
1063 (source
1064 (origin
1065 (method url-fetch)
1066 (uri (pypi-uri "pycrypto" version))
1067 (patches (search-patches "python-pycrypto-CVE-2013-7459.patch"))
1068 (sha256
1069 (base32
1070 "0g0ayql5b9mkjam8hym6zyg6bv77lbh66rv1fyvgqb17kfc1xkpj"))))
1071 (build-system python-build-system)
1072 (inputs
1073 `(("python" ,python)
1074 ("gmp" ,gmp)))
1075 (arguments
1076 `(#:phases
1077 (alist-cons-before
1078 'build 'set-build-env
1079 ;; pycrypto runs an autoconf configure script behind the scenes
1080 (lambda _
1081 (setenv "CONFIG_SHELL" (which "bash")))
1082 %standard-phases)))
1083 (home-page "http://www.pycrypto.org/")
1084 (synopsis "Cryptographic modules for Python")
1085 (description
1086 "Pycrypto is a collection of both secure hash functions (such as SHA256
1087 and RIPEMD160), and various encryption algorithms (AES, DES, RSA, ElGamal,
1088 etc.). The package is structured to make adding new modules easy.")
1089 (license license:public-domain)))
1090
1091 (define-public python2-pycrypto
1092 (let ((pycrypto (package-with-python2 python-pycrypto)))
1093 (package (inherit pycrypto)
1094 (inputs
1095 `(("python" ,python-2)
1096 ,@(alist-delete
1097 "python"
1098 (package-inputs pycrypto)))))))
1099
1100 (define-public python-eventlet
1101 (package
1102 (name "python-eventlet")
1103 (version "0.20.1")
1104 (source
1105 (origin
1106 (method url-fetch)
1107 (uri (pypi-uri "eventlet" version))
1108 (sha256
1109 (base32
1110 "0f3q55mq4n021wb7qa53pz3ix6i2py64sap66vsaqm2scjw83m9s"))))
1111 (build-system python-build-system)
1112 (propagated-inputs
1113 `(("python-greenlet" ,python-greenlet)))
1114 (arguments
1115 ;; TODO: Requires unpackaged 'enum-compat'.
1116 '(#:tests? #f))
1117 (home-page "http://eventlet.net")
1118 (synopsis "Concurrent networking library for Python")
1119 (description
1120 "Eventlet is a concurrent networking library for Python that
1121 allows you to change how you run your code, not how you write it.
1122 It uses @code{epoll} or @code{libevent} for highly scalable non-blocking I/O.
1123 Coroutines ensure that the developer uses a blocking style of programming
1124 that is similar to threading, but provide the benefits of non-blocking I/O.
1125 The event dispatch is implicit, which means you can easily use @code{Eventlet}
1126 from the Python interpreter, or as a small part of a larger application.")
1127 (license license:expat)))
1128
1129 (define-public python2-eventlet
1130 (let ((base (package-with-python2
1131 (strip-python2-variant python-eventlet))))
1132 (package (inherit base)
1133 (propagated-inputs
1134 `(("python2-enum34" ,python2-enum34)
1135 ,@(package-propagated-inputs base))))))
1136
1137 (define-public python-keyring
1138 (package
1139 (name "python-keyring")
1140 (version "8.7")
1141 (source
1142 (origin
1143 (method url-fetch)
1144 (uri (pypi-uri "keyring" version))
1145 (sha256
1146 (base32
1147 "0482rmi2x6p78wl2kz8qzyq21xz1sbbfwnv5x7dggar4vkwxhzfx"))))
1148 (build-system python-build-system)
1149 (native-inputs
1150 `(("python-setuptools-scm" ,python-setuptools-scm)))
1151 (propagated-inputs
1152 `(("python-pycrypto" ,python-pycrypto)))
1153 (arguments
1154 `(#:tests? #f)) ;TODO: tests require pytest
1155 (home-page "https://github.com/jaraco/keyring")
1156 (synopsis "Store and access your passwords safely")
1157 (description
1158 "The Python keyring lib provides a easy way to access the system keyring
1159 service from python. It can be used in any application that needs safe
1160 password storage.")
1161 ;; "MIT" and PSF dual license
1162 (license license:x11)))
1163
1164 (define-public python2-keyring
1165 (package-with-python2 python-keyring))
1166
1167 (define-public python-six
1168 (package
1169 (name "python-six")
1170 (version "1.10.0")
1171 (source
1172 (origin
1173 (method url-fetch)
1174 (uri (pypi-uri "six" version))
1175 (sha256
1176 (base32
1177 "0snmb8xffb3vsma0z67i0h0w2g2dy0p3gsgh9gi4i0kgc5l8spqh"))))
1178 (build-system python-build-system)
1179 (native-inputs
1180 `(("python-py" ,python-py)
1181 ("python-pytest" ,python-pytest)))
1182 (home-page "http://pypi.python.org/pypi/six/")
1183 (synopsis "Python 2 and 3 compatibility utilities")
1184 (description
1185 "Six is a Python 2 and 3 compatibility library. It provides utility
1186 functions for smoothing over the differences between the Python versions with
1187 the goal of writing Python code that is compatible on both Python versions.
1188 Six supports every Python version since 2.5. It is contained in only one
1189 Python file, so it can be easily copied into your project.")
1190 (license license:x11)))
1191
1192 (define-public python2-six
1193 (package-with-python2 python-six))
1194
1195 (define-public python-dateutil
1196 (package
1197 (name "python-dateutil")
1198 (version "2.6.0")
1199 (source
1200 (origin
1201 (method url-fetch)
1202 (uri (pypi-uri "python-dateutil" version))
1203 (sha256
1204 (base32
1205 "1lhq0hxjc3cfha101q02ld5ijlpfyjn2w1yh7wvpiy367pgzi8k2"))))
1206 (build-system python-build-system)
1207 (propagated-inputs
1208 `(("python-six" ,python-six)))
1209 (home-page "https://dateutil.readthedocs.io/en/stable/")
1210 (synopsis "Extensions to the standard datetime module")
1211 (description
1212 "The dateutil module provides powerful extensions to the standard
1213 datetime module, available in Python 2.3+.")
1214 (license license:bsd-3)))
1215
1216 (define-public python2-dateutil
1217 (package-with-python2 python-dateutil))
1218
1219 (define-public python-parsedatetime
1220 (package
1221 (name "python-parsedatetime")
1222 (version "2.4")
1223 (source
1224 (origin
1225 (method url-fetch)
1226 (uri (pypi-uri "parsedatetime" version))
1227 (sha256
1228 (base32
1229 "0jxqkjks7z9dn222cqgvskp4wr6d92aglinxq7pd2w4mzdc7r09x"))))
1230 (build-system python-build-system)
1231 (native-inputs
1232 `(("python-nose" ,python-nose)
1233 ("python-pyicu" ,python-pyicu)
1234 ("python-pytest" ,python-pytest)
1235 ("python-pytest-runner" ,python-pytest-runner)))
1236 (propagated-inputs
1237 `(("python-future" ,python-future)))
1238 (home-page "https://github.com/bear/parsedatetime/")
1239 (synopsis
1240 "Parse human-readable date/time text")
1241 (description
1242 "Parse human-readable date/time text.")
1243 (license license:asl2.0)))
1244
1245 (define-public python2-parsedatetime
1246 (package-with-python2 python-parsedatetime))
1247
1248 (define-public python-pandas
1249 (package
1250 (name "python-pandas")
1251 (version "0.19.2")
1252 (source
1253 (origin
1254 (method url-fetch)
1255 (uri (pypi-uri "pandas" version))
1256 (sha256
1257 (base32 "0540cnbwy2hc4hv2sxfs8i47xi91qzvzxfn80dl785ibiicly3vg"))
1258 (patches
1259 (search-patches "python-pandas-skip-failing-tests.patch"))))
1260 (build-system python-build-system)
1261 (propagated-inputs
1262 `(("python-numpy" ,python-numpy)
1263 ("python-pytz" ,python-pytz)
1264 ("python-dateutil" ,python-dateutil)))
1265 (native-inputs
1266 `(("python-nose" ,python-nose)
1267 ("python-cython" ,python-cython)))
1268 (home-page "http://pandas.pydata.org")
1269 (synopsis "Data structures for data analysis, time series, and statistics")
1270 (description
1271 "Pandas is a Python package providing fast, flexible, and expressive data
1272 structures designed to make working with structured (tabular,
1273 multidimensional, potentially heterogeneous) and time series data both easy
1274 and intuitive. It aims to be the fundamental high-level building block for
1275 doing practical, real world data analysis in Python.")
1276 (license license:bsd-3)))
1277
1278 (define-public python2-pandas
1279 (package-with-python2 python-pandas))
1280
1281 (define-public python-tzlocal
1282 (package
1283 (name "python-tzlocal")
1284 (version "1.2.2")
1285 (source
1286 (origin
1287 (method url-fetch)
1288 (uri (pypi-uri "tzlocal" version))
1289 (sha256
1290 (base32
1291 "0paj7vlsb0np8b5sp4bv64wxv7qk2piyp7xg29pkhdjwsbls9fnb"))))
1292 (build-system python-build-system)
1293 (propagated-inputs
1294 `(("python-pytz" ,python-pytz)))
1295 (home-page "https://github.com/regebro/tzlocal")
1296 (synopsis
1297 "Local timezone information for Python")
1298 (description
1299 "Tzlocal returns a tzinfo object with the local timezone information.
1300 This module attempts to fix a glaring hole in pytz, that there is no way to
1301 get the local timezone information, unless you know the zoneinfo name, and
1302 under several distributions that's hard or impossible to figure out.")
1303 (license license:cc0)))
1304
1305 (define-public python2-pysqlite
1306 (package
1307 (name "python2-pysqlite")
1308 (version "2.8.3")
1309 (source
1310 (origin
1311 (method url-fetch)
1312 (uri (pypi-uri "pysqlite" version))
1313 (sha256
1314 (base32
1315 "1424gwq9sil2ffmnizk60q36vydkv8rxs6m7xs987kz8cdc37lqp"))))
1316 (build-system python-build-system)
1317 (inputs
1318 `(("sqlite" ,sqlite)))
1319 (arguments
1320 `(#:python ,python-2 ; incompatible with Python 3
1321 #:tests? #f)) ; no test target
1322 (home-page "https://github.com/ghaering/pysqlite")
1323 (synopsis "SQLite bindings for Python")
1324 (description
1325 "Pysqlite provides SQLite bindings for Python that comply to the
1326 Database API 2.0T.")
1327 (license license:zlib)))
1328
1329
1330 (define-public python2-mechanize
1331 (package
1332 (name "python2-mechanize")
1333 (version "0.2.5")
1334 (source
1335 (origin
1336 (method url-fetch)
1337 (uri (string-append "https://pypi.python.org/packages/source/m/mechanize/mechanize-"
1338 version ".tar.gz"))
1339 (sha256
1340 (base32
1341 "0rj7r166i1dyrq0ihm5rijfmvhs8a04im28lv05c0c3v206v4rrf"))))
1342 (build-system python-build-system)
1343 (arguments
1344 `(#:python ,python-2 ; apparently incompatible with Python 3
1345 #:tests? #f))
1346 ;; test fails with message
1347 ;; AttributeError: 'module' object has no attribute 'test_pullparser'
1348 ;; (python-3.3.2) or
1349 ;; AttributeError: 'module' object has no attribute 'test_urllib2_localnet'
1350 ;; (python-2.7.5).
1351 ;; The source code is from March 2011 and probably not up-to-date
1352 ;; with respect to python unit tests.
1353 (home-page "http://wwwsearch.sourceforge.net/mechanize/")
1354 (synopsis
1355 "Stateful programmatic web browsing in Python")
1356 (description
1357 "Mechanize implements stateful programmatic web browsing in Python,
1358 after Andy Lester’s Perl module WWW::Mechanize.")
1359 (license (license:non-copyleft
1360 "file://COPYING"
1361 "See COPYING in the distribution."))))
1362
1363
1364 (define-public python-simplejson
1365 (package
1366 (name "python-simplejson")
1367 (version "3.10.0")
1368 (source
1369 (origin
1370 (method url-fetch)
1371 (uri (pypi-uri "simplejson" version))
1372 (sha256
1373 (base32
1374 "1qhwsykjlb85igb4cfl6v6gkprzbbg8gyqdd7zscc8w3x0ifcfwm"))))
1375 (build-system python-build-system)
1376 (home-page "http://simplejson.readthedocs.org/en/latest/")
1377 (synopsis
1378 "Json library for Python")
1379 (description
1380 "JSON (JavaScript Object Notation) is a subset of JavaScript
1381 syntax (ECMA-262 3rd edition) used as a lightweight data interchange
1382 format.
1383
1384 Simplejson exposes an API familiar to users of the standard library marshal
1385 and pickle modules. It is the externally maintained version of the json
1386 library contained in Python 2.6, but maintains compatibility with Python 2.5
1387 and (currently) has significant performance advantages, even without using
1388 the optional C extension for speedups. Simplejson is also supported on
1389 Python 3.3+.")
1390 (license license:x11)))
1391
1392 (define-public python2-simplejson
1393 (package-with-python2 python-simplejson))
1394
1395
1396 (define-public python-pyicu
1397 (package
1398 (name "python-pyicu")
1399 (version "1.9.5")
1400 (source
1401 (origin
1402 (method url-fetch)
1403 (uri (pypi-uri "PyICU" version))
1404 (sha256
1405 (base32
1406 "16rmxy9y0qhqqna2v49i7nzwm09as699rbyvh4raw7w602w55c3k"))))
1407 (build-system python-build-system)
1408 (arguments
1409 '(#:phases
1410 (modify-phases %standard-phases
1411 (add-before 'check 'delete-failing-test
1412 (lambda _
1413 ;; XXX: These tests require locales that are unavailable
1414 ;; in the build environment.
1415 (delete-file "test/test_DateTimeParserGenerator.py")
1416 #t)))))
1417 (inputs
1418 `(("icu4c" ,icu4c)))
1419 (home-page "http://pyicu.osafoundation.org/")
1420 (synopsis "Python extension wrapping the ICU C++ API")
1421 (description
1422 "PyICU is a python extension wrapping the ICU C++ API.")
1423 (license license:x11)))
1424
1425 (define-public python2-pyicu
1426 (package-with-python2 python-pyicu))
1427
1428 (define-public python2-dogtail
1429 ;; Python 2 only, as it leads to "TabError: inconsistent use of tabs and
1430 ;; spaces in indentation" with Python 3.
1431 (package
1432 (name "python2-dogtail")
1433 (version "0.9.9")
1434 (source (origin
1435 (method url-fetch)
1436 (uri (pypi-uri "dogtail" version))
1437 (sha256
1438 (base32
1439 "0p5wfssvzr9w0bvhllzbbd8fnp4cca2qxcpcsc33dchrmh5n552x"))))
1440 (build-system python-build-system)
1441 (arguments `(#:python ,python-2
1442 #:tests? #f)) ; invalid command "test"
1443 ;; Currently no offical homepage.
1444 (home-page "https://pypi.python.org/pypi/dogtail/")
1445 (synopsis "GUI test tool and automation framework written in Python")
1446 (description
1447 "Dogtail is a GUI test tool and automation framework written in Python.
1448 It uses Accessibility (a11y) technologies to communicate with desktop
1449 applications. dogtail scripts are written in Python and executed like any
1450 other Python program.")
1451 (license license:gpl2+)))
1452
1453 (define-public python2-empy
1454 (package
1455 (name "python2-empy")
1456 (version "3.3")
1457 (source (origin
1458 (method url-fetch)
1459 (uri (string-append "http://www.alcyone.com/software/empy/empy-"
1460 version ".tar.gz"))
1461 (sha256
1462 (base32
1463 "01g8mmkfnvjdmlhsihwyx56lrg7r5m5d2fg6mnxsvy6g0dnl69f6"))))
1464 (build-system python-build-system)
1465 (arguments
1466 `(#:python ,python-2
1467 #:phases (alist-replace
1468 'check
1469 (lambda _
1470 (zero? (system* "./test.sh")))
1471 %standard-phases)))
1472 (home-page "http://www.alcyone.com/software/empy/")
1473 (synopsis "Templating system for Python")
1474 (description
1475 "EmPy is a system for embedding Python expressions and statements in
1476 template text; it takes an EmPy source file, processes it, and produces
1477 output. This is accomplished via expansions, which are special signals to the
1478 EmPy system and are set off by a special prefix (by default the at sign, @@).
1479 EmPy can expand arbitrary Python expressions and statements in this way, as
1480 well as a variety of special forms. Textual data not explicitly delimited in
1481 this way is sent unaffected to the output, allowing Python to be used in
1482 effect as a markup language. Also supported are callbacks via hooks,
1483 recording and playback via diversions, and dynamic, chainable filters. The
1484 system is highly configurable via command line options and embedded
1485 commands.")
1486 (license license:lgpl2.1+)))
1487
1488 (define-public python2-element-tree
1489 (package
1490 (name "python2-element-tree")
1491 (version "1.2.6")
1492 (source (origin
1493 (method url-fetch)
1494 (uri (string-append
1495 "http://effbot.org/media/downloads/elementtree-"
1496 version "-20050316.tar.gz"))
1497 (sha256
1498 (base32
1499 "016bphqnlg0l4vslahhw4r0aanw95bpypy65r1i1acyb2wj5z7dj"))))
1500 (build-system python-build-system)
1501 (arguments
1502 `(#:python ,python-2 ; seems to be part of Python 3
1503 #:tests? #f)) ; no 'test' sub-command
1504 (synopsis "Toolkit for XML processing in Python")
1505 (description
1506 "ElementTree is a Python library supporting lightweight XML processing.")
1507 (home-page "http://effbot.org/zone/element-index.htm")
1508 (license (license:x11-style
1509 "http://docs.python.org/2/license.html"
1510 "Like \"CWI LICENSE AGREEMENT FOR PYTHON 0.9.0 THROUGH 1.2\"."))))
1511
1512 (define-public python2-pybugz
1513 (package
1514 (name "python2-pybugz")
1515 (version "0.6.11")
1516 (source (origin
1517 (method url-fetch)
1518 (uri (string-append
1519 "http://bits.liquidx.net/projects/pybugz/pybugz-"
1520 version ".tar.gz"))
1521 (sha256
1522 (base32
1523 "17ni00p08gp5lkxlrrcnvi3x09fmajnlbz4da03qcgl9q21ym4jd"))
1524 (patches (search-patches "pybugz-stty.patch"
1525 "pybugz-encode-error.patch"))))
1526 (build-system python-build-system)
1527 (arguments
1528 `(#:python ,python-2 ; SyntaxError with Python 3
1529 #:tests? #f)) ; no 'test' sub-command
1530 (propagated-inputs
1531 `(("element-tree" ,python2-element-tree)))
1532 (synopsis "Python and command-line interface to Bugzilla")
1533 (description
1534 "PyBugz is a Python library and command-line tool to query the Bugzilla
1535 bug tracking system. It is meant as an aid to speed up interaction with the
1536 bug tracker.")
1537 (home-page "http://www.liquidx.net/pybugz/")
1538 (license license:gpl2)))
1539
1540 (define-public python-enum34
1541 (package
1542 (name "python-enum34")
1543 (version "1.1.6")
1544 (source
1545 (origin
1546 (method url-fetch)
1547 (uri (pypi-uri "enum34" version))
1548 (sha256
1549 (base32
1550 "1cgm5ng2gcfrkrm3hc22brl6chdmv67b9zvva9sfs7gn7dwc9n4a"))))
1551 (build-system python-build-system)
1552 (home-page "https://pypi.python.org/pypi/enum34")
1553 (synopsis "Backported Python 3.4 Enum")
1554 (description
1555 "Enum34 is the new Python stdlib enum module available in Python 3.4
1556 backported for previous versions of Python from 2.4 to 3.3.")
1557 (license license:bsd-3)))
1558
1559 (define-public python2-enum34
1560 (package-with-python2 python-enum34))
1561
1562 (define-public python-parse-type
1563 (package
1564 (name "python-parse-type")
1565 (version "0.3.4")
1566 (source
1567 (origin
1568 (method url-fetch)
1569 (uri (string-append "https://pypi.python.org/packages/source/p/"
1570 "parse_type/parse_type-" version ".tar.gz"))
1571 (sha256
1572 (base32
1573 "0iv1c34npr4iynwpgv1vkjx9rjd18a85ir8c01gc5f7wp8iv7l1x"))))
1574 (build-system python-build-system)
1575 (arguments
1576 `(#:phases
1577 (modify-phases %standard-phases
1578 (add-after 'unpack 'patch-tests
1579 (lambda _
1580 (substitute* "tests/test_parse_type_parse.py"
1581 ;; Newer Python versions don't have the problem this test tests.
1582 (("self[.]assertRaises[(]parse.TooManyFields, p.parse, ''[)]")
1583 ""))
1584 #t)))))
1585 (propagated-inputs
1586 `(("python-six" ,python-six)
1587 ("python-parse" ,python-parse)))
1588 (native-inputs
1589 `(("python-pytest" ,python-pytest)
1590 ("python-pytest-runner" ,python-pytest-runner)))
1591 (home-page "https://github.com/jenisys/parse_type")
1592 (synopsis "Extended parse module")
1593 (description
1594 "Parse_type extends the python parse module.")
1595 (properties
1596 `((python2-variant . ,(delay python2-parse-type))))
1597 (license license:bsd-3)))
1598
1599 (define-public python2-parse-type
1600 (let ((base (package-with-python2
1601 (strip-python2-variant python-parse-type))))
1602 (package (inherit base)
1603 (propagated-inputs
1604 `(("python2-enum34" ,python2-enum34)
1605 ,@(package-propagated-inputs base))))))
1606
1607 (define-public python-parse
1608 (package
1609 (name "python-parse")
1610 (version "1.6.6")
1611 (source
1612 (origin
1613 (method url-fetch)
1614 (uri (pypi-uri "parse" version))
1615 (sha256
1616 (base32
1617 "0y31i3mwgv35qn0kzzjn9q8jqfdqmbi6sr6yfvn8rq4lqjm5lhvi"))
1618 (patches (search-patches "python-parse-too-many-fields.patch"))))
1619 (build-system python-build-system)
1620 (arguments
1621 `(#:phases
1622 (modify-phases %standard-phases
1623 (replace 'check
1624 (lambda _ (zero? (system* "python" "test_parse.py")))))))
1625 (home-page "https://github.com/r1chardj0n3s/parse")
1626 (synopsis "Parse strings")
1627 (description
1628 "Parse strings using a specification based on the Python format()
1629 syntax.")
1630 (license license:x11)))
1631
1632 (define-public python-polib
1633 (package
1634 (name "python-polib")
1635 (version "1.0.8")
1636 (source (origin
1637 (method url-fetch)
1638 (uri (pypi-uri "polib" version))
1639 (sha256
1640 (base32
1641 "1pq2hbm3m2q0cjdszk8mc4qa1vl3wcblh5nfyirlfnzb2pcy7zss"))))
1642 (build-system python-build-system)
1643 (home-page "https://bitbucket.org/izi/polib/wiki/Home")
1644 (synopsis "Manipulate, create and modify gettext files")
1645 (description "Polib can manipulate any gettext format (po, pot and mo)
1646 files. It can be used to create po files from scratch or to modify
1647 existing ones.")
1648 (license license:expat)))
1649
1650 (define-public python2-polib
1651 (let ((base (package-with-python2 (strip-python2-variant python-polib))))
1652 (package
1653 (inherit base)
1654 (arguments `(,@(package-arguments base)
1655 ;; Tests don't work with python2.
1656 #:tests? #f)))))
1657
1658 (define-public scons
1659 (package
1660 (name "scons")
1661 (version "2.5.1")
1662 (source (origin
1663 (method url-fetch)
1664 (uri (string-append "mirror://sourceforge/scons/scons/" version
1665 "/scons-" version ".tar.gz"))
1666 (sha256
1667 (base32
1668 "1wji1z9jdkhnmm99apx6fhld9cs52rr56aigniyrcsmlwy52298b"))))
1669 (build-system python-build-system)
1670 (arguments
1671 ;; With Python 3.x, fails to build with a syntax error.
1672 `(#:python ,python-2
1673 #:use-setuptools? #f ; still relies on distutils
1674 #:tests? #f)) ; no 'python setup.py test' command
1675 (home-page "http://scons.org/")
1676 (synopsis "Software construction tool written in Python")
1677 (description
1678 "SCons is a software construction tool. Think of SCons as an improved,
1679 cross-platform substitute for the classic Make utility with integrated
1680 functionality similar to autoconf/automake and compiler caches such as ccache.
1681 In short, SCons is an easier, more reliable and faster way to build
1682 software.")
1683 (license license:x11)))
1684
1685 (define-public python-extras
1686 (package
1687 (name "python-extras")
1688 (version "0.0.3")
1689 (source
1690 (origin
1691 (method url-fetch)
1692 (uri (string-append
1693 "https://pypi.python.org/packages/source/e/extras/extras-"
1694 version ".tar.gz"))
1695 (sha256
1696 (base32
1697 "1h7zx4dfyclalg0fqnfjijpn0f793a9mx8sy3b27gd31nr6dhq3s"))))
1698 (build-system python-build-system)
1699 (arguments
1700 ;; error in setup.cfg: command 'test' has no such option 'buffer'
1701 '(#:tests? #f))
1702 (home-page "https://github.com/testing-cabal/extras")
1703 (synopsis "Useful extensions to the Python standard library")
1704 (description
1705 "Extras is a set of extensions to the Python standard library.")
1706 (license license:expat)))
1707
1708 (define-public python2-extras
1709 (package-with-python2 python-extras))
1710
1711 (define-public python-mimeparse
1712 (package
1713 (name "python-mimeparse")
1714 (version "0.1.4")
1715 (source
1716 (origin
1717 (method url-fetch)
1718 (uri (string-append
1719 "https://pypi.python.org/packages/source/p/python-mimeparse/python-mimeparse-"
1720 version ".tar.gz"))
1721 (sha256
1722 (base32
1723 "1hyxg09kaj02ri0rmwjqi86wk4nd1akvv7n0dx77azz76wga4s9w"))))
1724 (build-system python-build-system)
1725 (arguments
1726 '(#:tests? #f)) ; no setup.py test command
1727 (home-page
1728 "https://github.com/dbtsai/python-mimeparse")
1729 (synopsis "Python library for parsing MIME types")
1730 (description
1731 "Mimeparse provides basic functions for parsing MIME type names and
1732 matching them against a list of media-ranges.")
1733 (license license:expat)))
1734
1735 (define-public python2-mimeparse
1736 (package-with-python2 python-mimeparse))
1737
1738 (define-public python-nose
1739 (package
1740 (name "python-nose")
1741 (version "1.3.7")
1742 (source
1743 (origin
1744 (method url-fetch)
1745 (uri (pypi-uri "nose" version))
1746 (sha256
1747 (base32
1748 "164a43k7k2wsqqk1s6vavcdamvss4mz0vd6pwzv2h9n8rgwzxgzi"))))
1749 (build-system python-build-system)
1750 (arguments
1751 '(#:tests? #f)) ; FIXME: test suite fails
1752 (home-page "http://readthedocs.org/docs/nose/")
1753 (synopsis "Python testing library")
1754 (description
1755 "Nose extends the unittest library to make testing easier.")
1756 (license license:lgpl2.0+)))
1757
1758 (define-public python2-nose
1759 (package-with-python2 python-nose))
1760
1761 (define-public python-nose2
1762 (package
1763 (name "python-nose2")
1764 (version "0.6.5")
1765 (source
1766 (origin
1767 (method url-fetch)
1768 (uri (pypi-uri "nose2" version))
1769 (sha256
1770 (base32
1771 "1x4zjq1zlyrh8b9ba0cmafd3w94pxhid408kibyjd3s6h1lap6s7"))))
1772 (build-system python-build-system)
1773 (arguments `(#:tests? #f)) ; 'module' object has no attribute 'collector'
1774 (propagated-inputs
1775 `(("python-cov-core" ,python-cov-core)
1776 ("python-pytest-cov" ,python-pytest-cov)
1777 ("python-six" ,python-six)))
1778 (home-page "https://github.com/nose-devs/nose2")
1779 (synopsis "Next generation of nicer testing for Python")
1780 (description
1781 "Nose2 is the next generation of nicer testing for Python, based on the
1782 plugins branch of unittest2. Nose2 aims to improve on nose by providing a
1783 better plugin api, being easier for users to configure, and simplifying internal
1784 interfaces and processes.")
1785 (license license:bsd-2)))
1786
1787 (define-public python2-nose2
1788 (package-with-python2 python-nose2))
1789
1790 (define-public python-unittest2
1791 (package
1792 (name "python-unittest2")
1793 (version "0.5.1")
1794 (source
1795 (origin
1796 (method url-fetch)
1797 (uri (string-append
1798 "https://pypi.python.org/packages/source/u/unittest2py3k/unittest2py3k-"
1799 version ".tar.gz"))
1800 (sha256
1801 (base32
1802 "00yl6lskygcrddx5zspkhr0ibgvpknl4678kkm6s626539grq93q"))))
1803 (build-system python-build-system)
1804 (home-page "http://pypi.python.org/pypi/unittest2")
1805 (synopsis "Python unit testing library")
1806 (description
1807 "Unittest2 is a replacement for the unittest module in the Python
1808 standard library.")
1809 (license license:psfl)))
1810
1811 (define-public python2-unittest2
1812 (package (inherit python-unittest2)
1813 (name "python2-unittest2")
1814 (version "0.5.1")
1815 (source
1816 (origin
1817 (method url-fetch)
1818 (uri (string-append
1819 "https://pypi.python.org/packages/source/u/unittest2/unittest2-"
1820 version ".tar.gz"))
1821 (sha256
1822 (base32
1823 "0wbs4i4x3x7klr3v35ss6p9mcqz883i1xgcpkhvl7n2lyv6yhpda"))))
1824 (arguments
1825 `(#:python ,python-2
1826 #:tests? #f)))) ; no setup.py test command
1827
1828 (define-public python-pafy
1829 (package
1830 (name "python-pafy")
1831 (version "0.5.3.1")
1832 (source
1833 (origin
1834 (method url-fetch)
1835 (uri (pypi-uri "pafy" version))
1836 (sha256
1837 (base32
1838 "1a7dxi95m1043rxx1r5x3ngb66nwlq6aqcasyqqjzmmmjps4zrim"))))
1839 (build-system python-build-system)
1840 (arguments
1841 `(#:tests? #f)) ; Currently pafy can not find itself in the tests
1842 (propagated-inputs
1843 ;; Youtube-dl is a python package which is imported in the file
1844 ;; "backend_youtube_dl.py", therefore it needs to be propagated.
1845 `(("youtube-dl" ,youtube-dl)))
1846 (home-page "https://np1.github.io/pafy/")
1847 (synopsis "Retrieve YouTube content and metadata")
1848 (description
1849 "@code{pafy} is a python library to retrieve YouTube content and metadata.")
1850 (license license:lgpl3+)))
1851
1852 (define-public python-py
1853 (package
1854 (name "python-py")
1855 (version "1.4.32")
1856 (source
1857 (origin
1858 (method url-fetch)
1859 (uri (pypi-uri "py" version))
1860 (sha256
1861 (base32
1862 "19s1pql9pq85h1qzsdwgyb8a3k1qgkvh33b02m8kfqhizz8rzf64"))))
1863 (build-system python-build-system)
1864 (arguments
1865 ;; FIXME: "ImportError: 'test' module incorrectly imported from
1866 ;; '/gnu/store/...-python-pytest-mimimal-3.0.5/lib/python3.5/site-packages'.
1867 ;; Expected '/tmp/guix-build-python-py-1.4.31.drv-0/py-1.4.31/py'.
1868 ;; Is this module globally installed?"
1869 '(#:tests? #f))
1870 (home-page "http://pylib.readthedocs.org/")
1871 (synopsis "Python library for parsing, I/O, instrospection, and logging")
1872 (description
1873 "Py is a Python library for file name parsing, .ini file parsing, I/O,
1874 code introspection, and logging.")
1875 (license license:expat)))
1876
1877 (define-public python2-py
1878 (package-with-python2 python-py))
1879
1880 (define-public python-pytest
1881 (package
1882 (name "python-pytest")
1883 (version "2.7.3")
1884 (source
1885 (origin
1886 (method url-fetch)
1887 (uri (string-append
1888 "https://pypi.python.org/packages/source/p/pytest/pytest-"
1889 version ".tar.gz"))
1890 (sha256
1891 (base32
1892 "1z4yi986f9n0p8qmzmn21m21m8j1x78hk3505f89baqm6pdw7afm"))
1893 (modules '((guix build utils)))
1894 (snippet
1895 ;; One of the tests involves the /usr directory, so it fails.
1896 '(substitute* "testing/test_argcomplete.py"
1897 (("def test_remove_dir_prefix\\(self\\):")
1898 "@pytest.mark.xfail\n def test_remove_dir_prefix(self):")))))
1899 (build-system python-build-system)
1900 (propagated-inputs
1901 `(("python-py" ,python-py)))
1902 (native-inputs
1903 `(("python-nose" ,python-nose)
1904 ("python-mock" ,python-mock)))
1905 (home-page "http://pytest.org")
1906 (synopsis "Python testing library")
1907 (description
1908 "Pytest is a testing tool that provides auto-discovery of test modules
1909 and functions, detailed info on failing assert statements, modular fixtures,
1910 and many external plugins.")
1911 (license license:expat)))
1912
1913 (define-public python2-pytest
1914 (package-with-python2 python-pytest))
1915
1916 ;; Some packages require a newer pytest.
1917 (define-public python-pytest-3.0
1918 (package
1919 (inherit python-pytest)
1920 (name "python-pytest")
1921 (version "3.0.7")
1922 (source (origin
1923 (method url-fetch)
1924 (uri (pypi-uri "pytest" version))
1925 (sha256
1926 (base32
1927 "1asc4b2nd2a4f0g3r12y97rslq5wliji7b73wwkvdrm5s7mrc1mp"))))
1928 (arguments
1929 `(#:phases
1930 (modify-phases %standard-phases
1931 (add-before 'check 'disable-invalid-test
1932 (lambda _
1933 (substitute* "testing/test_argcomplete.py"
1934 (("def test_remove_dir_prefix" line)
1935 (string-append "@pytest.mark.skip"
1936 "(reason=\"Assumes that /usr exists.\")\n "
1937 line)))
1938 #t)))))
1939 (native-inputs
1940 `(("python-nose" ,python-nose)
1941 ("python-mock" ,python-mock)
1942 ("python-hypothesis" ,python-hypothesis)))
1943 (properties `((python2-variant . ,(delay python2-pytest-3.0))))))
1944
1945 (define-public python2-pytest-3.0
1946 (let ((base (package-with-python2
1947 (strip-python2-variant python-pytest-3.0))))
1948 (package (inherit base)
1949 (native-inputs
1950 `(("python2-enum34" ,python2-enum34)
1951 ,@(package-native-inputs base))))))
1952
1953 (define-public python-pytest-cov
1954 (package
1955 (name "python-pytest-cov")
1956 (version "2.4.0")
1957 (source
1958 (origin
1959 (method url-fetch)
1960 (uri (pypi-uri "pytest-cov" version))
1961 (sha256
1962 (base32
1963 "03c2qc42r4bczyw93gd7n0qi1h1jfhw7fnbhi33c3vp1hs81gm2k"))))
1964 (build-system python-build-system)
1965 (arguments
1966 `(#:phases
1967 (modify-phases %standard-phases
1968 (replace 'check
1969 (lambda _
1970 ;; options taken from tox.ini
1971 ;; TODO: make "--restructuredtext" tests pass. They currently fail
1972 ;; with "Duplicate implicit target name"
1973 (zero? (system* "python" "./setup.py" "check"
1974 "--strict" "--metadata")))))))
1975 (propagated-inputs
1976 `(("python-coverage" ,python-coverage)
1977 ("python-pytest" ,python-pytest)))
1978 (home-page "https://github.com/pytest-dev/pytest-cov")
1979 (synopsis "Pytest plugin for measuring coverage")
1980 (description
1981 "Pytest-cov produces coverage reports. It supports centralised testing and
1982 distributed testing in both @code{load} and @code{each} modes. It also
1983 supports coverage of subprocesses.")
1984 (license license:expat)))
1985
1986 (define-public python2-pytest-cov
1987 (package-with-python2 python-pytest-cov))
1988
1989 (define-public python-pytest-runner
1990 (package
1991 (name "python-pytest-runner")
1992 (version "2.11.1")
1993 (source
1994 (origin
1995 (method url-fetch)
1996 (uri (pypi-uri "pytest-runner" version))
1997 (sha256
1998 (base32
1999 "1cw978kqqcq916b9gfns1qjqvg33c5ail5jhw9054dsynkm32flq"))))
2000 (build-system python-build-system)
2001 (arguments
2002 `(#:phases
2003 (modify-phases %standard-phases
2004 ;; The fancy way of setting the version with setuptools_scm does not
2005 ;; seem to work here.
2006 (add-after 'unpack 'set-version
2007 (lambda _
2008 (substitute* "docs/conf.py"
2009 (("version = setuptools_scm\\.get_version\\(root='\\.\\.')")
2010 (string-append "version = \"" ,version "\"")))
2011 #t)))))
2012 (native-inputs
2013 `(("python-pytest" ,python-pytest)
2014 ("python-setuptools-scm" ,python-setuptools-scm)))
2015 (home-page "https://github.com/pytest-dev/pytest-runner")
2016 (synopsis "Invoke py.test as a distutils command")
2017 (description
2018 "This package provides a @command{pytest-runner} command that
2019 @file{setup.py} files can use to run tests.")
2020 (license license:expat)))
2021
2022 (define-public python2-pytest-runner
2023 (package-with-python2 python-pytest-runner))
2024
2025 (define-public python-pytest-mock
2026 (package
2027 (name "python-pytest-mock")
2028 (version "1.2")
2029 (source
2030 (origin
2031 (method url-fetch)
2032 (uri (pypi-uri "pytest-mock" version ".zip"))
2033 (sha256
2034 (base32
2035 "03zxar5drzm7ksqyrwypjaza3cri6wqvpr6iam92djvg6znp32gp"))))
2036 (build-system python-build-system)
2037 (native-inputs
2038 `(("unzip" ,unzip)))
2039 (propagated-inputs
2040 `(("python-pytest" ,python-pytest)))
2041 (home-page "https://github.com/pytest-dev/pytest-mock/")
2042 (synopsis "Thin-wrapper around the mock package for easier use with py.test")
2043 (description
2044 "This plugin installs a @code{mocker} fixture which is a thin-wrapper
2045 around the patching API provided by the @code{mock} package, but with the
2046 benefit of not having to worry about undoing patches at the end of a test.
2047 The mocker fixture has the same API as @code{mock.patch}, supporting the
2048 same arguments.")
2049 (properties `((python2-variant . ,(delay python2-pytest-mock))))
2050 (license license:expat)))
2051
2052 (define-public python2-pytest-mock
2053 (let ((base (package-with-python2
2054 (strip-python2-variant python-pytest-mock))))
2055 (package (inherit base)
2056 (propagated-inputs
2057 `(("python2-mock" ,python2-mock)
2058 ,@(package-propagated-inputs base))))))
2059
2060 (define-public python-pytest-xdist
2061 (package
2062 (name "python-pytest-xdist")
2063 (version "1.14")
2064 (source
2065 (origin
2066 (method url-fetch)
2067 (uri (pypi-uri "pytest-xdist" version ".zip"))
2068 (sha256
2069 (base32
2070 "08rn2l39ds60xshs4js787l84pfckksqklfq2wq9x8ig2aci2pja"))
2071 (modules '((guix build utils)))
2072 (snippet
2073 '(begin
2074 ;; Remove pre-compiled .pyc files from source.
2075 (for-each delete-file-recursively
2076 (find-files "." "__pycache__" #:directories? #t))
2077 (for-each delete-file (find-files "." "\\.pyc$"))
2078 #t))))
2079 (build-system python-build-system)
2080 (arguments
2081 '(#:tests? #f)) ;FIXME: Some tests are failing.
2082 ;; #:phases
2083 ;; (modify-phases %standard-phases
2084 ;; (delete 'check)
2085 ;; (add-after 'install 'check
2086 ;; (lambda* (#:key inputs outputs #:allow-other-keys)
2087 ;; (add-installed-pythonpath inputs outputs)
2088 ;; (zero? (system* "py.test" "-v")))))
2089 (native-inputs
2090 `(("unzip" ,unzip)
2091 ("python-setuptools-scm" ,python-setuptools-scm)))
2092 (propagated-inputs
2093 `(("python-execnet" ,python-execnet)
2094 ("python-pytest" ,python-pytest)
2095 ("python-py" ,python-py)))
2096 (home-page
2097 "https://github.com/pytest-dev/pytest-xdist")
2098 (synopsis
2099 "Plugin for py.test with distributed testing and loop-on-failing modes")
2100 (description
2101 "The pytest-xdist plugin extends py.test with some unique test execution
2102 modes: parallelization, running tests in boxed subprocesses, the ability
2103 to run tests repeatedly when failed, and the ability to run tests on multiple
2104 Python interpreters or platforms. It uses rsync to copy the existing
2105 program code to a remote location, executes there, and then syncs the
2106 result back.")
2107 (license license:expat)))
2108
2109 (define-public python2-pytest-xdist
2110 (package-with-python2 python-pytest-xdist))
2111
2112 (define-public python-scripttest
2113 (package
2114 (name "python-scripttest")
2115 (version "1.3")
2116 (source
2117 (origin
2118 (method url-fetch)
2119 (uri (string-append
2120 "https://pypi.python.org/packages/source/s/scripttest/scripttest-"
2121 version ".tar.gz"))
2122 (sha256
2123 (base32
2124 "0f4w84k8ck82syys7yg9maz93mqzc8p5ymis941x034v44jzq74m"))))
2125 (build-system python-build-system)
2126 (native-inputs
2127 `(("python-pytest" ,python-pytest)))
2128 (home-page "http://pythonpaste.org/scripttest/")
2129 (synopsis "Python library to test command-line scripts")
2130 (description "Scripttest is a Python helper library for testing
2131 interactive command-line applications. With it you can run a script in a
2132 subprocess and see the output as well as any file modifications.")
2133 (license license:expat)))
2134
2135 (define-public python2-scripttest
2136 (package-with-python2 python-scripttest))
2137
2138 (define-public python-testtools
2139 (package
2140 (name "python-testtools")
2141 (version "1.4.0")
2142 (source
2143 (origin
2144 (method url-fetch)
2145 (uri (pypi-uri "testtools" version))
2146 (sha256
2147 (base32
2148 "1vw8yljnd75d396hhw6s2hrf4cclzy845ifd5am0lxsl235z3i8c"))))
2149 (build-system python-build-system)
2150 (arguments
2151 `(#:phases
2152 (modify-phases %standard-phases
2153 (add-after 'unpack 'fix-module-imports
2154 (lambda _
2155 (substitute* "setup.py"
2156 (("'unittest2>=0.8.0',") ""))
2157 (substitute* '("testtools/testcase.py"
2158 "testtools/testsuite.py"
2159 "testtools/run.py"
2160 "testtools/tests/test_run.py"
2161 "testtools/tests/test_testsuite.py"
2162 "testtools/tests/test_deferredruntest.py")
2163 ;; unittest2 is a backport of Python2.7 features to Python 2.4.
2164 (("import unittest2 as unittest") "import unittest")
2165 (("import unittest2") "import unittest as unittest2")
2166 (("from unittest2 import") "from unittest import"))
2167 (substitute* "testtools/tests/test_testresult.py"
2168 ;; NUL in source code is not allowed (raises ValueError).
2169 (("\\x00\\x04") "\\x04"))
2170 #t)))))
2171 (propagated-inputs
2172 `(("python-mimeparse" ,python-mimeparse)
2173 ("python-extras" ,python-extras)))
2174 (home-page "https://github.com/testing-cabal/testtools")
2175 (synopsis
2176 "Extensions to the Python standard library unit testing framework")
2177 (description
2178 "Testtools extends the Python standard library unit testing framework to
2179 provide matchers, more debugging information, and cross-Python
2180 compatibility.")
2181 (license license:psfl)))
2182
2183 (define-public python2-testtools
2184 (package-with-python2 python-testtools))
2185
2186 (define-public python-testscenarios
2187 (package
2188 (name "python-testscenarios")
2189 (version "0.4")
2190 (source
2191 (origin
2192 (method url-fetch)
2193 (uri (string-append
2194 "https://pypi.python.org/packages/source/t/testscenarios/testscenarios-"
2195 version ".tar.gz"))
2196 (sha256
2197 (base32
2198 "1671jvrvqlmbnc42j7pc5y6vc37q44aiwrq0zic652pxyy2fxvjg"))))
2199 (build-system python-build-system)
2200 (propagated-inputs
2201 `(("python-testtools" ,python-testtools)))
2202 (home-page "https://launchpad.net/testscenarios")
2203 (synopsis "Pyunit extension for dependency injection")
2204 (description
2205 "Testscenarios provides clean dependency injection for Python unittest
2206 style tests.")
2207 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2208
2209 (define-public python2-testscenarios
2210 (package-with-python2 python-testscenarios))
2211
2212 (define-public python-testresources
2213 (package
2214 (name "python-testresources")
2215 (version "0.2.7")
2216 (source
2217 (origin
2218 (method url-fetch)
2219 (uri (string-append
2220 "https://pypi.python.org/packages/source/t/testresources/testresources-"
2221 version ".tar.gz"))
2222 (sha256
2223 (base32
2224 "0cbj3plbllyz42c4b5xxgwaa7mml54lakslrn4kkhinxhdri22md"))))
2225 (build-system python-build-system)
2226 (home-page "https://launchpad.net/testresources")
2227 (synopsis
2228 "Pyunit extension for managing test resources")
2229 (description
2230 "Testresources is an extension to Python's unittest to allow declarative
2231 use of resources by test cases.")
2232 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2233
2234 (define-public python2-testresources
2235 (package-with-python2 python-testresources))
2236
2237 (define-public python-subunit
2238 (package
2239 (name "python-subunit")
2240 (version "0.0.21")
2241 (source
2242 (origin
2243 (method url-fetch)
2244 (uri (string-append
2245 "https://pypi.python.org/packages/source/p/python-subunit/python-subunit-"
2246 version ".tar.gz"))
2247 (sha256
2248 (base32
2249 "1nkw9wfbvizmpajbj3in8ns07g7lwkiv8hip14jjlwk3cacls6jv"))))
2250 (build-system python-build-system)
2251 (propagated-inputs
2252 `(("python-extras" ,python-extras)
2253 ("python-mimeparse" ,python-mimeparse)))
2254 (native-inputs
2255 `(("python-testscenarios" ,python-testscenarios)))
2256 (home-page "http://launchpad.net/subunit")
2257 (synopsis "Python implementation of the subunit protocol")
2258 (description
2259 "Python-subunit is a Python implementation of the subunit test streaming
2260 protocol.")
2261 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2262
2263 (define-public python2-subunit
2264 (package-with-python2 python-subunit))
2265
2266 ;; Recent versions of python-fixtures and python-testrepository need
2267 ;; python-pbr for packaging, which itself needs these two packages for
2268 ;; testing.
2269 ;; To fix this circular dependency, we use a build of python-pbr, based on the
2270 ;; same source, just without any test dependencies and with tests disabled.
2271 ;; python-pbr-minmal is then used to package python-fixtures and
2272 ;; python-testrepository.
2273 ;; Strictly speaking we currently could remove the test-requirements from the
2274 ;; normal python-pbr package (and save this package) since test are disabled
2275 ;; there anyway. But this may change in future.
2276 (define python-pbr-minimal
2277 (package
2278 (name "python-pbr-minimal")
2279 (version "1.10.0")
2280 (source
2281 (origin
2282 (method url-fetch)
2283 (uri (pypi-uri "pbr" version))
2284 (sha256
2285 (base32
2286 "177kd9kbv1hvf2ban7l3x9ymzbi1md4hkaymwbgnz7ihf312hr0q"))
2287 (patches (search-patches "python-pbr-fix-man-page-support.patch"))))
2288 (build-system python-build-system)
2289 (arguments
2290 `(#:tests? #f))
2291 (home-page "http://docs.openstack.org/developer/pbr/")
2292 (synopsis "Minimal build of python-pbr used for bootstrapping")
2293 (description
2294 "Used only for bootstrapping python2-pbr, you should not need this.")
2295 (license license:asl2.0)))
2296
2297 (define python2-pbr-minimal
2298 (package-with-python2 python-pbr-minimal))
2299
2300 (define-public python-pbr
2301 (package
2302 (inherit python-pbr-minimal)
2303 (name "python-pbr")
2304 (arguments
2305 `(#:tests? #f)) ;; Most tests seem to use the Internet.
2306 (propagated-inputs
2307 `(("git" ,git))) ;; pbr actually uses the "git" binary.
2308 (native-inputs
2309 `(("python-fixtures" ,python-fixtures)
2310 ;; discover, coverage, hacking, subunit
2311 ("python-mock" ,python-mock)
2312 ("python-six" ,python-six)
2313 ("python-sphinx" ,python-sphinx)
2314 ("python-testrepository" ,python-testrepository)
2315 ("python-testresources" ,python-testresources)
2316 ("python-testscenarios" ,python-testscenarios)
2317 ("python-testtools" ,python-testtools)
2318 ("python-virtualenv" ,python-virtualenv)))
2319 (synopsis "Enhance the default behavior of Python’s setuptools")
2320 (description
2321 "Python Build Reasonableness (PBR) is a library that injects some useful
2322 and sensible default behaviors into your setuptools run. It will set
2323 versions, process requirements files and generate AUTHORS and ChangeLog file
2324 from git information.
2325 ")))
2326
2327 (define-public python2-pbr
2328 (package-with-python2 python-pbr))
2329
2330 (define-public python-fixtures
2331 (package
2332 (name "python-fixtures")
2333 (version "1.4.0")
2334 (source
2335 (origin
2336 (method url-fetch)
2337 (uri (pypi-uri "fixtures" version))
2338 (sha256
2339 (base32
2340 "0djxvdwm8s60dbfn7bhf40x6g818p3b3mlwijm1c3bqg7msn271y"))))
2341 (build-system python-build-system)
2342 (arguments
2343 '(#:phases
2344 (modify-phases %standard-phases
2345 (replace 'check
2346 (lambda _
2347 (zero? (system* "python" "-m" "testtools.run"
2348 "fixtures.test_suite")))))))
2349 (propagated-inputs
2350 `(("python-six" ,python-six)))
2351 (native-inputs
2352 `(("python-mock" ,python-mock)
2353 ("python-pbr-minimal" ,python-pbr-minimal)
2354 ("python-testtools" ,python-testtools)))
2355 (home-page "https://launchpad.net/python-fixtures")
2356 (synopsis "Python test fixture library")
2357 (description
2358 "Fixtures provides a way to create reusable state, useful when writing
2359 Python tests.")
2360 (license (list license:bsd-3 license:asl2.0)))) ; at user's option
2361
2362 (define-public python2-fixtures
2363 (package-with-python2 python-fixtures))
2364
2365 (define-public python-testrepository
2366 (package
2367 (name "python-testrepository")
2368 (version "0.0.20")
2369 (source
2370 (origin
2371 (method url-fetch)
2372 (uri (string-append
2373 "https://pypi.python.org/packages/source/t/testrepository/testrepository-"
2374 version ".tar.gz"))
2375 (sha256
2376 (base32
2377 "1ssqb07c277010i6gzzkbdd46gd9mrj0bi0i8vn560n2k2y4j93m"))))
2378 (build-system python-build-system)
2379 (arguments
2380 ;; FIXME: Many tests are failing.
2381 '(#:tests? #f))
2382 (propagated-inputs
2383 `(("python-fixtures" ,python-fixtures)
2384 ("python-subunit" ,python-subunit)
2385 ("python-testtools" ,python-testtools)))
2386 (native-inputs
2387 `(("python-pbr-minimal" ,python-pbr-minimal) ;; same as for building fixture
2388 ("python-mimeparse" ,python-mimeparse)))
2389 (home-page "https://launchpad.net/testrepository")
2390 (synopsis "Database for Python test results")
2391 (description "Testrepository provides a database of test results which can
2392 be used as part of a developer's workflow to check things such as what tests
2393 have failed since the last commit or what tests are currently failing.")
2394 (license (list license:bsd-3 license:asl2.0)))) ; at user's option
2395
2396 (define-public python2-testrepository
2397 (package-with-python2 python-testrepository))
2398
2399 (define-public python-coverage
2400 (package
2401 (name "python-coverage")
2402 (version "4.1")
2403 (source
2404 (origin
2405 (method url-fetch)
2406 (uri (pypi-uri "coverage" version))
2407 (sha256
2408 (base32
2409 "01rbr4br4lsk0lwn8fb96zwd2xr4f0mg1w7iq3j11i8f5ig2nqs1"))))
2410 (build-system python-build-system)
2411 (arguments
2412 ;; FIXME: 95 tests failed, 539 passed, 6 skipped, 2 errors.
2413 '(#:tests? #f))
2414 (home-page "http://nedbatchelder.com/code/coverage")
2415 (synopsis "Code coverage measurement for Python")
2416 (description
2417 "Coverage measures code coverage, typically during test execution. It
2418 uses the code analysis tools and tracing hooks provided in the Python standard
2419 library to determine which lines are executable, and which have been
2420 executed.")
2421 (license license:bsd-3)))
2422
2423 (define-public python2-coverage
2424 (package-with-python2 python-coverage))
2425
2426 (define-public python-cov-core
2427 (package
2428 (name "python-cov-core")
2429 (version "1.15.0")
2430 (source
2431 (origin
2432 (method url-fetch)
2433 (uri (pypi-uri "cov-core" version))
2434 (sha256
2435 (base32
2436 "0k3np9ymh06yv1ib96sb6wfsxjkqhmik8qfsn119vnhga9ywc52a"))))
2437 (build-system python-build-system)
2438 (propagated-inputs
2439 `(("python-coverage" ,python-coverage)))
2440 (home-page "https://github.com/schlamar/cov-core")
2441 (synopsis "Coverage plugin core for pytest-cov, nose-cov and nose2-cov")
2442 (description
2443 "This is a library package for use by @code{pytest-cov}, @code{nose-cov}
2444 and @code{nose2-cov}. It is useful for developing coverage plugins for these
2445 testing frameworks.")
2446 (license license:expat)))
2447
2448 (define-public python2-cov-core
2449 (package-with-python2 python-cov-core))
2450
2451 (define-public python-discover
2452 (package
2453 (name "python-discover")
2454 (version "0.4.0")
2455 (source
2456 (origin
2457 (method url-fetch)
2458 (uri (string-append
2459 "https://pypi.python.org/packages/source/d/discover/discover-"
2460 version ".tar.gz"))
2461 (sha256
2462 (base32
2463 "0y8d0zwiqar51kxj8lzmkvwc3b8kazb04gk5zcb4nzg5k68zmhq5"))))
2464 (build-system python-build-system)
2465 (home-page "http://pypi.python.org/pypi/discover/")
2466 (synopsis
2467 "Python test discovery for unittest")
2468 (description
2469 "Discover provides test discovery for unittest, a feature that has been
2470 backported from Python 2.7 for Python 2.4+.")
2471 (license license:bsd-3)))
2472
2473 (define-public python2-discover
2474 (package-with-python2 python-discover))
2475
2476 (define-public behave
2477 (package
2478 (name "behave")
2479 (version "1.2.5")
2480 (source (origin
2481 (method url-fetch)
2482 (uri (pypi-uri "behave" version ".tar.bz2"))
2483 (sha256
2484 (base32
2485 "1iypp6z46r19n4xmgx6m1lwmlpfjh8vapq8izigrqlaarvp2y64c"))))
2486 (build-system python-build-system)
2487 (propagated-inputs
2488 `(("python-six" ,python-six)
2489 ("python-parse" ,python-parse)
2490 ("python-parse-type" ,python-parse-type)))
2491 (arguments `(#:tests? #f)) ;TODO: tests require nose>=1.3 and
2492 ;PyHamcrest>=1.8
2493 (home-page "https://github.com/behave/behave")
2494 (synopsis "Python behavior-driven development")
2495 (description
2496 "Behave is a tool for behavior-driven development in python.
2497 Behavior-driven development (or BDD) is an agile software development
2498 technique that encourages collaboration between developers, QA and
2499 non-technical or business participants in a software project. Behave uses
2500 tests written in a natural language style, backed up by Python code.")
2501 (license license:x11)))
2502
2503 (define-public python-exif-read
2504 (package
2505 (name "python-exif-read")
2506 (version "2.1.2")
2507 (source (origin
2508 (method url-fetch)
2509 (uri (pypi-uri "ExifRead" version))
2510 (sha256
2511 (base32
2512 "1b90jf6m9vxh9nanhpyvqdq7hmfx5iggw1l8kq10jrs6xgr49qkr"))))
2513 (build-system python-build-system)
2514 (arguments `(#:tests? #f)) ; no tests
2515 (home-page "https://github.com/ianare/exif-py")
2516 (synopsis "Python library to extract EXIF data from image files")
2517 (description
2518 "ExifRead is a Python library to extract EXIF data from tiff and jpeg
2519 files.")
2520 (license license:bsd-3)))
2521
2522 (define-public python2-exif-read
2523 (package-with-python2 python-exif-read))
2524
2525 (define-public python-pyld
2526 (package
2527 (name "python-pyld")
2528 (version "0.7.1")
2529 (source (origin
2530 (method url-fetch)
2531 (uri (pypi-uri "PyLD" version))
2532 (sha256
2533 (base32
2534 "1m0fs6897vxfkf7awah5i66i7b7smm5fnywf1w50fpzyfbfhr156"))))
2535 (build-system python-build-system)
2536 (arguments `(#:tests? #f)) ; no tests
2537 (home-page "https://github.com/digitalbazaar/pyld")
2538 (synopsis "Python implementation of the JSON-LD specification")
2539 (description
2540 "PyLD is an implementation of the JSON-LD specification.")
2541 (license license:bsd-3)))
2542
2543 (define-public python2-pyld
2544 (package-with-python2 python-pyld))
2545
2546 (define-public python-certifi
2547 (package
2548 (name "python-certifi")
2549 (version "2017.1.23")
2550 (source (origin
2551 (method url-fetch)
2552 (uri (pypi-uri "certifi" version))
2553 (sha256
2554 (base32
2555 "1klrzl3hgvcf2mjk00g0k3kk1p2z27vzwnxivwar4vhjmjvpz1w1"))))
2556 (build-system python-build-system)
2557 (home-page "https://certifi.io/")
2558 (synopsis "Python CA certificate bundle")
2559 (description
2560 "Certifi is a Python library that contains a CA certificate bundle, which
2561 is used by the Requests library to verify HTTPS requests.")
2562 (license license:asl2.0)))
2563
2564 (define-public python2-certifi
2565 (package-with-python2 python-certifi))
2566
2567 (define-public python-click
2568 (package
2569 (name "python-click")
2570 (version "6.7")
2571 (source
2572 (origin
2573 (method url-fetch)
2574 (uri (pypi-uri "click" version))
2575 (sha256
2576 (base32
2577 "02qkfpykbq35id8glfgwc38yc430427yd05z1wc5cnld8zgicmgi"))))
2578 (build-system python-build-system)
2579 (arguments
2580 `(#:phases
2581 (modify-phases %standard-phases
2582 (add-after 'unpack 'fix-paths
2583 (lambda* (#:key inputs #:allow-other-keys)
2584 (let ((glibc (assoc-ref inputs ,(if (%current-target-system)
2585 "cross-libc" "libc"))))
2586 (substitute* "click/_unicodefun.py"
2587 (("'locale'")
2588 (string-append "'" glibc "/bin/locale'"))))
2589 #t))
2590 (replace 'check
2591 (lambda _
2592 (zero? (system* "make" "test")))))))
2593 (native-inputs
2594 `(("python-pytest" ,python-pytest)))
2595 (home-page "http://click.pocoo.org")
2596 (synopsis "Command line library for Python")
2597 (description
2598 "Click is a Python package for creating command line interfaces in a
2599 composable way with as little code as necessary. Its name stands for
2600 \"Command Line Interface Creation Kit\". It's highly configurable but comes
2601 with sensible defaults out of the box.")
2602 (license license:bsd-3)))
2603
2604 (define-public python2-click
2605 (package-with-python2 python-click))
2606
2607 (define-public python-wheel
2608 (package
2609 (name "python-wheel")
2610 (version "0.30.0a0")
2611 (source
2612 (origin
2613 (method url-fetch)
2614 (uri (pypi-uri "wheel" version))
2615 (sha256
2616 (base32
2617 "1nm6mn8isny0hr86rhbfrpfj867c0phf001xgsd69xfp9ady1wwq"))))
2618 (build-system python-build-system)
2619 (native-inputs
2620 `(("python-jsonschema" ,python-jsonschema)
2621 ("python-pytest-cov" ,python-pytest-cov)))
2622 (home-page "https://bitbucket.org/pypa/wheel/")
2623 (synopsis "Format for built Python packages")
2624 (description
2625 "A wheel is a ZIP-format archive with a specially formatted filename and
2626 the @code{.whl} extension. It is designed to contain all the files for a PEP
2627 376 compatible install in a way that is very close to the on-disk format. Many
2628 packages will be properly installed with only the @code{Unpack} step and the
2629 unpacked archive preserves enough information to @code{Spread} (copy data and
2630 scripts to their final locations) at any later time. Wheel files can be
2631 installed with a newer @code{pip} or with wheel's own command line utility.")
2632 (license license:expat)
2633 (properties `((python2-variant . ,(delay python2-wheel))))))
2634
2635 (define-public python2-wheel
2636 (let ((wheel (package-with-python2
2637 (strip-python2-variant python-wheel))))
2638 (package (inherit wheel)
2639 (native-inputs `(("python2-functools32" ,python2-functools32)
2640 ,@(package-native-inputs wheel))))))
2641
2642
2643 (define-public python-requests
2644 (package
2645 (name "python-requests")
2646 (version "2.13.0")
2647 (source (origin
2648 (method url-fetch)
2649 (uri (pypi-uri "requests" version))
2650 (sha256
2651 (base32
2652 "1s0wg4any4dsv5l3hqjxqk2zgb7pdbqhy9rhc8kh3aigfq4ws8jp"))))
2653 ;; TODO: unbundle urllib3 and chardet.
2654 (build-system python-build-system)
2655 (arguments
2656 ;; FIXME: Some tests require network access.
2657 '(#:tests? #f))
2658 (home-page "http://python-requests.org/")
2659 (synopsis "Python HTTP library")
2660 (description
2661 "Requests is a Python HTTP client library. It aims to be easier to use
2662 than Python’s urllib2 library.")
2663 (license license:asl2.0)))
2664
2665 ;; Some software requires an older version of Requests, notably Docker
2666 ;; Compose.
2667 (define-public python-requests-2.7
2668 (package (inherit python-requests)
2669 (version "2.7.0")
2670 (source (origin
2671 (method url-fetch)
2672 (uri (pypi-uri "requests" version))
2673 (sha256
2674 (base32
2675 "0gdr9dxm24amxpbyqpbh3lbwxc2i42hnqv50sigx568qssv3v2ir"))))))
2676
2677 (define-public python2-requests
2678 (package-with-python2 python-requests))
2679
2680 (define-public python-vcversioner
2681 (package
2682 (name "python-vcversioner")
2683 (version "2.16.0.0")
2684 (source
2685 (origin
2686 (method url-fetch)
2687 (uri (pypi-uri "vcversioner" version))
2688 (sha256
2689 (base32
2690 "16z10sm78jd7ca3jbkgc3q5i8a8q7y1h21q1li21yy3rlhbhrrns"))))
2691 (build-system python-build-system)
2692 (synopsis "Python library for version number discovery")
2693 (description "Vcversioner is a Python library that inspects tagging
2694 information in a variety of version control systems in order to discover
2695 version numbers.")
2696 (home-page "https://github.com/habnabit/vcversioner")
2697 (license license:isc)))
2698
2699 (define-public python2-vcversioner
2700 (package-with-python2 python-vcversioner))
2701
2702 (define-public python-jsonschema
2703 (package
2704 (name "python-jsonschema")
2705 (version "2.5.1")
2706 (source (origin
2707 (method url-fetch)
2708 (uri
2709 (string-append
2710 "https://pypi.python.org/packages/source/j/jsonschema/jsonschema-"
2711 version ".tar.gz"))
2712 (sha256
2713 (base32
2714 "0hddbqjm4jq63y8jf44nswina1crjs16l9snb6m3vvgyg31klrrn"))))
2715 (build-system python-build-system)
2716 (arguments
2717 '(#:phases
2718 (modify-phases %standard-phases
2719 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
2720 (native-inputs
2721 `(("python-nose" ,python-nose)
2722 ("python-vcversioner" ,python-vcversioner)))
2723 (home-page "https://github.com/Julian/jsonschema")
2724 (synopsis "Implementation of JSON Schema for Python")
2725 (description
2726 "Jsonschema is an implementation of JSON Schema for Python.")
2727 (license license:expat)
2728 (properties `((python2-variant . ,(delay python2-jsonschema))))))
2729
2730 (define-public python2-jsonschema
2731 (let ((jsonschema (package-with-python2
2732 (strip-python2-variant python-jsonschema))))
2733 (package (inherit jsonschema)
2734 (native-inputs
2735 `(("python2-mock" ,python2-mock)
2736 ,@(package-native-inputs jsonschema)))
2737 (propagated-inputs
2738 `(("python2-functools32" ,python2-functools32))))))
2739
2740 (define-public python-schema
2741 (package
2742 (name "python-schema")
2743 (version "0.6.6")
2744 (source
2745 (origin
2746 (method url-fetch)
2747 (uri (pypi-uri "schema" version))
2748 (sha256
2749 (base32
2750 "1lw28j9w9vxyigg7vkfkvi6ic9lgjkdnfvnxdr7pklslqvzmk2vm"))))
2751 (build-system python-build-system)
2752 (native-inputs
2753 `(("python-pytest" ,python-pytest)))
2754 (home-page "https://github.com/keleshev/schema")
2755 (synopsis "Simple data validation library")
2756 (description
2757 "@code{python-schema} is a library for validating Python data
2758 structures, such as those obtained from config-files, forms, external
2759 services or command-line parsing, converted from JSON/YAML (or
2760 something else) to Python data-types.")
2761 (license license:psfl)))
2762
2763 (define-public python2-schema
2764 (package-with-python2 python-schema))
2765
2766 (define-public python-schema-0.5
2767 (package (inherit python-schema)
2768 (version "0.5.0")
2769 (source
2770 (origin
2771 (method url-fetch)
2772 (uri (pypi-uri "schema" version))
2773 (sha256
2774 (base32
2775 "10zqvpaky51kgb8nd42bk7jwl8cn2zvayxjpdc1wwmpybj92x67s"))))))
2776
2777 (define-public python2-schema-0.5
2778 (package-with-python2 python-schema-0.5))
2779
2780 (define-public python-kitchen
2781 (package
2782 (name "python-kitchen")
2783 (version "1.2.4")
2784 (source
2785 (origin
2786 (method url-fetch)
2787 (uri (pypi-uri "kitchen" version))
2788 (sha256
2789 (base32
2790 "0ggv3p4x8jvmmzhp0xm00h6pvh1g0gmycw71rjwagnrj8n23vxrq"))))
2791 (build-system python-build-system)
2792 (propagated-inputs
2793 `(("python-chardet" ,python-chardet)))
2794 (home-page "https://github.com/fedora-infra/kitchen")
2795 (synopsis "Python API for snippets")
2796 (description "@code{kitchen} module provides a python API for all sorts of
2797 little useful snippets of code that everybody ends up writing for their projects
2798 but never seem big enough to build an independent release. Use kitchen and stop
2799 cutting and pasting that code over and over.")
2800 (license (list license:lgpl2.1+
2801 ;; subprocess.py, test_subprocess.py,
2802 ;; kitchen/pycompat25/defaultdict.py:
2803 license:psfl))))
2804
2805 (define-public python2-kitchen
2806 (package-with-python2 python-kitchen))
2807
2808 (define-public python-unidecode
2809 (package
2810 (name "python-unidecode")
2811 (version "0.04.20")
2812 (source (origin
2813 (method url-fetch)
2814 (uri (pypi-uri "Unidecode" version))
2815 (sha256
2816 (base32
2817 "1q00i8gpsq3d9r0q8wk4b290fxl0kqlsdk7iadvli45in6s1hi7d"))))
2818 (build-system python-build-system)
2819 (home-page "https://pypi.python.org/pypi/Unidecode")
2820 (synopsis "ASCII transliterations of Unicode text")
2821 (description
2822 "Unidecode provides ASCII transliterations of Unicode text. Unidecode is
2823 useful when integrating with legacy code that doesn't support Unicode, or for
2824 ease of entry of non-Roman names on a US keyboard, or when constructing ASCII
2825 machine identifiers from human-readable Unicode strings that should still be
2826 somewhat intelligeble.")
2827 (license license:gpl2+)))
2828
2829 (define-public python2-unidecode
2830 (package-with-python2 python-unidecode))
2831
2832 (define-public python-pyjwt
2833 (package
2834 (name "python-pyjwt")
2835 (version "1.4.0")
2836 (source
2837 (origin
2838 (method url-fetch)
2839 (uri (pypi-uri "PyJWT" version))
2840 (sha256
2841 (base32
2842 "1556v2jppd8mjkkj66pxb5rcazm35jq81r233mdl8hfmz9n3icp1"))))
2843 (build-system python-build-system)
2844 (native-inputs
2845 `(("python-pytest" ,python-pytest)
2846 ("python-pytest-cov" ,python-pytest-cov)
2847 ("python-pytest-runner" ,python-pytest-runner)))
2848 (home-page "https://github.com/progrium/pyjwt")
2849 (synopsis "JSON Web Token implementation in Python")
2850 (description
2851 "PyJWT is a JSON Web Token implementation written in Python.")
2852 (license license:expat)))
2853
2854 (define-public python2-pyjwt
2855 (package-with-python2 python-pyjwt))
2856
2857 (define-public python-pykka
2858 (package
2859 (name "python-pykka")
2860 (version "1.2.1")
2861 (source
2862 (origin
2863 (method url-fetch)
2864 (uri (pypi-uri "Pykka" version))
2865 (sha256
2866 (base32
2867 "049w3r0mdnnw7xv19jiq7rvls9k7xs73x05b4qs5d6z4vvmgyiz8"))))
2868 (build-system python-build-system)
2869 (native-inputs
2870 `(("python-mock" ,python-mock)
2871 ("python-nose" ,python-nose)
2872 ("python-gevent" ,python-gevent)
2873 ("python-eventlet" ,python-eventlet)))
2874 (home-page "https://www.pykka.org/")
2875 (synopsis "Pykka is a Python implementation of the actor model")
2876 (description
2877 "Pykka is a Python implementation of the actor model.
2878 The actor model introduces some simple rules to control the sharing
2879 of state and cooperation between execution units, which makes it
2880 easier to build concurrent applications.")
2881 (license license:asl2.0)))
2882
2883 (define-public python2-pykka
2884 (package-with-python2 python-pykka))
2885
2886 (define-public python-oauthlib
2887 (package
2888 (name "python-oauthlib")
2889 (version "1.0.3")
2890 (source (origin
2891 (method url-fetch)
2892 (uri (pypi-uri "oauthlib" version))
2893 (sha256
2894 (base32
2895 "1bfrj70vdjxjw74khbyh6f0dksv7p5rh2346jnlrffyacd3gwjzg"))))
2896 (build-system python-build-system)
2897 (native-inputs
2898 `(("python-nose" ,python-nose)
2899 ("python-mock" ,python-mock)
2900 ("python-cryptography" ,python-cryptography)
2901 ("python-pyjwt" ,python-pyjwt)
2902 ("python-blinker" ,python-blinker)))
2903 (home-page "https://github.com/idan/oauthlib")
2904 (synopsis "OAuth implementation for Python")
2905 (description
2906 "Oauthlib is a generic, spec-compliant, thorough implementation of the
2907 OAuth request-signing logic.")
2908 (license license:bsd-3)
2909 (properties `((python2-variant . ,(delay python2-oauthlib))))))
2910
2911 (define-public python2-oauthlib
2912 (let ((base (package-with-python2 (strip-python2-variant python-oauthlib))))
2913 (package
2914 (inherit base)
2915 (native-inputs `(("python2-unittest2" ,python2-unittest2)
2916 ,@(package-native-inputs base))))))
2917
2918 (define-public python-itsdangerous
2919 (package
2920 (name "python-itsdangerous")
2921 (version "0.24")
2922 (source
2923 (origin
2924 (method url-fetch)
2925 (uri (string-append
2926 "https://pypi.python.org/packages/source/i/itsdangerous/itsdangerous-"
2927 version ".tar.gz"))
2928 (sha256
2929 (base32
2930 "06856q6x675ly542ig0plbqcyab6ksfzijlyf1hzhgg3sgwgrcyb"))))
2931 (build-system python-build-system)
2932 (home-page "https://github.com/mitsuhiko/itsdangerous")
2933 (synopsis "Python library for passing data to/from untrusted environments")
2934 (description
2935 "Itsdangerous provides various helpers to pass trusted data to untrusted
2936 environments and back.")
2937 (license license:bsd-3)))
2938
2939 (define-public python2-itsdangerous
2940 (package-with-python2 python-itsdangerous))
2941
2942 (define-public python-pyyaml
2943 (package
2944 (name "python-pyyaml")
2945 (version "3.12")
2946 (source
2947 (origin
2948 (method url-fetch)
2949 (uri (pypi-uri "PyYAML" version))
2950 (sha256
2951 (base32
2952 "1aqjl8dk9amd4zr99n8v2qxzgmr2hdvqfma4zh7a41rj6336c9sr"))))
2953 (build-system python-build-system)
2954 (inputs
2955 `(("libyaml" ,libyaml)))
2956 (home-page "http://pyyaml.org/wiki/PyYAML")
2957 (synopsis "YAML parser and emitter for Python")
2958 (description
2959 "PyYAML is a YAML parser and emitter for Python. PyYAML features a
2960 complete YAML 1.1 parser, Unicode support, pickle support, capable extension
2961 API, and sensible error messages. PyYAML supports standard YAML tags and
2962 provides Python-specific tags that allow to represent an arbitrary Python
2963 object.")
2964 (license license:expat)))
2965
2966 (define-public python2-pyyaml
2967 (package-with-python2 python-pyyaml))
2968
2969 (define-public python-virtualenv
2970 (package
2971 (name "python-virtualenv")
2972 (version "15.0.3")
2973 (source
2974 (origin
2975 (method url-fetch)
2976 (uri (pypi-uri "virtualenv" version))
2977 (sha256
2978 (base32
2979 "07cbajzk8l05k5zhlw0b9wbf2is65bl9v6zrn2a0iyn57w6pd73d"))))
2980 (build-system python-build-system)
2981 (arguments
2982 `(#:phases
2983 (modify-phases %standard-phases
2984 (replace 'check
2985 (lambda _
2986 ;; Disable failing test. See upstream bug report
2987 ;; https://github.com/pypa/virtualenv/issues/957
2988 (substitute* "tests/test_virtualenv.py"
2989 (("skipif.*") "skipif(True, reason=\"Guix\")\n"))
2990 (zero? (system* "py.test")))))))
2991 (native-inputs
2992 `(("python-mock" ,python-mock)
2993 ("python-pytest" ,python-pytest)))
2994 (home-page "https://virtualenv.pypa.io/")
2995 (synopsis "Virtual Python environment builder")
2996 (description
2997 "Virtualenv is a tool to create isolated Python environments.")
2998 (license license:expat)))
2999
3000 (define-public python2-virtualenv
3001 (package-with-python2 python-virtualenv))
3002
3003 (define-public python-markupsafe
3004 (package
3005 (name "python-markupsafe")
3006 (version "0.23")
3007 (source
3008 (origin
3009 (method url-fetch)
3010 (uri (string-append
3011 "https://pypi.python.org/packages/source/M/MarkupSafe/MarkupSafe-"
3012 version ".tar.gz"))
3013 (sha256
3014 (base32
3015 "1hvip33wva3fnmvfp9x5klqri7hpl1hkgqmjbss18nmrb7zimv54"))))
3016 (build-system python-build-system)
3017 (home-page "https://github.com/mitsuhiko/markupsafe")
3018 (synopsis "XML/HTML/XHTML markup safe string implementation for Python")
3019 (description
3020 "Markupsafe provides an XML/HTML/XHTML markup safe string implementation
3021 for Python.")
3022 (license license:bsd-3)))
3023
3024 (define-public python2-markupsafe
3025 (package-with-python2 python-markupsafe))
3026
3027 (define-public python-jinja2
3028 (package
3029 (name "python-jinja2")
3030 (version "2.8")
3031 (source
3032 (origin
3033 (method url-fetch)
3034 (uri (pypi-uri "Jinja2" version))
3035 (sha256
3036 (base32
3037 "1x0v41lp5m1pjix3l46zx02b7lqp2hflgpnxwkywxynvi3zz47xw"))))
3038 (build-system python-build-system)
3039 (propagated-inputs
3040 `(("python-markupsafe" ,python-markupsafe)))
3041 (home-page "http://jinja.pocoo.org/")
3042 (synopsis "Python template engine")
3043 (description
3044 "Jinja2 is a small but fast and easy to use stand-alone template engine
3045 written in pure Python.")
3046 (license license:bsd-3)))
3047
3048 (define-public python2-jinja2
3049 (package-with-python2 python-jinja2))
3050
3051 (define-public python-pystache
3052 (package
3053 (name "python-pystache")
3054 (version "0.5.4")
3055 (source (origin
3056 (method url-fetch)
3057 (uri (pypi-uri "pystache" version))
3058 (sha256
3059 (base32
3060 "0nmqsfmiw4arjxqkmf9z66ml950pcdjk6aq4gin4sywmzdjw5fzp"))))
3061 (build-system python-build-system)
3062 (arguments
3063 '(#:tests? #f)) ; FIXME: Python 3 tests are failing.
3064 (home-page "http://defunkt.io/pystache/")
3065 (synopsis "Python logic-less template engine")
3066 (description
3067 "Pystache is a Python implementation of the framework agnostic,
3068 logic-free templating system Mustache.")
3069 (license license:expat)
3070 (properties `((python2-variant . ,(delay python2-pystache))))))
3071
3072 (define-public python2-pystache
3073 (package (inherit (package-with-python2
3074 (strip-python2-variant python-pystache)))
3075 (arguments
3076 `(#:python ,python-2
3077 #:phases
3078 (modify-phases %standard-phases
3079 (replace 'check
3080 (lambda _
3081 (zero? (system* "python" "test_pystache.py")))))))))
3082
3083 (define-public python-joblib
3084 (package
3085 (name "python-joblib")
3086 (version "0.10.3")
3087 (source (origin
3088 (method url-fetch)
3089 (uri (pypi-uri "joblib" version))
3090 (sha256
3091 (base32
3092 "0787k919zlfmgymprz5bzv0v1df5bbirlf3awrghmjgvkrd9dci9"))
3093 (modules '((guix build utils)))
3094 (snippet
3095 '(begin
3096 ;; Remove pre-compiled .pyc files from source.
3097 (for-each delete-file-recursively
3098 (find-files "." "__pycache__" #:directories? #t))
3099 (for-each delete-file (find-files "." "\\.pyc$"))
3100 #t))))
3101 (build-system python-build-system)
3102 (arguments
3103 `(#:phases
3104 (modify-phases %standard-phases
3105 (add-before 'check 'disable-failing-tests
3106 (lambda _
3107 ;; This numpydoc tests fails for unknown reasons
3108 (delete-file "doc/sphinxext/numpydoc/tests/test_docscrape.py")
3109 ;; This numpydoc test depends on matplotlib, which is not a
3110 ;; required input.
3111 (delete-file "doc/sphinxext/numpydoc/tests/test_plot_directive.py")
3112 ;; These tests fail to execute sys.executable
3113 (substitute* "joblib/test/test_parallel.py"
3114 (("import nose" line)
3115 (string-append "from nose.plugins.skip import SkipTest\n" line))
3116 (("def test_nested_parallel_warnings" line)
3117 (string-append "@SkipTest\n" line))
3118 (("def test_parallel_with_interactively_defined_functions" line)
3119 (string-append "@SkipTest\n" line)))
3120 #t)))))
3121 ;; Provide nose to enable tests command
3122 (native-inputs
3123 `(("python-nose" ,python-nose)
3124 ("python-sphinx" ,python-sphinx)
3125 ("python-docutils" ,python-docutils)
3126 ("python-numpydoc" ,python-numpydoc)))
3127 (home-page "http://pythonhosted.org/joblib/")
3128 (synopsis "Using Python functions as pipeline jobs")
3129 (description
3130 "Joblib is a set of tools to provide lightweight pipelining in Python.
3131 In particular, joblib offers: transparent disk-caching of the output values
3132 and lazy re-evaluation (memoize pattern), easy simple parallel computing
3133 logging and tracing of the execution.")
3134 (license license:bsd-3)))
3135
3136 (define-public python2-joblib
3137 (package-with-python2 python-joblib))
3138
3139 (define-public python-docutils
3140 (package
3141 (name "python-docutils")
3142 (version "0.13.1")
3143 (source
3144 (origin
3145 (method url-fetch)
3146 (uri (pypi-uri "docutils" version))
3147 (sha256
3148 (base32
3149 "1gkma47i609jfs7dssxn4y9vsz06qi0l5q41nws0zgkpnrghz33i"))))
3150 (build-system python-build-system)
3151 (arguments
3152 '(#:tests? #f)) ; no setup.py test command
3153 (home-page "http://docutils.sourceforge.net/")
3154 (synopsis "Python Documentation Utilities")
3155 (description
3156 "Docutils is a modular system for processing documentation into useful
3157 formats, such as HTML, XML, and LaTeX. For input Docutils supports
3158 reStructuredText.")
3159 ;; Most of the source code is public domain, but some source files are
3160 ;; licensed under the PFSL, BSD 2-clause, and GPLv3+ licenses.
3161 (license (list license:public-domain license:psfl license:bsd-2 license:gpl3+))))
3162
3163 (define-public python2-docutils
3164 (package-with-python2 python-docutils))
3165
3166 (define-public python-pygments
3167 (package
3168 (name "python-pygments")
3169 (version "2.1.3")
3170 (source
3171 (origin
3172 (method url-fetch)
3173 (uri (pypi-uri "Pygments" version))
3174 (sha256
3175 (base32
3176 "10axnp2wpjnq9g8wg53fx0c70dfxqrz498jyz8mrdx9a3flwir48"))))
3177 (build-system python-build-system)
3178 (arguments
3179 ;; FIXME: Tests require sphinx, which depends on this.
3180 '(#:tests? #f))
3181 (home-page "http://pygments.org/")
3182 (synopsis "Syntax highlighting")
3183 (description
3184 "Pygments is a syntax highlighting package written in Python.")
3185 (license license:bsd-2)))
3186
3187 (define-public python2-pygments
3188 (package-with-python2 python-pygments))
3189
3190 (define-public python-sphinxcontrib-websupport
3191 (package
3192 (name "python-sphinxcontrib-websupport")
3193 (version "1.0.1")
3194 (source (origin
3195 (method url-fetch)
3196 (uri (pypi-uri "sphinxcontrib-websupport" version))
3197 (sha256
3198 (base32
3199 "1f9f0wjpi9nhikbyaz6d19s7qvzdf1nq2g5dsh640fma4q9rd1bs"))))
3200 (build-system python-build-system)
3201 (propagated-inputs
3202 `(("python-mock" ,python-mock)
3203 ("python-pytest" ,python-pytest)
3204 ("python-xapian-bindings" ,python-xapian-bindings)))
3205 ;; Needed for running the test suite
3206 (native-inputs
3207 `(("python-six" ,python-six)
3208 ("python-jinja2" ,python-jinja2)
3209 ("python-docutils" ,python-docutils)
3210 ("python-sphinx" ,python-sphinx)
3211 ("python-sqlalchemy" ,python-sqlalchemy)
3212 ("python-whoosh" ,python-whoosh)))
3213 (home-page "http://sphinx-doc.org/")
3214 (synopsis "Sphinx API for web applications")
3215 (description "This package provides a Python API to easily integrate
3216 Sphinx documentation into your web application. It provides tools to
3217 integrate Sphinx documents in web templates and to handle searches.")
3218 (license license:bsd-3)))
3219
3220 (define-public python-sphinx
3221 (package
3222 (name "python-sphinx")
3223 (version "1.5.1")
3224 (source
3225 (origin
3226 (method url-fetch)
3227 (uri (pypi-uri "Sphinx" version))
3228 (sha256
3229 (base32
3230 "1i8p9idnli4gr0y4x67yakbdk5w6a0xjzhrg6bg51y9d1fi7fslf"))))
3231 (build-system python-build-system)
3232 (arguments
3233 `(#:phases
3234 (modify-phases %standard-phases
3235 (replace 'check
3236 (lambda _
3237 ;; Requires Internet access.
3238 (delete-file "tests/test_build_linkcheck.py")
3239 (zero? (system* "make" "test")))))))
3240 (propagated-inputs
3241 `(("python-imagesize" ,python-imagesize)
3242 ("python-sphinx-alabaster-theme"
3243 ,python-sphinx-alabaster-theme)
3244 ("python-babel" ,python-babel)
3245 ("python-snowballstemmer" ,python-snowballstemmer)
3246 ("python-docutils" ,python-docutils)
3247 ("python-jinja2" ,python-jinja2)
3248 ("python-pygments" ,python-pygments)
3249 ("python-requests" ,python-requests)
3250 ("python-six" ,python-six)))
3251 (native-inputs
3252 `(("graphviz" ,graphviz)
3253 ("python-html5lib" ,python-html5lib)
3254 ("python-mock" ,python-mock)
3255 ("python-nose" ,python-nose)))
3256 (home-page "http://sphinx-doc.org/")
3257 (synopsis "Python documentation generator")
3258 (description "Sphinx is a tool that makes it easy to create documentation
3259 for Python projects or other documents consisting of multiple reStructuredText
3260 sources.")
3261 (license license:bsd-3)
3262 (properties `((python2-variant . ,(delay python2-sphinx))))))
3263
3264 (define-public python-sphinx-1.6
3265 (package (inherit python-sphinx)
3266 (name "python-sphinx")
3267 (version "1.6.3")
3268 (source (origin
3269 (method url-fetch)
3270 (uri (pypi-uri "Sphinx" version))
3271 (sha256
3272 (base32
3273 "1rj6f3i8hmrx2qlkshi5kp5xcy98dlynwlyl05yvflj5f66dp2xg"))))
3274 (arguments
3275 `(#:phases
3276 (modify-phases %standard-phases
3277 (replace 'check
3278 (lambda _
3279 ;; Requires Internet access.
3280 (delete-file "tests/test_build_linkcheck.py")
3281 (substitute* "tests/test_build_latex.py"
3282 (("@pytest.mark.sphinx\\('latex', testroot='images'\\)")
3283 "@pytest.mark.skip()"))
3284 (zero? (system* "make" "test")))))))
3285 (propagated-inputs
3286 `(("python-sphinxcontrib-websupport" ,python-sphinxcontrib-websupport)
3287 ,@(package-propagated-inputs python-sphinx)))
3288 (native-inputs
3289 `(("python-pytest" ,python-pytest-3.0)
3290 ("imagemagick" ,imagemagick) ; for "convert"
3291 ,@(package-native-inputs python-sphinx)))
3292 (properties '())))
3293
3294 (define-public python-sphinx-1.5.3
3295 (package
3296 (inherit python-sphinx)
3297 (name "python-sphinx")
3298 (version "1.5.3")
3299 (source
3300 (origin
3301 (method url-fetch)
3302 (uri (pypi-uri "Sphinx" version))
3303 (sha256
3304 (base32
3305 "0kw1axswbvaavr8ggyf4qr6hnisnrzlbkkcdada69vk1x9xjassg"))))
3306 (native-inputs
3307 `(("python-pytest" ,python-pytest-3.0)
3308 ,@(package-native-inputs python-sphinx)))))
3309
3310 (define-public python2-sphinx
3311 (let ((base (package-with-python2 (strip-python2-variant python-sphinx))))
3312 (package
3313 (inherit base)
3314 (native-inputs `(("python2-mock" ,python2-mock)
3315 ("python2-enum34" ,python2-enum34)
3316 ,@(package-native-inputs base)))
3317 (propagated-inputs `(("python2-pytz" ,python2-pytz)
3318 ,@(package-propagated-inputs base))))))
3319
3320 (define-public python-sphinx-rtd-theme
3321 (package
3322 (name "python-sphinx-rtd-theme")
3323 (version "0.2.4")
3324 (source
3325 (origin
3326 (method url-fetch)
3327 (uri (pypi-uri "sphinx_rtd_theme" version))
3328 (sha256
3329 (base32
3330 "05rlhjzdyapr2w74jjs7mrm8hi69qskcr5vya9f9drpsys7lpxrd"))))
3331 (build-system python-build-system)
3332 (arguments '(#:tests? #f)) ; No tests.
3333 (propagated-inputs
3334 `(("python-sphinx" ,python-sphinx)))
3335 (home-page "https://github.com/snide/sphinx_rtd_theme/")
3336 (synopsis "ReadTheDocs.org theme for Sphinx")
3337 (description "A theme for Sphinx used by ReadTheDocs.org.")
3338 (license license:expat)))
3339
3340 (define-public python2-sphinx-rtd-theme
3341 (package-with-python2 python-sphinx-rtd-theme))
3342
3343 (define-public python-rst.linker
3344 (package
3345 (name "python-rst.linker")
3346 (version "1.7")
3347 (source
3348 (origin
3349 (method url-fetch)
3350 (uri (pypi-uri "rst.linker" version))
3351 (sha256
3352 (base32
3353 "0bh4lnj2p1nh0wf5pgxgfbrp27xhb1rinahkb5j7s3qprq6qn0sr"))))
3354 (build-system python-build-system)
3355 (propagated-inputs
3356 `(("python-dateutil" ,python-dateutil)
3357 ("python-six" ,python-six)))
3358 (native-inputs
3359 `(("python-setuptools-scm" ,python-setuptools-scm)))
3360 ;; Test would require path.py, which would introduce a cyclic dependence.
3361 (arguments `(#:tests? #f))
3362 ;; Note: As of version 1.7 the documentation is not worth building.
3363 (home-page "https://github.com/jaraco/rst.linker")
3364 (synopsis "Sphinx plugin to add links and timestamps")
3365 (description "rst.linker allows to automatically replace text by a
3366 reStructuredText external reference or timestamps. It's primary purpose is to
3367 augment the changelog, but it can be used for other documents, too.")
3368 (license license:expat)))
3369
3370 (define-public python2-rst.linker
3371 (package-with-python2 python-rst.linker))
3372
3373 (define-public python-feedgenerator
3374 (package
3375 (name "python-feedgenerator")
3376 (version "1.9")
3377 (source
3378 (origin
3379 (method url-fetch)
3380 (uri (pypi-uri "feedgenerator" version))
3381 (sha256
3382 (base32
3383 "01mirwkm7xfx539hmvj7g9da1j51gw5lsx74dr0glizskjm5vq2s"))
3384 (modules '((guix build utils)))
3385 (snippet
3386 '(begin
3387 ;; Remove pre-compiled .pyc files from source.
3388 (for-each delete-file-recursively
3389 (find-files "." "__pycache__" #:directories? #t))
3390 (for-each delete-file (find-files "." "\\.pyc$"))
3391 #t))))
3392 (build-system python-build-system)
3393 (propagated-inputs
3394 `(("python-pytz" ,python-pytz)
3395 ("python-six" ,python-six)))
3396 (home-page "https://github.com/getpelican/feedgenerator")
3397 (synopsis
3398 "Standalone version of Django's Atom/RSS feed generator")
3399 (description
3400 "Feedgenerator-py3k is a standalone version of Django's feedgenerator,
3401 which can produce feeds in RSS 2.0, RSS 0.91, and Atom formats.")
3402 (license license:bsd-3)))
3403
3404 (define-public python2-feedgenerator
3405 (package-with-python2 python-feedgenerator))
3406
3407 (define-public python-blinker
3408 (package
3409 (name "python-blinker")
3410 (version "1.4")
3411 (source
3412 (origin
3413 (method url-fetch)
3414 (uri (pypi-uri "blinker" version))
3415 (sha256
3416 (base32
3417 "1dpq0vb01p36jjwbhhd08ylvrnyvcc82yxx3mwjx6awrycjyw6j7"))))
3418 (build-system python-build-system)
3419 (home-page "http://pythonhosted.org/blinker/")
3420 (synopsis "Fast, simple object-to-object and broadcast signaling")
3421 (description
3422 "Blinker provides a fast dispatching system that allows any number of
3423 interested parties to subscribe to events, or \"signals\".")
3424 (license license:expat)))
3425
3426 (define-public python2-blinker
3427 (package-with-python2 python-blinker))
3428
3429 (define-public pelican
3430 (package
3431 (name "pelican")
3432 (version "3.6.3")
3433 (source
3434 (origin
3435 (method url-fetch)
3436 (uri (pypi-uri "pelican" version))
3437 (sha256
3438 (base32
3439 "1hn94rb4q3zmcq16in055xikal4dba5hfx3zznq7warllcgc9f8k"))))
3440 (build-system python-build-system)
3441 (propagated-inputs
3442 `(("python-feedgenerator" ,python-feedgenerator)
3443 ("python-jinja2" ,python-jinja2)
3444 ("python-pygments" ,python-pygments)
3445 ("python-docutils" ,python-docutils)
3446 ("python-pytz" ,python-pytz)
3447 ("python-blinker" ,python-blinker)
3448 ("python-unidecode" ,python-unidecode)
3449 ("python-six" ,python-six)
3450 ("python-dateutil" ,python-dateutil)))
3451 (home-page "http://getpelican.com/")
3452 (arguments
3453 `(;; XXX Requires a lot more packages to do unit tests :P
3454 #:tests? #f
3455 #:phases (modify-phases %standard-phases
3456 (add-before
3457 'install 'adjust-requires
3458 ;; Since feedgenerator is installed from git, it doesn't
3459 ;; conform to the version requirements.
3460 ;;
3461 ;; We *do have* "feedgenerator >= 1.6", but strip off the
3462 ;; version requirement so setuptools doesn't get confused.
3463 (lambda _
3464 (substitute* "setup.py"
3465 (("['\"]feedgenerator.*?['\"]")
3466 "'feedgenerator'")))))))
3467 (synopsis "Python-based static site publishing system")
3468 (description
3469 "Pelican is a tool to generate a static blog from reStructuredText,
3470 Markdown input files, and more. Pelican uses Jinja2 for templating
3471 and is very extensible.")
3472 (license license:agpl3+)))
3473
3474 (define-public python-scikit-learn
3475 (package
3476 (name "python-scikit-learn")
3477 (version "0.18.1")
3478 (source
3479 (origin
3480 (method url-fetch)
3481 (uri (string-append
3482 "https://github.com/scikit-learn/scikit-learn/archive/"
3483 version ".tar.gz"))
3484 (file-name (string-append name "-" version ".tar.gz"))
3485 (sha256
3486 (base32
3487 "1hwswckdmd27f7k1jvwdc0m4mqrgxl2s245yq1scq34v124bjqgq"))))
3488 (build-system python-build-system)
3489 (arguments
3490 `(#:phases
3491 (modify-phases %standard-phases
3492 (delete 'check)
3493 (add-after 'install 'check
3494 ;; Running tests from the source directory requires
3495 ;; an "inplace" build with paths relative to CWD.
3496 ;; http://scikit-learn.org/stable/developers/advanced_installation.html#testing
3497 ;; Use the installed version instead.
3498 (lambda* (#:key inputs outputs #:allow-other-keys)
3499 (add-installed-pythonpath inputs outputs)
3500 ;; some tests require access to "$HOME"
3501 (setenv "HOME" "/tmp")
3502 ;; Step out of the source directory just to be sure.
3503 (chdir "..")
3504 (zero? (system* "nosetests" "-v" "sklearn")))))))
3505 (inputs
3506 `(("openblas" ,openblas)))
3507 (native-inputs
3508 `(("python-nose" ,python-nose)
3509 ("python-cython" ,python-cython)))
3510 (propagated-inputs
3511 `(("python-numpy" ,python-numpy)
3512 ("python-scipy" ,python-scipy)))
3513 (home-page "http://scikit-learn.org/")
3514 (synopsis "Machine Learning in Python")
3515 (description
3516 "Scikit-learn provides simple and efficient tools for data
3517 mining and data analysis.")
3518 (license license:bsd-3)))
3519
3520 (define-public python2-scikit-learn
3521 (package-with-python2 python-scikit-learn))
3522
3523 (define-public python-scikit-image
3524 (package
3525 (name "python-scikit-image")
3526 (version "0.11.3")
3527 (source
3528 (origin
3529 (method url-fetch)
3530 (uri (string-append
3531 "https://pypi.python.org/packages/source/s/scikit-image/scikit-image-"
3532 version ".tar.gz"))
3533 (sha256
3534 (base32 "0jz416fqvpahqyffw8plmszzfj669w8wvf3y9clnr5lr6a7md3kn"))))
3535 (build-system python-build-system)
3536 (arguments
3537 ;; TODO: Some tests require running X11 server. Disable them?
3538 '(#:tests? #f))
3539 ;; See DEPENDS.txt for the list of build and run time requiremnts
3540 (propagated-inputs
3541 `(("python-matplotlib" ,python-matplotlib)
3542 ("python-networkx" ,python-networkx)
3543 ("python-scipy" ,python-scipy)
3544 ("python-pillow" ,python-pillow)))
3545 (native-inputs
3546 `(("python-numpy" ,python-numpy)
3547 ("python-cython" ,python-cython)
3548 ("python-six" ,python-six)))
3549 (home-page "http://scikit-image.org/")
3550 (synopsis "Image processing in Python")
3551 (description
3552 "Scikit-image is a collection of algorithms for image processing.")
3553 (license license:bsd-3)))
3554
3555 (define-public python2-scikit-image
3556 (package-with-python2 python-scikit-image))
3557
3558 (define-public python-redis
3559 (package
3560 (name "python-redis")
3561 (version "2.10.5")
3562 (source
3563 (origin
3564 (method url-fetch)
3565 (uri (pypi-uri "redis" version))
3566 (sha256
3567 (base32 "0csmrkxb29x7xs9b51zplwkkq2hwnbh9jns1g85dykn5rxmaxysx"))))
3568 (build-system python-build-system)
3569 ;; Tests require a running Redis server
3570 (arguments '(#:tests? #f))
3571 ;; As long as we are not running test, we do not need this input :-)
3572 ;;(native-inputs
3573 ;; `(("python-pytest" ,python-pytest)))
3574 (home-page "https://github.com/andymccurdy/redis-py")
3575 (synopsis "Redis Python client")
3576 (description
3577 "This package provides a Python interface to the Redis key-value store.")
3578 (license license:expat)))
3579
3580 (define-public python2-redis
3581 (package-with-python2 python-redis))
3582
3583 (define-public python-rq
3584 (package
3585 (name "python-rq")
3586 (version "0.7.1")
3587 (source
3588 (origin
3589 (method url-fetch)
3590 (uri (pypi-uri "rq" version))
3591 (sha256
3592 (base32 "0gaq5pnh0zy46r8jvygi0ifbvz3pq6i7xla78ijcgjw0x77qzsdh"))))
3593 (build-system python-build-system)
3594 (propagated-inputs
3595 `(("python-click" ,python-click)
3596 ("python-redis" ,python-redis)))
3597 (home-page "http://python-rq.org/")
3598 (synopsis "Simple job queues for Python")
3599 (description
3600 "RQ (Redis Queue) is a simple Python library for queueing jobs and
3601 processing them in the background with workers. It is backed by Redis and it
3602 is designed to have a low barrier to entry.")
3603 (license license:bsd-2)))
3604
3605 (define-public python2-rq
3606 (package-with-python2 python-rq))
3607
3608 (define-public python-cython
3609 (package
3610 (name "python-cython")
3611 (version "0.25.2")
3612 (source
3613 (origin
3614 (method url-fetch)
3615 (uri (pypi-uri "Cython" version))
3616 (patches (search-patches "python-cython-fix-tests-32bit.patch"))
3617 (sha256
3618 (base32
3619 "01h3lrf6d98j07iakifi81qjszh6faa37ibx7ylva1vsqbwx2hgi"))))
3620 (build-system python-build-system)
3621 ;; we need the full python package and not just the python-wrapper
3622 ;; because we need libpython3.3m.so
3623 (inputs
3624 `(("python" ,python)))
3625 (arguments
3626 `(#:phases
3627 (modify-phases %standard-phases
3628 (add-before 'check 'set-HOME
3629 ;; some tests require access to "$HOME/.cython"
3630 (lambda _ (setenv "HOME" "/tmp")))
3631 (replace 'check
3632 (lambda _ (zero? (system* "python" "runtests.py" "-vv")))))))
3633 (home-page "http://cython.org/")
3634 (synopsis "C extensions for Python")
3635 (description "Cython is an optimising static compiler for both the Python
3636 programming language and the extended Cython programming language. It makes
3637 writing C extensions for Python as easy as Python itself.")
3638 (license license:asl2.0)
3639 (properties `((python2-variant . ,(delay python2-cython))))))
3640
3641 (define-public python2-cython
3642 (package (inherit (package-with-python2
3643 (strip-python2-variant python-cython)))
3644 (name "python2-cython")
3645 (inputs
3646 `(("python-2" ,python-2))))) ; this is not automatically changed
3647
3648 ;; The RPython toolchain currently does not support Python 3.
3649 (define-public python2-rpython
3650 (package
3651 (name "python2-rpython")
3652 (version "0.1.4")
3653 (source
3654 (origin
3655 (method url-fetch)
3656 (uri (pypi-uri "rpython" version))
3657 (sha256
3658 (base32
3659 "07pps06fq4c4wmi5ii0sgh9zgwniz5y7frqhm28g3a154l163fxc"))))
3660 (build-system python-build-system)
3661 (arguments `(#:python ,python-2))
3662 (native-inputs
3663 `(("python2-pytest" ,python2-pytest))) ; needed for running tests
3664 (home-page "https://rpython.readthedocs.org")
3665 (synopsis "Framework for implementing interpreters and virtual machines")
3666 (description "RPython is a translation and support framework for
3667 producing implementations of dynamic languages, emphasizing a clean separation
3668 between language specification and implementation aspects.")
3669 (license license:expat)))
3670
3671 (define-public python-numpy
3672 (package
3673 (name "python-numpy")
3674 (version "1.12.0")
3675 (source
3676 (origin
3677 (method url-fetch)
3678 (uri (string-append
3679 "https://github.com/numpy/numpy/archive/v" version ".tar.gz"))
3680 (file-name (string-append name "-" version ".tar.gz"))
3681 (sha256
3682 (base32
3683 "025d4j4aakcp8w5i5diqh812cbbjgac7jszx1j56ivrbi1i8vv7d"))))
3684 (build-system python-build-system)
3685 (inputs
3686 `(("openblas" ,openblas)
3687 ("lapack" ,lapack)))
3688 (native-inputs
3689 `(("python-cython" ,python-cython)
3690 ("python-nose" ,python-nose)
3691 ("gfortran" ,gfortran)))
3692 (arguments
3693 `(#:phases
3694 (modify-phases %standard-phases
3695 (add-before 'build 'set-environment-variables
3696 (lambda* (#:key inputs #:allow-other-keys)
3697 (call-with-output-file "site.cfg"
3698 (lambda (port)
3699 (format port
3700 "[openblas]
3701 libraries = openblas
3702 library_dirs = ~a/lib
3703 include_dirs = ~a/include
3704
3705 # backslash-n to make emacs happy
3706 \n[lapack]
3707 lapack_libs = lapack
3708 library_dirs = ~a/lib
3709 include_dirs = ~a/include
3710 "
3711 (assoc-ref inputs "openblas")
3712 (assoc-ref inputs "openblas")
3713 (assoc-ref inputs "lapack")
3714 (assoc-ref inputs "lapack"))))
3715 ;; Use "gcc" executable, not "cc".
3716 (substitute* "numpy/distutils/system_info.py"
3717 (("c = distutils\\.ccompiler\\.new_compiler\\(\\)")
3718 "c = distutils.ccompiler.new_compiler(); c.set_executables(compiler='gcc',compiler_so='gcc',linker_exe='gcc',linker_so='gcc -shared')"))
3719 #t))
3720 ;; Tests can only be run after the library has been installed and not
3721 ;; within the source directory.
3722 (delete 'check)
3723 (add-after 'install 'check
3724 (lambda* (#:key outputs inputs #:allow-other-keys)
3725 ;; Make installed package available for running the tests
3726 (add-installed-pythonpath inputs outputs)
3727 (with-directory-excursion "/tmp"
3728 (zero? (system* "python" "-c"
3729 "import numpy; numpy.test(verbose=2)"))))))))
3730 (home-page "http://www.numpy.org/")
3731 (synopsis "Fundamental package for scientific computing with Python")
3732 (description "NumPy is the fundamental package for scientific computing
3733 with Python. It contains among other things: a powerful N-dimensional array
3734 object, sophisticated (broadcasting) functions, tools for integrating C/C++
3735 and Fortran code, useful linear algebra, Fourier transform, and random number
3736 capabilities.")
3737 (license license:bsd-3)))
3738
3739 (define-public python2-numpy
3740 (package-with-python2 python-numpy))
3741
3742 (define-public python-munch
3743 (package
3744 (name "python-munch")
3745 (version "2.0.4")
3746 (source
3747 (origin
3748 (method url-fetch)
3749 (uri (pypi-uri "munch" version))
3750 (sha256
3751 (base32
3752 "1cmqg91xnqx8gvnh4pmp0bfl1dfcm65d5p9mg73zz8pkjhx6h80l"))))
3753 (build-system python-build-system)
3754 (home-page "https://github.com/Infinidat/munch")
3755 (synopsis "Dot-accessible dictionary")
3756 (description "Munch is a dot-accessible dictionary similar to JavaScript
3757 objects.")
3758 (license license:expat)))
3759
3760 (define-public python2-munch
3761 (package-with-python2 python-munch))
3762
3763 (define-public python2-fastlmm
3764 (package
3765 (name "python2-fastlmm")
3766 (version "0.2.21")
3767 (source
3768 (origin
3769 (method url-fetch)
3770 (uri (pypi-uri "fastlmm" version ".zip"))
3771 (sha256
3772 (base32
3773 "1q8c34rpmwkfy3r4d5172pzdkpfryj561897z9r3x22gq7813x1m"))))
3774 (build-system python-build-system)
3775 (arguments
3776 `(#:python ,python-2)) ; only Python 2.7 is supported
3777 (propagated-inputs
3778 `(("python2-numpy" ,python2-numpy)
3779 ("python2-scipy" ,python2-scipy)
3780 ("python2-matplotlib" ,python2-matplotlib)
3781 ("python2-pandas" ,python2-pandas)
3782 ("python2-scikit-learn" ,python2-scikit-learn)
3783 ("python2-pysnptools" ,python2-pysnptools)))
3784 (native-inputs
3785 `(("unzip" ,unzip)
3786 ("python2-cython" ,python2-cython)
3787 ("python2-mock" ,python2-mock)
3788 ("python2-nose" ,python2-nose)))
3789 (home-page "http://research.microsoft.com/en-us/um/redmond/projects/mscompbio/fastlmm/")
3790 (synopsis "Perform genome-wide association studies on large data sets")
3791 (description
3792 "FaST-LMM, which stands for Factored Spectrally Transformed Linear Mixed
3793 Models, is a program for performing both single-SNP and SNP-set genome-wide
3794 association studies (GWAS) on extremely large data sets.")
3795 (license license:asl2.0)))
3796
3797 (define-public python-numpy-documentation
3798 (package
3799 (name "python-numpy-documentation")
3800 (version (package-version python-numpy))
3801 (source (package-source python-numpy))
3802 (build-system python-build-system)
3803 (native-inputs
3804 `(("python-matplotlib" ,python-matplotlib)
3805 ("python-numpy" ,python-numpy)
3806 ("pkg-config" ,pkg-config)
3807 ("python-sphinx" ,python-sphinx)
3808 ("python-numpydoc" ,python-numpydoc)
3809 ("texlive" ,(texlive-union (list texlive-fonts-amsfonts
3810 texlive-fonts-ec
3811 texlive-generic-ifxetex
3812 texlive-generic-pdftex
3813 texlive-latex-amsfonts
3814 texlive-latex-capt-of
3815 texlive-latex-cmap
3816 texlive-latex-environ
3817 texlive-latex-eqparbox
3818 texlive-latex-etoolbox
3819 texlive-latex-expdlist
3820 texlive-latex-fancyhdr
3821 texlive-latex-fancyvrb
3822 texlive-latex-fncychap
3823 texlive-latex-float
3824 texlive-latex-framed
3825 texlive-latex-geometry
3826 texlive-latex-graphics
3827 texlive-latex-hyperref
3828 texlive-latex-mdwtools
3829 texlive-latex-multirow
3830 texlive-latex-oberdiek
3831 texlive-latex-parskip
3832 texlive-latex-preview
3833 texlive-latex-tabulary
3834 texlive-latex-threeparttable
3835 texlive-latex-titlesec
3836 texlive-latex-trimspaces
3837 texlive-latex-ucs
3838 texlive-latex-upquote
3839 texlive-latex-url
3840 texlive-latex-varwidth
3841 texlive-latex-wrapfig)))
3842 ("texinfo" ,texinfo)
3843 ("perl" ,perl)
3844 ("scipy-sphinx-theme"
3845 ,(origin ; The build script expects scipy-sphinx-theme as a git submodule
3846 (method git-fetch)
3847 (uri (git-reference
3848 (url "https://github.com/scipy/scipy-sphinx-theme.git")
3849 (commit "c466764e2231ba132c09826b5b138fffa1cfcec3")))
3850 (sha256
3851 (base32
3852 "0q2y87clwlsgc7wvlsn9pzyssybcq10plwhq2w1ydykfsyyqbmkl"))))
3853 ,@(package-native-inputs python-numpy)))
3854 (arguments
3855 `(#:tests? #f ; we're only generating the documentation
3856 #:phases
3857 (modify-phases %standard-phases
3858 (delete 'build)
3859 (replace 'install
3860 (lambda* (#:key inputs outputs #:allow-other-keys)
3861 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
3862 (doc (string-append
3863 data "/doc/" ,name "-"
3864 ,(package-version python-numpy)))
3865 (info-reader (string-append data "/info"))
3866 (html (string-append doc "/html"))
3867 (scipy-sphinx-theme "scipy-sphinx-theme")
3868 (sphinx-theme-checkout (assoc-ref inputs scipy-sphinx-theme))
3869 (pyver ,(string-append "PYVER=")))
3870
3871 ;; FIXME: this is needed to for texlive-union to generate
3872 ;; fonts, which are not found.
3873 (setenv "HOME" "/tmp")
3874
3875 (with-directory-excursion "doc"
3876 (copy-recursively sphinx-theme-checkout scipy-sphinx-theme)
3877 (mkdir-p html)
3878 (system* "make" "html" pyver)
3879 (system* "make" "latex" "PAPER=a4" pyver)
3880 (system* "make" "-C" "build/latex"
3881 "all-pdf" "PAPER=a4" pyver)
3882 ;; FIXME: Generation of the info file fails.
3883 ;; (system* "make" "info" pyver)
3884 ;; (mkdir-p info)
3885 ;; (copy-file "build/texinfo/numpy.info"
3886 ;; (string-append info "/numpy.info"))
3887 (for-each (lambda (file)
3888 (copy-file (string-append "build/latex" file)
3889 (string-append doc file)))
3890 '("/numpy-ref.pdf" "/numpy-user.pdf"))
3891 (with-directory-excursion "build/html"
3892 (for-each (lambda (file)
3893 (let* ((dir (dirname file))
3894 (tgt-dir (string-append html "/" dir)))
3895 (unless (equal? "." dir)
3896 (mkdir-p tgt-dir))
3897 (install-file file html)))
3898 (find-files "." ".*")))))
3899 #t)))))
3900 (home-page (package-home-page python-numpy))
3901 (synopsis "Documentation for the python-numpy package")
3902 (description (package-description python-numpy))
3903 (license (package-license python-numpy))))
3904
3905 (define-public python2-numpy-documentation
3906 (let ((numpy-documentation (package-with-python2 python-numpy-documentation)))
3907 (package
3908 (inherit numpy-documentation)
3909 (native-inputs `(("python2-functools32" ,python2-functools32)
3910 ,@(package-native-inputs numpy-documentation))))))
3911
3912 (define-public python-pygit2
3913 (package
3914 (name "python-pygit2")
3915 (version "0.25.0")
3916 (source
3917 (origin
3918 (method url-fetch)
3919 (uri (pypi-uri "pygit2" version))
3920 (sha256
3921 (base32
3922 "0wf5rp0fvrw7j3j18dvwjq6xqlbm611wd55aphrfpps0v1gxh3ny"))
3923 (patches
3924 (search-patches "python-pygit2-disable-network-tests.patch"))))
3925 (build-system python-build-system)
3926 (propagated-inputs
3927 `(("python-six" ,python-six)
3928 ("python-cffi" ,python-cffi)
3929 ("libgit2" ,libgit2)
3930 ("python-tox" ,python-tox)))
3931 (home-page "https://github.com/libgit2/pygit2")
3932 (synopsis "Python bindings for libgit2")
3933 (description "Pygit2 is a set of Python bindings to the libgit2 shared
3934 library, libgit2 implements Git plumbing.")
3935 ;; GPL2.0 only, with linking exception.
3936 (license license:gpl2)))
3937
3938 (define-public python2-pygit2
3939 (package-with-python2 python-pygit2))
3940
3941 (define-public python-pyparsing
3942 (package
3943 (name "python-pyparsing")
3944 (version "2.0.3")
3945 (source
3946 (origin
3947 (method url-fetch)
3948 (uri (string-append "mirror://sourceforge/pyparsing/pyparsing"
3949 "/pyparsing-" version
3950 "/pyparsing-" version ".tar.gz"))
3951 (sha256
3952 (base32
3953 "0kw4py7gn45j93q8r7bzajfrjdc3xlsn2yzln41lf9zmrghjkrq6"))))
3954 (build-system python-build-system)
3955 (outputs '("out" "doc"))
3956 (arguments
3957 `(#:tests? #f ; no test target
3958 #:modules ((guix build python-build-system)
3959 (guix build utils))
3960 #:phases
3961 (alist-cons-after
3962 'install 'install-doc
3963 (lambda* (#:key outputs #:allow-other-keys)
3964 (let* ((doc (string-append (assoc-ref outputs "doc")
3965 "/share/doc/" ,name "-" ,version))
3966 (html-doc (string-append doc "/html"))
3967 (examples (string-append doc "/examples")))
3968 (mkdir-p html-doc)
3969 (mkdir-p examples)
3970 (for-each
3971 (lambda (dir tgt)
3972 (map (lambda (file)
3973 (install-file file tgt))
3974 (find-files dir ".*")))
3975 (list "docs" "htmldoc" "examples")
3976 (list doc html-doc examples))))
3977 %standard-phases)))
3978 (home-page "http://pyparsing.wikispaces.com")
3979 (synopsis "Python parsing class library")
3980 (description
3981 "The pyparsing module is an alternative approach to creating and
3982 executing simple grammars, vs. the traditional lex/yacc approach, or the use
3983 of regular expressions. The pyparsing module provides a library of classes
3984 that client code uses to construct the grammar directly in Python code.")
3985 (license license:expat)))
3986
3987 (define-public python2-pyparsing
3988 (package-with-python2 python-pyparsing))
3989
3990 (define-public python-numpydoc
3991 (package
3992 (name "python-numpydoc")
3993 (version "0.5")
3994 (source
3995 (origin
3996 (method url-fetch)
3997 (uri (string-append
3998 "https://pypi.python.org/packages/source/n/numpydoc/numpydoc-"
3999 version ".tar.gz"))
4000 (sha256
4001 (base32
4002 "0d4dnifaxkll50jx6czj05y8cb4ny60njd2wz299sj2jxfy51w4k"))
4003 (modules '((guix build utils)))
4004 (snippet
4005 '(begin
4006 ;; Drop a test requiring matplotlib, which we cannot add as an
4007 ;; input since it would create a circular dependency: Extend the
4008 ;; test for Python 3, where it is already dropped, to Python 2.
4009 (substitute* "numpydoc/tests/test_plot_directive.py"
4010 (("3") "2"))))))
4011 (build-system python-build-system)
4012 (propagated-inputs
4013 `(("python-sphinx" ,python-sphinx)))
4014 (native-inputs
4015 `(("python-nose" ,python-nose)))
4016 (home-page "https://pypi.python.org/pypi/numpydoc")
4017 (synopsis
4018 "Numpy's Sphinx extensions")
4019 (description
4020 "Sphinx extension to support docstrings in Numpy format.")
4021 (license license:bsd-2)))
4022
4023 (define-public python2-numpydoc
4024 (package-with-python2 python-numpydoc))
4025
4026 (define-public python-numexpr
4027 (package
4028 (name "python-numexpr")
4029 (version "2.6.1")
4030 (source
4031 (origin
4032 (method url-fetch)
4033 (uri (pypi-uri "numexpr" version))
4034 (sha256
4035 (base32
4036 "01lsja72m32z0i5p8rwxbfyzk4mplh72k2a140nwh8vv4wpyfbnv"))))
4037 (build-system python-build-system)
4038 (arguments `(#:tests? #f)) ; no tests included
4039 (propagated-inputs
4040 `(("python-numpy" ,python-numpy)))
4041 (home-page "https://github.com/pydata/numexpr")
4042 (synopsis "Fast numerical expression evaluator for NumPy")
4043 (description
4044 "Numexpr is a fast numerical expression evaluator for NumPy. With it,
4045 expressions that operate on arrays are accelerated and use less memory than
4046 doing the same calculation in Python. In addition, its multi-threaded
4047 capabilities can make use of all your cores, which may accelerate
4048 computations, most specially if they are not memory-bounded (e.g. those using
4049 transcendental functions).")
4050 (license license:expat)))
4051
4052 (define-public python2-numexpr
4053 (package-with-python2 python-numexpr))
4054
4055 (define-public python-cycler
4056 (package
4057 (name "python-cycler")
4058 (version "0.10.0")
4059 (source (origin
4060 (method url-fetch)
4061 (uri (pypi-uri "cycler" version))
4062 (sha256
4063 (base32
4064 "1n69n23fak1gjxlrbhqisi2b9pv3ckrfj98llx3p53953082syyd"))))
4065 (build-system python-build-system)
4066 (arguments
4067 ;; XXX: The current version requires 'coveralls' which we don't have.
4068 ;; Enable this for the next release which uses 'python-pytest'.
4069 '(#:tests? #f))
4070 (propagated-inputs
4071 `(("python-six" ,python-six)))
4072 (home-page "http://matplotlib.org/cycler/")
4073 (synopsis "Composable keyword argument iterator")
4074 (description
4075 "When using @code{matplotlib} and plotting more than one line, it is
4076 common to want to be able to want to be able to cycle over one or more artist
4077 styles; but the plotting logic can quickly become involved.
4078 To address this and enable easy cycling over arbitrary @code{kwargs}, the
4079 @code{Cycler} class was developed.")
4080 (license license:bsd-3)))
4081
4082 (define-public python2-cycler
4083 (package-with-python2 python-cycler))
4084
4085 (define-public python-colorspacious
4086 (package
4087 (name "python-colorspacious")
4088 (version "1.1.0")
4089 (source
4090 (origin
4091 (method url-fetch)
4092 (uri (string-append "https://github.com/njsmith/colorspacious/archive/v"
4093 version ".tar.gz"))
4094 (file-name (string-append name "-" version))
4095 (sha256
4096 (base32 "1vflh5jm32qb0skza2i8pjacv09w6gq84fqpp2nj77s0rbmzgr4k"))))
4097 (build-system python-build-system)
4098 (propagated-inputs
4099 `(("python-numpy" ,python-numpy)))
4100 (native-inputs
4101 `(("python-nose" ,python-nose)))
4102 (arguments
4103 `(#:phases
4104 (modify-phases %standard-phases
4105 (replace 'check
4106 (lambda _
4107 (zero? (system* "nosetests" "--all-modules" "-v" "colorspacious")))))))
4108 (home-page "https://github.com/njsmith/colorspacious")
4109 (synopsis "Python library for colorspace conversions")
4110 (description "@code{colorspacious} is a Python library that lets you
4111 convert between colorspaces like sRGB, XYZ, CIEL*a*b*, CIECAM02, CAM02-UCS, etc.")
4112 (license license:expat)))
4113
4114 (define-public python2-colorspacious
4115 (package-with-python2 python-colorspacious))
4116
4117 (define-public python-matplotlib
4118 (package
4119 (name "python-matplotlib")
4120 (version "2.0.0")
4121 (source
4122 (origin
4123 (method url-fetch)
4124 (uri (string-append
4125 "https://github.com/matplotlib/matplotlib/archive/v" version ".tar.gz"))
4126 (file-name (string-append name "-" version ".tar.gz"))
4127 (sha256
4128 (base32
4129 "0w3k5m5qb3wsd7yhvmg042xddvligklvcq2visk2c5wnph3hhsln"))))
4130 (build-system python-build-system)
4131 (propagated-inputs ; the following packages are all needed at run time
4132 `(("python-cycler" ,python-cycler)
4133 ("python-pyparsing" ,python-pyparsing)
4134 ("python-pygobject" ,python-pygobject)
4135 ("gobject-introspection" ,gobject-introspection)
4136 ("python-tkinter" ,python "tk")
4137 ("python-dateutil" ,python-dateutil)
4138 ("python-numpy" ,python-numpy)
4139 ("python-pillow" ,python-pillow)
4140 ("python-pytz" ,python-pytz)
4141 ("python-six" ,python-six)
4142 ;; The 'gtk+' package (and 'gdk-pixbuf', 'atk' and 'pango' propagated
4143 ;; from 'gtk+') provides the required 'typelib' files used by
4144 ;; 'gobject-introspection'. The location of these files is set with the
4145 ;; help of the environment variable GI_TYPELIB_PATH. At build time this
4146 ;; is done automatically by a 'native-search-path' procedure. However,
4147 ;; at run-time the user must set this variable as follows:
4148 ;;
4149 ;; export GI_TYPELIB_PATH=~/.guix-profile/lib/girepository-1.0
4150 ("gtk+" ,gtk+)
4151 ;; From version 1.4.0 'matplotlib' makes use of 'cairocffi' instead of
4152 ;; 'pycairo'. However, 'pygobject' makes use of a 'pycairo' 'context'
4153 ;; object. For this reason we need to import both libraries.
4154 ;; https://pythonhosted.org/cairocffi/cffi_api.html#converting-pycairo
4155 ("python-pycairo" ,python-pycairo)
4156 ("python-cairocffi" ,python-cairocffi)))
4157 (inputs
4158 `(("libpng" ,libpng)
4159 ("imagemagick" ,imagemagick)
4160 ("freetype" ,freetype)
4161 ("cairo" ,cairo)
4162 ("glib" ,glib)
4163 ;; FIXME: Add backends when available.
4164 ;("python-wxpython" ,python-wxpython)
4165 ("python-pyqt" ,python-pyqt)
4166 ("tcl" ,tcl)
4167 ("tk" ,tk)))
4168 (native-inputs
4169 `(("pkg-config" ,pkg-config)
4170 ("python-nose" ,python-nose)
4171 ("python-mock" ,python-mock)))
4172 (arguments
4173 `(#:phases
4174 (modify-phases %standard-phases
4175 (add-before 'build 'configure-environment
4176 (lambda* (#:key outputs inputs #:allow-other-keys)
4177 (let ((cairo (assoc-ref inputs "cairo"))
4178 (gtk+ (assoc-ref inputs "gtk+")))
4179 ;; Setting these directories in the 'basedirlist' of 'setup.cfg'
4180 ;; has not effect.
4181 (setenv "LD_LIBRARY_PATH"
4182 (string-append cairo "/lib:" gtk+ "/lib"))
4183 (setenv "HOME" (getcwd))
4184 (call-with-output-file "setup.cfg"
4185 (lambda (port)
4186 (format port "[directories]~%
4187 basedirlist = ~a,~a~%
4188 [rc_options]~%
4189 backend = TkAgg~%"
4190 (assoc-ref inputs "tcl")
4191 (assoc-ref inputs "tk")))))
4192 #t)))))
4193 (home-page "http://matplotlib.org")
4194 (synopsis "2D plotting library for Python")
4195 (description
4196 "Matplotlib is a Python 2D plotting library which produces publication
4197 quality figures in a variety of hardcopy formats and interactive environments
4198 across platforms. Matplotlib can be used in Python scripts, the python and
4199 ipython shell, web application servers, and six graphical user interface
4200 toolkits.")
4201 (license license:psfl)
4202 (properties `((python2-variant . ,(delay python2-matplotlib))))))
4203
4204 (define-public python2-matplotlib
4205 (let ((matplotlib (package-with-python2
4206 (strip-python2-variant python-matplotlib))))
4207 (package (inherit matplotlib)
4208 ;; Make sure to use special packages for Python 2 instead
4209 ;; of those automatically rewritten by package-with-python2.
4210 (propagated-inputs
4211 `(("python2-pycairo" ,python2-pycairo)
4212 ("python2-functools32" ,python2-functools32)
4213 ("python2-pygobject-2" ,python2-pygobject-2)
4214 ("python2-subprocess32" ,python2-subprocess32)
4215 ("python2-tkinter" ,python-2 "tk")
4216 ,@(fold alist-delete (package-propagated-inputs matplotlib)
4217 '("python-pycairo" "python-pygobject" "python-tkinter")))))))
4218
4219 (define-public python-matplotlib-documentation
4220 (package
4221 (name "python-matplotlib-documentation")
4222 (version (package-version python-matplotlib))
4223 (source (package-source python-matplotlib))
4224 (build-system python-build-system)
4225 (native-inputs
4226 `(("python-matplotlib" ,python-matplotlib)
4227 ("python-colorspacious" ,python-colorspacious)
4228 ("python-sphinx" ,python-sphinx)
4229 ("python-numpydoc" ,python-numpydoc)
4230 ("python-ipython" ,python-ipython)
4231 ("python-mock" ,python-mock)
4232 ("graphviz" ,graphviz)
4233 ("texlive" ,texlive)
4234 ("texinfo" ,texinfo)
4235 ,@(package-native-inputs python-matplotlib)))
4236 (arguments
4237 `(#:tests? #f ; we're only generating documentation
4238 #:phases
4239 (modify-phases %standard-phases
4240 (replace 'build
4241 (lambda _
4242 (chdir "doc")
4243 ;; Produce pdf in 'A4' format.
4244 (substitute* "conf.py"
4245 (("latex_paper_size = 'letter'") "")
4246 ;; latex_paper_size is deprecated -> set paper size using
4247 ;; latex_elements
4248 (("latex_elements\\['pointsize'\\] = '11pt'" match)
4249 ;; insert at a point where latex_elements{} is defined:
4250 (string-append match "\nlatex_elements['papersize'] = 'a4paper'")))
4251 (zero? (system* "python" "make.py" "html" "latex" "texinfo"))))
4252 (replace 'install
4253 (lambda* (#:key inputs outputs #:allow-other-keys)
4254 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
4255 (doc (string-append data "/doc/python-matplotlib-" ,version))
4256 (info (string-append data "/info"))
4257 (html (string-append doc "/html")))
4258 (mkdir-p html)
4259 (mkdir-p info)
4260 (copy-recursively "build/html" html)
4261 (symlink (string-append html "/_images")
4262 (string-append info "/matplotlib-figures"))
4263 (with-directory-excursion "build/texinfo"
4264 (substitute* "matplotlib.texi"
4265 (("@image\\{([^,]*)" all file)
4266 (string-append "@image{matplotlib-figures/" file)))
4267 (symlink (string-append html "/_images")
4268 "./matplotlib-figures")
4269 (system* "makeinfo" "--no-split"
4270 "-o" "matplotlib.info" "matplotlib.texi"))
4271 (copy-file "build/texinfo/matplotlib.info"
4272 (string-append info "/matplotlib.info"))
4273 (copy-file "build/latex/Matplotlib.pdf"
4274 (string-append doc "/Matplotlib.pdf")))
4275 #t)))))
4276 (home-page (package-home-page python-matplotlib))
4277 (synopsis "Documentation for the python-matplotlib package")
4278 (description (package-description python-matplotlib))
4279 (license (package-license python-matplotlib))))
4280
4281 (define-public python2-matplotlib-documentation
4282 (package-with-python2 python-matplotlib-documentation))
4283
4284 (define-public python2-pysnptools
4285 (package
4286 (name "python2-pysnptools")
4287 (version "0.3.9")
4288 (source
4289 (origin
4290 (method url-fetch)
4291 (uri (pypi-uri "pysnptools" version ".zip"))
4292 (sha256
4293 (base32
4294 "1wybggjzz8zw7aav4pjsg2h22xp17a1lghrprza1pxwlm7wf96y2"))))
4295 (build-system python-build-system)
4296 (arguments
4297 `(#:python ,python-2)) ; only Python 2.7 is supported
4298 (propagated-inputs
4299 `(("python2-numpy" ,python2-numpy)
4300 ("python2-scipy" ,python2-scipy)
4301 ("python2-pandas" ,python2-pandas)))
4302 (native-inputs
4303 `(("python2-cython" ,python2-cython)))
4304 (native-inputs
4305 `(("unzip" ,unzip)))
4306 (home-page "http://research.microsoft.com/en-us/um/redmond/projects/mscompbio/")
4307 (synopsis "Library for reading and manipulating genetic data")
4308 (description
4309 "PySnpTools is a library for reading and manipulating genetic data. It
4310 can, for example, efficiently read whole PLINK *.bed/bim/fam files or parts of
4311 those files. It can also efficiently manipulate ranges of integers using set
4312 operators such as union, intersection, and difference.")
4313 (license license:asl2.0)))
4314
4315 (define-public python-rpy2
4316 (package
4317 (name "python-rpy2")
4318 (version "2.7.6")
4319 (source
4320 (origin
4321 (method url-fetch)
4322 (uri (pypi-uri "rpy2" version))
4323 (sha256
4324 (base32
4325 "0nhan2qvrw7b7gg5zddwa22kybdv3x1g26vkd7q8lvnkgzrs4dga"))))
4326 (build-system python-build-system)
4327 (arguments
4328 '(#:phases
4329 (modify-phases %standard-phases
4330 (delete 'check)
4331 (add-after 'install 'check
4332 (lambda* (#:key outputs inputs #:allow-other-keys)
4333 ;; It's easier to run tests after install.
4334 ;; Make installed package available for running the tests
4335 (add-installed-pythonpath inputs outputs)
4336 (zero? (system* "python" "-m" "rpy2.tests" "-v")))))))
4337 (propagated-inputs
4338 `(("python-six" ,python-six)))
4339 (inputs
4340 `(("readline" ,readline)
4341 ("icu4c" ,icu4c)
4342 ("pcre" ,pcre)
4343 ("r-minimal" ,r-minimal)
4344 ("r-survival" ,r-survival)))
4345 (native-inputs
4346 `(("zlib" ,zlib)))
4347 (home-page "http://rpy.sourceforge.net/")
4348 (synopsis "Python interface to the R language")
4349 (description "rpy2 is a redesign and rewrite of rpy. It is providing a
4350 low-level interface to R from Python, a proposed high-level interface,
4351 including wrappers to graphical libraries, as well as R-like structures and
4352 functions.")
4353 (license license:gpl3+)))
4354
4355 (define-public python2-rpy2
4356 (let ((rpy2 (package-with-python2 python-rpy2)))
4357 (package (inherit rpy2)
4358 (propagated-inputs
4359 `(("python2-singledispatch" ,python2-singledispatch)
4360 ,@(package-propagated-inputs rpy2))))))
4361
4362 (define-public python-scipy
4363 (package
4364 (name "python-scipy")
4365 (version "0.18.1")
4366 (source
4367 (origin
4368 (method url-fetch)
4369 (uri (string-append "https://github.com/scipy/scipy/archive/v"
4370 version ".tar.gz"))
4371 (file-name (string-append name "-" version ".tar.gz"))
4372 (sha256
4373 (base32
4374 "17slsrfawjp7if6qrlx03zhgp05350ginxx8ddpw9zqx43x905sn"))))
4375 (build-system python-build-system)
4376 (propagated-inputs
4377 `(("python-numpy" ,python-numpy)
4378 ("python-matplotlib" ,python-matplotlib)
4379 ("python-pyparsing" ,python-pyparsing)))
4380 (inputs
4381 `(("lapack" ,lapack)
4382 ("openblas" ,openblas)))
4383 (native-inputs
4384 `(("python-cython" ,python-cython)
4385 ("python-nose" ,python-nose)
4386 ("python-sphinx" ,python-sphinx)
4387 ("python-numpydoc" ,python-numpydoc)
4388 ("gfortran" ,gfortran)
4389 ("perl" ,perl)))
4390 (outputs '("out" "doc"))
4391 (arguments
4392 `(#:phases
4393 (modify-phases %standard-phases
4394 (add-before 'build 'configure-openblas
4395 (lambda* (#:key inputs #:allow-other-keys)
4396 (call-with-output-file "site.cfg"
4397 (lambda (port)
4398 (format port
4399 "[blas]
4400 libraries = openblas
4401 library_dirs = ~a/lib
4402 include_dirs = ~a/include
4403
4404 # backslash-n to make emacs happy
4405 \n[atlas]
4406 library_dirs = ~a/lib
4407 atlas_libs = openblas
4408 "
4409 (assoc-ref inputs "openblas")
4410 (assoc-ref inputs "openblas")
4411 (assoc-ref inputs "openblas"))))
4412 #t))
4413 (add-after 'install 'install-doc
4414 (lambda* (#:key inputs outputs #:allow-other-keys)
4415 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
4416 (doc (string-append data "/doc/" ,name "-" ,version))
4417 (html (string-append doc "/html"))
4418 (pyver ,(string-append "PYVER=")))
4419 ;; Make installed package available for building the
4420 ;; documentation
4421 (add-installed-pythonpath inputs outputs)
4422 (with-directory-excursion "doc"
4423 ;; Fix generation of images for mathematical expressions.
4424 (substitute* (find-files "source" "conf\\.py")
4425 (("pngmath_use_preview = True")
4426 "pngmath_use_preview = False"))
4427 (mkdir-p html)
4428 (system* "make" "html" pyver)
4429 (with-directory-excursion "build/html"
4430 (for-each (lambda (file)
4431 (let* ((dir (dirname file))
4432 (tgt-dir (string-append html "/" dir)))
4433 (install-file file html)))
4434 (find-files "." ".*")))))
4435 #t))
4436 (add-after 'unpack 'fix-tests
4437 (lambda _
4438 (substitute* "scipy/integrate/tests/test_quadpack.py"
4439 (("libm.so") "libm.so.6"))
4440 #t))
4441 ;; Tests can only be run after the library has been installed and not
4442 ;; within the source directory.
4443 (delete 'check)
4444 (add-after 'install 'check
4445 (lambda* (#:key inputs outputs #:allow-other-keys)
4446 (add-installed-pythonpath inputs outputs)
4447 (with-directory-excursion "/tmp"
4448 (zero? (system* "python" "-c"
4449 "import scipy; scipy.test('full')")))
4450 #t)))))
4451 (home-page "http://www.scipy.org/")
4452 (synopsis "The Scipy library provides efficient numerical routines")
4453 (description "The SciPy library is one of the core packages that make up
4454 the SciPy stack. It provides many user-friendly and efficient numerical
4455 routines such as routines for numerical integration and optimization.")
4456 (properties `((python2-variant . ,(delay python2-scipy))))
4457 (license license:bsd-3)))
4458
4459 (define-public python2-scipy
4460 (package-with-python2
4461 (strip-python2-variant python-scipy)))
4462
4463 (define-public python-sockjs-tornado
4464 (package
4465 (name "python-sockjs-tornado")
4466 (version "1.0.3")
4467 (source
4468 (origin
4469 (method url-fetch)
4470 (uri (pypi-uri "sockjs-tornado" version))
4471 (sha256
4472 (base32
4473 "16cff40nniqsyvda1pb2j3b4zwmrw7y2g1vqq78lp20xpmhnwwkd"))))
4474 (build-system python-build-system)
4475 (arguments
4476 `(;; There are no tests, and running the test phase requires missing
4477 ;; dependencies
4478 #:tests? #f))
4479 (propagated-inputs
4480 `(("python-tornado" ,python-tornado)))
4481 (home-page "http://github.com/mrjoes/sockjs-tornado/")
4482 (synopsis
4483 "SockJS python server implementation on top of Tornado framework")
4484 (description
4485 "SockJS-tornado provides the server side counterpart to a SockJS client
4486 library, through the Tornado framework.
4487
4488 SockJS provides a low latency, full duplex, cross-domain communication channel
4489 between a web browser and web server.")
4490 (license license:expat)))
4491
4492 (define-public python2-sockjs-tornado
4493 (package-with-python2 python-sockjs-tornado))
4494
4495 (define-public python-socksipy-branch
4496 (package
4497 (name "python-socksipy-branch")
4498 (version "1.01")
4499 (source
4500 (origin
4501 (method url-fetch)
4502 (uri (pypi-uri "SocksiPy-branch" version))
4503 (sha256
4504 (base32
4505 "01l41v4g7fy9fzvinmjxy6zcbhgqaif8dhdqm4w90fwcw9h51a8p"))))
4506 (build-system python-build-system)
4507 (arguments
4508 `(#:tests? #f)) ; There are no tests
4509 (home-page "https://code.google.com/archive/p/socksipy-branch/")
4510 (synopsis "Python SOCKS module")
4511 (description
4512 "SocksiPy - A Python SOCKS client module. It provides a
4513 socket-like interface that supports connections to any TCP
4514 service through the use of a SOCKS4, SOCKS5 or HTTP proxy.
4515 The original version was developed by Dan Haim, this is a
4516 branch created by Mario Vilas to address some open issues,
4517 as the original project seems to have been abandoned circa 2007.")
4518 (license license:bsd-3)))
4519
4520 (define-public python2-socksipy-branch
4521 (package-with-python2 python-socksipy-branch))
4522
4523 (define-public python-sqlalchemy
4524 (package
4525 (name "python-sqlalchemy")
4526 (version "1.0.12")
4527 (source
4528 (origin
4529 (method url-fetch)
4530 (uri (string-append "https://pypi.python.org/packages/source/S/"
4531 "SQLAlchemy/SQLAlchemy-" version ".tar.gz"))
4532 (sha256
4533 (base32
4534 "1l8qclhd0s90w3pvwhi5mjxdwr5j7gw7cjka2fx6f2vqmq7f4yb6"))))
4535 (build-system python-build-system)
4536 (native-inputs
4537 `(("python-cython" ,python-cython) ;for c extensions
4538 ("python-pytest" ,python-pytest)
4539 ("python-mock" ,python-mock))) ;for tests
4540 (arguments
4541 `(#:phases (alist-replace
4542 'check
4543 (lambda _ (zero? (system* "py.test")))
4544 %standard-phases)))
4545 (home-page "http://www.sqlalchemy.org")
4546 (synopsis "Database abstraction library")
4547 (description
4548 "SQLAlchemy is the Python SQL toolkit and Object Relational Mapper that
4549 gives application developers the full power and flexibility of SQL. It
4550 provides a full suite of well known enterprise-level persistence patterns,
4551 designed for efficient and high-performing database access, adapted into a
4552 simple and Pythonic domain language.")
4553 (license license:x11)))
4554
4555 (define-public python2-sqlalchemy
4556 (package-with-python2 python-sqlalchemy))
4557
4558 (define-public python-pycodestyle
4559 (package
4560 (name "python-pycodestyle")
4561 (version "2.3.1")
4562 (source
4563 (origin
4564 (method url-fetch)
4565 (uri (pypi-uri "pycodestyle" version))
4566 (sha256
4567 (base32
4568 "0rk78b66p57ala26mdldl9lafr48blv5s659sah9q50qnfjmc8k8"))))
4569 (build-system python-build-system)
4570 (home-page "https://pycodestyle.readthedocs.io/")
4571 (synopsis "Python style guide checker")
4572 (description "@code{pycodestyle} (formerly pep8) is a tool to check
4573 Python code against some of the style conventions in
4574 @url{http://www.python.org/dev/peps/pep-0008/,PEP 8}.")
4575 (license license:expat)))
4576
4577 (define-public python2-pycodestyle
4578 (package-with-python2 python-pycodestyle))
4579
4580 (define-public python-orderedmultidict
4581 (package
4582 (name "python-orderedmultidict")
4583 (version "0.7.11")
4584 (source
4585 (origin
4586 (method url-fetch)
4587 (uri (pypi-uri "orderedmultidict" version))
4588 (sha256
4589 (base32
4590 "0dls862ibm7qbq4fnvwx0xn1v9hwyzywbff8xjjdr42dd75208yw"))))
4591 (build-system python-build-system)
4592 (arguments
4593 `(#:phases
4594 (modify-phases %standard-phases
4595 (add-after 'unpack 'fix-tests
4596 (lambda _
4597 ;; The package uses nosetest for running the tests.
4598 ;; Adding this initfile allows to run the test suite
4599 ;; without requiring nosetest.
4600 (zero? (system* "touch" "tests/__init__.py")))))))
4601 (propagated-inputs
4602 `(("python-six" ,python-six)))
4603 (native-inputs
4604 `(("python-pycodestyle" ,python-pycodestyle)))
4605 (home-page "https://github.com/gruns/orderedmultidict")
4606 (synopsis "Python Ordered Multivalue Dictionary - omdict")
4607 (description "This package contains a library for ordered multivalue
4608 dictionaries. A multivalue dictionary is a dictionary that can store
4609 multiple values for the same key. An ordered multivalue dictionary is a
4610 multivalue dictionary that retains the order of insertions and deletions.")
4611 (license license:unlicense)))
4612
4613 (define-public python2-orderedmultidict
4614 (package-with-python2 python-orderedmultidict))
4615
4616 (define-public python-furl
4617 (package
4618 (name "python-furl")
4619 (version "0.5.6")
4620 (source
4621 (origin
4622 (method url-fetch)
4623 (uri (pypi-uri "furl" version))
4624 (sha256
4625 (base32
4626 "0lzpfpm686hvz3sr1mcrnd1b3lgmnw8v59gb43wfi98r3b671pqc"))))
4627 (build-system python-build-system)
4628 (propagated-inputs
4629 `(("python-six" ,python-six)
4630 ("python-orderedmultidict" ,python-orderedmultidict)))
4631 (native-inputs
4632 `(("python-pycodestyle" ,python-pycodestyle)))
4633 (home-page "https://github.com/gruns/furl")
4634 (synopsis "URL manipulation in Python")
4635 (description "Furl provides an easy-to-use alternative to the
4636 @code{urllib} and @code{urlparse} modules for manipulating URLs.")
4637 (license license:unlicense)))
4638
4639 (define-public python2-furl
4640 (package-with-python2 python-furl))
4641
4642 (define-public python-flaky
4643 (package
4644 (name "python-flaky")
4645 (version "3.4.0")
4646 (source (origin
4647 (method url-fetch)
4648 (uri (pypi-uri "flaky" version))
4649 (sha256
4650 (base32
4651 "18pkmf79rfkfpy1d2rrx3v55nxj762ilyk9rvd6s6dccxw58imsa"))))
4652 (build-system python-build-system)
4653 (arguments
4654 ;; TODO: Tests require 'coveralls' and 'genty' which are not in Guix yet.
4655 '(#:tests? #f))
4656 (home-page "https://github.com/box/flaky")
4657 (synopsis "Automatically rerun flaky tests")
4658 (description
4659 "Flaky is a plugin for @code{nose} or @code{py.test} that automatically
4660 reruns flaky tests.
4661
4662 Ideally, tests reliably pass or fail, but sometimes test fixtures must rely
4663 on components that aren't 100% reliable. With flaky, instead of removing
4664 those tests or marking them to @code{@skip}, they can be automatically
4665 retried.")
4666 (license license:asl2.0)))
4667
4668 (define-public python2-flaky
4669 (package-with-python2 python-flaky))
4670
4671 (define-public python-flask-babel
4672 (package
4673 (name "python-flask-babel")
4674 (version "0.11.1")
4675 (source
4676 (origin
4677 (method url-fetch)
4678 (uri (pypi-uri "Flask-Babel" version))
4679 (sha256
4680 (base32
4681 "16b80cipdba9xj3jlaiaq6wgrgpjb70w3j01jjy9hbp4k71kd6yj"))))
4682 (build-system python-build-system)
4683 (propagated-inputs
4684 `(("python-flask" ,python-flask)
4685 ("python-babel" ,python-babel)
4686 ("python-jinja2" ,python-jinja2)
4687 ("python-pytz" ,python-pytz)))
4688 (home-page "https://github.com/python-babel/flask-babel")
4689 (synopsis "Add i18n/l10n support to Flask applications")
4690 (description "This package implements internationalization and localization
4691 support for Flask. This is based on the Python babel module as well as pytz -
4692 both of which are installed automatically if you install this library.")
4693 (license license:bsd-3)))
4694
4695 (define-public python2-flask-babel
4696 (package-with-python2 python-flask-babel))
4697
4698 (define-public python-sqlalchemy-utils
4699 (package
4700 (name "python-sqlalchemy-utils")
4701 (version "0.32.13")
4702 (source
4703 (origin
4704 (method url-fetch)
4705 (uri (pypi-uri "SQLAlchemy-Utils" version))
4706 (sha256
4707 (base32
4708 "0vsib7gidjamzsz6w4s5pdhxzxsrkghjnm4sqwk94igjrl3i5ixj"))))
4709 (build-system python-build-system)
4710 (arguments
4711 '(#:tests? #f)) ; FIXME: Many tests require a running database server.
4712 ;; #:phases
4713 ;; (modify-phases %standard-phases
4714 ;; (replace 'check
4715 ;; (lambda _
4716 ;; (zero? (system* "py.test" "sqlalchemy_utils" "tests")))))
4717 (propagated-inputs
4718 `(("python-six" ,python-six)
4719 ("python-sqlalchemy" ,python-sqlalchemy)))
4720 (native-inputs
4721 `(("python-dateutil" ,python-dateutil)
4722 ("python-flexmock" ,python-flexmock)
4723 ("python-psycopg2" ,python-psycopg2)
4724 ("python-pytest" ,python-pytest)
4725 ("python-pytz" ,python-pytz)))
4726 (home-page "https://github.com/kvesteri/sqlalchemy-utils")
4727 (synopsis "Various utility functions for SQLAlchemy")
4728 (description
4729 "SQLAlchemy-utils provides various utility functions and custom data types
4730 for SQLAlchemy. SQLAlchemy is an SQL database abstraction library for Python.
4731
4732 You might also want to install the following optional dependencies:
4733 @enumerate
4734 @item @code{python-passlib}
4735 @item @code{python-babel}
4736 @item @code{python-cryptography}
4737 @item @code{python-pytz}
4738 @item @code{python-psycopg2}
4739 @item @code{python-furl}
4740 @item @code{python-flask-babel}
4741 @end enumerate
4742 ")
4743 (license license:bsd-3)))
4744
4745 (define-public python2-sqlalchemy-utils
4746 (package-with-python2 python-sqlalchemy-utils))
4747
4748 (define-public python-alembic
4749 (package
4750 (name "python-alembic")
4751 (version "0.8.10")
4752 (source
4753 (origin
4754 (method url-fetch)
4755 (uri (pypi-uri "alembic" version))
4756 (sha256
4757 (base32
4758 "06br9sfqypnjlal6fsbnky3zb0askwcn3diz8k3kwa0qcblm0fqf"))))
4759 (build-system python-build-system)
4760 (native-inputs
4761 `(("python-mock" ,python-mock)
4762 ("python-pytest-cov" ,python-pytest-cov)))
4763 (propagated-inputs
4764 `(("python-sqlalchemy" ,python-sqlalchemy)
4765 ("python-mako" ,python-mako)
4766 ("python-editor" ,python-editor)))
4767 (home-page "http://bitbucket.org/zzzeek/alembic")
4768 (synopsis
4769 "Database migration tool for SQLAlchemy")
4770 (description
4771 "Alembic is a lightweight database migration tool for usage with the
4772 SQLAlchemy Database Toolkit for Python.")
4773 (license license:expat)))
4774
4775 (define-public python2-alembic
4776 (package-with-python2 python-alembic))
4777
4778 (define-public python-autopep8
4779 (package
4780 (name "python-autopep8")
4781 (version "1.2.4")
4782 (source
4783 (origin
4784 (method url-fetch)
4785 (uri (pypi-uri "autopep8" version))
4786 (sha256
4787 (base32
4788 "18parm383lfn42a00wklv3qf20p4v277f1x3cn58x019dqk1xqrq"))))
4789 (build-system python-build-system)
4790 (propagated-inputs
4791 `(("python-pep8" ,python-pep8)))
4792 (home-page "https://github.com/hhatto/autopep8")
4793 (synopsis "Format Python code according to the PEP 8 style guide")
4794 (description
4795 "@code{autopep8} automatically formats Python code to conform to
4796 the PEP 8 style guide. It uses the pycodestyle utility to determine
4797 what parts of the code needs to be formatted. @code{autopep8} is
4798 capable of fixing most of the formatting issues that can be reported
4799 by pycodestyle.")
4800 (license (license:non-copyleft
4801 "https://github.com/hhatto/autopep8/blob/master/LICENSE"))))
4802
4803 (define-public python2-autopep8
4804 (package-with-python2 python-autopep8))
4805
4806 (define-public python-distutils-extra
4807 (package
4808 (name "python-distutils-extra")
4809 (version "2.38")
4810 (source
4811 (origin
4812 (method url-fetch)
4813 (uri (string-append "https://launchpad.net/python-distutils-extra/trunk/"
4814 version "/+download/python-distutils-extra-"
4815 version ".tar.gz"))
4816 (sha256
4817 (base32
4818 "0lx15kcbby9zisx33p2h5hgakgwh2bvh0ibag8z0px4j6ifhs41x"))))
4819 (build-system python-build-system)
4820 (home-page "https://launchpad.net/python-distutils-extra/")
4821 (synopsis "Enhancements to Python's distutils")
4822 (description
4823 "The python-distutils-extra module enables you to easily integrate
4824 gettext support, themed icons, and scrollkeeper-based documentation into
4825 Python's distutils.")
4826 (license license:gpl2)))
4827
4828 (define-public python2-distutils-extra
4829 (package-with-python2 python-distutils-extra))
4830
4831 (define-public python2-elib.intl
4832 (package
4833 (name "python2-elib.intl")
4834 (version "0.0.3")
4835 (source
4836 (origin
4837 ;; This project doesn't tag releases or publish tarballs, so we take
4838 ;; source from a (semi-arbitrary, i.e. latest as of now) git commit.
4839 (method git-fetch)
4840 (uri (git-reference
4841 (url "https://github.com/dieterv/elib.intl.git")
4842 (commit "d09997cfef")))
4843 (sha256
4844 (base32
4845 "0y7vzff9xgbnaay7m0va1arl6g68ncwrvbgwl7jqlclsahzzb09d"))))
4846 (build-system python-build-system)
4847 (arguments
4848 ;; incompatible with Python 3 (exception syntax)
4849 `(#:python ,python-2
4850 #:tests? #f))
4851 (home-page "https://github.com/dieterv/elib.intl")
4852 (synopsis "Enhanced internationalization for Python")
4853 (description
4854 "The elib.intl module provides enhanced internationalization (I18N)
4855 services for your Python modules and applications.")
4856 (license license:lgpl3+)))
4857
4858 (define-public python-pillow
4859 (package
4860 (name "python-pillow")
4861 (version "3.3.3")
4862 (source
4863 (origin
4864 (method url-fetch)
4865 (uri (pypi-uri "Pillow" version))
4866 (patches (search-patches "python-pillow-freetype-2.7-test-failure.patch"))
4867 (sha256
4868 (base32
4869 "0xkv0p1d73gz0a1qaasf0ai4262g8f334j07vd60bjrxs2wr3nmj"))))
4870 (build-system python-build-system)
4871 (native-inputs
4872 `(("python-nose" ,python-nose)))
4873 (inputs
4874 `(("freetype" ,freetype)
4875 ("lcms" ,lcms)
4876 ("zlib" ,zlib)
4877 ("libjpeg" ,libjpeg)
4878 ("openjpeg" ,openjpeg)
4879 ("libtiff" ,libtiff)
4880 ("libwebp" ,libwebp)))
4881 (arguments
4882 `(#:phases (modify-phases %standard-phases
4883 (add-after
4884 'install 'check-installed
4885 (lambda* (#:key outputs inputs #:allow-other-keys)
4886 (begin
4887 (setenv "HOME" (getcwd))
4888 ;; Make installed package available for running the
4889 ;; tests
4890 (add-installed-pythonpath inputs outputs)
4891 (and (zero? (system* "python" "selftest.py"
4892 "--installed"))
4893 (zero? (system* "python" "test-installed.py"))))))
4894 (delete 'check))))
4895 (home-page "https://pypi.python.org/pypi/Pillow")
4896 (synopsis "Fork of the Python Imaging Library")
4897 (description
4898 "The Python Imaging Library adds image processing capabilities to your
4899 Python interpreter. This library provides extensive file format support, an
4900 efficient internal representation, and fairly powerful image processing
4901 capabilities. The core image library is designed for fast access to data
4902 stored in a few basic pixel formats. It should provide a solid foundation for
4903 a general image processing tool.")
4904 (license (license:x11-style
4905 "http://www.pythonware.com/products/pil/license.htm"
4906 "The PIL Software License"))))
4907
4908 (define-public python2-pillow
4909 (package-with-python2 python-pillow))
4910
4911 (define-public python-pycparser
4912 (package
4913 (name "python-pycparser")
4914 (version "2.17")
4915 (source
4916 (origin
4917 (method url-fetch)
4918 (uri (pypi-uri "pycparser" version))
4919 (sha256
4920 (base32
4921 "1dkkjri0miidqb1zcqhqljfa34fcy9k5akasgwsv6k622zlk3b0a"))))
4922 (outputs '("out" "doc"))
4923 (build-system python-build-system)
4924 (native-inputs
4925 `(("pkg-config" ,pkg-config)))
4926 (arguments
4927 `(#:phases
4928 (modify-phases %standard-phases
4929 (replace 'check
4930 (lambda _
4931 (with-directory-excursion "tests"
4932 (zero? (system* "python" "all_tests.py")))))
4933 (add-after 'install 'install-doc
4934 (lambda* (#:key outputs #:allow-other-keys)
4935 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
4936 (doc (string-append data "/doc/" ,name "-" ,version))
4937 (examples (string-append doc "/examples")))
4938 (mkdir-p examples)
4939 (for-each (lambda (file)
4940 (copy-file (string-append "." file)
4941 (string-append doc file)))
4942 '("/README.rst" "/CHANGES" "/LICENSE"))
4943 (copy-recursively "examples" examples)))))))
4944 (home-page "https://github.com/eliben/pycparser")
4945 (synopsis "C parser in Python")
4946 (description
4947 "Pycparser is a complete parser of the C language, written in pure Python
4948 using the PLY parsing library. It parses C code into an AST and can serve as
4949 a front-end for C compilers or analysis tools.")
4950 (license license:bsd-3)))
4951
4952 (define-public python2-pycparser
4953 (package-with-python2 python-pycparser))
4954
4955 (define-public python-cffi
4956 (package
4957 (name "python-cffi")
4958 (version "1.10.0")
4959 (source
4960 (origin
4961 (method url-fetch)
4962 (uri (pypi-uri "cffi" version))
4963 (sha256
4964 (base32 "1mffyilq4qycm8gs4wkgb18rnqil8a9blqq77chdlshzxc8jkc5k"))))
4965 (build-system python-build-system)
4966 (outputs '("out" "doc"))
4967 (inputs
4968 `(("libffi" ,libffi)))
4969 (propagated-inputs ; required at run-time
4970 `(("python-pycparser" ,python-pycparser)))
4971 (native-inputs
4972 `(("pkg-config" ,pkg-config)
4973 ("python-sphinx" ,python-sphinx)
4974 ("python-pytest" ,python-pytest)))
4975 (arguments
4976 `(#:modules ((ice-9 ftw)
4977 (srfi srfi-26)
4978 (guix build utils)
4979 (guix build python-build-system))
4980 #:phases
4981 (modify-phases %standard-phases
4982 (replace 'check
4983 (lambda _
4984 (setenv "PYTHONPATH"
4985 (string-append
4986 (getenv "PYTHONPATH")
4987 ":" (getcwd) "/build/"
4988 (car (scandir "build" (cut string-prefix? "lib." <>)))))
4989
4990 ;; XXX The "normal" approach of setting CC and friends does
4991 ;; not work here. Is this the correct way of doing things?
4992 (substitute* "testing/embedding/test_basic.py"
4993 (("c = distutils\\.ccompiler\\.new_compiler\\(\\)")
4994 (string-append "c = distutils.ccompiler.new_compiler();"
4995 "c.set_executables(compiler='gcc',"
4996 "compiler_so='gcc',linker_exe='gcc',"
4997 "linker_so='gcc -shared')")))
4998 (substitute* "testing/cffi0/test_ownlib.py"
4999 (("'cc testownlib") "'gcc testownlib"))
5000 (zero? (system* "py.test" "-v" "c/" "testing/"))))
5001 (add-after 'install 'install-doc
5002 (lambda* (#:key outputs #:allow-other-keys)
5003 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5004 (doc (string-append data "/doc/" ,name "-" ,version))
5005 (html (string-append doc "/html")))
5006 (with-directory-excursion "doc"
5007 (system* "make" "html")
5008 (mkdir-p html)
5009 (copy-recursively "build/html" html))
5010 (copy-file "LICENSE" (string-append doc "/LICENSE"))
5011 #t))))))
5012 (home-page "http://cffi.readthedocs.org")
5013 (synopsis "Foreign function interface for Python")
5014 (description
5015 "Foreign Function Interface for Python calling C code.")
5016 (license license:expat)))
5017
5018 (define-public python2-cffi
5019 (package-with-python2 python-cffi))
5020
5021 (define-public python-xcffib
5022 (package
5023 (name "python-xcffib")
5024 (version "0.5.1")
5025 (source
5026 (origin
5027 (method url-fetch)
5028 (uri (pypi-uri "xcffib" version))
5029 (sha256
5030 (base32
5031 "09gbnmr5vn58mm8xi3fmd7fz6743cks6c46dphnxzwax6zsxmy60"))))
5032 (build-system python-build-system)
5033 (inputs
5034 `(("libxcb" ,libxcb)))
5035 (propagated-inputs
5036 `(("python-cffi" ,python-cffi) ; used at run time
5037 ("python-six" ,python-six)))
5038 (arguments
5039 `(;; FIXME: Tests need more work. See ".travis.yml" in the repository.
5040 #:tests? #f
5041 #:phases
5042 (modify-phases %standard-phases
5043 (add-after 'unpack 'fix-libxcb-path
5044 (lambda* (#:key inputs #:allow-other-keys)
5045 (let ((libxcb (assoc-ref inputs "libxcb")))
5046 (substitute* '("xcffib/__init__.py")
5047 (("^soname = \"") (string-append "soname = \"" libxcb "/lib/")))
5048 #t)))
5049 (add-after 'install 'install-doc
5050 (lambda* (#:key outputs #:allow-other-keys)
5051 (let ((doc (string-append (assoc-ref outputs "out") "/share"
5052 "/doc/" ,name "-" ,version)))
5053 (mkdir-p doc)
5054 (copy-file "README.md"
5055 (string-append doc "/README.md"))
5056 #t))))))
5057 (home-page "https://github.com/tych0/xcffib")
5058 (synopsis "XCB Python bindings")
5059 (description
5060 "Xcffib is a replacement for xpyb, an XCB Python bindings. It adds
5061 support for Python 3 and PyPy. It is based on cffi.")
5062 (license license:expat)))
5063
5064 (define-public python2-xcffib
5065 (package-with-python2 python-xcffib))
5066
5067 (define-public python-cairocffi
5068 (package
5069 (name "python-cairocffi")
5070 (version "0.8.0")
5071 (source
5072 (origin
5073 (method url-fetch)
5074 ;; The archive on pypi is missing the 'utils' directory!
5075 (uri (string-append "https://github.com/Kozea/cairocffi/archive/v"
5076 version ".tar.gz"))
5077 (file-name (string-append name "-" version ".tar.gz"))
5078 (sha256
5079 (base32
5080 "1rk2dvy3fxrga6bvvxc2fi5lbaynm5h4a0w0aaxyn3bc77rszjg9"))))
5081 (build-system python-build-system)
5082 (outputs '("out" "doc"))
5083 (inputs
5084 `(("gdk-pixbuf" ,gdk-pixbuf)
5085 ("cairo" ,cairo)))
5086 (native-inputs
5087 `(("pkg-config" ,pkg-config)
5088 ("python-sphinx" ,python-sphinx)
5089 ("python-docutils" ,python-docutils)))
5090 (propagated-inputs
5091 `(("python-xcffib" ,python-xcffib))) ; used at run time
5092 (arguments
5093 `(;; FIXME: Tests cannot find 'libcairo.so.2'.
5094 #:tests? #f
5095 #:phases
5096 (modify-phases %standard-phases
5097 (add-after 'install 'install-doc
5098 (lambda* (#:key inputs outputs #:allow-other-keys)
5099 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5100 (doc (string-append data "/doc/" ,name "-" ,version))
5101 (html (string-append doc "/html")))
5102 (setenv "LD_LIBRARY_PATH"
5103 (string-append (assoc-ref inputs "cairo") "/lib" ":"
5104 (assoc-ref inputs "gdk-pixbuf") "/lib"))
5105 (setenv "LANG" "en_US.UTF-8")
5106 (mkdir-p html)
5107 (for-each (lambda (file)
5108 (copy-file (string-append "." file)
5109 (string-append doc file)))
5110 '("/README.rst" "/CHANGES" "/LICENSE"))
5111 (system* "python" "setup.py" "build_sphinx")
5112 (copy-recursively "docs/_build/html" html)
5113 #t))))))
5114 (home-page "https://github.com/Kozea/cairocffi")
5115 (synopsis "Python bindings and object-oriented API for Cairo")
5116 (description
5117 "Cairocffi is a CFFI-based drop-in replacement for Pycairo, a set of
5118 Python bindings and object-oriented API for cairo. Cairo is a 2D vector
5119 graphics library with support for multiple backends including image buffers,
5120 PNG, PostScript, PDF, and SVG file output.")
5121 (license license:bsd-3)))
5122
5123 (define-public python2-cairocffi
5124 (package-with-python2 python-cairocffi))
5125
5126 (define-public python-decorator
5127 (package
5128 (name "python-decorator")
5129 (version "4.0.10")
5130 (source
5131 (origin
5132 (method url-fetch)
5133 (uri (pypi-uri "decorator" version))
5134 (sha256
5135 (base32 "0w7hg59hlpq74jpyja4yfryap0ccjvchgpkfp20rhj9krgnrhvlw"))))
5136 (build-system python-build-system)
5137 (arguments '(#:tests? #f)) ; no test target
5138 (home-page "https://pypi.python.org/pypi/decorator/")
5139 (synopsis "Python module to simplify usage of decorators")
5140 (description
5141 "The aim of the decorator module is to simplify the usage of decorators
5142 for the average programmer, and to popularize decorators usage giving examples
5143 of useful decorators, such as memoize, tracing, redirecting_stdout, locked,
5144 etc. The core of this module is a decorator factory.")
5145 (license license:expat)))
5146
5147 (define-public python2-decorator
5148 (package-with-python2 python-decorator))
5149
5150 (define-public python-drmaa
5151 (package
5152 (name "python-drmaa")
5153 (version "0.7.7")
5154 (source
5155 (origin
5156 (method url-fetch)
5157 (uri (pypi-uri "drmaa" version))
5158 (sha256
5159 (base32 "0xzqriqyvk5b8hszbavsyxd29wm3sxirm8zvvdm73rs2iq7w4hkx"))))
5160 (build-system python-build-system)
5161 ;; The test suite requires libdrmaa which is provided by the cluster
5162 ;; environment. At runtime the environment variable DRMAA_LIBRARY_PATH
5163 ;; should be set to the path of the libdrmaa library.
5164 (arguments '(#:tests? #f))
5165 (native-inputs
5166 `(("python-nose" ,python-nose)))
5167 (home-page "https://pypi.python.org/pypi/drmaa")
5168 (synopsis "Python bindings for the DRMAA library")
5169 (description
5170 "A Python package for Distributed Resource Management (DRM) job
5171 submission and control. This package is an implementation of the DRMAA 1.0
5172 Python language binding specification.")
5173 (license license:bsd-3)))
5174
5175 (define-public python2-drmaa
5176 (package-with-python2 python-drmaa))
5177
5178 (define-public python-gridmap
5179 (package
5180 (name "python-gridmap")
5181 (version "0.13.0")
5182 (source
5183 (origin
5184 (method url-fetch)
5185 (uri (string-append
5186 "https://github.com/pygridtools/gridmap/archive/v"
5187 version ".tar.gz"))
5188 (file-name (string-append name "-" version ".tar.gz"))
5189 (sha256
5190 (base32 "1gzjg2k6f14i1msm2b0ax8d9ds1hvk6qd5nlaivg8m4cxqp4cp1x"))))
5191 (build-system python-build-system)
5192 (arguments
5193 '(#:tests? #f)) ; FIXME: Requires python-cherrypy.
5194 (propagated-inputs
5195 `(("python-psutil" ,python-psutil)
5196 ("python-drmaa" ,python-drmaa)
5197 ("python-pyzmq" ,python-pyzmq)))
5198 (home-page "https://github.com/pygridtools/gridmap")
5199 (synopsis "Create jobs on a cluster directly from Python")
5200 (description
5201 "Gridmap is a Python package to allow you to easily create jobs on the
5202 cluster directly from Python. You can directly map Python functions onto the
5203 cluster without needing to write any wrapper code yourself.")
5204 (license license:gpl3+)))
5205
5206 (define-public python2-gridmap
5207 (package-with-python2 python-gridmap))
5208
5209 (define-public python-pexpect
5210 (package
5211 (name "python-pexpect")
5212 (version "4.2.1")
5213 (source
5214 (origin
5215 (method url-fetch)
5216 (uri (pypi-uri "pexpect" version))
5217 (sha256
5218 (base32 "14ls7k99pwvl21zqv65kzrhccv50j89m5ij1hf0slmsvlxjj84rx"))))
5219 (build-system python-build-system)
5220 (arguments
5221 `(#:phases
5222 (modify-phases %standard-phases
5223 (add-before 'check 'prepare-tests
5224 (lambda _
5225 (substitute* (find-files "tests")
5226 (("/bin/ls") (which "ls"))
5227 (("/bin/echo") (which "echo"))
5228 (("/bin/which") (which "which"))
5229 ;; Many tests try to use the /bin directory which
5230 ;; is not present in the build environment.
5231 ;; Use one that's non-empty and unlikely to change.
5232 (("/bin'") "/dev'"))
5233 ;; XXX: Socket connection test gets "Connection reset by peer".
5234 ;; Why does it not work? Delete for now.
5235 (delete-file "tests/test_socket.py")
5236 #t))
5237 (replace 'check (lambda _ (zero? (system* "nosetests" "-v")))))))
5238 (native-inputs
5239 `(("python-nose" ,python-nose)
5240 ("python-pytest" ,python-pytest-3.0)
5241 ("man-db" ,man-db)
5242 ("which" ,which)))
5243 (propagated-inputs
5244 `(("python-ptyprocess" ,python-ptyprocess)))
5245 (home-page "http://pexpect.readthedocs.org/")
5246 (synopsis "Controlling interactive console applications")
5247 (description
5248 "Pexpect is a pure Python module for spawning child applications;
5249 controlling them; and responding to expected patterns in their output.
5250 Pexpect works like Don Libes’ Expect. Pexpect allows your script to spawn a
5251 child application and control it as if a human were typing commands.")
5252 (license license:isc)))
5253
5254 (define-public python2-pexpect
5255 (package-with-python2 python-pexpect))
5256
5257 (define-public python-setuptools-scm
5258 (package
5259 (name "python-setuptools-scm")
5260 (version "1.15.0")
5261 (source (origin
5262 (method url-fetch)
5263 (uri (pypi-uri "setuptools_scm" version))
5264 (sha256
5265 (base32
5266 "0bwyc5markib0i7i2qlyhdzxhiywzxbkfiapldma8m91m82jvwfs"))))
5267 (build-system python-build-system)
5268 (home-page "https://github.com/pypa/setuptools_scm/")
5269 (synopsis "Manage Python package versions in SCM metadata")
5270 (description
5271 "Setuptools_scm handles managing your Python package versions in
5272 @dfn{software configuration management} (SCM) metadata instead of declaring
5273 them as the version argument or in a SCM managed file.")
5274 (license license:expat)))
5275
5276 (define-public python2-setuptools-scm
5277 (package-with-python2 python-setuptools-scm))
5278
5279 (define-public python-pathpy
5280 (package
5281 (name "python-pathpy")
5282 (version "8.1.1")
5283 (source
5284 (origin
5285 (method url-fetch)
5286 (uri (string-append "https://pypi.python.org/packages/source/p/"
5287 "path.py/path.py-" version ".tar.gz"))
5288 (sha256
5289 (base32 "1p8s1l2vfkqhqxdhqlj0g1jjw4f1as2frr35sjcpjjpd5a89y41f"))))
5290 (outputs '("out" "doc"))
5291 (build-system python-build-system)
5292 (propagated-inputs
5293 `(("python-appdirs" ,python-appdirs)))
5294 (native-inputs
5295 `(("python-setuptools-scm" ,python-setuptools-scm)
5296 ("python-sphinx" ,python-sphinx)
5297 ("python-rst.linker" ,python-rst.linker)
5298 ("python-pytest" ,python-pytest)
5299 ("python-pytest-runner" ,python-pytest-runner)))
5300 (arguments
5301 `(#:phases
5302 (modify-phases %standard-phases
5303 (add-after 'build 'build-doc
5304 (lambda _
5305 (setenv "LANG" "en_US.UTF-8")
5306 (zero? (system* "python" "setup.py" "build_sphinx"))))
5307 (add-after 'install 'install-doc
5308 (lambda* (#:key outputs #:allow-other-keys)
5309 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5310 (doc (string-append data "/doc/" ,name "-" ,version))
5311 (html (string-append doc "/html")))
5312 (mkdir-p html)
5313 (for-each (lambda (file)
5314 (copy-file file (string-append doc "/" file)))
5315 '("README.rst" "CHANGES.rst"))
5316 (copy-recursively "build/sphinx/html" html)))))))
5317 (home-page "https://github.com/jaraco/path.py")
5318 (synopsis "Python module wrapper for built-in os.path")
5319 (description
5320 "@code{path.py} implements path objects as first-class entities, allowing
5321 common operations on files to be invoked on those path objects directly.")
5322 (license license:expat)))
5323
5324 (define-public python2-pathpy
5325 (package-with-python2 python-pathpy))
5326
5327 (define-public python-pickleshare
5328 (package
5329 (name "python-pickleshare")
5330 (version "0.5")
5331 (source
5332 (origin
5333 (method url-fetch)
5334 (uri (string-append "https://pypi.python.org/packages/source/p/"
5335 "pickleshare/pickleshare-" version ".tar.gz"))
5336 (sha256
5337 (base32 "11ljr90j3p6qswdrbl7p4cjb2i93f6vn0vx9anzpshsx0d2mggn0"))))
5338 (build-system python-build-system)
5339 (propagated-inputs
5340 `(("python-pathpy" ,python-pathpy)))
5341 (home-page "https://github.com/vivainio/pickleshare")
5342 (synopsis "Tiny key value database with concurrency support")
5343 (description
5344 "PickleShare is a small ‘shelve’-like datastore with concurrency support.
5345 Like shelve, a PickleShareDB object acts like a normal dictionary. Unlike
5346 shelve, many processes can access the database simultaneously. Changing a
5347 value in database is immediately visible to other processes accessing the same
5348 database. Concurrency is possible because the values are stored in separate
5349 files. Hence the “database” is a directory where all files are governed by
5350 PickleShare.")
5351 (license license:expat)))
5352
5353 (define-public python2-pickleshare
5354 (package-with-python2 python-pickleshare))
5355
5356 (define-public python-simplegeneric
5357 (package
5358 (name "python-simplegeneric")
5359 (version "0.8.1")
5360 (source
5361 (origin
5362 (method url-fetch)
5363 (uri (string-append "https://pypi.python.org/packages/source/s/"
5364 "simplegeneric/simplegeneric-" version ".zip"))
5365 (sha256
5366 (base32 "0wwi1c6md4vkbcsfsf8dklf3vr4mcdj4mpxkanwgb6jb1432x5yw"))))
5367 (build-system python-build-system)
5368 (native-inputs
5369 `(("unzip" ,unzip)))
5370 (home-page "http://cheeseshop.python.org/pypi/simplegeneric")
5371 (synopsis "Python module for simple generic functions")
5372 (description
5373 "The simplegeneric module lets you define simple single-dispatch generic
5374 functions, akin to Python’s built-in generic functions like @code{len()},
5375 @code{iter()} and so on. However, instead of using specially-named methods,
5376 these generic functions use simple lookup tables, akin to those used by
5377 e.g. @code{pickle.dump()} and other generic functions found in the Python
5378 standard library.")
5379 (license license:zpl2.1)))
5380
5381 (define-public python2-simplegeneric
5382 (package-with-python2 python-simplegeneric))
5383
5384 (define-public python-ipython-genutils
5385 ;; TODO: This package is retired, check if can be removed, see description.
5386 (package
5387 (name "python-ipython-genutils")
5388 (version "0.1.0")
5389 (source
5390 (origin
5391 (method url-fetch)
5392 (uri (string-append "https://pypi.python.org/packages/source/i/"
5393 "ipython_genutils/ipython_genutils-"
5394 version ".tar.gz"))
5395 (sha256
5396 (base32 "19l2pp1c64ansr89l3cqh19jdi2ixhssdzx0vz4n6r52a6i281is"))))
5397 (build-system python-build-system)
5398 (arguments `(#:tests? #f)) ; no tests
5399 (home-page "http://ipython.org")
5400 (synopsis "Vestigial utilities from IPython")
5401 (description
5402 "This package provides retired utilities from IPython. No packages
5403 outside IPython/Jupyter should depend on it.
5404
5405 This package shouldn't exist. It contains some common utilities shared by
5406 Jupyter and IPython projects during The Big Split. As soon as possible, those
5407 packages will remove their dependency on this, and this package will go
5408 away.")
5409 (license license:bsd-3)))
5410
5411 (define-public python2-ipython-genutils
5412 (package-with-python2 python-ipython-genutils))
5413
5414 (define-public python-traitlets
5415 (package
5416 (name "python-traitlets")
5417 (version "4.2.0")
5418 (source
5419 (origin
5420 (method url-fetch)
5421 (uri (pypi-uri "traitlets" version))
5422 (sha256
5423 (base32
5424 "1afy08sa5n9gnkvh3da49c16zkyv598vchv0p1hp7zzjy8895hz4"))))
5425 (build-system python-build-system)
5426 (arguments
5427 `(#:phases
5428 (modify-phases %standard-phases
5429 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
5430 (propagated-inputs
5431 `(("python-ipython-genutils" ,python-ipython-genutils)
5432 ("python-decorator" ,python-decorator)))
5433 (native-inputs
5434 `(("python-mock" ,python-mock)
5435 ("python-nose" ,python-nose)))
5436 (home-page "http://ipython.org")
5437 (synopsis "Configuration system for Python applications")
5438 (description
5439 "Traitlets is a framework that lets Python classes have attributes with
5440 type checking, dynamically calculated default values, and ‘on change’
5441 callbacks. The package also includes a mechanism to use traitlets for
5442 configuration, loading values from files or from command line arguments. This
5443 is a distinct layer on top of traitlets, so you can use traitlets in your code
5444 without using the configuration machinery.")
5445 (license license:bsd-3)))
5446
5447 (define-public python2-traitlets
5448 (package-with-python2 python-traitlets))
5449
5450 (define-public python-jupyter-core
5451 (package
5452 (name "python-jupyter-core")
5453 (version "4.2.1")
5454 (source
5455 (origin
5456 (method url-fetch)
5457 (uri (string-append (pypi-uri "jupyter_core" version)))
5458 (sha256
5459 (base32
5460 "1cy7inv218dgh4m1fbzbsiqpz733ylgjrj62jxqpfzs3r2cm7ic9"))))
5461 (build-system python-build-system)
5462 ;; FIXME: not sure how to run the tests
5463 (arguments `(#:tests? #f))
5464 (propagated-inputs
5465 `(("python-traitlets" ,python-traitlets)))
5466 (home-page "http://jupyter.org/")
5467 (synopsis "Jupyter base package")
5468 (description
5469 "Jupyter core is the base package on which Jupyter projects rely.")
5470 (license license:bsd-3)))
5471
5472 (define-public python2-jupyter-core
5473 (package-with-python2 python-jupyter-core))
5474
5475 (define-public python-jupyter-client
5476 (package
5477 (name "python-jupyter-client")
5478 (version "4.4.0")
5479 (source
5480 (origin
5481 (method url-fetch)
5482 (uri (pypi-uri "jupyter_client" version))
5483 (sha256
5484 (base32
5485 "1vjjrpjw7k5sh982pbjnslv7byfbfazjw9g92jvs7dz5qbx556n9"))))
5486 (build-system python-build-system)
5487 ;; Tests fail because of missing native python kernel which I assume is
5488 ;; provided by the ipython package, which we cannot use because it would
5489 ;; cause a dependency cycle.
5490 (arguments `(#:tests? #f))
5491 (propagated-inputs
5492 `(("python-pyzmq" ,python-pyzmq)
5493 ("python-traitlets" ,python-traitlets)
5494 ("python-jupyter-core" ,python-jupyter-core)))
5495 (home-page "http://jupyter.org/")
5496 (synopsis "Jupyter protocol implementation and client libraries")
5497 (description
5498 "The @code{jupyter_client} package contains the reference implementation
5499 of the Jupyter protocol. It also provides client and kernel management APIs
5500 for working with kernels, and the @code{jupyter kernelspec} entrypoint for
5501 installing @code{kernelspec}s for use with Jupyter frontends.")
5502 (license license:bsd-3)))
5503
5504 (define-public python2-jupyter-client
5505 (package-with-python2 python-jupyter-client))
5506
5507 (define-public python-ipykernel
5508 (package
5509 (name "python-ipykernel")
5510 (version "4.5.2")
5511 (source
5512 (origin
5513 (method url-fetch)
5514 (uri (pypi-uri "ipykernel" version))
5515 (sha256
5516 (base32 "0qllv0k6zzv1r1cj1x2ygxmlrrqhbslzj8rc6r6fg3kc1rgz4m2s"))))
5517 (build-system python-build-system)
5518 ;; The tests load a submodule of IPython. However, IPython itself depends
5519 ;; on ipykernel.
5520 (arguments `(#:tests? #f))
5521 (propagated-inputs
5522 ;; imported at runtime during connect
5523 `(("python-jupyter-client" ,python-jupyter-client)))
5524 (home-page "http://ipython.org")
5525 (synopsis "IPython Kernel for Jupyter")
5526 (description
5527 "This package provides the IPython kernel for Jupyter.")
5528 (license license:bsd-3)))
5529
5530 (define-public python2-ipykernel
5531 (package-with-python2 python-ipykernel))
5532
5533 (define-public python-testpath
5534 (package
5535 (name "python-testpath")
5536 (version "0.2")
5537 (source
5538 (origin
5539 (method url-fetch)
5540 (uri (string-append "https://github.com/jupyter/testpath/archive/"
5541 version ".tar.gz"))
5542 (file-name (string-append name "-" version ".tar.gz"))
5543 (sha256
5544 (base32
5545 "04kh3fgvmqz6cfcw79q70qwjz7ib7lxm27cc548iy2rpr33qqf55"))))
5546 (build-system python-build-system)
5547 (arguments
5548 `(#:tests? #f ; this package does not even have a setup.py
5549 #:modules ((guix build python-build-system)
5550 (guix build utils)
5551 (srfi srfi-1))
5552 #:imported-modules (,@%python-build-system-modules
5553 (srfi srfi-1))
5554 #:phases
5555 (modify-phases %standard-phases
5556 (delete 'install)
5557 (replace 'build
5558 (lambda* (#:key inputs outputs #:allow-other-keys)
5559 (let* ((version (last
5560 (string-split (assoc-ref inputs "python") #\-)))
5561 (x.y (string-join (take (string-split version #\.) 2)
5562 "."))
5563 (dir (string-append
5564 (assoc-ref outputs "out")
5565 "/lib/python" x.y "/site-packages/testpath")))
5566 (mkdir-p dir)
5567 (copy-recursively "testpath" dir))
5568 #t)))))
5569 (home-page "https://github.com/takluyver/testpath")
5570 (synopsis "Test utilities for code working with files and commands")
5571 (description
5572 "Testpath is a collection of utilities for Python code working with files
5573 and commands. It contains functions to check things on the filesystem, and
5574 tools for mocking system commands and recording calls to those.")
5575 (license license:expat)))
5576
5577 (define-public python2-testpath
5578 (package-with-python2 python-testpath))
5579
5580 (define-public python-ipython
5581 (package
5582 (name "python-ipython")
5583 (version "5.2.2")
5584 (source
5585 (origin
5586 (method url-fetch)
5587 (uri (pypi-uri "ipython" version ".tar.gz"))
5588 (sha256
5589 (base32 "1qhjwa9cyz1np7rhv3p4ip13lkgbqsad62l24xkwiq1ic2gwiqbf"))))
5590 (build-system python-build-system)
5591 (outputs '("out" "doc"))
5592 (propagated-inputs
5593 `(("python-pyzmq" ,python-pyzmq)
5594 ("python-prompt-toolkit" ,python-prompt-toolkit)
5595 ("python-terminado" ,python-terminado)
5596 ("python-matplotlib" ,python-matplotlib)
5597 ("python-numpy" ,python-numpy)
5598 ("python-numpydoc" ,python-numpydoc)
5599 ("python-jinja2" ,python-jinja2)
5600 ("python-mistune" ,python-mistune)
5601 ("python-pexpect" ,python-pexpect)
5602 ("python-pickleshare" ,python-pickleshare)
5603 ("python-simplegeneric" ,python-simplegeneric)
5604 ("python-jsonschema" ,python-jsonschema)
5605 ("python-traitlets" ,python-traitlets)
5606 ("python-ipykernel" ,python-ipykernel)
5607 ("python-nbformat" ,python-nbformat)
5608 ("python-pygments" ,python-pygments)))
5609 (inputs
5610 `(("readline" ,readline)
5611 ("which" ,which)))
5612 (native-inputs
5613 `(("graphviz" ,graphviz)
5614 ("pkg-config" ,pkg-config)
5615 ("python-requests" ,python-requests) ;; for tests
5616 ("python-testpath" ,python-testpath)
5617 ("python-nose" ,python-nose)
5618 ("python-sphinx" ,python-sphinx)
5619 ("python-shpinx-rtd-theme" ,python-sphinx-rtd-theme)
5620 ;; FIXME: It's possible that a smaller union would work just as well.
5621 ("texlive" ,(texlive-union (list texlive-fonts-amsfonts
5622 texlive-fonts-ec
5623 texlive-generic-ifxetex
5624 texlive-generic-pdftex
5625 texlive-latex-amsfonts
5626 texlive-latex-capt-of
5627 texlive-latex-cmap
5628 texlive-latex-environ
5629 texlive-latex-eqparbox
5630 texlive-latex-etoolbox
5631 texlive-latex-expdlist
5632 texlive-latex-fancyhdr
5633 texlive-latex-fancyvrb
5634 texlive-latex-fncychap
5635 texlive-latex-float
5636 texlive-latex-framed
5637 texlive-latex-geometry
5638 texlive-latex-graphics
5639 texlive-latex-hyperref
5640 texlive-latex-mdwtools
5641 texlive-latex-multirow
5642 texlive-latex-oberdiek
5643 texlive-latex-parskip
5644 texlive-latex-preview
5645 texlive-latex-tabulary
5646 texlive-latex-threeparttable
5647 texlive-latex-titlesec
5648 texlive-latex-trimspaces
5649 texlive-latex-ucs
5650 texlive-latex-upquote
5651 texlive-latex-url
5652 texlive-latex-varwidth
5653 texlive-latex-wrapfig)))
5654 ("texinfo" ,texinfo)))
5655 (arguments
5656 `(#:phases
5657 (modify-phases %standard-phases
5658 (add-after
5659 'install 'install-doc
5660 (lambda* (#:key inputs outputs #:allow-other-keys)
5661 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5662 (doc (string-append data "/doc/" ,name "-" ,version))
5663 (html (string-append doc "/html"))
5664 (man1 (string-append data "/man/man1"))
5665 (info (string-append data "/info"))
5666 (examples (string-append doc "/examples"))
5667 (python-arg (string-append "PYTHON=" (which "python"))))
5668 (setenv "LANG" "en_US.utf8")
5669 ;; Make installed package available for running the tests
5670 (add-installed-pythonpath inputs outputs)
5671 (with-directory-excursion "docs"
5672 ;; FIXME: pdf fails to build
5673 ;;(system* "make" "pdf" "PAPER=a4")
5674 (system* "make" python-arg "html")
5675 (system* "make" python-arg "info"))
5676 (copy-recursively "docs/man" man1)
5677 (copy-recursively "examples" examples)
5678 (copy-recursively "docs/build/html" html)
5679 ;; (copy-file "docs/build/latex/ipython.pdf"
5680 ;; (string-append doc "/ipython.pdf"))
5681 (mkdir-p info)
5682 (copy-file "docs/build/texinfo/ipython.info"
5683 (string-append info "/ipython.info"))
5684 (copy-file "COPYING.rst" (string-append doc "/COPYING.rst")))))
5685 ;; Tests can only be run after the library has been installed and not
5686 ;; within the source directory.
5687 (delete 'check)
5688 (add-after
5689 'install 'check
5690 (lambda* (#:key inputs outputs tests? #:allow-other-keys)
5691 (if tests?
5692 (with-directory-excursion "/tmp"
5693 ;; Make installed package available for running the tests
5694 (add-installed-pythonpath inputs outputs)
5695 (setenv "HOME" "/tmp/") ;; required by a test
5696 (zero? (system* (string-append (assoc-ref outputs "out")
5697 "/bin/iptest"))))
5698 #t)))
5699 (add-before
5700 'install 'fix-tests
5701 (lambda* (#:key inputs #:allow-other-keys)
5702 (substitute* "./IPython/utils/_process_posix.py"
5703 (("/usr/bin/env', 'which") (which "which")))
5704 (substitute* "./IPython/core/tests/test_inputtransformer.py"
5705 (("#!/usr/bin/env python")
5706 (string-append "#!" (which "python"))))
5707 ;; Disable 1 failing test
5708 (substitute* "./IPython/core/tests/test_magic.py"
5709 (("def test_dirops\\(\\):" all)
5710 (string-append "@dec.skipif(True)\n" all))))))))
5711 (home-page "http://ipython.org")
5712 (synopsis "IPython is a tool for interactive computing in Python")
5713 (description
5714 "IPython provides a rich architecture for interactive computing with:
5715 Powerful interactive shells, a browser-based notebook, support for interactive
5716 data visualization, embeddable interpreters and tools for parallel
5717 computing.")
5718 (license license:bsd-3)
5719 (properties `((python2-variant . ,(delay python2-ipython))))))
5720
5721 (define-public python2-ipython
5722 (let ((ipython (package-with-python2 (strip-python2-variant python-ipython))))
5723 (package
5724 (inherit ipython)
5725 ;; FIXME: add pyreadline once available.
5726 (propagated-inputs
5727 `(("python2-backports-shutil-get-terminal-size"
5728 ,python2-backports-shutil-get-terminal-size)
5729 ("python2-pathlib2" ,python2-pathlib2)
5730 ,@(package-propagated-inputs ipython)))
5731 (native-inputs
5732 `(("python2-mock" ,python2-mock)
5733 ,@(package-native-inputs ipython))))))
5734
5735 (define-public python-isodate
5736 (package
5737 (name "python-isodate")
5738 (version "0.5.4")
5739 (source
5740 (origin
5741 (method url-fetch)
5742 (uri (pypi-uri "isodate" version))
5743 (sha256
5744 (base32
5745 "0cafaiwixgpxwh9dsd28qb0dbzsj6xpxjdkyk30ns91ps10mq422"))))
5746 (build-system python-build-system)
5747 (home-page
5748 "http://cheeseshop.python.org/pypi/isodate")
5749 (synopsis
5750 "Python date parser and formatter")
5751 (description
5752 "Python-isodate is a python module for parsing and formatting
5753 ISO 8601 dates, time and duration.")
5754 (license license:bsd-3)))
5755
5756 (define-public python2-isodate
5757 (package-with-python2 python-isodate))
5758
5759 (define-public python-html5lib
5760 (package
5761 (name "python-html5lib")
5762 (version "1.0b10")
5763 (source
5764 (origin
5765 (method url-fetch)
5766 (uri (pypi-uri "html5lib" version))
5767 (sha256
5768 (base32
5769 "1yd068a5c00wd0ajq0hqimv7fd82lhrw0w3s01vbhy9bbd6xapqd"))))
5770 (build-system python-build-system)
5771 (propagated-inputs
5772 `(("python-six" ,python-six)
5773 ("python-webencodings" ,python-webencodings)))
5774 (arguments
5775 `(#:test-target "check"))
5776 (home-page
5777 "https://github.com/html5lib/html5lib-python")
5778 (synopsis
5779 "Python HTML parser based on the WHATWG HTML specifcation")
5780 (description
5781 "Html5lib is an HTML parser based on the WHATWG HTML specifcation
5782 and written in Python.")
5783 (license license:expat)))
5784
5785 (define-public python2-html5lib
5786 (package-with-python2 python-html5lib))
5787
5788 ;; Needed for python-bleach, a dependency of python-notebook
5789 (define-public python-html5lib-0.9
5790 (package
5791 (inherit python-html5lib)
5792 (version "0.999")
5793 (source
5794 (origin
5795 (method url-fetch)
5796 (uri (pypi-uri "html5lib" version))
5797 (sha256
5798 (base32
5799 "17n4zfsj6ynmbwdwviywmj8r6nzr3xvfx2zs0xhndmvm51z7z263"))))))
5800
5801 (define-public python2-html5lib-0.9
5802 (package-with-python2 python-html5lib-0.9))
5803
5804 (define-public python-webencodings
5805 (package
5806 (name "python-webencodings")
5807 (version "0.5")
5808 (source (origin
5809 (method url-fetch)
5810 (uri (pypi-uri "webencodings" version))
5811 (sha256
5812 (base32
5813 "015rw7662lkpb9aqiqah2hbizk6w531badqwjpz41rr47glmxid5"))))
5814 (build-system python-build-system)
5815 (arguments
5816 '(#:phases
5817 (modify-phases %standard-phases
5818 (replace 'check
5819 (lambda _
5820 (zero? (system* "py.test" "-v" "webencodings/tests.py")))))))
5821 (native-inputs
5822 `(("python-pytest" ,python-pytest)))
5823 (home-page "https://github.com/SimonSapin/python-webencodings")
5824 (synopsis "Character encoding aliases for legacy web content")
5825 (description
5826 "In order to be compatible with legacy web content when interpreting
5827 something like @code{Content-Type: text/html; charset=latin1}, tools need
5828 to use a particular set of aliases for encoding labels as well as some
5829 overriding rules. For example, @code{US-ASCII} and @code{iso-8859-1} on
5830 the web are actually aliases for @code{windows-1252}, and an @code{UTF-8}
5831 or @code{UTF-16} BOM takes precedence over any other encoding declaration.
5832 The WHATWG @url{https://encoding.spec.whatwg.org/,Encoding} standard
5833 defines all such details so that implementations do not have to
5834 reverse-engineer each other.
5835
5836 This module implements the Encoding standard and has encoding labels and
5837 BOM detection, but the actual implementation for encoders and decoders
5838 is Python’s.")
5839 (license license:bsd-3)))
5840
5841 (define-public python2-webencodings
5842 (package-with-python2 python-webencodings))
5843
5844 (define-public python-urwid
5845 (package
5846 (name "python-urwid")
5847 (version "1.3.1")
5848 (source
5849 (origin
5850 (method url-fetch)
5851 (uri (pypi-uri "urwid" version))
5852 (sha256
5853 (base32
5854 "18cnd1wdjcas08x5qwa5ayw6jsfcn33w4d9f7q3s29fy6qzc1kng"))))
5855 (build-system python-build-system)
5856 (arguments
5857 `(#:phases
5858 (modify-phases %standard-phases
5859 ;; Disable failing test. Bug filed upstream:
5860 ;; https://github.com/wardi/urwid/issues/164
5861 ;; TODO: check again for python-urwid > 1.3.1 or python > 3.4.3.
5862 (add-after 'unpack 'disable-failing-test
5863 (lambda _
5864 (substitute* "urwid/tests/test_event_loops.py"
5865 (("test_remove_watch_file")
5866 "disable_remove_watch_file")))))))
5867 (home-page "http://urwid.org")
5868 (synopsis "Console user interface library for Python")
5869 (description
5870 "Urwid is a curses-based UI/widget library for Python. It includes many
5871 features useful for text console applications.")
5872 (license license:lgpl2.1+)))
5873
5874 (define-public python2-urwid
5875 (let ((python2-urwid (package-with-python2 python-urwid)))
5876 (package
5877 (inherit python2-urwid)
5878 (arguments
5879 (append
5880 '(#:phases
5881 (modify-phases %standard-phases
5882 ;; Disable the vterm tests because of non-deterministic failures
5883 ;; with Python 2. See https://github.com/urwid/urwid/issues/230.
5884 (add-after 'unpack 'delete-test_vterm.py
5885 (delete-file "urwid/tests/test_vterm.py"))))
5886 (package-arguments python-urwid))))))
5887
5888 (define-public python-openid
5889 (package
5890 (name "python-openid")
5891 (version "3.0.10")
5892 (source
5893 (origin
5894 (method url-fetch)
5895 (uri (pypi-uri "python3-openid" version))
5896 (sha256
5897 (base32
5898 "1x3nh3fycqfn43jp5j5pb4q4y2jxp4mdka4absaa3bc0078qd758"))))
5899 (build-system python-build-system)
5900 (arguments
5901 `(#:phases
5902 (modify-phases %standard-phases
5903 (replace 'check
5904 (lambda _
5905 (zero? (system* "./admin/runtests")))))))
5906 (properties `((python2-variant . ,(delay python2-openid))))
5907 (propagated-inputs
5908 `(("python-defusedxml" ,python-defusedxml)))
5909 (native-inputs
5910 `(("python-psycopg2" ,python-psycopg2)
5911 ("python-django" ,python-django)))
5912 (home-page "https://github.com/necaris/python3-openid")
5913 (synopsis "OpenID support for servers and consumers")
5914 (description "This library provides OpenID authentication for Python, both
5915 for clients and servers.")
5916 (license license:asl2.0)))
5917
5918 (define-public python2-openid
5919 (package
5920 (name "python2-openid")
5921 (version "2.2.5")
5922 (source
5923 (origin
5924 (method url-fetch)
5925 (uri (pypi-uri "python-openid" version))
5926 (sha256
5927 (base32
5928 "1vvhxlghjan01snfdc4k7ykd80vkyjgizwgg9bncnin8rqz1ricj"))))
5929 (build-system python-build-system)
5930 (arguments
5931 ;; Python 3 support is in `python3-openid`, a separate package.
5932 `(#:python ,python-2))
5933 (home-page "https://github.com/openid/python-openid")
5934 (synopsis "OpenID support for servers and consumers")
5935 (description "This library provides OpenID authentication for Python, both
5936 for clients and servers.")
5937 (license license:asl2.0)))
5938
5939 (define-public python-urwidtrees
5940 (package
5941 (name "python-urwidtrees")
5942 (version "1.0.2")
5943 (source
5944 (origin
5945 (method url-fetch)
5946 ;; package author intends on distributing via github rather than pypi:
5947 ;; https://github.com/pazz/alot/issues/877#issuecomment-230173331
5948 (uri (string-append "https://github.com/pazz/urwidtrees/archive/"
5949 version ".tar.gz"))
5950 (file-name (string-append name "-" version ".tar.gz"))
5951 (sha256
5952 (base32
5953 "0d30lyd3s2a97rhqfax5w9ssqds2z6aydqx3c6j2c2lk3cb4ngvh"))))
5954 (build-system python-build-system)
5955 (arguments
5956 '(#:tests? #f)) ; no tests
5957 (propagated-inputs `(("python-urwid" ,python-urwid)))
5958 (home-page "https://github.com/pazz/urwidtrees")
5959 (synopsis "Tree widgets for urwid")
5960 (description "Urwidtrees is a Widget Container API for the @code{urwid}
5961 toolkit. Use it to build trees of widgets.")
5962 (license license:gpl3+)))
5963
5964 (define-public python2-urwidtrees
5965 (package-with-python2 python-urwidtrees))
5966
5967 (define-public python-dbus
5968 (package
5969 (name "python-dbus")
5970 (version "1.2.0")
5971 (source
5972 (origin
5973 (method url-fetch)
5974 (uri (string-append
5975 "https://dbus.freedesktop.org/releases/dbus-python/dbus-python-"
5976 version ".tar.gz"))
5977 (sha256
5978 (base32 "1py62qir966lvdkngg0v8k1khsqxwk5m4s8nflpk1agk5f5nqb71"))))
5979 (build-system gnu-build-system)
5980 (arguments
5981 '(#:phases
5982 (modify-phases %standard-phases
5983 (add-before
5984 'check 'pre-check
5985 (lambda _
5986 ;; XXX: For the missing '/etc/machine-id'.
5987 (substitute* "test/run-test.sh"
5988 (("DBUS_FATAL_WARNINGS=1")
5989 "DBUS_FATAL_WARNINGS=0"))
5990 #t)))))
5991 (native-inputs
5992 `(("pkg-config" ,pkg-config)))
5993 (inputs
5994 `(("python" ,python)
5995 ("dbus-glib" ,dbus-glib)))
5996 (synopsis "Python bindings for D-bus")
5997 (description "python-dbus provides bindings for libdbus, the reference
5998 implementation of D-Bus.")
5999 (home-page "http://www.freedesktop.org/wiki/Software/DBusBindings/")
6000 (license license:expat)))
6001
6002 (define-public python2-dbus
6003 (package (inherit python-dbus)
6004 (name "python2-dbus")
6005 (inputs `(("python" ,python-2)
6006 ,@(alist-delete "python"
6007 (package-inputs python-dbus)
6008 equal?)))
6009 ;; FIXME: on Python 2, the test_utf8 fails with:
6010 ;; "ValueError: unichr() arg not in range(0x10000) (narrow Python build)"
6011 (arguments `(#:tests? #f))))
6012
6013 (define-public python-apsw
6014 (package
6015 (name "python-apsw")
6016 (version "3.9.2-r1")
6017 (source
6018 (origin
6019 (method url-fetch)
6020 (uri (pypi-uri "apsw" version))
6021 (sha256
6022 (base32
6023 "0w4jb0wpx785qw42r3h4fh7gl5w2968q48i7gygybsfxck8nzffs"))))
6024 (build-system python-build-system)
6025 (inputs
6026 `(("sqlite" ,sqlite)))
6027 (arguments
6028 `(#:phases
6029 (modify-phases %standard-phases
6030 (delete 'check)
6031 (add-after 'install 'check
6032 (lambda* (#:key inputs outputs #:allow-other-keys)
6033 (add-installed-pythonpath inputs outputs)
6034 (zero? (system* "python" "setup.py" "test")))))))
6035 (home-page "https://github.com/rogerbinns/apsw/")
6036 (synopsis "Another Python SQLite Wrapper")
6037 (description "APSW is a Python wrapper for the SQLite
6038 embedded relational database engine. In contrast to other wrappers such as
6039 pysqlite it focuses on being a minimal layer over SQLite attempting just to
6040 translate the complete SQLite API into Python.")
6041 (license license:zlib)))
6042
6043 (define-public python2-apsw
6044 (package-with-python2 python-apsw))
6045
6046 (define-public python-lxml
6047 (package
6048 (name "python-lxml")
6049 (version "3.6.0")
6050 (source
6051 (origin
6052 (method url-fetch)
6053 (uri (pypi-uri "lxml" version))
6054 (sha256
6055 (base32
6056 "1pvbmiy2m7jwv493kilbghhj2pkh8wy1na3ji350vhzhlwlclx4w"))))
6057 (build-system python-build-system)
6058 (inputs
6059 `(("libxml2" ,libxml2)
6060 ("libxslt" ,libxslt)))
6061 (home-page "http://lxml.de/")
6062 (synopsis
6063 "Python XML processing library")
6064 (description
6065 "The lxml XML toolkit is a Pythonic binding for the C libraries
6066 libxml2 and libxslt.")
6067 (license license:bsd-3))) ; and a few more, see LICENSES.txt
6068
6069 (define-public python2-lxml
6070 (package-with-python2 python-lxml))
6071
6072 ;; beautifulsoup4 has a totally different namespace than 3.x,
6073 ;; and pypi seems to put it under its own name, so I guess we should too
6074 (define-public python-beautifulsoup4
6075 (package
6076 (name "python-beautifulsoup4")
6077 (version "4.5.3")
6078 (source
6079 (origin
6080 (method url-fetch)
6081 (uri (pypi-uri "beautifulsoup4" version))
6082 (sha256
6083 (base32
6084 "0glaw1vyxnbp03fni7h5496n6iib0n5iim4gax1n0ngscs9s075j"))))
6085 (build-system python-build-system)
6086 (arguments
6087 `(#:phases
6088 (modify-phases %standard-phases
6089 ;; The Python 2 source is the definitive source of beautifulsoup4. We
6090 ;; must use this conversion script when building with Python 3. The
6091 ;; conversion script also runs the tests.
6092 ;; For more information, see the file 'convert-py3k' in the source
6093 ;; distribution.
6094 (replace 'check
6095 (lambda _ (zero? (system* "./convert-py3k")))))))
6096 (home-page
6097 "http://www.crummy.com/software/BeautifulSoup/bs4/")
6098 (synopsis
6099 "Python screen-scraping library")
6100 (description
6101 "Beautiful Soup is a Python library designed for rapidly setting up
6102 screen-scraping projects. It offers Pythonic idioms for navigating,
6103 searching, and modifying a parse tree, providing a toolkit for
6104 dissecting a document and extracting what you need. It automatically
6105 converts incoming documents to Unicode and outgoing documents to UTF-8.")
6106 (license license:expat)
6107 (properties `((python2-variant . ,(delay python2-beautifulsoup4))))))
6108
6109 (define-public python2-beautifulsoup4
6110 (package
6111 (inherit (package-with-python2
6112 (strip-python2-variant python-beautifulsoup4)))
6113 (arguments `(#:python ,python-2))))
6114
6115 (define-public python-cssutils
6116 (package
6117 (name "python-cssutils")
6118 (version "1.0.1")
6119 (source
6120 (origin
6121 (method url-fetch)
6122 (uri (pypi-uri "cssutils" version))
6123 (sha256
6124 (base32
6125 "0qwha9x1wml2qmipbcz03gndnlwhzrjdvw9i09si247a90l8p8fq"))))
6126 (build-system python-build-system)
6127 (native-inputs
6128 `(("unzip" ,unzip))) ; for unpacking the source
6129 (arguments
6130 `(#:tests? #f)) ;tests require python-pbr < 1.7.0
6131 (home-page "http://cthedot.de/cssutils/")
6132 (synopsis
6133 "CSS Cascading Style Sheets library for Python")
6134 (description
6135 "Cssutils is a Python package for parsing and building CSS
6136 Cascading Style Sheets. Currently it provides a DOM only and no rendering
6137 options.")
6138 (license license:lgpl3+)))
6139
6140 (define-public python2-cssutils
6141 (package-with-python2 python-cssutils))
6142
6143 (define-public python-cssselect
6144 (package
6145 (name "python-cssselect")
6146 (version "0.9.2")
6147 (source
6148 (origin
6149 (method url-fetch)
6150 (uri (pypi-uri "cssselect" version))
6151 (sha256
6152 (base32
6153 "1xg6gbva1yswghiycmgincv6ab4bn7hpm720ndbj40h8xycmnfvi"))))
6154 (build-system python-build-system)
6155 (arguments
6156 ;; tests fail with message
6157 ;; AttributeError: 'module' object has no attribute 'tests'
6158 `(#:tests? #f))
6159 (home-page
6160 "https://pythonhosted.org/cssselect/")
6161 (synopsis
6162 "CSS3 selector parser and translator to XPath 1.0")
6163 (description
6164 "Cssselect ia a Python module that parses CSS3 Selectors and translates
6165 them to XPath 1.0 expressions. Such expressions can be used in lxml or
6166 another XPath engine to find the matching elements in an XML or HTML document.")
6167 (license license:bsd-3)))
6168
6169 (define-public python2-cssselect
6170 (package-with-python2 python-cssselect))
6171
6172 (define-public python-openid-cla
6173 (package
6174 (name "python-openid-cla")
6175 (version "1.2")
6176 (source
6177 (origin
6178 (method url-fetch)
6179 (uri (pypi-uri "python-openid-cla" version))
6180 (sha256
6181 (base32
6182 "102hy2qisvjxp5s0v9lvwqi4f2dk0dhns40vjgn008yxc7k0h3cr"))))
6183 (build-system python-build-system)
6184 (arguments '(#:tests? #f)) ; No tests.
6185 (home-page "https://github.com/puiterwijk/python-openid-cla/")
6186 (synopsis "Implementation of the OpenID CLA extension for python-openid")
6187 (description "@code{openid-cla} is an implementation of the OpenID
6188 contributor license agreement extension for python-openid.")
6189 (license license:bsd-3)))
6190
6191 (define-public python2-openid-cla
6192 (package-with-python2 python-openid-cla))
6193
6194 (define-public python-openid-teams
6195 (package
6196 (name "python-openid-teams")
6197 (version "1.1")
6198 (source
6199 (origin
6200 (method url-fetch)
6201 (uri (pypi-uri "python-openid-teams" version))
6202 (sha256
6203 (base32
6204 "05zrh78alav24rxkbqlpbad6d3x2nljk6z6j7kflxf3vdqa7w969"))))
6205 (build-system python-build-system)
6206 (arguments '(#:tests? #f)) ; No tests.
6207 (home-page "https://github.com/puiterwijk/python-openid-teams/")
6208 (synopsis "Implementation of the OpenID teams extension for python-openid")
6209 (description
6210 "@code{openid-teams} is an implementation of the OpenID
6211 teams extension for python-openid.")
6212 (license license:bsd-3)))
6213
6214 (define-public python2-openid-teams
6215 (package-with-python2 python-openid-teams))
6216
6217 (define-public python-netifaces
6218 (package
6219 (name "python-netifaces")
6220 (version "0.10.4")
6221 (source
6222 (origin
6223 (method url-fetch)
6224 (uri (string-append
6225 "https://pypi.python.org/packages/source/n/netifaces/netifaces-"
6226 version
6227 ".tar.gz"))
6228 (sha256
6229 (base32
6230 "1plw237a4zib4z8s62g0mrs8gm3kjfrp5sxh6bbk9nl3rdls2mln"))))
6231 (build-system python-build-system)
6232 (home-page
6233 "https://bitbucket.org/al45tair/netifaces")
6234 (synopsis
6235 "Python module for portable network interface information")
6236 (description
6237 "Netifaces is a Python module providing information on network
6238 interfaces in an easy and portable manner.")
6239 (license license:expat)))
6240
6241 (define-public python2-netifaces
6242 (package-with-python2 python-netifaces))
6243
6244 (define-public python-networkx
6245 (package
6246 (name "python-networkx")
6247 (version "1.11")
6248 (source
6249 (origin
6250 (method url-fetch)
6251 (uri (pypi-uri "networkx" version))
6252 (sha256
6253 (base32 "1f74s56xb4ggixiq0vxyfxsfk8p20c7a099lpcf60izv1php03hd"))))
6254 (build-system python-build-system)
6255 ;; python-decorator is needed at runtime
6256 (propagated-inputs
6257 `(("python-decorator" ,python-decorator)))
6258 (native-inputs
6259 `(("python-nose" ,python-nose)))
6260 (home-page "http://networkx.github.io/")
6261 (synopsis "Python module for creating and manipulating graphs and networks")
6262 (description
6263 "NetworkX is a Python package for the creation, manipulation, and study
6264 of the structure, dynamics, and functions of complex networks.")
6265 (license license:bsd-3)))
6266
6267 (define-public python2-networkx
6268 (package-with-python2 python-networkx))
6269
6270 (define-public snakemake
6271 (package
6272 (name "snakemake")
6273 (version "3.13.3")
6274 (source
6275 (origin
6276 (method url-fetch)
6277 (uri (pypi-uri "snakemake" version))
6278 (sha256
6279 (base32 "1nixb944r4hlskwkzc4wjs34b40xpxpw9gmhhm5p09gvmm22ap5d"))))
6280 (build-system python-build-system)
6281 (arguments
6282 ;; TODO: Package missing test dependencies.
6283 '(#:tests? #f
6284 #:phases
6285 (modify-phases %standard-phases
6286 ;; For cluster execution Snakemake will call Python. Since there is
6287 ;; no suitable PYTHONPATH set, cluster execution will fail. We fix
6288 ;; this by calling the snakemake wrapper instead.
6289 (add-after 'unpack 'call-wrapper-not-wrapped-snakemake
6290 (lambda* (#:key outputs #:allow-other-keys)
6291 (substitute* "snakemake/executors.py"
6292 (("\\{sys.executable\\} -m snakemake")
6293 (string-append (assoc-ref outputs "out")
6294 "/bin/snakemake")))
6295 #t)))))
6296 (propagated-inputs
6297 `(("python-wrapt" ,python-wrapt)
6298 ("python-requests" ,python-requests)))
6299 (home-page "https://bitbucket.org/snakemake/snakemake/wiki/Home")
6300 (synopsis "Python-based execution environment for make-like workflows")
6301 (description
6302 "Snakemake aims to reduce the complexity of creating workflows by
6303 providing a clean and modern domain specific specification language (DSL) in
6304 Python style, together with a fast and comfortable execution environment.")
6305 (license license:expat)))
6306
6307 (define-public python-seaborn
6308 (package
6309 (name "python-seaborn")
6310 (version "0.7.1")
6311 (source
6312 (origin
6313 (method url-fetch)
6314 (uri (pypi-uri "seaborn" version))
6315 (sha256
6316 (base32 "0pawrqc3mxpwd5g9pvi9gba02637bh5c8ldpp8izfwpfn52469zs"))))
6317 (build-system python-build-system)
6318 (arguments
6319 '(#:tests? #f)) ; Tests requires a running X11 server.
6320 (propagated-inputs
6321 `(("python-pandas" ,python-pandas)
6322 ("python-matplotlib" ,python-matplotlib)
6323 ("python-scipy" ,python-scipy)))
6324 (home-page "http://stanford.edu/~mwaskom/software/seaborn/")
6325 (synopsis "Statistical data visualization")
6326 (description
6327 "Seaborn is a library for making attractive and informative statistical
6328 graphics in Python. It is built on top of matplotlib and tightly integrated
6329 with the PyData stack, including support for numpy and pandas data structures
6330 and statistical routines from scipy and statsmodels.")
6331 (license license:bsd-3)
6332 (properties `((python2-variant . ,(delay python2-seaborn))))))
6333
6334 (define-public python2-seaborn
6335 (let ((base (package-with-python2 (strip-python2-variant python-seaborn))))
6336 (package
6337 (inherit base)
6338 (propagated-inputs `(("python2-pytz" ,python2-pytz)
6339 ,@(package-propagated-inputs base))))))
6340
6341 (define-public python-mpmath
6342 (package
6343 (name "python-mpmath")
6344 (version "0.19")
6345 (source (origin
6346 (method url-fetch)
6347 (uri (string-append "http://mpmath.org/files/mpmath-"
6348 version ".tar.gz"))
6349 (sha256
6350 (base32
6351 "08ijsr4ifrqv3cjc26mkw0dbvyygsa99in376hr4b96ddm1gdpb8"))))
6352 (build-system python-build-system)
6353 (arguments
6354 '(#:phases
6355 (modify-phases %standard-phases
6356 (replace 'check
6357 (lambda _
6358 (zero?
6359 (system* "python" "mpmath/tests/runtests.py" "-local")))))))
6360 (home-page "http://mpmath.org")
6361 (synopsis "Arbitrary-precision floating-point arithmetic in python")
6362 (description
6363 "@code{mpmath} can be used as an arbitrary-precision substitute for
6364 Python's float/complex types and math/cmath modules, but also does much
6365 more advanced mathematics.")
6366 (license license:bsd-3)))
6367
6368 (define-public python2-mpmath
6369 (package-with-python2 python-mpmath))
6370
6371 (define-public python-sympy
6372 (package
6373 (name "python-sympy")
6374 (version "1.0")
6375 (source
6376 (origin
6377 (method url-fetch)
6378 (uri (string-append
6379 "https://github.com/sympy/sympy/releases/download/sympy-"
6380 version "/sympy-" version ".tar.gz"))
6381 (sha256
6382 (base32 "1bpzjwr9hrr7w88v4vgnj9lr6vxcldc94si13n8xpr1rv08d5b1y"))))
6383 (build-system python-build-system)
6384 (propagated-inputs
6385 `(("python-mpmath" ,python-mpmath)))
6386 (home-page "http://www.sympy.org/")
6387 (synopsis "Python library for symbolic mathematics")
6388 (description
6389 "SymPy is a Python library for symbolic mathematics. It aims to become a
6390 full-featured computer algebra system (CAS) while keeping the code as simple
6391 as possible in order to be comprehensible and easily extensible.")
6392 (license license:bsd-3)))
6393
6394 (define-public python2-sympy
6395 (package-with-python2 python-sympy))
6396
6397 (define-public python-q
6398 (package
6399 (name "python-q")
6400 (version "2.6")
6401 (source
6402 (origin
6403 (method url-fetch)
6404 (uri (pypi-uri "q" version))
6405 (sha256
6406 (base32
6407 "1mgfazh8fkizh6walra2zv885f3lcgr3nb02v1frfm4p8ddcy3yy"))))
6408 (build-system python-build-system)
6409 (home-page "https://github.com/zestyping/q")
6410 (synopsis "Quick-and-dirty debugging output for tired programmers")
6411 (description
6412 "q is a Python module for \"print\" style of debugging Python code. It
6413 provides convenient short API for print out of values, tracebacks, and
6414 falling into the Python interpreter.")
6415 (license license:asl2.0)))
6416
6417 (define-public python2-q
6418 (package-with-python2 python-q))
6419
6420 (define-public python-testlib
6421 (package
6422 (name "python-testlib")
6423 (version "0.6.5")
6424 (source
6425 (origin
6426 (method url-fetch)
6427 (uri (string-append
6428 "https://pypi.python.org/packages/source/t/testlib/testlib-"
6429 version ".zip"))
6430 (sha256
6431 (base32 "1mz26cxn4x8bbgv0rn0mvj2z05y31rkc8009nvdlb3lam5b4mj3y"))))
6432 (build-system python-build-system)
6433 (native-inputs
6434 `(("unzip" ,unzip))) ; for unpacking the source
6435 (synopsis "Python micro test suite harness")
6436 (description "A micro unittest suite harness for Python.")
6437 (home-page "https://github.com/trentm/testlib")
6438 (license license:expat)))
6439
6440 (define-public python2-testlib
6441 (package-with-python2 python-testlib))
6442
6443 (define-public python2-xlib
6444 (package
6445 (name "python2-xlib")
6446 (version "0.14")
6447 (source (origin
6448 (method url-fetch)
6449 (uri (string-append "mirror://sourceforge/python-xlib/python-xlib"
6450 "/" version "/"
6451 "python-xlib-" version ".tar.gz"))
6452 (sha256
6453 (base32
6454 "1sv0447j0rx8cgs3jhjl695p5pv13ihglcjlrrz1kq05lsvb0wa7"))))
6455 (build-system python-build-system)
6456 (arguments
6457 `(#:python ,python-2 ;Python 2 only
6458 #:tests? #f)) ;no tests
6459 (home-page "http://python-xlib.sourceforge.net/")
6460 (synopsis "Python X11 client library")
6461 (description
6462 "The Python X Library is intended to be a fully functional X client
6463 library for Python programs. It is useful to implement low-level X clients.
6464 It is written entirely in Python.")
6465 (license license:gpl2+)))
6466
6467 (define-public python-singledispatch
6468 (package
6469 (name "python-singledispatch")
6470 (version "3.4.0.3")
6471 (source
6472 (origin
6473 (method url-fetch)
6474 (uri (pypi-uri "singledispatch" version))
6475 (sha256
6476 (base32
6477 "171b7ip0hsq5qm83np40h3phlr36ym18w0lay0a8v08kvy3sy1jv"))))
6478 (build-system python-build-system)
6479 (native-inputs
6480 `(("python-six" ,python-six))) ; required for conversion, not at run-time
6481 (home-page
6482 "http://docs.python.org/3/library/functools.html#functools.singledispatch")
6483 (synopsis "Backport of singledispatch feature from Python 3.4")
6484 (description
6485 "This library brings functools.singledispatch from Python 3.4 to Python
6486 2.6-3.3.")
6487 (license license:expat)))
6488
6489 (define-public python2-singledispatch
6490 (package-with-python2 python-singledispatch))
6491
6492 (define-public python-tornado
6493 (package
6494 (name "python-tornado")
6495 (version "4.5.1")
6496 (source
6497 (origin
6498 (method url-fetch)
6499 (uri (pypi-uri "tornado" version))
6500 (sha256
6501 (base32 "1zbkgcdfq81k298awrm8p0xwbwwn2p3nbizdglzfbkskhai082fv"))))
6502 (build-system python-build-system)
6503 (arguments
6504 '(;; FIXME: Two tests error out with:
6505 ;; AssertionError: b'Error in atexit._run_exitfuncs:\nFileNotF[44 chars]ry\n' != b''
6506 ;; #:phases
6507 ;; (modify-phases %standard-phases
6508 ;; (replace 'check
6509 ;; (lambda _
6510 ;; ;; 'setup.py test' hits an AssertionError on BSD-specific
6511 ;; ;; "tornado/platform/kqueue.py". This is the supported method:
6512 ;; (zero? (system* "python" "-m" "tornado.test")))))
6513 #:tests? #f))
6514 (native-inputs
6515 `(("python-certifi" ,python-certifi)))
6516 (propagated-inputs
6517 `(("python-backports-abc" ,python-backports-abc)))
6518 (home-page "http://www.tornadoweb.org/")
6519 (synopsis "Python web framework and asynchronous networking library")
6520 (description
6521 "Tornado is a Python web framework and asynchronous networking library,
6522 originally developed at FriendFeed. By using non-blocking network I/O,
6523 Tornado can scale to tens of thousands of open connections, making it ideal
6524 for long polling, WebSockets, and other applications that require a long-lived
6525 connection to each user.")
6526 (license license:asl2.0)
6527 (properties `((python2-variant . ,(delay python2-tornado))))))
6528
6529 (define-public python2-tornado
6530 (let ((tornado (package-with-python2 (strip-python2-variant python-tornado))))
6531 (package (inherit tornado)
6532 (propagated-inputs
6533 `(("python2-backport-ssl-match-hostname"
6534 ,python2-backport-ssl-match-hostname)
6535 ("python2-singledispatch" ,python2-singledispatch)
6536 ,@(package-propagated-inputs tornado))))))
6537
6538 ;; the python- version can be removed with python-3.5
6539 (define-public python-backports-abc
6540 (package
6541 (name "python-backports-abc")
6542 (version "0.5")
6543 (source
6544 (origin
6545 (method url-fetch)
6546 (uri (pypi-uri "backports_abc" version))
6547 (sha256
6548 (base32
6549 "1pkv8d1zxj5f9i227dxbjczncbv7ks7ywnjwyxfjagm02i2yafq3"))))
6550 (build-system python-build-system)
6551 (home-page "https://github.com/cython/backports_abc")
6552 (synopsis "Backport of additions to the 'collections.abc' module")
6553 (description
6554 "Python-backports-abc provides a backport of additions to the
6555 'collections.abc' module in Python-3.5.")
6556 (license license:psfl)))
6557
6558 (define-public python2-backports-abc
6559 (package-with-python2 python-backports-abc))
6560
6561 (define-public python-backports-csv
6562 (package
6563 (name "python-backports-csv")
6564 (version "1.0.5")
6565 (source
6566 (origin
6567 (method url-fetch)
6568 (uri (pypi-uri "backports.csv" version))
6569 (sha256
6570 (base32
6571 "1imzbrradkfn8s2m1qcimyn74dn1mz2p3j381jljn166rf2i6hlc"))))
6572 (build-system python-build-system)
6573 (home-page "https://github.com/ryanhiebert/backports.csv")
6574 (synopsis "Backport of Python 3's csv module for Python 2")
6575 (description
6576 "Provides a backport of Python 3's @code{csv} module for parsing
6577 comma separated values. The API of the @code{csv} module in Python 2
6578 is drastically different from the @code{csv} module in Python 3.
6579 This is due, for the most part, to the difference between str in
6580 Python 2 and Python 3.")
6581 (license license:psfl)))
6582
6583 (define-public python2-backports-csv
6584 (package-with-python2 python-backports-csv))
6585
6586 (define-public python2-backports-shutil-get-terminal-size
6587 (package
6588 (name "python2-backports-shutil-get-terminal-size")
6589 (version "1.0.0")
6590 (source
6591 (origin
6592 (method url-fetch)
6593 (uri (pypi-uri "backports.shutil_get_terminal_size" version))
6594 (sha256
6595 (base32
6596 "107cmn7g3jnbkp826zlj8rrj19fam301qvaqf0f3905f5217lgki"))))
6597 (build-system python-build-system)
6598 (arguments
6599 `(#:python ,python-2
6600 #:phases
6601 (modify-phases %standard-phases
6602 (replace 'check
6603 (lambda _
6604 (zero? (system* "py.test" "-v")))))))
6605 (native-inputs
6606 `(("python2-pytest" ,python2-pytest)))
6607 (home-page "https://github.com/chrippa/backports.shutil_get_terminal_size")
6608 (synopsis "Backport of Python 3.3's @code{shutil.get_terminal_size}")
6609 (description
6610 "This package provides a backport of the @code{get_terminal_size
6611 function} from Python 3.3's @code{shutil}.
6612 Unlike the original version it is written in pure Python rather than C,
6613 so it might be a tiny bit slower.")
6614 (license license:expat)))
6615
6616 (define-public python-waf
6617 (package
6618 (name "python-waf")
6619 (version "1.9.8")
6620 (source (origin
6621 (method url-fetch)
6622 (uri (string-append "https://waf.io/"
6623 "waf-" version ".tar.bz2"))
6624 (sha256
6625 (base32
6626 "0wl4cnmp06lfxqjxaan58bqxn27smhydz0sg5prrfbl3bsw4gv6q"))))
6627 (build-system python-build-system)
6628 (arguments
6629 '(#:phases
6630 (modify-phases %standard-phases
6631 (replace 'build
6632 (lambda _
6633 (zero? (system* "python" "waf-light" "configure" "build"))))
6634 (replace 'check
6635 (lambda _
6636 (zero? (system* "python" "waf" "--version"))))
6637 (replace 'install
6638 (lambda _
6639 (copy-file "waf" %output))))))
6640 (home-page "https://waf.io/")
6641 (synopsis "Python-based build system")
6642 (description
6643 "Waf is a Python-based framework for configuring, compiling and installing
6644 applications.")
6645 (license license:bsd-3)))
6646
6647 (define-public python2-waf
6648 (package-with-python2 python-waf))
6649
6650 (define-public python-pyzmq
6651 (package
6652 (name "python-pyzmq")
6653 (version "15.1.0")
6654 (source
6655 (origin
6656 (method url-fetch)
6657 (uri (pypi-uri "pyzmq" version))
6658 (sha256
6659 (base32 "13fhwnlvsvxv72kfhqbpn6qi7msh8mc8377mpabv32skk2cjfnxx"))))
6660 (build-system python-build-system)
6661 (arguments
6662 `(#:configure-flags
6663 (list (string-append "--zmq=" (assoc-ref %build-inputs "zeromq")))
6664 ;; FIXME: You must build pyzmq with 'python setup.py build_ext
6665 ;; --inplace' for 'python setup.py test' to work.
6666 #:tests? #f))
6667 (inputs
6668 `(("zeromq" ,zeromq)))
6669 (native-inputs
6670 `(("pkg-config" ,pkg-config)
6671 ("python-nose" ,python-nose)))
6672 (home-page "https://github.com/zeromq/pyzmq")
6673 (synopsis "Python bindings for 0MQ")
6674 (description
6675 "PyZMQ is the official Python binding for the ZeroMQ messaging library.")
6676 (license license:bsd-4)))
6677
6678 (define-public python2-pyzmq
6679 (package-with-python2 python-pyzmq))
6680
6681 (define-public python-pep8
6682 (package
6683 (name "python-pep8")
6684 (version "1.7.0")
6685 (source
6686 (origin
6687 (method url-fetch)
6688 (uri (pypi-uri "pep8" version))
6689 (sha256
6690 (base32
6691 "002rkl4lsn6x2mxmf8ar00l0m8i3mzrc6pnzz77blyksmpsxa4x1"))))
6692 (build-system python-build-system)
6693 (home-page "http://pep8.readthedocs.org/")
6694 (synopsis "Python style guide checker")
6695 (description
6696 "This tools checks Python code against some of the style conventions in
6697 PEP 8.")
6698 (license license:expat)))
6699
6700 (define-public python2-pep8
6701 (package-with-python2 python-pep8))
6702
6703 (define-public python-pyflakes
6704 (package
6705 (name "python-pyflakes")
6706 (version "1.0.0")
6707 (source
6708 (origin
6709 (method url-fetch)
6710 (uri (pypi-uri "pyflakes" version))
6711 (sha256
6712 (base32
6713 "0qs2sgqszq7wcplis8509wk2ygqcrwzbs1ghfj3svvivq2j377pk"))))
6714 (build-system python-build-system)
6715 (home-page
6716 "https://github.com/pyflakes/pyflakes")
6717 (synopsis "Passive checker of Python programs")
6718 (description
6719 "Pyflakes statically checks Python source code for common errors.")
6720 (license license:expat)))
6721
6722 (define-public python2-pyflakes
6723 (package-with-python2 python-pyflakes))
6724
6725 (define-public python-mccabe
6726 (package
6727 (name "python-mccabe")
6728 (version "0.4.0")
6729 (source
6730 (origin
6731 (method url-fetch)
6732 (uri (pypi-uri "mccabe" version))
6733 (sha256
6734 (base32
6735 "0yr08a36h8lqlif10l4xcikbbig7q8f41gqywir7rrvnv3mi4aws"))))
6736 (build-system python-build-system)
6737 (native-inputs
6738 `(("python-pytest" ,python-pytest)
6739 ("python-pytest-runner" ,python-pytest-runner)))
6740 (home-page "https://github.com/flintwork/mccabe")
6741 (synopsis "McCabe checker, plugin for flake8")
6742 (description
6743 "This package provides a Flake8 plug-in to compute the McCabe cyclomatic
6744 complexity of Python source code.")
6745 (license license:expat)))
6746
6747 (define-public python2-mccabe
6748 (package-with-python2 python-mccabe))
6749
6750 (define-public python-mccabe-0.2.1
6751 (package (inherit python-mccabe)
6752 (version "0.2.1")
6753 (source
6754 (origin
6755 (method url-fetch)
6756 (uri (pypi-uri "mccabe" version))
6757 (sha256
6758 (base32
6759 "0fi4a81kr5bcv5p4xgibqr595hyj5dafkqgsmfk96mfy8w71fajs"))))))
6760
6761 (define-public python2-mccabe-0.2.1
6762 (package-with-python2 python-mccabe-0.2.1))
6763
6764 ;; Flake8 2.4.1 requires an older version of pep8.
6765 ;; This should be removed ASAP.
6766 (define-public python-pep8-1.5.7
6767 (package (inherit python-pep8)
6768 (version "1.5.7")
6769 (source
6770 (origin
6771 (method url-fetch)
6772 (uri (string-append
6773 "https://pypi.python.org/packages/source/p/pep8/pep8-"
6774 version
6775 ".tar.gz"))
6776 (sha256
6777 (base32
6778 "12b9bbdbwnspxgak14xg58c130x2n0blxzlms5jn2dszn8qj3d0m"))))
6779 (arguments
6780 ;; XXX Tests not compatible with Python 3.5.
6781 '(#:tests? #f))))
6782
6783 (define-public python2-pep8-1.5.7
6784 (package-with-python2 python-pep8-1.5.7))
6785
6786 ;; Flake8 2.4.1 requires an older version of pyflakes.
6787 ;; This should be removed ASAP.
6788 (define-public python-pyflakes-0.8.1
6789 (package (inherit python-pyflakes)
6790 (version "0.8.1")
6791 (source
6792 (origin
6793 (method url-fetch)
6794 (uri (string-append
6795 "https://pypi.python.org/packages/source/p/pyflakes/pyflakes-"
6796 version
6797 ".tar.gz"))
6798 (sha256
6799 (base32
6800 "0sbpq6pqm1i9wqi41mlfrsc5rk92jv4mskvlyxmnhlbdnc80ma1z"))))
6801 (arguments
6802 ;; XXX Tests not compatible with Python 3.5.
6803 '(#:tests? #f))))
6804
6805 (define-public python2-pyflakes-0.8.1
6806 (package-with-python2 python-pyflakes-0.8.1))
6807
6808 (define-public python-flake8
6809 (package
6810 (name "python-flake8")
6811 (version "2.5.4")
6812 (source
6813 (origin
6814 (method url-fetch)
6815 (uri (pypi-uri "flake8" version))
6816 (sha256
6817 (base32
6818 "0bs9cz4fr99r2rwig1b8jwaadl1nan7kgpdzqwj0bwbckwbmh7nc"))
6819 (modules '((guix build utils)))
6820 (snippet
6821 '(begin
6822 ;; Remove pre-compiled .pyc files from source.
6823 (for-each delete-file-recursively
6824 (find-files "." "__pycache__" #:directories? #t))
6825 (for-each delete-file (find-files "." "\\.pyc$"))
6826 #t))))
6827 (build-system python-build-system)
6828 (propagated-inputs
6829 `(("python-pep8" ,python-pep8)
6830 ("python-pyflakes" ,python-pyflakes)
6831 ("python-mccabe" ,python-mccabe)))
6832 (native-inputs
6833 `(("python-mock" ,python-mock) ; TODO: only required for < 3.3
6834 ("python-nose" ,python-nose)))
6835 (home-page "https://gitlab.com/pycqa/flake8")
6836 (synopsis
6837 "The modular source code checker: pep8, pyflakes and co")
6838 (description
6839 "Flake8 is a wrapper around PyFlakes, pep8 and python-mccabe.")
6840 (license license:expat)))
6841
6842 (define-public python2-flake8
6843 (package-with-python2 python-flake8))
6844
6845 (define-public python-flake8-polyfill
6846 (package
6847 (name "python-flake8-polyfill")
6848 (version "1.0.1")
6849 (source
6850 (origin
6851 (method url-fetch)
6852 (uri (pypi-uri "flake8-polyfill" version))
6853 (sha256
6854 (base32
6855 "02gn2wxvh9vnf7m7dld7ca4l60mg5c370hv3swwppkngwaqmcw67"))))
6856 (build-system python-build-system)
6857 (arguments
6858 '(#:phases
6859 (modify-phases %standard-phases
6860 (replace 'check
6861 (lambda _
6862 (setenv "PYTHONPATH"
6863 (string-append (getcwd) "/build/lib:"
6864 (getenv "PYTHONPATH")))
6865 (zero? (system* "py.test" "-v")))))))
6866 (native-inputs
6867 `(("python-flake8" ,python-flake8)
6868 ("python-mock" ,python-mock)
6869 ("python-pycodestyle" ,python-pycodestyle)
6870 ("python-pytest" ,python-pytest)))
6871 (home-page "https://gitlab.com/pycqa/flake8-polyfill")
6872 (synopsis "Polyfill package for Flake8 plugins")
6873 (description
6874 "This package that provides some compatibility helpers for Flake8
6875 plugins that intend to support Flake8 2.x and 3.x simultaneously.")
6876 (license license:expat)))
6877
6878 (define-public python2-flake8-polyfill
6879 (package-with-python2 python-flake8-polyfill))
6880
6881 (define-public python-mistune
6882 (package
6883 (name "python-mistune")
6884 (version "0.7.3")
6885 (source
6886 (origin
6887 (method url-fetch)
6888 (uri (pypi-uri "mistune" version))
6889 (sha256
6890 (base32
6891 "04xpk1zvslhq3xpnf01g3ag0dy9wfv4z28p093r8k49vvxlyil11"))))
6892 (build-system python-build-system)
6893 (native-inputs
6894 `(("python-nose" ,python-nose)
6895 ("python-cython" ,python-cython)))
6896 (home-page "https://github.com/lepture/mistune")
6897 (synopsis "Markdown parser in pure Python")
6898 (description "This package provides a fast markdown parser in pure
6899 Python.")
6900 (license license:bsd-3)))
6901
6902 (define-public python2-mistune
6903 (package-with-python2 python-mistune))
6904
6905 (define-public python-markdown
6906 (package
6907 (name "python-markdown")
6908 (version "2.6.8")
6909 (source
6910 (origin
6911 (method url-fetch)
6912 (uri (pypi-uri "Markdown" version))
6913 (sha256
6914 (base32
6915 "0cqfhr1km2s5d8jm6hbwgkrrj9hvkjf2gab3s2axlrw1clgaij0a"))))
6916 (build-system python-build-system)
6917 (arguments
6918 `(#:phases
6919 (modify-phases %standard-phases
6920 (replace 'check
6921 (lambda _
6922 (zero? (system* "python" "run-tests.py")))))))
6923 (native-inputs
6924 `(("python-nose" ,python-nose)
6925 ("python-pyyaml" ,python-pyyaml)))
6926 (home-page "https://pythonhosted.org/Markdown/")
6927 (synopsis "Python implementation of Markdown")
6928 (description
6929 "This package provides a Python implementation of John Gruber's
6930 Markdown. The library features international input, various Markdown
6931 extensions, and several HTML output formats. A command line wrapper
6932 markdown_py is also provided to convert Markdown files to HTML.")
6933 (license license:bsd-3)))
6934
6935 (define-public python2-markdown
6936 (package-with-python2 python-markdown))
6937
6938 (define-public python-ptyprocess
6939 (package
6940 (name "python-ptyprocess")
6941 (version "0.5.1")
6942 (source
6943 (origin
6944 (method url-fetch)
6945 (uri (string-append
6946 "https://pypi.python.org/packages/source/p/ptyprocess/ptyprocess-"
6947 version ".tar.gz"))
6948 (sha256
6949 (base32
6950 "19l1xrjn4l9gjz01s3vg92gn2dd9d8mw1v86ppkzlnr9m5iwwc05"))))
6951 (build-system python-build-system)
6952 (native-inputs
6953 `(("python-nose" ,python-nose)))
6954 (arguments
6955 `(#:phases
6956 (modify-phases %standard-phases
6957 (replace 'check
6958 (lambda _
6959 (zero? (system* "nosetests")))))))
6960 (home-page "https://github.com/pexpect/ptyprocess")
6961 (synopsis "Run a subprocess in a pseudo terminal")
6962 (description
6963 "This package provides a Python library used to launch a subprocess in a
6964 pseudo terminal (pty), and interact with both the process and its pty.")
6965 (license license:isc)))
6966
6967 (define-public python2-ptyprocess
6968 (package-with-python2 python-ptyprocess))
6969
6970 (define-public python-cram
6971 (package
6972 (name "python-cram")
6973 (version "0.7")
6974 (home-page "https://bitheap.org/cram/")
6975 (source (origin
6976 (method url-fetch)
6977 (uri (list (string-append home-page "cram-"
6978 version ".tar.gz")
6979 (pypi-uri "cram" version)))
6980 (sha256
6981 (base32
6982 "0bvz6fwdi55rkrz3f50zsy35gvvwhlppki2yml5bj5ffy9d499vx"))))
6983 (arguments
6984 '(#:phases
6985 (modify-phases %standard-phases
6986 (add-after 'unpack 'patch-source
6987 (lambda _
6988 (substitute* (find-files "cram" ".*\\.py$")
6989 ;; Replace default shell path.
6990 (("/bin/sh") (which "sh")))
6991 (substitute* (find-files "tests" ".*\\.t$")
6992 (("md5") "md5sum")
6993 (("/bin/bash") (which "bash"))
6994 (("/bin/sh") (which "sh")))
6995 (substitute* "cram/_test.py"
6996 ;; This hack works around a bug triggered by substituting
6997 ;; the /bin/sh paths. "tests/usage.t" compares the output of
6998 ;; "cram -h", which breaks the output at 80 characters. This
6999 ;; causes the line showing the default shell to break into two
7000 ;; lines, but the test expects a single line...
7001 (("env\\['COLUMNS'\\] = '80'")
7002 "env['COLUMNS'] = '160'"))
7003 #t))
7004 (delete 'check)
7005 (add-after 'install 'check
7006 ;; The test phase uses the built library and executable.
7007 ;; It's easier to run it after install since the build
7008 ;; directory contains version-specific PATH.
7009 (lambda* (#:key inputs outputs #:allow-other-keys)
7010 (add-installed-pythonpath inputs outputs)
7011 (setenv "PATH" (string-append (getenv "PATH") ":"
7012 (assoc-ref outputs "out") "/bin"))
7013 (zero? (system* "make" "test")))))))
7014 (build-system python-build-system)
7015 (native-inputs
7016 `(("python-coverage" ,python-coverage)
7017 ("which" ,which)))
7018 (synopsis "Simple testing framework for command line applications")
7019 (description
7020 "Cram is a functional testing framework for command line applications.
7021 Cram tests look like snippets of interactive shell sessions. Cram runs each
7022 command and compares the command output in the test with the command’s actual
7023 output.")
7024 (license license:gpl2+)))
7025
7026 (define-public python2-cram
7027 (package-with-python2 python-cram))
7028
7029 (define-public python-terminado
7030 (package
7031 (name "python-terminado")
7032 (version "0.6")
7033 (source
7034 (origin
7035 (method url-fetch)
7036 (uri (pypi-uri "terminado" version))
7037 (sha256
7038 (base32
7039 "09h1kwi86g5mrk14s4pgbhshd602zry29lnpxamcqz864kva22rc"))))
7040 (build-system python-build-system)
7041 (propagated-inputs
7042 `(("python-tornado" ,python-tornado)
7043 ("python-ptyprocess" ,python-ptyprocess)))
7044 (native-inputs
7045 `(("python-nose" ,python-nose)))
7046 (arguments
7047 `(#:phases
7048 (modify-phases %standard-phases
7049 (replace 'check
7050 (lambda _
7051 (zero? (system* "nosetests")))))))
7052 (home-page "https://github.com/takluyver/terminado")
7053 (synopsis "Terminals served to term.js using Tornado websockets")
7054 (description "This package provides a Tornado websocket backend for the
7055 term.js Javascript terminal emulator library.")
7056 (license license:bsd-2)
7057 (properties `((python2-variant . ,(delay python2-terminado))))))
7058
7059 (define-public python2-terminado
7060 (let ((terminado (package-with-python2 (strip-python2-variant python-terminado))))
7061 (package (inherit terminado)
7062 (propagated-inputs
7063 `(("python2-backport-ssl-match-hostname"
7064 ,python2-backport-ssl-match-hostname)
7065 ,@(package-propagated-inputs terminado))))))
7066
7067 (define-public python-straight-plugin
7068 (package
7069 (name "python-straight-plugin")
7070 (version "1.4.1")
7071 (source
7072 (origin
7073 (method url-fetch)
7074 (uri (pypi-uri "straight.plugin" version))
7075 (sha256
7076 (base32
7077 "069pjll4383p4kkgvcc40hgyvf79j2wdbpgwz77yigzxksh1gj62"))))
7078 (build-system python-build-system)
7079 (home-page "https://github.com/ironfroggy/straight.plugin")
7080 (synopsis "Simple namespaced plugin facility")
7081 (description "Straight Plugin provides a type of plugin you can create from
7082 almost any existing Python modules, and an easy way for outside developers to
7083 add functionality and customization to your projects with their own plugins.")
7084 (license license:expat)))
7085
7086 (define-public python2-straight-plugin
7087 (package-with-python2 python-straight-plugin))
7088
7089 (define-public python-fonttools
7090 (package
7091 (name "python-fonttools")
7092 (version "2.5")
7093 (source (origin
7094 (method url-fetch)
7095 (uri (string-append
7096 "https://pypi.python.org/packages/source/F/FontTools/"
7097 "fonttools-" version ".tar.gz"))
7098 (sha256
7099 (base32
7100 "08ay3x4ijarwhl60gqx2i9jzq6pxs20p4snc2d1q5jagh4rn39lb"))))
7101 (build-system python-build-system)
7102 (arguments
7103 '(#:test-target "check"
7104 #:phases
7105 (modify-phases %standard-phases
7106 (add-after 'unpack 'patch-setuppy
7107 ;; Remove the undocumented "extra_path" argument, which adds an
7108 ;; intervening directories between site-packages and the package
7109 ;; directory.
7110 (lambda _
7111 (substitute* "setup.py"
7112 (("^[ \t]*extra_path *= *'FontTools',") ""))
7113 #t)))))
7114 (home-page "https://github.com/behdad/fonttools")
7115 (synopsis "Tools to manipulate font files")
7116 (description
7117 "FontTools/TTX is a library to manipulate font files from Python. It
7118 supports reading and writing of TrueType/OpenType fonts, reading and writing
7119 of AFM files, reading (and partially writing) of PS Type 1 fonts. The package
7120 also contains a tool called “TTX” which converts TrueType/OpenType fonts to and
7121 from an XML-based format.")
7122 (license (license:non-copyleft
7123 "file://LICENSE.txt"
7124 "See LICENSE.txt in the distribution."))))
7125
7126 (define-public python2-fonttools
7127 (package-with-python2 python-fonttools))
7128
7129 (define-public python-ly
7130 (package
7131 (name "python-ly")
7132 (version "0.9.4")
7133 (source
7134 (origin
7135 (method url-fetch)
7136 (uri (string-append "https://pypi.python.org/packages/57/4f/"
7137 "889579244947368f28eda66b782331b1e75f83fd72e63f9ece93cd7a18f9"
7138 "/python-ly-" version ".tar.gz"))
7139 (sha256
7140 (base32
7141 "0g6n288l83sfwavxh1aryi0aqvsr3sp7v6f903mckwqa4scpky62"))))
7142 (build-system python-build-system)
7143 (arguments
7144 ;; FIXME: Some tests need network access.
7145 '(#:tests? #f))
7146 (synopsis "Tool and library for manipulating LilyPond files")
7147 (description "This package provides a Python library to parse, manipulate
7148 or create documents in LilyPond format. A command line program ly is also
7149 provided that can be used to do various manipulations with LilyPond files.")
7150 (home-page "https://pypi.python.org/pypi/python-ly")
7151 (license license:gpl2+)))
7152
7153 (define-public python-appdirs
7154 (package
7155 (name "python-appdirs")
7156 (version "1.4.3")
7157 (source
7158 (origin
7159 (method url-fetch)
7160 (uri (pypi-uri "appdirs" version))
7161 (sha256
7162 (base32
7163 "14id6wxi12lgyw0mg3bcfnf888ad07jz9yj46gfzhn186z8rcn4y"))))
7164 (build-system python-build-system)
7165 (home-page "https://github.com/ActiveState/appdirs")
7166 (synopsis
7167 "Determine platform-specific dirs, e.g. a \"user data dir\"")
7168 (description
7169 "This module provides a portable way of finding out where user data
7170 should be stored on various operating systems.")
7171 (license license:expat)))
7172
7173 (define-public python2-appdirs
7174 (package-with-python2 python-appdirs))
7175
7176 (define-public python-llfuse
7177 (package
7178 (name "python-llfuse")
7179 (version "1.2")
7180 (source (origin
7181 (method url-fetch)
7182 (uri (string-append
7183 "https://bitbucket.org/nikratio/python-llfuse/downloads/"
7184 "llfuse-" version ".tar.bz2"))
7185 (sha256
7186 (base32
7187 "11hms1x68bf1bqbqy7w3wpffqsd3jkgricmzrc1hrnwkswfzzlr4"))))
7188 (build-system python-build-system)
7189 (inputs
7190 `(("fuse" ,fuse)
7191 ("attr" ,attr)))
7192 (native-inputs
7193 `(("pkg-config" ,pkg-config)))
7194 (synopsis "Python bindings for FUSE")
7195 (description
7196 "Python-LLFUSE is a set of Python bindings for the low level FUSE API.")
7197 (home-page "https://bitbucket.org/nikratio/python-llfuse/")
7198 (license license:lgpl2.0+)
7199 (properties `((python2-variant . ,(delay python2-llfuse))))))
7200
7201 (define-public python2-llfuse
7202 (package (inherit (package-with-python2
7203 (strip-python2-variant python-llfuse)))
7204 (propagated-inputs `(("python2-contextlib2" ,python2-contextlib2)))))
7205
7206 ;; For attic-0.16
7207 (define-public python-llfuse-0.41
7208 (package (inherit python-llfuse)
7209 (version "0.41.1")
7210 (source (origin
7211 (method url-fetch)
7212 (uri (string-append
7213 "https://bitbucket.org/nikratio/python-llfuse/downloads/"
7214 "llfuse-" version ".tar.bz2"))
7215 (sha256
7216 (base32
7217 "1imlqw9b73086y97izr036f58pgc5akv4ihc2rrf8j5h75jbrlaa"))))
7218 ;; Python-LLFUSE < 0.42 includes underscore.js, which is MIT (expat)
7219 ;; licensed. The rest of the package is licensed under LGPL2.0 or later.
7220 (license (list license:expat license:lgpl2.0+))))
7221
7222 (define-public python-msgpack
7223 (package
7224 (name "python-msgpack")
7225 (version "0.4.8")
7226 (source (origin
7227 (method url-fetch)
7228 (uri (pypi-uri "msgpack-python" version))
7229 (sha256
7230 (base32
7231 "11pqk5braa6wndpnr1dhg64js82vjgxnm0lzy73rwl831zgijaqs"))))
7232 (build-system python-build-system)
7233 (synopsis "MessagePack (de)serializer")
7234 (description "MessagePack is a fast, compact binary serialization format,
7235 suitable for similar data to JSON. This package provides CPython bindings for
7236 reading and writing MessagePack data.")
7237 (home-page "https://pypi.python.org/pypi/msgpack-python/")
7238 (license license:asl2.0)))
7239
7240 (define-public python2-msgpack
7241 (package-with-python2 python-msgpack))
7242
7243 (define-public python-netaddr
7244 (package
7245 (name "python-netaddr")
7246 (version "0.7.18")
7247 (source
7248 (origin
7249 (method url-fetch)
7250 (uri (string-append
7251 "https://pypi.python.org/packages/source/n/netaddr/netaddr-"
7252 version
7253 ".tar.gz"))
7254 (sha256
7255 (base32
7256 "06dxjlbcicq7q3vqy8agq11ra01kvvd47j4mk6dmghjsyzyckxd1"))))
7257 (build-system python-build-system)
7258 (arguments `(#:tests? #f)) ;; No tests.
7259 (home-page "https://github.com/drkjam/netaddr/")
7260 (synopsis "Pythonic manipulation of network addresses")
7261 (description
7262 "A Python library for representing and manipulating IPv4, IPv6, CIDR, EUI
7263 and MAC network addresses.")
7264 (license license:bsd-3)))
7265
7266 (define-public python2-netaddr
7267 (package-with-python2 python-netaddr))
7268
7269 (define-public python-wrapt
7270 (package
7271 (name "python-wrapt")
7272 (version "1.10.8")
7273 (source
7274 (origin
7275 (method url-fetch)
7276 (uri (pypi-uri "wrapt" version))
7277 (sha256
7278 (base32
7279 "0wrcm1mydvfivbkzz0h81ygzdchnscshi6xvy5n3r21r9s0px8af"))))
7280 (build-system python-build-system)
7281 (arguments
7282 ;; Tests are not included in the tarball, they are only available in the
7283 ;; git repository.
7284 `(#:tests? #f))
7285 (home-page "https://github.com/GrahamDumpleton/wrapt")
7286 (synopsis "Module for decorators, wrappers and monkey patching")
7287 (description
7288 "The aim of the wrapt module is to provide a transparent object proxy for
7289 Python, which can be used as the basis for the construction of function
7290 wrappers and decorator functions.")
7291 (license license:bsd-2)))
7292
7293 (define-public python2-wrapt
7294 (package-with-python2 python-wrapt))
7295
7296 (define-public python-iso8601
7297 (package
7298 (name "python-iso8601")
7299 (version "0.1.11")
7300 (source
7301 (origin
7302 (method url-fetch)
7303 (uri (pypi-uri "iso8601" version))
7304 (sha256
7305 (base32
7306 "0c7gh3lsdjds262h0v1sqc66l7hqgfwbakn96qrhdbl0i3vm5yz8"))))
7307 (build-system python-build-system)
7308 (native-inputs
7309 `(("python-pytest" ,python-pytest)))
7310 (home-page "https://bitbucket.org/micktwomey/pyiso8601")
7311 (synopsis "Module to parse ISO 8601 dates")
7312 (description
7313 "This module parses the most common forms of ISO 8601 date strings (e.g.
7314 @code{2007-01-14T20:34:22+00:00}) into @code{datetime} objects.")
7315 (license license:expat)))
7316
7317 (define-public python2-iso8601
7318 (package-with-python2 python-iso8601))
7319
7320 (define-public python-monotonic
7321 (package
7322 (name "python-monotonic")
7323 (version "0.3")
7324 (source
7325 (origin
7326 (method url-fetch)
7327 (uri (string-append
7328 "https://pypi.python.org/packages/source/m/monotonic/monotonic-"
7329 version
7330 ".tar.gz"))
7331 (sha256
7332 (base32
7333 "0yz0bcbwx8r2c01czzfpbrxddynxyk9k95jj8h6sgcb7xmfvl998"))))
7334 (build-system python-build-system)
7335 (home-page "https://github.com/atdt/monotonic")
7336 (synopsis "Implementation of time.monotonic() for Python 2 & < 3.3")
7337 (description
7338 "This module provides a monotonic() function which returns the value (in
7339 fractional seconds) of a clock which never goes backwards.")
7340 (license license:asl2.0)))
7341
7342 (define-public python2-monotonic
7343 (package-with-python2 python-monotonic))
7344
7345 (define-public python-webob
7346 (package
7347 (name "python-webob")
7348 (version "1.5.1")
7349 (source
7350 (origin
7351 (method url-fetch)
7352 (uri (pypi-uri "WebOb" version))
7353 (sha256
7354 (base32
7355 "02bhhzijfhv8hmi1i54d4b0v43liwhnywhflvxsv4x3zax9s3afq"))))
7356 (build-system python-build-system)
7357 (native-inputs
7358 `(("python-nose" ,python-nose)))
7359 (home-page "http://webob.org/")
7360 (synopsis "WSGI request and response object")
7361 (description
7362 "WebOb provides wrappers around the WSGI request environment, and an
7363 object to help create WSGI responses.")
7364 (license license:expat)))
7365
7366 (define-public python2-webob
7367 (package-with-python2 python-webob))
7368
7369 (define-public python-xlrd
7370 (package
7371 (name "python-xlrd")
7372 (version "1.0.0")
7373 (source (origin
7374 (method url-fetch)
7375 (uri (pypi-uri "xlrd" version))
7376 (sha256
7377 (base32
7378 "0s8hjiz01vbhy85xalrz0qlsmd9ypf36zjqrf97hh984spapvy0g"))))
7379 (build-system python-build-system)
7380 (arguments
7381 `(#:phases
7382 (modify-phases %standard-phases
7383 ;; Current test in setup.py does not work as of 1.0.0, so use nose to
7384 ;; run tests instead for now.
7385 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
7386 (native-inputs `(("python-nose" ,python-nose)))
7387 (home-page "http://www.python-excel.org/")
7388 (synopsis "Library for extracting data from Excel files")
7389 (description "This packages provides a library to extract data from
7390 spreadsheets using Microsoft Excel proprietary file formats @samp{.xls} and
7391 @samp{.xlsx} (versions 2.0 onwards). It has support for Excel dates and is
7392 Unicode-aware. It is not intended as an end-user tool.")
7393 (license license:bsd-3)))
7394
7395 (define-public python2-xlrd
7396 (package-with-python2 python-xlrd))
7397
7398 (define-public python-prettytable
7399 (package
7400 (name "python-prettytable")
7401 (version "0.7.2")
7402 (source
7403 (origin
7404 (method url-fetch)
7405 (uri (string-append
7406 "https://pypi.python.org/packages/source/P/PrettyTable/"
7407 "prettytable-" version ".tar.bz2"))
7408 (sha256
7409 (base32
7410 "0diwsicwmiq2cpzpxri7cyl5fmsvicafw6nfqf6p6p322dji2g45"))))
7411 (build-system python-build-system)
7412 (home-page "http://code.google.com/p/prettytable/")
7413 (synopsis "Display tabular data in an ASCII table format")
7414 (description
7415 "A library designed to represent tabular data in visually appealing ASCII
7416 tables. PrettyTable allows for selection of which columns are to be printed,
7417 independent alignment of columns (left or right justified or centred) and
7418 printing of sub-tables by specifying a row range.")
7419 (license license:bsd-3)))
7420
7421 (define-public python2-prettytable
7422 (package-with-python2 python-prettytable))
7423
7424 (define-public python-tables
7425 (package
7426 (name "python-tables")
7427 (version "3.2.2")
7428 (source
7429 (origin
7430 (method url-fetch)
7431 (uri (pypi-uri "tables" version))
7432 (sha256
7433 (base32
7434 "117s6w7s3yxafpmf3zz3svana7xfrsviw01va1xp7h8ylx8v6r1m"))
7435 (modules '((guix build utils)))
7436 (snippet
7437 '(begin
7438 ;; Remove pre-compiled .pyc files from source.
7439 (for-each delete-file-recursively
7440 (find-files "." "__pycache__" #:directories? #t))
7441 (for-each delete-file (find-files "." "\\.pyc$"))
7442 #t))))
7443 (build-system python-build-system)
7444 (arguments
7445 `(;; FIXME: python-build-system does not pass configure-flags to "build"
7446 ;; or "check", so we must override the build and check phases.
7447 #:phases
7448 (modify-phases %standard-phases
7449 (add-after 'unpack 'use-gcc
7450 (lambda _
7451 (substitute* "setup.py"
7452 (("compiler = new_compiler\\(\\)" line)
7453 (string-append line
7454 "\ncompiler.set_executables(compiler='gcc',"
7455 "compiler_so='gcc',"
7456 "linker_exe='gcc',"
7457 "linker_so='gcc -shared')")))
7458 #t))
7459 (replace 'build
7460 (lambda* (#:key inputs #:allow-other-keys)
7461 (zero? (system* "python" "setup.py" "build"
7462 (string-append "--hdf5="
7463 (assoc-ref inputs "hdf5"))))))
7464 (replace 'check
7465 (lambda* (#:key inputs #:allow-other-keys)
7466 (zero? (system* "python" "setup.py" "check"
7467 (string-append "--hdf5="
7468 (assoc-ref inputs "hdf5")))))))))
7469 (propagated-inputs
7470 `(("python-numexpr" ,python-numexpr)
7471 ("python-numpy" ,python-numpy)))
7472 (native-inputs
7473 `(("python-cython" ,python-cython)
7474 ("pkg-config" ,pkg-config)))
7475 (inputs
7476 `(("hdf5" ,hdf5)
7477 ("bzip2" ,bzip2)
7478 ("zlib" ,zlib)))
7479 (home-page "http://www.pytables.org/")
7480 (synopsis "Hierarchical datasets for Python")
7481 (description "PyTables is a package for managing hierarchical datasets and
7482 designed to efficiently cope with extremely large amounts of data.")
7483 (license license:bsd-3)))
7484
7485 (define-public python2-tables
7486 (package-with-python2 python-tables))
7487
7488 (define-public python-pyasn1
7489 (package
7490 (name "python-pyasn1")
7491 (version "0.2.3")
7492 (source
7493 (origin
7494 (method url-fetch)
7495 (uri (pypi-uri "pyasn1" version))
7496 (sha256
7497 (base32
7498 "1b86yx23c1x74clai05a5ma8c8nfmhlx3j1mxq0ff657i2ylx33k"))))
7499 (build-system python-build-system)
7500 (home-page "http://pyasn1.sourceforge.net/")
7501 (synopsis "ASN.1 types and codecs")
7502 (description
7503 "This is an implementation of ASN.1 types and codecs in Python. It is
7504 suitable for a wide range of protocols based on the ASN.1 specification.")
7505 (license license:bsd-2)))
7506
7507 (define-public python2-pyasn1
7508 (package-with-python2 python-pyasn1))
7509
7510 (define-public python-pyasn1-modules
7511 (package
7512 (name "python-pyasn1-modules")
7513 (version "0.0.8")
7514 (source
7515 (origin
7516 (method url-fetch)
7517 (uri (pypi-uri "pyasn1-modules" version))
7518 (sha256
7519 (base32
7520 "0drqgw81xd3fxdlg89kgd79zzrabvfncvkbybi2wr6w2y4s1jmhh"))))
7521 (build-system python-build-system)
7522 (propagated-inputs
7523 `(("python-pyasn1" ,python-pyasn1)))
7524 (home-page "https://sourceforge.net/projects/pyasn1/")
7525 (synopsis "ASN.1 codec implementations")
7526 (description
7527 "Pyasn1-modules is a collection of Python modules providing ASN.1 types and
7528 implementations of ASN.1-based codecs and protocols.")
7529 (license license:bsd-3)))
7530
7531 (define-public python2-pyasn1-modules
7532 (package-with-python2 python-pyasn1-modules))
7533
7534 (define-public python-ipaddress
7535 (package
7536 (name "python-ipaddress")
7537 (version "1.0.18")
7538 (source (origin
7539 (method url-fetch)
7540 (uri (pypi-uri "ipaddress" version))
7541 (sha256
7542 (base32
7543 "1q8klj9d84cmxgz66073x1j35cplr3r77vx1znhxiwl5w74391ax"))))
7544 (build-system python-build-system)
7545 (home-page "https://github.com/phihag/ipaddress")
7546 (synopsis "IP address manipulation library")
7547 (description
7548 "This package provides a fast, lightweight IPv4/IPv6 manipulation library
7549 in Python. This library is used to create, poke at, and manipulate IPv4 and
7550 IPv6 addresses and networks. This is a port of the Python 3.3 ipaddress
7551 module to older versions of Python.")
7552 (license license:psfl)))
7553
7554 (define-public python2-ipaddress
7555 (package-with-python2 python-ipaddress))
7556
7557 (define-public python2-ipaddr
7558 (package
7559 (name "python2-ipaddr")
7560 (version "2.1.11")
7561 (source
7562 (origin
7563 (method url-fetch)
7564 (uri (pypi-uri "ipaddr" version))
7565 (sha256
7566 (base32 "1dwq3ngsapjc93fw61rp17fvzggmab5x1drjzvd4y4q0i255nm8v"))))
7567 (build-system python-build-system)
7568 (arguments
7569 `(#:python ,python-2 ;version 2 only
7570 #:phases
7571 (modify-phases %standard-phases
7572 (replace 'check
7573 (lambda* _
7574 (zero? (system* "python" "ipaddr_test.py")))))))
7575 (home-page "https://github.com/google/ipaddr-py")
7576 (synopsis "IP address manipulation library")
7577 (description
7578 "Ipaddr is a Python@tie{}2 library for creating and manupilating IPv4 and
7579 IPv6 addresses and networks.
7580
7581 For new implementations you may prefer to use the standard module
7582 @code{ipaddress}, which was introduced in Python 3.3 and backported to older
7583 versions of Python.")
7584 (license license:asl2.0)))
7585
7586 (define-public python-idna
7587 (package
7588 (name "python-idna")
7589 (version "2.5")
7590 (source
7591 (origin
7592 (method url-fetch)
7593 (uri (pypi-uri "idna" version))
7594 (sha256
7595 (base32
7596 "1ara12a7k2zc69msa0arrvw00gn61a6i6by01xb3lkkc0h4cxd9w"))))
7597 (build-system python-build-system)
7598 (home-page "https://github.com/kjd/idna")
7599 (synopsis "Internationalized domain names in applications")
7600 (description
7601 "This is a library to support the Internationalised Domain Names in
7602 Applications (IDNA) protocol as specified in RFC 5891. This version of the
7603 protocol is often referred to as “IDNA2008” and can produce different results
7604 from the earlier standard from 2003. The library is also intended to act as a
7605 suitable drop-in replacement for the “encodings.idna” module that comes with
7606 the Python standard library but currently only supports the older 2003
7607 specification.")
7608 (license license:bsd-4)))
7609
7610 (define-public python2-idna
7611 (package-with-python2 python-idna))
7612
7613 (define-public python-pretend
7614 (package
7615 (name "python-pretend")
7616 (version "1.0.8")
7617 (source
7618 (origin
7619 (method url-fetch)
7620 (uri (string-append "https://pypi.python.org/packages/source/p/"
7621 "pretend/pretend-" version ".tar.gz"))
7622 (sha256
7623 (base32
7624 "0r5r7ygz9m6d2bklflbl84cqhjkc2q12xgis8268ygjh30g2q3wk"))))
7625 (build-system python-build-system)
7626 (home-page "https://github.com/alex/pretend")
7627 (synopsis "Library for stubbing in Python")
7628 (description
7629 "Pretend is a library to make stubbing with Python easier. Stubbing is a
7630 technique for writing tests. You may hear the term mixed up with mocks,
7631 fakes, or doubles. Basically, a stub is an object that returns pre-canned
7632 responses, rather than doing any computation.")
7633 (license license:bsd-3)))
7634
7635 (define-public python2-pretend
7636 (package-with-python2 python-pretend))
7637
7638 (define-public python-cryptography-vectors
7639 (package
7640 (name "python-cryptography-vectors")
7641 (version "2.0")
7642 (source
7643 (origin
7644 (method url-fetch)
7645 (uri (pypi-uri "cryptography_vectors" version))
7646 (sha256
7647 (base32
7648 "0qadys01517k5wy0rifxip02p08kzrqxm5j0lmmlp0kr07h9jc7h"))))
7649 (build-system python-build-system)
7650 (home-page "https://github.com/pyca/cryptography")
7651 (synopsis "Test vectors for the cryptography package")
7652 (description
7653 "This package contains test vectors for the cryptography package.")
7654 ;; Distributed under either BSD-3 or ASL2.0
7655 (license (list license:bsd-3 license:asl2.0))))
7656
7657 (define-public python2-cryptography-vectors
7658 (package-with-python2 python-cryptography-vectors))
7659
7660 (define-public python-cryptography
7661 (package
7662 (name "python-cryptography")
7663 (version "2.0")
7664 (source
7665 (origin
7666 (method url-fetch)
7667 (uri (pypi-uri "cryptography" version))
7668 (sha256
7669 (base32
7670 "1c40qlxyn1jgg99f3pqi7146d3561rn9zdqc7w8f7kwr9ysm696k"))))
7671 (build-system python-build-system)
7672 (inputs
7673 `(("openssl" ,openssl)))
7674 (propagated-inputs
7675 `(("python-asn1crypto" ,python-asn1crypto)
7676 ("python-cffi" ,python-cffi)
7677 ("python-six" ,python-six)
7678 ("python-idna" ,python-idna)
7679 ("python-iso8601" ,python-iso8601)))
7680 (native-inputs
7681 `(("python-cryptography-vectors" ,python-cryptography-vectors)
7682 ("python-hypothesis" ,python-hypothesis)
7683 ("python-pretend" ,python-pretend)
7684 ("python-pytz" ,python-pytz)
7685 ("python-pytest" ,python-pytest-3.0)))
7686 (home-page "https://github.com/pyca/cryptography")
7687 (synopsis "Cryptographic recipes and primitives for Python")
7688 (description
7689 "cryptography is a package which provides cryptographic recipes and
7690 primitives to Python developers. It aims to be the “cryptographic standard
7691 library” for Python. The package includes both high level recipes, and low
7692 level interfaces to common cryptographic algorithms such as symmetric ciphers,
7693 message digests and key derivation functions.")
7694 ;; Distributed under either BSD-3 or ASL2.0
7695 (license (list license:bsd-3 license:asl2.0))
7696 (properties `((python2-variant . ,(delay python2-cryptography))))))
7697
7698 (define-public python2-cryptography
7699 (let ((crypto (package-with-python2
7700 (strip-python2-variant python-cryptography))))
7701 (package (inherit crypto)
7702 (propagated-inputs
7703 `(("python2-ipaddress" ,python2-ipaddress)
7704 ("python2-backport-ssl-match-hostname"
7705 ,python2-backport-ssl-match-hostname)
7706 ("python2-enum34" ,python2-enum34)
7707 ,@(package-propagated-inputs crypto))))))
7708
7709 (define-public python-pyopenssl
7710 (package
7711 (name "python-pyopenssl")
7712 (version "17.1.0")
7713 (source
7714 (origin
7715 (method url-fetch)
7716 (uri (pypi-uri "pyOpenSSL" version))
7717 (patches
7718 (search-patches "python-pyopenssl-17.1.0-test-overflow.patch"))
7719 (sha256
7720 (base32
7721 "0qwmqhfsq84ydir9dz273ypmlcvs7v71m1jns0sd4k0h6lfsa82s"))))
7722 (build-system python-build-system)
7723 (arguments
7724 '(#:phases
7725 (modify-phases %standard-phases
7726 (delete 'check)
7727 (add-after 'install 'check
7728 (lambda* (#:key inputs outputs #:allow-other-keys)
7729 (add-installed-pythonpath inputs outputs)
7730 (zero? (system* "py.test" "-v" "-k"
7731 (string-append
7732 ;; This test tries to look up certificates from
7733 ;; the compiled-in default path in OpenSSL, which
7734 ;; does not exist in the build environment.
7735 "not test_fallback_default_verify_paths "
7736 ;; This test attempts to make a connection to
7737 ;; an external web service.
7738 "and not test_set_default_verify_paths"))))))))
7739 (propagated-inputs
7740 `(("python-cryptography" ,python-cryptography)
7741 ("python-six" ,python-six)))
7742 (inputs
7743 `(("openssl" ,openssl)))
7744 (native-inputs
7745 `(("python-pretend" ,python-pretend)
7746 ("python-pytest" ,python-pytest-3.0)))
7747 (home-page "https://github.com/pyca/pyopenssl")
7748 (synopsis "Python wrapper module around the OpenSSL library")
7749 (description
7750 "PyOpenSSL is a high-level wrapper around a subset of the OpenSSL
7751 library.")
7752 (license license:asl2.0)))
7753
7754 (define-public python2-pyopenssl
7755 (package-with-python2 python-pyopenssl))
7756
7757 (define-public python-pip
7758 (package
7759 (name "python-pip")
7760 (version "9.0.1")
7761 (source
7762 (origin
7763 (method url-fetch)
7764 (uri (pypi-uri "pip" version))
7765 (sha256
7766 (base32
7767 "03clr9c1dih5n9c00c592zzvf6r1ffimywkaq9agcqdllzhl7wh9"))))
7768 (build-system python-build-system)
7769 (arguments
7770 '(#:tests? #f)) ; there are no tests in the pypi archive.
7771 (home-page "https://pip.pypa.io/")
7772 (synopsis "Package manager for Python software")
7773 (description
7774 "Pip is a package manager for Python software, that finds packages on the
7775 Python Package Index (PyPI).")
7776 (license license:expat)))
7777
7778 (define-public python2-pip
7779 (package-with-python2 python-pip))
7780
7781 (define-public python-tlsh
7782 (package
7783 (name "python-tlsh")
7784 (version "3.4.4")
7785 (home-page "https://github.com/trendmicro/tlsh")
7786 (source (origin
7787 (method url-fetch)
7788 (uri (string-append "https://github.com/trendmicro/tlsh/archive/v"
7789 version ".tar.gz"))
7790 (sha256
7791 (base32
7792 "00bhzjqrlh7v538kbkbn8lgx976j1138al3sdhklaizqjvpwyk4r"))
7793 (file-name (string-append name "-" version ".tar.gz"))))
7794 (build-system cmake-build-system)
7795 (arguments
7796 '(#:out-of-source? #f
7797 #:phases (modify-phases %standard-phases
7798 (replace
7799 'install
7800 (lambda* (#:key outputs #:allow-other-keys)
7801 ;; Build and install the Python bindings. The underlying
7802 ;; C++ library is apparently not meant to be installed.
7803 (let ((out (assoc-ref outputs "out")))
7804 (with-directory-excursion "py_ext"
7805 (and (system* "python" "setup.py" "build")
7806 (system* "python" "setup.py" "install"
7807 (string-append "--prefix=" out))))))))))
7808 (inputs `(("python" ,python-wrapper))) ;for the bindings
7809 (synopsis "Fuzzy matching library for Python")
7810 (description
7811 "Trend Micro Locality Sensitive Hash (TLSH) is a fuzzy matching library.
7812 Given a byte stream with a minimum length of 256 bytes, TLSH generates a hash
7813 value which can be used for similarity comparisons. Similar objects have
7814 similar hash values, which allows for the detection of similar objects by
7815 comparing their hash values. The byte stream should have a sufficient amount
7816 of complexity; for example, a byte stream of identical bytes will not generate
7817 a hash value.")
7818 (license license:asl2.0)))
7819
7820 (define-public python2-tlsh
7821 (package
7822 (inherit python-tlsh)
7823 (name "python2-tlsh")
7824 (inputs `(("python" ,python-2)))))
7825
7826 (define-public python-termcolor
7827 (package
7828 (name "python-termcolor")
7829 (version "1.1.0")
7830 (source
7831 (origin
7832 (method url-fetch)
7833 (uri (pypi-uri "termcolor" version))
7834 (sha256
7835 (base32
7836 "0fv1vq14rpqwgazxg4981904lfyp84mnammw7y046491cv76jv8x"))))
7837 (build-system python-build-system)
7838 (arguments
7839 ;; There are no tests.
7840 `(#:tests? #f))
7841 (home-page "http://pypi.python.org/pypi/termcolor")
7842 (synopsis "ANSII Color formatting for terminal output")
7843 (description
7844 "This package provides ANSII Color formatting for output in terminals.")
7845 (license license:expat)))
7846
7847 (define-public python2-termcolor
7848 (package-with-python2 python-termcolor))
7849
7850 (define-public python-libarchive-c
7851 (package
7852 (name "python-libarchive-c")
7853 (version "2.2")
7854 (source (origin
7855 (method url-fetch)
7856 (uri (pypi-uri "libarchive-c" version))
7857 (sha256
7858 (base32
7859 "0z4r7v3dhd6b3120mav05ff08srih176r2rg5k8kn7mjd9pslm2x"))))
7860 (build-system python-build-system)
7861 (arguments
7862 '(#:phases (modify-phases %standard-phases
7863 (add-before
7864 'build 'reference-libarchive
7865 (lambda* (#:key inputs #:allow-other-keys)
7866 ;; Retain the absolute file name of libarchive.so.
7867 (let ((libarchive (assoc-ref inputs "libarchive")))
7868 (substitute* "libarchive/ffi.py"
7869 (("find_library\\('archive'\\)")
7870 (string-append "'" libarchive
7871 "/lib/libarchive.so'")))))))))
7872 (inputs
7873 `(("libarchive" ,libarchive)))
7874 (home-page "https://github.com/Changaco/python-libarchive-c")
7875 (synopsis "Python interface to libarchive")
7876 (description
7877 "This package provides Python bindings to libarchive, a C library to
7878 access possibly compressed archives in many different formats. It uses
7879 Python's @code{ctypes} foreign function interface (FFI).")
7880 (license license:lgpl2.0+)))
7881
7882 (define-public python2-libarchive-c
7883 (package-with-python2 python-libarchive-c))
7884
7885 (define-public python-file
7886 (package
7887 (inherit file)
7888 (name "python-file")
7889 (source (origin
7890 (inherit (package-source file))
7891 ;; This patch should not be applied to python2-file.
7892 (patches (search-patches "python-file-double-encoding-bug.patch"))))
7893 (build-system python-build-system)
7894 (arguments
7895 '(#:tests? #f ;no tests
7896 #:configure-flags '("--single-version-externally-managed" "--root=/")
7897 #:phases (modify-phases %standard-phases
7898 (add-before 'build 'change-directory
7899 (lambda _
7900 (chdir "python")
7901 #t))
7902 (add-before 'build 'set-library-file-name
7903 (lambda* (#:key inputs #:allow-other-keys)
7904 (let ((file (assoc-ref inputs "file")))
7905 (substitute* "magic.py"
7906 (("find_library\\('magic'\\)")
7907 (string-append "'" file "/lib/libmagic.so'")))
7908 #t))))))
7909 (inputs `(("file" ,file)))
7910 (self-native-input? #f)
7911 (synopsis "Python bindings to the libmagic file type guesser. Note that
7912 this module and the python-magic module both provide a \"magic.py\" file;
7913 these two modules, which are different and were developed separately, both
7914 serve the same purpose: provide Python bindings for libmagic.")))
7915
7916 (define-public python2-file
7917 (package-with-python2 python-file))
7918
7919 (define-public python-debian
7920 (package
7921 (name "python-debian")
7922 (version "0.1.28")
7923 (source
7924 (origin
7925 (method url-fetch)
7926 (uri (pypi-uri name version))
7927 (sha256
7928 (base32
7929 "0i15f0xzx679sd0ldq2sls9pnnps9fv6vhqvnv9dzf4qhma42i0y"))))
7930 (build-system python-build-system)
7931 (propagated-inputs
7932 `(("python-six" ,python-six)))
7933 (home-page "http://packages.debian.org/sid/python-debian")
7934 (synopsis "Debian package related modules")
7935 (description
7936 ;; XXX: Use @enumerate instead of @itemize to work around
7937 ;; <http://bugs.gnu.org/21772>.
7938 "This package provides Python modules that abstract many formats of
7939 Debian-related files, such as:
7940
7941 @enumerate
7942 @item Debtags information;
7943 @item @file{debian/changelog} files;
7944 @item packages files, pdiffs;
7945 @item control files of single or multiple RFC822-style paragraphs---e.g.
7946 @file{debian/control}, @file{.changes}, @file{.dsc};
7947 @item Raw @file{.deb} and @file{.ar} files, with (read-only) access to
7948 contained files and meta-information.
7949 @end enumerate\n")
7950
7951 ;; Modules are either GPLv2+ or GPLv3+.
7952 (license license:gpl3+)))
7953
7954 (define-public python2-debian
7955 (package-with-python2 python-debian))
7956
7957 (define-public python-nbformat
7958 (package
7959 (name "python-nbformat")
7960 (version "4.1.0")
7961 (source
7962 (origin
7963 (method url-fetch)
7964 (uri (pypi-uri "nbformat" version))
7965 (sha256
7966 (base32
7967 "0mq8iki3d4mnx7wy05phss7x98mds4fqydin8lcagidp1knw1xnv"))))
7968 (build-system python-build-system)
7969 (arguments `(#:tests? #f)) ; no test target
7970 (propagated-inputs
7971 `(("python-ipython-genutils" ,python-ipython-genutils)
7972 ("python-jsonschema" ,python-jsonschema)
7973 ("python-jupyter-core" ,python-jupyter-core)
7974 ("python-traitlets" ,python-traitlets)))
7975 (home-page "http://jupyter.org")
7976 (synopsis "Jupyter Notebook format")
7977 (description "This package provides the reference implementation of the
7978 Jupyter Notebook format and Python APIs for working with notebooks.")
7979 (license license:bsd-3)))
7980
7981 (define-public python2-nbformat
7982 (package-with-python2 python-nbformat))
7983
7984 (define-public python-bleach
7985 (package
7986 (name "python-bleach")
7987 (version "1.4.3")
7988 (source
7989 (origin
7990 (method url-fetch)
7991 (uri (pypi-uri "bleach" version))
7992 (sha256
7993 (base32
7994 "0jvg3jxrvnx7xmm9gj262v60ib452xlnwlb0navyp7jsvcd0d4qj"))))
7995 (build-system python-build-system)
7996 (propagated-inputs
7997 `(("python-html5lib" ,python-html5lib-0.9)
7998 ("python-six" ,python-six)))
7999 (native-inputs
8000 `(("python-nose" ,python-nose)))
8001 (home-page "https://github.com/jsocol/bleach")
8002 (synopsis "Whitelist-based HTML-sanitizing tool")
8003 (description "Bleach is an easy whitelist-based HTML-sanitizing tool.")
8004 (license license:asl2.0)))
8005
8006 (define-public python2-bleach
8007 (package-with-python2 python-bleach))
8008
8009 (define-public python-entrypoints
8010 (package
8011 (name "python-entrypoints")
8012 (version "0.2.2")
8013 (source
8014 (origin
8015 (method url-fetch)
8016 (uri (string-append "https://github.com/takluyver/entrypoints/archive/"
8017 version ".tar.gz"))
8018 (file-name (string-append name "-" version ".tar.gz"))
8019 (sha256
8020 (base32
8021 "0azqlkh3j0za080lsf5crnhaxx3c93k9dpv5ihkhf5cppgw5sjz5"))))
8022 (build-system python-build-system)
8023 ;; The package does not come with a setup.py file, so we have to generate
8024 ;; one ourselves.
8025 (arguments
8026 `(#:tests? #f
8027 #:phases
8028 (modify-phases %standard-phases
8029 (add-after 'unpack 'create-setup.py
8030 (lambda _
8031 (call-with-output-file "setup.py"
8032 (lambda (port)
8033 (format port "\
8034 from setuptools import setup
8035 setup(name='entrypoints', version='~a', py_modules=['entrypoints'])
8036 " ,version))))))))
8037 (home-page "https://github.com/takluyver/entrypoints")
8038 (synopsis "Discover and load entry points from installed Python packages")
8039 (description "Entry points are a way for Python packages to advertise
8040 objects with some common interface. The most common examples are
8041 @code{console_scripts} entry points, which define shell commands by
8042 identifying a Python function to run. The @code{entrypoints} module contains
8043 functions to find and load entry points.")
8044 (license license:expat)))
8045
8046 (define-public python2-entrypoints
8047 (package-with-python2 python-entrypoints))
8048
8049 (define-public python-nbconvert
8050 (package
8051 (name "python-nbconvert")
8052 (version "5.0.0b1")
8053 (source
8054 (origin
8055 (method url-fetch)
8056 (uri (pypi-uri "nbconvert" version))
8057 (sha256
8058 (base32
8059 "0brclbb18l4nmd5qy3dl9wn05rjdh1fz4rmzdlfqacj12rcdvdgp"))))
8060 (build-system python-build-system)
8061 (arguments
8062 `(;; The "bdist_egg" target is disabled by default, causing the installation
8063 ;; to fail.
8064 #:configure-flags (list "bdist_egg")
8065 ;; FIXME: 5 failures, 40 errors.
8066 #:tests? #f))
8067 ;; #:phases
8068 ;; (modify-phases %standard-phases
8069 ;; (replace 'check
8070 ;; (lambda _
8071 ;; (zero? (system* "py.test" "-v")))))
8072 (native-inputs
8073 `(("python-pytest" ,python-pytest)))
8074 (propagated-inputs
8075 `(("python-bleach" ,python-bleach)
8076 ("python-entrypoints" ,python-entrypoints)
8077 ("python-jinja2" ,python-jinja2)
8078 ("python-jupyter-core" ,python-jupyter-core)
8079 ("python-mistune" ,python-mistune)
8080 ("python-nbformat" ,python-nbformat)
8081 ("python-pygments" ,python-pygments)
8082 ("python-traitlets" ,python-traitlets)))
8083 (home-page "http://jupyter.org")
8084 (synopsis "Converting Jupyter Notebooks")
8085 (description "The @code{nbconvert} tool, @{jupyter nbconvert}, converts
8086 notebooks to various other formats via Jinja templates. It allows you to
8087 convert an @code{.ipynb} notebook file into various static formats including:
8088
8089 @enumerate
8090 @item HTML
8091 @item LaTeX
8092 @item PDF
8093 @item Reveal JS
8094 @item Markdown (md)
8095 @item ReStructured Text (rst)
8096 @item executable script
8097 @end enumerate\n")
8098 (license license:bsd-3)))
8099
8100 (define-public python2-nbconvert
8101 (package-with-python2 python-nbconvert))
8102
8103 (define-public python-notebook
8104 (package
8105 (name "python-notebook")
8106 (version "4.2.3")
8107 (source (origin
8108 (method url-fetch)
8109 (uri (pypi-uri "notebook" version))
8110 (sha256
8111 (base32
8112 "0laq5c2f21frq6xcdckgq7raqhznbjb0qs0357g612z87wyn1a9r"))))
8113 (build-system python-build-system)
8114 (arguments
8115 `(#:phases
8116 (modify-phases %standard-phases
8117 (replace 'check
8118 (lambda _
8119 ;; HOME must be set for tests
8120 (setenv "HOME" "/tmp")
8121 (zero? (system* "nosetests")))))))
8122 (propagated-inputs
8123 `(("python-jupyter-core" ,python-jupyter-core)
8124 ("python-nbformat" ,python-nbformat)
8125 ("python-nbconvert" ,python-nbconvert)
8126 ("python-ipython" ,python-ipython)))
8127 (native-inputs
8128 `(("python-nose" ,python-nose)
8129 ("python-sphinx" ,python-sphinx)
8130 ("python-requests" ,python-requests)))
8131 (home-page "http://jupyter.org/")
8132 (synopsis "Web-based notebook environment for interactive computing")
8133 (description
8134 "The Jupyter HTML notebook is a web-based notebook environment for
8135 interactive computing.")
8136 (properties `((python2-variant . ,(delay python2-notebook))))
8137 (license license:bsd-3)))
8138
8139 (define-public python2-notebook
8140 (let ((base (package-with-python2
8141 (strip-python2-variant python-notebook))))
8142 (package (inherit base)
8143 (native-inputs
8144 `(("python2-mock" ,python2-mock)
8145 ,@(package-native-inputs base)))
8146 (arguments
8147 (substitute-keyword-arguments (package-arguments base)
8148 ((#:phases phases)
8149 `(modify-phases ,phases
8150 (add-before 'check 'disable-test-case
8151 ;; The test requires network access to localhost. Curiously it
8152 ;; fails with Python 2 only. Simply make the test-case return
8153 ;; immediately.
8154 (lambda _
8155 (substitute*
8156 "notebook/services/nbconvert/tests/test_nbconvert_api.py"
8157 (("formats = self.nbconvert_api") "return #")))))))))))
8158
8159 (define-public python-widgetsnbextension
8160 (package
8161 (name "python-widgetsnbextension")
8162 (version "1.2.6")
8163 (source
8164 (origin
8165 (method url-fetch)
8166 (uri (pypi-uri "widgetsnbextension" version))
8167 (sha256
8168 (base32
8169 "0lff2mrwrgsa1mxmwx3phl9xvy0jqfpg6khbmxy53jbq56rwy666"))))
8170 (build-system python-build-system)
8171 (propagated-inputs
8172 `(("python-notebook" ,python-notebook)))
8173 (native-inputs
8174 `(("python-certifi" ,python-certifi)
8175 ("python-nose" ,python-nose)))
8176 (home-page "http://ipython.org")
8177 (synopsis "IPython HTML widgets for Jupyter")
8178 (description "This package provides interactive HTML widgets for Jupyter
8179 notebooks.")
8180 (license license:bsd-3)))
8181
8182 (define-public python2-widgetsnbextension
8183 (package-with-python2 python-widgetsnbextension))
8184
8185 (define-public python-ipywidgets
8186 (package
8187 (name "python-ipywidgets")
8188 (version "5.2.2")
8189 (source
8190 (origin
8191 (method url-fetch)
8192 (uri (pypi-uri "ipywidgets" version))
8193 (sha256
8194 (base32
8195 "1lk0qrr5l9a0z7qkkn30hv5832whxwxymf1l576fmmad0n7hkxms"))))
8196 (build-system python-build-system)
8197 ;; FIXME: it's not clear how to run the tests.
8198 (arguments `(#:tests? #f))
8199 (propagated-inputs
8200 `(("python-ipykernel" ,python-ipykernel)
8201 ("python-ipython" ,python-ipython)
8202 ("python-traitlets" ,python-traitlets)
8203 ("python-widgetsnbextension" ,python-widgetsnbextension)))
8204 (home-page "http://ipython.org")
8205 (synopsis "IPython HTML widgets for Jupyter")
8206 (description "Ipywidgets are interactive HTML widgets for Jupyter
8207 notebooks and the IPython kernel. Notebooks come alive when interactive
8208 widgets are used. Users gain control of their data and can visualize changes
8209 in the data.")
8210 (license license:bsd-3)))
8211
8212 (define-public python2-ipywidgets
8213 (package-with-python2 python-ipywidgets))
8214
8215 (define-public python-jupyter-console
8216 (package
8217 (name "python-jupyter-console")
8218 (version "5.0.0")
8219 (source
8220 (origin
8221 (method url-fetch)
8222 (uri (pypi-uri "jupyter_console" version))
8223 (sha256
8224 (base32
8225 "04acmkwsi99rcg3vb54c6n492zv35s92h2ahabc0w6wj976cipvx"))))
8226 (build-system python-build-system)
8227 ;; FIXME: it's not clear how to run the tests.
8228 (arguments `(#:tests? #f))
8229 (propagated-inputs
8230 `(("python-ipykernel" ,python-ipykernel)
8231 ("python-ipython" ,python-ipython)
8232 ("python-jupyter-client" ,python-jupyter-client)
8233 ("python-prompt-toolkit" ,python-prompt-toolkit)
8234 ("python-pygments" ,python-pygments)))
8235 (home-page "https://jupyter.org")
8236 (synopsis "Jupyter terminal console")
8237 (description "This package provides a terminal-based console frontend for
8238 Jupyter kernels. It also allows for console-based interaction with non-Python
8239 Jupyter kernels such as IJulia and IRKernel.")
8240 (license license:bsd-3)))
8241
8242 (define-public python2-jupyter-console
8243 (package-with-python2 python-jupyter-console))
8244
8245 (define-public jupyter
8246 (package
8247 (name "jupyter")
8248 (version "1.0.0")
8249 (source
8250 (origin
8251 (method url-fetch)
8252 (uri (pypi-uri "jupyter" version))
8253 (sha256
8254 (base32
8255 "0pwf3pminkzyzgx5kcplvvbvwrrzd3baa7lmh96f647k30rlpp6r"))))
8256 (build-system python-build-system)
8257 ;; FIXME: it's not clear how to run the tests.
8258 (arguments `(#:tests? #f))
8259 (propagated-inputs
8260 `(("python-ipykernel" ,python-ipykernel)
8261 ("python-ipywidgets" ,python-ipywidgets)
8262 ("python-jupyter-console" ,python-jupyter-console)
8263 ("python-nbconvert" ,python-nbconvert)
8264 ("python-notebook" ,python-notebook)))
8265 (home-page "http://jupyter.org")
8266 (synopsis "Web application for interactive documents")
8267 (description
8268 "The Jupyter Notebook is a web application that allows you to create and
8269 share documents that contain live code, equations, visualizations and
8270 explanatory text. Uses include: data cleaning and transformation, numerical
8271 simulation, statistical modeling, machine learning and much more.")
8272 (license license:bsd-3)))
8273
8274 (define-public python-chardet
8275 (package
8276 (name "python-chardet")
8277 (version "2.3.0")
8278 (source
8279 (origin
8280 (method url-fetch)
8281 (uri (string-append
8282 "https://pypi.python.org/packages/source/c/chardet/chardet-"
8283 version
8284 ".tar.gz"))
8285 (sha256
8286 (base32
8287 "1ak87ikcw34fivcgiz2xvi938dmclh078az65l9x3rmgljrkhgp5"))))
8288 (build-system python-build-system)
8289 (home-page "https://github.com/chardet/chardet")
8290 (synopsis "Universal encoding detector for Python 2 and 3")
8291 (description
8292 "This package provides @code{chardet}, a Python module that can
8293 automatically detect a wide range of file encodings.")
8294 (license license:lgpl2.1+)))
8295
8296 (define-public python2-chardet
8297 (package-with-python2 python-chardet))
8298
8299 (define-public python-docopt
8300 (package
8301 (name "python-docopt")
8302 (version "0.6.2")
8303 (source
8304 (origin
8305 (method url-fetch)
8306 ;; The release on PyPI does not include tests.
8307 (uri (string-append
8308 "https://github.com/docopt/docopt/archive/"
8309 version ".tar.gz"))
8310 (file-name (string-append name "-" version ".tar.gz"))
8311 (sha256
8312 (base32
8313 "16bf890xbdz3m30rsv2qacklh2rdn1zrfspfnwzx9g7vwz8yw4r1"))))
8314 (build-system python-build-system)
8315 (native-inputs
8316 `(("python-pytest" ,python-pytest)))
8317 (arguments
8318 `(#:phases (alist-replace
8319 'check
8320 (lambda _ (zero? (system* "py.test")))
8321 %standard-phases)))
8322 (home-page "http://docopt.org")
8323 (synopsis "Command-line interface description language for Python")
8324 (description "This library allows the user to define a command-line
8325 interface from a program's help message rather than specifying it
8326 programatically with command-line parsers like @code{getopt} and
8327 @code{argparse}.")
8328 (license license:expat)))
8329
8330 (define-public python2-docopt
8331 (package-with-python2 python-docopt))
8332
8333 (define-public python-zope-event
8334 (package
8335 (name "python-zope-event")
8336 (version "4.1.0")
8337 (source
8338 (origin
8339 (method url-fetch)
8340 (uri (string-append "https://pypi.python.org/packages/source/z"
8341 "/zope.event/zope.event-" version ".tar.gz"))
8342 (sha256
8343 (base32
8344 "11p75zpfz3ffhz21nzx9wb23xs993ck5s6hkjcvhswwizni5jynw"))))
8345 (build-system python-build-system)
8346 (home-page "http://pypi.python.org/pypi/zope.event")
8347 (synopsis "Event publishing system for Python")
8348 (description "Zope.event provides an event publishing API, intended for
8349 use by applications which are unaware of any subscribers to their events. It
8350 is a simple event-dispatching system on which more sophisticated event
8351 dispatching systems can be built.")
8352 (license license:zpl2.1)))
8353
8354 (define-public python2-zope-event
8355 (package-with-python2 python-zope-event))
8356
8357 (define-public python-zope-interface
8358 (package
8359 (name "python-zope-interface")
8360 (version "4.1.3")
8361 (source
8362 (origin
8363 (method url-fetch)
8364 (uri (string-append "https://pypi.python.org/packages/source/z"
8365 "/zope.interface/zope.interface-" version ".tar.gz"))
8366 (sha256
8367 (base32
8368 "0ks8h73b2g4bkad821qbv0wzjppdrwys33i7ka45ik3wxjg1l8if"))))
8369 (build-system python-build-system)
8370 (native-inputs
8371 `(("python-zope-event" ,python-zope-event)))
8372 (home-page "https://github.com/zopefoundation/zope.interface")
8373 (synopsis "Python implementation of the \"design by contract\"
8374 methodology")
8375 (description "Zope.interface provides an implementation of \"object
8376 interfaces\" for Python. Interfaces are a mechanism for labeling objects as
8377 conforming to a given API or contract.")
8378 (license license:zpl2.1)))
8379
8380 (define-public python2-zope-interface
8381 (package-with-python2 python-zope-interface))
8382
8383 (define-public python-zope-exceptions
8384 (package
8385 (name "python-zope-exceptions")
8386 (version "4.0.8")
8387 (source
8388 (origin
8389 (method url-fetch)
8390 (uri (string-append "https://pypi.python.org/packages/source/z"
8391 "/zope.exceptions/zope.exceptions-"
8392 version ".tar.gz"))
8393 (sha256
8394 (base32
8395 "0zwxaaa66sqxg5k7zcrvs0fbg9ym1njnxnr28dfmchzhwjvwnfzl"))))
8396 (build-system python-build-system)
8397 (arguments
8398 '(#:tests? #f)) ; circular dependency with zope.testrunner
8399 (propagated-inputs
8400 `(("python-zope-interface" ,python-zope-interface)))
8401 (home-page "http://cheeseshop.python.org/pypi/zope.exceptions")
8402 (synopsis "Zope exceptions")
8403 (description "Zope.exceptions provides general-purpose exception types
8404 that have uses outside of the Zope framework.")
8405 (license license:zpl2.1)))
8406
8407 (define-public python2-zope-exceptions
8408 (package-with-python2 python-zope-exceptions))
8409
8410 (define-public python-zope-testing
8411 (package
8412 (name "python-zope-testing")
8413 (version "4.5.0")
8414 (source
8415 (origin
8416 (method url-fetch)
8417 (uri (string-append "https://pypi.python.org/packages/source/z"
8418 "/zope.testing/zope.testing-" version ".tar.gz"))
8419 (sha256
8420 (base32
8421 "1yvglxhzvhl45mndvn9gskx2ph30zz1bz7rrlyfs62fv2pvih90s"))
8422 (modules '((guix build utils)))
8423 (snippet
8424 '(begin
8425 ;; Remove pre-compiled .pyc files backup files from source.
8426 (for-each delete-file (find-files "." "(\\.pyc|~)$"))
8427 #t))))
8428 (build-system python-build-system)
8429 (native-inputs
8430 `(("python-zope-exceptions" ,python-zope-exceptions)))
8431 (propagated-inputs
8432 `(("python-zope-interface" ,python-zope-interface)))
8433 (home-page "http://pypi.python.org/pypi/zope.testing")
8434 (synopsis "Zope testing helpers")
8435 (description "Zope.testing provides a number of testing utilities for HTML
8436 forms, HTTP servers, regular expressions, and more.")
8437 (license license:zpl2.1)))
8438
8439 (define-public python2-zope-testing
8440 (package-with-python2 python-zope-testing))
8441
8442 (define-public python-zope-testrunner
8443 (package
8444 (name "python-zope-testrunner")
8445 (version "4.4.9")
8446 (source
8447 (origin
8448 (method url-fetch)
8449 (uri (string-append "https://pypi.python.org/packages/source/z"
8450 "/zope.testrunner/zope.testrunner-"
8451 version ".zip"))
8452 (sha256
8453 (base32
8454 "1r7iqknhh55y45f64mz5hghgvzx34h1i11k350s0avx6q8gznja1"))))
8455 (build-system python-build-system)
8456 (arguments
8457 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8458 (native-inputs
8459 `(("python-six" ,python-six)
8460 ;("python-zope-interface" ,python-zope-interface)
8461 ("python-zope-exceptions" ,python-zope-exceptions)
8462 ("python-zope-testing" ,python-zope-testing)
8463 ("unzip" ,unzip)))
8464 (propagated-inputs
8465 `(("python-zope-interface" ,python-zope-interface)))
8466 (home-page "http://pypi.python.org/pypi/zope.testrunner")
8467 (synopsis "Zope testrunner script")
8468 (description "Zope.testrunner provides a script for running Python
8469 tests.")
8470 (license license:zpl2.1)))
8471
8472 (define-public python2-zope-testrunner
8473 (let ((base (package-with-python2 python-zope-testrunner)))
8474 (package
8475 (inherit base)
8476 (native-inputs
8477 (append (package-native-inputs base)
8478 `(("python2-subunit" ,python2-subunit)
8479 ("python2-mimeparse" ,python2-mimeparse)))))))
8480
8481 (define-public python-zope-i18nmessageid
8482 (package
8483 (name "python-zope-i18nmessageid")
8484 (version "4.0.3")
8485 (source
8486 (origin
8487 (method url-fetch)
8488 (uri (string-append
8489 "https://pypi.python.org/packages/source/z"
8490 "/zope.i18nmessageid/zope.i18nmessageid-"
8491 version ".tar.gz"))
8492 (sha256
8493 (base32
8494 "1rslyph0klk58dmjjy4j0jxy21k03azksixc3x2xhqbkv97cmzml"))))
8495 (build-system python-build-system)
8496 (home-page "http://pypi.python.org/pypi/zope.i18nmessageid")
8497 (synopsis "Message identifiers for internationalization")
8498 (description "Zope.i18nmessageid provides facilities for declaring
8499 internationalized messages within program source text.")
8500 (license license:zpl2.1)))
8501
8502 (define-public python2-zope-i18nmessageid
8503 (package-with-python2 python-zope-i18nmessageid))
8504
8505 (define-public python-zope-schema
8506 (package
8507 (name "python-zope-schema")
8508 (version "4.4.2")
8509 (source
8510 (origin
8511 (method url-fetch)
8512 (uri (string-append "https://pypi.python.org/packages/source/z"
8513 "/zope.schema/zope.schema-" version ".tar.gz"))
8514 (sha256
8515 (base32
8516 "1p943jdxb587dh7php4vx04qvn7b2877hr4qs5zyckvp5afhhank"))))
8517 (build-system python-build-system)
8518 (arguments
8519 '(#:tests? #f)) ; FIXME: Tests can't find zope.event.
8520 (propagated-inputs
8521 `(("python-zope-event" ,python-zope-event)
8522 ("python-zope-exceptions", python-zope-exceptions)
8523 ("python-zope-interface" ,python-zope-interface)))
8524 (native-inputs
8525 `(("python-zope-testing" ,python-zope-testing)
8526 ("python-coverage" ,python-coverage)
8527 ("python-nose" ,python-nose)))
8528 (home-page "http://pypi.python.org/pypi/zope.schema")
8529 (synopsis "Zope data schemas")
8530 (description "Zope.scheme provides extensions to zope.interface for
8531 defining data schemas.")
8532 (license license:zpl2.1)))
8533
8534 (define-public python2-zope-schema
8535 (package-with-python2 python-zope-schema))
8536
8537 (define-public python-zope-configuration
8538 (package
8539 (name "python-zope-configuration")
8540 (version "4.0.3")
8541 (source (origin
8542 (method url-fetch)
8543 (uri (string-append "https://pypi.python.org/packages/source/z"
8544 "/zope.configuration/zope.configuration-"
8545 version ".tar.gz"))
8546 (sha256
8547 (base32
8548 "1x9dfqypgympnlm25p9m43xh4qv3p7d75vksv9pzqibrb4cggw5n"))))
8549 (build-system python-build-system)
8550 (arguments
8551 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8552 (propagated-inputs
8553 `(("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
8554 ("python-zope-schema" ,python-zope-schema)))
8555 (home-page "http://pypi.python.org/pypi/zope.configuration")
8556 (synopsis "Zope Configuration Markup Language")
8557 (description "Zope.configuration implements ZCML, the Zope Configuration
8558 Markup Language.")
8559 (license license:zpl2.1)))
8560
8561 (define-public python2-zope-configuration
8562 (package-with-python2 python-zope-configuration))
8563
8564 (define-public python-zope-proxy
8565 (package
8566 (name "python-zope-proxy")
8567 (version "4.1.6")
8568 (source
8569 (origin
8570 (method url-fetch)
8571 (uri (string-append "https://pypi.python.org/packages/source/z"
8572 "/zope.proxy/zope.proxy-" version ".tar.gz"))
8573 (sha256
8574 (base32
8575 "0pqwwmvm1prhwv1ziv9lp8iirz7xkwb6n2kyj36p2h0ppyyhjnm4"))))
8576 (build-system python-build-system)
8577 (arguments
8578 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8579 (propagated-inputs
8580 `(("python-zope-interface" ,python-zope-interface)))
8581 (home-page "http://pypi.python.org/pypi/zope.proxy")
8582 (synopsis "Generic, transparent proxies")
8583 (description "Zope.proxy provides generic, transparent proxies for Python.
8584 Proxies are special objects which serve as mostly-transparent wrappers around
8585 another object, intervening in the apparent behavior of the wrapped object
8586 only when necessary to apply the policy (e.g., access checking, location
8587 brokering, etc.) for which the proxy is responsible.")
8588 (license license:zpl2.1)))
8589
8590 (define-public python2-zope-proxy
8591 (package-with-python2 python-zope-proxy))
8592
8593 (define-public python-zope-location
8594 (package
8595 (name "python-zope-location")
8596 (version "4.0.3")
8597 (source
8598 (origin
8599 (method url-fetch)
8600 (uri (string-append "https://pypi.python.org/packages/source/z"
8601 "/zope.location/zope.location-" version ".tar.gz"))
8602 (sha256
8603 (base32
8604 "1nj9da4ksiyv3h8n2vpzwd0pb03mdsh7zy87hfpx72b6p2zcwg74"))))
8605 (build-system python-build-system)
8606 (arguments
8607 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8608 (propagated-inputs
8609 `(("python-zope-proxy" ,python-zope-proxy)
8610 ("python-zope-schema" ,python-zope-schema)))
8611 (home-page "http://pypi.python.org/pypi/zope.location/")
8612 (synopsis "Zope location library")
8613 (description "Zope.location implements the concept of \"locations\" in
8614 Zope3, which are are special objects that have a structural location.")
8615 (license license:zpl2.1)))
8616
8617 (define-public python2-zope-location
8618 (package-with-python2 python-zope-location))
8619
8620 (define-public python-zope-security
8621 (package
8622 (name "python-zope-security")
8623 (version "4.0.3")
8624 (source
8625 (origin
8626 (method url-fetch)
8627 (uri (string-append "https://pypi.python.org/packages/source/z"
8628 "/zope.security/zope.security-" version ".tar.gz"))
8629 (sha256
8630 (base32
8631 "14zmf684amc0x32kq05yxnhfqd1cmyhafkw05gn81rn90zjv6ssy"))))
8632 (build-system python-build-system)
8633 (arguments
8634 '(#:tests? #f)) ; FIXME: Tests can't find zope.testrunner.
8635 (propagated-inputs
8636 `(("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
8637 ("python-zope-proxy" ,python-zope-proxy)
8638 ("python-zope-schema" ,python-zope-schema)))
8639 (native-inputs
8640 `(("python-six" ,python-six)
8641 ("python-zope-component" ,python-zope-component)
8642 ("python-zope-configuration" ,python-zope-configuration)
8643 ("python-zope-location" ,python-zope-location)
8644 ("python-zope-testrunner" ,python-zope-testrunner)
8645 ("python-zope-testing" ,python-zope-testing)))
8646 (home-page "http://pypi.python.org/pypi/zope.security")
8647 (synopsis "Zope security framework")
8648 (description "Zope.security provides a generic mechanism to implement
8649 security policies on Python objects.")
8650 (license license:zpl2.1)))
8651
8652 (define-public python2-zope-security
8653 (let ((zope-security (package-with-python2 python-zope-security)))
8654 (package (inherit zope-security)
8655 (propagated-inputs
8656 `(("python2-zope-testrunner" ,python2-zope-testrunner)
8657 ,@(alist-delete
8658 "python-zope-testrunner"
8659 (package-propagated-inputs zope-security)))))))
8660
8661 (define-public python-zope-component
8662 (package
8663 (name "python-zope-component")
8664 (version "4.3.0")
8665 (source
8666 (origin
8667 (method url-fetch)
8668 (uri (pypi-uri "zope.component" version))
8669 (sha256
8670 (base32
8671 "1hlvzwj1kcfz1qms1dzhwsshpsf38z9clmyksb1gh41n8k3kchdv"))))
8672 (build-system python-build-system)
8673 (arguments
8674 ;; Skip tests due to circular dependency with python-zope-security.
8675 '(#:tests? #f))
8676 (native-inputs
8677 `(("python-zope-testing" ,python-zope-testing)))
8678 (propagated-inputs
8679 `(("python-zope-event" ,python-zope-event)
8680 ("python-zope-interface" ,python-zope-interface)
8681 ("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
8682 ("python-zope-configuration" ,python-zope-configuration)))
8683 (home-page "https://github.com/zopefoundation/zope.component")
8684 (synopsis "Zope Component Architecture")
8685 (description "Zope.component represents the core of the Zope Component
8686 Architecture. Together with the zope.interface package, it provides
8687 facilities for defining, registering and looking up components.")
8688 (license license:zpl2.1)))
8689
8690 (define-public python2-zope-component
8691 (package-with-python2 python-zope-component))
8692
8693 (define-public python-pythondialog
8694 (package
8695 (name "python-pythondialog")
8696 (version "3.4.0")
8697 (source
8698 (origin
8699 (method url-fetch)
8700 (uri (pypi-uri "pythondialog" version))
8701 (sha256
8702 (base32
8703 "1728ghsran47jczn9bhlnkvk5bvqmmbihabgif5h705b84r1272c"))))
8704 (build-system python-build-system)
8705 (arguments
8706 `(#:phases
8707 (modify-phases %standard-phases
8708 (add-after 'unpack 'patch-path
8709 (lambda* (#:key inputs #:allow-other-keys)
8710 (let* ((dialog (assoc-ref inputs "dialog")))
8711 ;; Since this library really wants to grovel the search path, we
8712 ;; must hardcode dialog's store path into it.
8713 (substitute* "dialog.py"
8714 (("os.getenv\\(\"PATH\", \":/bin:/usr/bin\"\\)")
8715 (string-append "os.getenv(\"PATH\") + \":" dialog "/bin\"")))
8716 #t))))
8717 #:tests? #f)) ; no test suite
8718 (propagated-inputs
8719 `(("dialog" ,dialog)))
8720 (home-page "http://pythondialog.sourceforge.net/")
8721 (synopsis "Python interface to the UNIX dialog utility")
8722 (description "A Python wrapper for the dialog utility. Its purpose is to
8723 provide an easy to use, pythonic and comprehensive Python interface to dialog.
8724 This allows one to make simple text-mode user interfaces on Unix-like systems")
8725 (license license:lgpl2.1)
8726 (properties `((python2-variant . ,(delay python2-pythondialog))))))
8727
8728 (define-public python2-pythondialog
8729 (let ((base (package-with-python2 (strip-python2-variant python-pythondialog))))
8730 (package
8731 (inherit base)
8732 (version (package-version python-pythondialog))
8733 (source (origin
8734 (method url-fetch)
8735 (uri (pypi-uri "python2-pythondialog" version))
8736 (sha256
8737 (base32
8738 "0d8k7lxk50imdyx85lv8j98i4c93a71iwpapnl1506rpkbm9qvd9")))))))
8739
8740 (define-public python-pyrfc3339
8741 (package
8742 (name "python-pyrfc3339")
8743 (version "1.0")
8744 (source
8745 (origin
8746 (method url-fetch)
8747 (uri (pypi-uri "pyRFC3339" version))
8748 (sha256
8749 (base32
8750 "0dgm4l9y8jiax5cp6yxjd2i27cq8h33sh81n1wfbmnmqb32cdywd"))))
8751 (build-system python-build-system)
8752 (propagated-inputs
8753 `(("python-pytz" ,python-pytz)))
8754 (native-inputs
8755 `(("python-nose" ,python-nose)))
8756 (home-page "https://github.com/kurtraschke/pyRFC3339")
8757 (synopsis "Python timestamp library")
8758 (description "Python library for generating and parsing RFC 3339-compliant
8759 timestamps.")
8760 (license license:expat)))
8761
8762 (define-public python2-pyrfc3339
8763 (package-with-python2 python-pyrfc3339))
8764
8765 (define-public python-werkzeug
8766 (package
8767 (name "python-werkzeug")
8768 (version "0.11.15")
8769 (source
8770 (origin
8771 (method url-fetch)
8772 (uri (pypi-uri "Werkzeug" version))
8773 (sha256
8774 (base32
8775 "1h5wycw8yj7q0grqsjnsqflmrlsdagvl2j4dsgdncci6mjc7fpa5"))))
8776 (build-system python-build-system)
8777 (native-inputs
8778 `(("python-pytest" ,python-pytest)))
8779 (home-page "http://werkzeug.pocoo.org/")
8780 (synopsis "Utilities for WSGI applications")
8781 (description "One of the most advanced WSGI utility modules. It includes a
8782 powerful debugger, full-featured request and response objects, HTTP utilities to
8783 handle entity tags, cache control headers, HTTP dates, cookie handling, file
8784 uploads, a powerful URL routing system and a bunch of community-contributed
8785 addon modules.")
8786 (license license:x11)))
8787
8788 (define-public python2-werkzeug
8789 (package-with-python2 python-werkzeug))
8790
8791 (define-public python-configobj
8792 (package
8793 (name "python-configobj")
8794 (version "5.0.6")
8795 (source (origin
8796 (method url-fetch)
8797 (uri (string-append
8798 "https://pypi.python.org/packages/source/c/configobj/"
8799 "configobj-" version ".tar.gz"))
8800 (sha256
8801 (base32
8802 "00h9rcmws03xvdlfni11yb60bz3kxfvsj6dg6nrpzj71f03nbxd2"))
8803 ;; Patch setup.py so it looks for python-setuptools, which is
8804 ;; required to parse the keyword 'install_requires' in setup.py.
8805 (patches (search-patches "python-configobj-setuptools.patch"))))
8806 (build-system python-build-system)
8807 (propagated-inputs
8808 `(("python-six" ,python-six)))
8809 (synopsis "Config file reading, writing and validation")
8810 (description "ConfigObj is a simple but powerful config file reader and
8811 writer: an ini file round tripper. Its main feature is that it is very easy to
8812 use, with a straightforward programmer’s interface and a simple syntax for
8813 config files.")
8814 (home-page "https://github.com/DiffSK/configobj")
8815 (license license:bsd-3)))
8816
8817 (define-public python2-configobj
8818 (package-with-python2 python-configobj))
8819
8820 (define-public python-configargparse
8821 (package
8822 (name "python-configargparse")
8823 (version "0.10.0")
8824 (source (origin
8825 (method url-fetch)
8826 (uri (string-append
8827 "https://pypi.python.org/packages/source/C/ConfigArgParse/"
8828 "ConfigArgParse-" version ".tar.gz"))
8829 (sha256
8830 (base32
8831 "19wh919gbdbzxzpagg52q3lm62yicm95ddlcx77dyjc1slyshl1v"))))
8832 (build-system python-build-system)
8833 (arguments
8834 ;; FIXME: Bug in test suite filed upstream:
8835 ;; https://github.com/bw2/ConfigArgParse/issues/32
8836 '(#:tests? #f))
8837 (synopsis "Replacement for argparse")
8838 (description "A drop-in replacement for argparse that allows options to also
8839 be set via config files and/or environment variables.")
8840 (home-page "https://github.com/bw2/ConfigArgParse")
8841 (license license:expat)))
8842
8843 (define-public python2-configargparse
8844 (package-with-python2 python-configargparse))
8845
8846 (define-public python-ndg-httpsclient
8847 (package
8848 (name "python-ndg-httpsclient")
8849 (version "0.4.2")
8850 (source (origin
8851 (method url-fetch)
8852 (uri (pypi-uri "ndg_httpsclient" version))
8853 (sha256
8854 (base32
8855 "1b5qirv46v4dpnmfqviwq42mdwfcby4dxmz0i41wad2337pqf2aq"))))
8856 (build-system python-build-system)
8857 (arguments
8858 '(;; The tests appear to require networking.
8859 #:tests? #f))
8860 (propagated-inputs
8861 `(("python-pyopenssl" ,python-pyopenssl)))
8862 (synopsis "HTTPS support for Python's httplib and urllib2")
8863 (description "This is a HTTPS client implementation for httplib and urllib2
8864 based on PyOpenSSL. PyOpenSSL provides a more fully featured SSL implementation
8865 over the default provided with Python and importantly enables full verification
8866 of the SSL peer.")
8867 (home-page "https://github.com/cedadev/ndg_httpsclient/")
8868 (license license:bsd-3)))
8869
8870 ;; python2-openssl requires special care, so package-with-python2 is
8871 ;; insufficient.
8872 (define-public python2-ndg-httpsclient
8873 (package (inherit python-ndg-httpsclient)
8874 (name "python2-ndg-httpsclient")
8875 (arguments `(#:python ,python-2))
8876 (propagated-inputs
8877 `(("python2-pyopenssl" ,python2-pyopenssl)))))
8878
8879 (define-public python-contextlib2
8880 (package
8881 (name "python-contextlib2")
8882 (version "0.4.0")
8883 (source
8884 (origin
8885 (method url-fetch)
8886 (uri (pypi-uri "contextlib2" version))
8887 (sha256
8888 (base32
8889 "0cmp131dlh0d0zvw0aza1zd13glvngzk8lb4avks0hm7yxwdr9am"))))
8890 (build-system python-build-system)
8891 (arguments
8892 `(#:phases
8893 (modify-phases %standard-phases
8894 (replace 'check
8895 (lambda _ (zero?
8896 (system*
8897 "python" "test_contextlib2.py" "-v")))))))
8898 (home-page "http://contextlib2.readthedocs.org/")
8899 (synopsis "Tools for decorators and context managers")
8900 (description "This module is primarily a backport of the Python
8901 3.2 contextlib to earlier Python versions. Like contextlib, it
8902 provides utilities for common tasks involving decorators and context
8903 managers. It also contains additional features that are not part of
8904 the standard library.")
8905 (license license:psfl)))
8906
8907 (define-public python2-contextlib2
8908 (package-with-python2 python-contextlib2))
8909
8910 (define-public python-texttable
8911 (package
8912 (name "python-texttable")
8913 (version "0.8.7")
8914 (source
8915 (origin
8916 (method url-fetch)
8917 (uri (pypi-uri "texttable" version))
8918 (sha256
8919 (base32
8920 "1liiiydgkg37i46a418aw19fyf6z3ds51wdwwpyjbs12x0phhf4a"))))
8921 (build-system python-build-system)
8922 (arguments '(#:tests? #f)) ; no tests
8923 (home-page "https://github.com/foutaise/texttable/")
8924 (synopsis "Python module for creating simple ASCII tables")
8925 (description "Texttable is a Python module for creating simple ASCII
8926 tables.")
8927 (license license:lgpl2.1+)))
8928
8929 (define-public python2-texttable
8930 (package-with-python2 python-texttable))
8931
8932 (define-public python-websocket-client
8933 (package
8934 (name "python-websocket-client")
8935 (version "0.37.0")
8936 (source
8937 (origin
8938 (method url-fetch)
8939 (uri (pypi-uri "websocket_client" version))
8940 (sha256
8941 (base32
8942 "0h9glp1jll3z76ly3kg08aqgxqk0a68p4zi9yn50353bh5nj92v7"))))
8943 (build-system python-build-system)
8944 (propagated-inputs
8945 `(("python-six" ,python-six)))
8946 (home-page "https://github.com/liris/websocket-client")
8947 (synopsis "WebSocket client for Python")
8948 (description "The Websocket-client module provides the low level APIs for
8949 WebSocket usage in Python programs.")
8950 (license license:lgpl2.1+)))
8951
8952 (define-public python2-websocket-client
8953 (package-with-python2 python-websocket-client))
8954
8955 (define-public python-atomicwrites
8956 (package
8957 (name "python-atomicwrites")
8958 (version "1.1.5")
8959 (source (origin
8960 (method url-fetch)
8961 (uri (pypi-uri "atomicwrites" version))
8962 (sha256
8963 (base32
8964 "11bm90fwm2avvf4f3ib8g925w7jr4m11vcsinn1bi6ns4bm32214"))))
8965 (build-system python-build-system)
8966 (synopsis "Atomic file writes in Python")
8967 (description "Library for atomic file writes using platform dependent tools
8968 for atomic file system operations.")
8969 (home-page "https://github.com/untitaker/python-atomicwrites")
8970 (license license:expat)))
8971
8972 (define-public python2-atomicwrites
8973 (package-with-python2 python-atomicwrites))
8974
8975 (define-public python-requests-toolbelt
8976 (package
8977 (name "python-requests-toolbelt")
8978 (version "0.6.2")
8979 (source (origin
8980 (method url-fetch)
8981 (uri (string-append
8982 "https://pypi.python.org/packages/"
8983 "e1/a4/a94c037bc72ad70441aff1403d3243510d2542ddca7759faaeffeb11aefe/"
8984 "requests-toolbelt-" version ".tar.gz"))
8985 (sha256
8986 (base32
8987 "15q9nrgp85nqlr4kdz1zvj8z2npafi2sr12y7fqgxbkq28j1aci6"))))
8988 (build-system python-build-system)
8989 (native-inputs
8990 `(("python-betamax" ,python-betamax)
8991 ("python-mock" ,python-mock)
8992 ("python-pytest" ,python-pytest)))
8993 (propagated-inputs
8994 `(("python-requests" ,python-requests)))
8995 (synopsis "Extensions to python-requests")
8996 (description "This is a toolbelt of useful classes and functions to be used
8997 with python-requests.")
8998 (home-page "https://github.com/sigmavirus24/requests-toolbelt")
8999 (license license:asl2.0)))
9000
9001 (define-public python-click-threading
9002 (package
9003 (name "python-click-threading")
9004 (version "0.2.0")
9005 (source (origin
9006 (method url-fetch)
9007 (uri (string-append
9008 "https://pypi.python.org/packages/"
9009 "fe/b7/e7f609d18a2a351cb71616adcf54df1acd82f83cb9b5936935a4d20e2c23/"
9010 "click-threading-" version ".tar.gz"))
9011 (sha256
9012 (base32
9013 "18bcqikxwb3drb8rf60cclxkxw52521b38ax3byah6j8cn8y9p4j"))))
9014 (build-system python-build-system)
9015 (propagated-inputs
9016 `(("python-click" ,python-click)))
9017 (synopsis "Utilities for multithreading in Click")
9018 (description "This package provides utilities for multithreading in Click
9019 applications.")
9020 (home-page "https://github.com/click-contrib/click-threading")
9021 (license license:expat)))
9022
9023 (define-public python-click-log
9024 (package
9025 (name "python-click-log")
9026 (version "0.1.8")
9027 (source (origin
9028 (method url-fetch)
9029 (uri (pypi-uri "click-log" version))
9030 (sha256
9031 (base32
9032 "14ikfjfgnzf21mjniq9lfk2igzykgzfvwwrk85nw2b9fq44109sp"))))
9033 (build-system python-build-system)
9034 (propagated-inputs
9035 `(("python-click" ,python-click)))
9036 (synopsis "Logging for click applications")
9037 (description "This package provides a Python library for logging Click
9038 applications.")
9039 (home-page "https://github.com/click-contrib/click-log")
9040 (license license:expat)))
9041
9042 (define-public python-apipkg
9043 (package
9044 (name "python-apipkg")
9045 (version "1.4")
9046 (source (origin
9047 (method url-fetch)
9048 (uri (pypi-uri "apipkg" version))
9049 (sha256
9050 (base32
9051 "1iks5701qnp3dlr3q1d9qm68y2plp2m029irhpz92a44psfkjf1f"))))
9052 (build-system python-build-system)
9053 (native-inputs
9054 `(("python-pytest" ,python-pytest)))
9055 (synopsis "Namespace control and lazy-import mechanism")
9056 (description "With apipkg you can control the exported namespace of a Python
9057 package and greatly reduce the number of imports for your users. It is a small
9058 pure Python module that works on virtually all Python versions.")
9059 (home-page "https://bitbucket.org/hpk42/apipkg")
9060 (license license:expat)))
9061
9062 (define-public python2-apipkg
9063 (package-with-python2 python-apipkg))
9064
9065 (define-public python-execnet
9066 (package
9067 (name "python-execnet")
9068 (version "1.4.1")
9069 (source (origin
9070 (method url-fetch)
9071 (uri (pypi-uri "execnet" version))
9072 (sha256
9073 (base32
9074 "1rpk1vyclhg911p3hql0m0nrpq7q7mysxnaaw6vs29cpa6kx8vgn"))))
9075 (build-system python-build-system)
9076 (arguments
9077 `(;; 2 failed, 275 passed, 670 skipped, 4 xfailed
9078 ;; The two test failures are caused by the lack of an `ssh` executable.
9079 ;; The test suite can be run with pytest after the 'install' phase.
9080 #:tests? #f))
9081 (native-inputs
9082 `(("python-pytest" ,python-pytest)
9083 ("python-setuptools-scm" ,python-setuptools-scm)))
9084 (propagated-inputs
9085 `(("python-apipkg" ,python-apipkg)))
9086 (synopsis "Rapid multi-Python deployment")
9087 (description "Execnet provides a share-nothing model with
9088 channel-send/receive communication for distributing execution across many
9089 Python interpreters across version, platform and network barriers. It has a
9090 minimal and fast API targeting the following uses:
9091 @enumerate
9092 @item distribute tasks to (many) local or remote CPUs
9093 @item write and deploy hybrid multi-process applications
9094 @item write scripts to administer multiple environments
9095 @end enumerate")
9096 (home-page "http://codespeak.net/execnet/")
9097 (license license:expat)))
9098
9099 (define-public python2-execnet
9100 (package-with-python2 python-execnet))
9101
9102 (define-public python-trollius-redis
9103 (package
9104 (name "python-trollius-redis")
9105 (version "0.1.4")
9106 (source
9107 (origin
9108 (method url-fetch)
9109 (uri (pypi-uri "trollius_redis" version))
9110 (sha256
9111 (base32
9112 "0k3vypszmgmaipgw9xscvgm79h2zd6p6ci8gdp5sxl6g5kbqr9fy"))))
9113 (build-system python-build-system)
9114 ;; TODO: Tests require packaging 'hiredis'.
9115 (arguments '(#:tests? #f))
9116 (home-page "https://github.com/benjolitz/trollius-redis")
9117 (synopsis "Port of asyncio-redis to trollius")
9118 (description "@code{trollius-redis} is a Redis client for Python
9119 trollius. It is an asynchronious IO (PEP 3156) implementation of the
9120 Redis protocol.")
9121 (license license:bsd-2)))
9122
9123 (define-public python2-trollius-redis
9124 (package-with-python2 python-trollius-redis))
9125
9126 ;;; The software provided by this package was integrated into pytest 2.8.
9127 (define-public python-pytest-cache
9128 (package
9129 (name "python-pytest-cache")
9130 (version "1.0")
9131 (source (origin
9132 (method url-fetch)
9133 (uri (pypi-uri "pytest-cache" version))
9134 (sha256
9135 (base32
9136 "1a873fihw4rhshc722j4h6j7g3nj7xpgsna9hhg3zn6ksknnhx5y"))))
9137 (build-system python-build-system)
9138 (propagated-inputs
9139 `(("python-apipkg" ,python-apipkg)
9140 ("python-execnet" ,python-execnet)
9141 ("python-py" ,python-py)
9142 ("python-pytest" ,python-pytest)))
9143 (synopsis "Py.test plugin with mechanisms for caching across test runs")
9144 (description "The pytest-cache plugin provides tools to rerun failures from
9145 the last py.test invocation.")
9146 (home-page "https://bitbucket.org/hpk42/pytest-cache/")
9147 (license license:expat)))
9148
9149 (define-public python2-pytest-cache
9150 (package-with-python2 python-pytest-cache))
9151
9152 (define-public python-pytest-localserver
9153 (package
9154 (name "python-pytest-localserver")
9155 (version "0.3.5")
9156 (source (origin
9157 (method url-fetch)
9158 (uri (pypi-uri "pytest-localserver" version))
9159 (sha256
9160 (base32
9161 "0dvqspjr6va55zwmnnc2mmpqc7mm65kxig9ya44x1z8aadzxpa4p"))))
9162 (build-system python-build-system)
9163 (arguments
9164 `(#:phases (modify-phases %standard-phases
9165 (replace 'check
9166 (lambda _
9167 (zero? (system* "py.test" "--genscript=runtests.py"))
9168 (zero? (system* "py.test")))))))
9169 (native-inputs
9170 `(("python-pytest" ,python-pytest)
9171 ("python-requests" ,python-requests)
9172 ("python-six" ,python-six)))
9173 (propagated-inputs
9174 `(("python-werkzeug" ,python-werkzeug)))
9175 (synopsis "Py.test plugin to test server connections locally")
9176 (description "Pytest-localserver is a plugin for the pytest testing
9177 framework which enables you to test server connections locally.")
9178 (home-page "https://pypi.python.org/pypi/pytest-localserver")
9179 (license license:expat)))
9180
9181 (define-public python-wsgi-intercept
9182 (package
9183 (name "python-wsgi-intercept")
9184 (version "1.2.2")
9185 (source (origin
9186 (method url-fetch)
9187 (uri (string-append
9188 "https://pypi.python.org/packages/"
9189 "38/76/ebcbc24d0cb77db34520a3ca6ed1bd43ace17d182bbd8dd7d976f1c176fb/"
9190 "wsgi_intercept-" version ".tar.gz"))
9191 (sha256
9192 (base32
9193 "0kjj2v2dvmnpdd5h5gk9rzz0f54rhjb0yiz3zg65bmp65slfw65d"))))
9194 (build-system python-build-system)
9195 (propagated-inputs
9196 `(("python-six" ,python-six)))
9197 (native-inputs
9198 `(("python-pytest" ,python-pytest)
9199 ("python-httplib2" ,python-httplib2)
9200 ("python-requests" ,python-requests)
9201 ("python-urllib3" ,python-urllib3)))
9202 (synopsis "Puts a WSGI application in place of a real URI for testing")
9203 (description "Wsgi_intercept installs a WSGI application in place of a real
9204 URI for testing. Testing a WSGI application normally involves starting a
9205 server at a local host and port, then pointing your test code to that address.
9206 Instead, this library lets you intercept calls to any specific host/port
9207 combination and redirect them into a WSGI application importable by your test
9208 program. Thus, you can avoid spawning multiple processes or threads to test
9209 your Web app.")
9210 (home-page "https://github.com/cdent/wsgi-intercept")
9211 (license license:expat)))
9212
9213 (define-public python-pytest-xprocess
9214 (package
9215 (name "python-pytest-xprocess")
9216 (version "0.9.1")
9217 (source (origin
9218 (method url-fetch)
9219 (uri (pypi-uri "pytest-xprocess" version))
9220 (sha256
9221 (base32
9222 "17zlql1xqw3ywcgwwbqmw633aly99lab12hm02asr8awvg5603pp"))))
9223 (build-system python-build-system)
9224 (propagated-inputs
9225 `(("python-pytest" ,python-pytest)
9226 ("python-pytest-cache" ,python-pytest-cache)
9227 ("python-psutil" ,python-psutil)))
9228 (synopsis "Pytest plugin to manage external processes across test runs")
9229 (description "Pytest-xprocess is an experimental py.test plugin for managing
9230 processes across test runs.")
9231 (home-page "https://bitbucket.org/pytest-dev/pytest-xprocess")
9232 (license license:expat)))
9233
9234 (define-public python-icalendar
9235 (package
9236 (name "python-icalendar")
9237 (version "3.11.5")
9238 (source (origin
9239 (method url-fetch)
9240 (uri (pypi-uri "icalendar" version))
9241 (sha256
9242 (base32
9243 "0y6f2js983ag0d138xx4pzyc71gf44hyqmjsdvw6pq2xrkpj8jzk"))))
9244 (build-system python-build-system)
9245 (propagated-inputs
9246 `(("python-dateutil" ,python-dateutil)
9247 ("python-pytz" ,python-pytz)))
9248 (synopsis "Python library for parsing iCalendar files")
9249 (description "The icalendar package is a parser/generator of iCalendar
9250 files for use with Python.")
9251 (home-page "https://github.com/collective/icalendar")
9252 (license license:bsd-2)))
9253
9254 (define-public python-sphinxcontrib-newsfeed
9255 (package
9256 (name "python-sphinxcontrib-newsfeed")
9257 (version "0.1.4")
9258 (source (origin
9259 (method url-fetch)
9260 (uri (pypi-uri "sphinxcontrib-newsfeed" version))
9261 (sha256
9262 (base32
9263 "1d7gam3mn8v4in4p16yn3v10vps7nnaz6ilw99j4klij39dqd37p"))))
9264 (arguments '(#:tests? #f)) ; No tests.
9265 (build-system python-build-system)
9266 (propagated-inputs
9267 `(("python-sphinx" ,python-sphinx)))
9268 (synopsis "News Feed extension for Sphinx")
9269 (description "Sphinxcontrib-newsfeed is an extension for adding a simple
9270 Blog, News or Announcements section to a Sphinx website.")
9271 (home-page "https://bitbucket.org/prometheus/sphinxcontrib-newsfeed")
9272 (license license:bsd-2)))
9273
9274 (define-public python-args
9275 (package
9276 (name "python-args")
9277 (version "0.1.0")
9278 (source (origin
9279 (method url-fetch)
9280 (uri (pypi-uri "args" version))
9281 (sha256
9282 (base32
9283 "057qzi46h5dmxdqknsbrssn78lmqjlnm624iqdhrnpk26zcbi1d7"))))
9284 (build-system python-build-system)
9285 (home-page "https://github.com/kennethreitz/args")
9286 (synopsis "Command-line argument parser")
9287 (description
9288 "This library provides a Python module to parse command-line arguments.")
9289 (license license:bsd-3)))
9290
9291 (define-public python2-args
9292 (package-with-python2 python-args))
9293
9294 (define-public python-clint
9295 (package
9296 (name "python-clint")
9297 (version "0.5.1")
9298 (source (origin
9299 (method url-fetch)
9300 (uri (pypi-uri "clint" version))
9301 (sha256
9302 (base32
9303 "1an5lkkqk1zha47198p42ji3m94xmzx1a03dn7866m87n4r4q8h5"))))
9304 (build-system python-build-system)
9305 (arguments
9306 '(#:phases
9307 (modify-phases %standard-phases
9308 (replace 'check
9309 (lambda _
9310 (zero? (system* "py.test" "-v")))))))
9311 (native-inputs
9312 `(("python-pytest" ,python-pytest)))
9313 (propagated-inputs
9314 `(("python-args" ,python-args)))
9315 (home-page "https://github.com/kennethreitz/clint")
9316 (synopsis "Command-line interface tools")
9317 (description
9318 "Clint is a Python module filled with a set of tools for developing
9319 command-line applications, including tools for colored and indented
9320 output, progress bar display, and pipes.")
9321 (license license:isc)))
9322
9323 (define-public python2-clint
9324 (package-with-python2 python-clint))
9325
9326 (define-public python-astor
9327 (package
9328 (name "python-astor")
9329 (version "0.5")
9330 (source (origin
9331 (method url-fetch)
9332 (uri (pypi-uri "astor" version))
9333 (sha256
9334 (base32
9335 "1fdafq5hkis1fxqlmhw0sn44zp2ar46nxhbc22cvwg7hsd8z5gsa"))))
9336 (build-system python-build-system)
9337 (home-page "https://github.com/berkerpeksag/astor")
9338 (synopsis "Read and write Python ASTs")
9339 (description
9340 "Astor is designed to allow easy manipulation of Python source via the
9341 Abstract Syntax Tree.")
9342 (license license:bsd-3)))
9343
9344 (define-public python2-astor
9345 (package-with-python2 python-astor))
9346
9347 (define-public python-rply
9348 (package
9349 (name "python-rply")
9350 (version "0.7.4")
9351 (source (origin
9352 (method url-fetch)
9353 (uri (pypi-uri "rply" version))
9354 (sha256
9355 (base32
9356 "12rp1d9ba7nvd5rhaxi6xzx1rm67r1k1ylsrkzhpwnphqpb06cvj"))))
9357 (build-system python-build-system)
9358 (propagated-inputs
9359 `(("python-appdirs" ,python-appdirs)))
9360 (home-page "https://github.com/alex/rply")
9361 (synopsis "Parser generator for Python")
9362 (description
9363 "This package provides a pure Python based parser generator, that also
9364 works with RPython. It is a more-or-less direct port of David Bazzley's PLY,
9365 with a new public API, and RPython support.")
9366 (license license:bsd-3)))
9367
9368 (define-public python2-rply
9369 (package-with-python2 python-rply))
9370
9371 (define-public python-hy
9372 (package
9373 (name "python-hy")
9374 (version "0.11.1")
9375 (source (origin
9376 (method url-fetch)
9377 (uri (pypi-uri "hy" version))
9378 (sha256
9379 (base32
9380 "1msqv747iz12r73mz4qvsmlwkddwjvrahlrk7ysrcz07h7dsscxs"))))
9381 (build-system python-build-system)
9382 (arguments
9383 '(#:phases
9384 (modify-phases %standard-phases
9385 (replace 'check
9386 (lambda _
9387 ;; Tests require write access to HOME.
9388 (setenv "HOME" "/tmp")
9389 (zero? (system* "nosetests")))))))
9390 (native-inputs
9391 `(("python-coverage" ,python-coverage)
9392 ("python-nose" ,python-nose)))
9393 (propagated-inputs
9394 `(("python-astor" ,python-astor)
9395 ("python-clint" ,python-clint)
9396 ("python-rply" ,python-rply)))
9397 (home-page "http://hylang.org/")
9398 (synopsis "Lisp frontend to Python")
9399 (description
9400 "Hy is a dialect of Lisp that's embedded in Python. Since Hy transforms
9401 its Lisp code into the Python Abstract Syntax Tree, you have the whole world of
9402 Python at your fingertips, in Lisp form.")
9403 (license license:expat)))
9404
9405 (define-public python2-hy
9406 (package-with-python2 python-hy))
9407
9408 (define-public python-rauth
9409 (package
9410 (name "python-rauth")
9411 (version "0.7.3")
9412 (source
9413 (origin
9414 (method url-fetch)
9415 (uri (pypi-uri "rauth" version))
9416 (sha256
9417 (base32
9418 "02kv8w8l98ky223avyq7vw7x1f2ya9chrm59r77ylq45qb0xnk2j"))))
9419 (build-system python-build-system)
9420 (arguments
9421 `(#:test-target "check"))
9422 (propagated-inputs
9423 `(("python-requests" ,python-requests)))
9424 (home-page "https://github.com/litl/rauth")
9425 (synopsis "Python library for OAuth 1.0/a, 2.0, and Ofly")
9426 (description
9427 "Rauth is a Python library for OAuth 1.0/a, 2.0, and Ofly. It also
9428 provides service wrappers for convenient connection initialization and
9429 authenticated session objects providing things like keep-alive.")
9430 (license license:expat)
9431 (properties `((python2-variant . ,(delay python2-rauth))))))
9432
9433 (define-public python2-rauth
9434 (let ((base (package-with-python2 (strip-python2-variant python-rauth))))
9435 (package
9436 (inherit base)
9437 (native-inputs `(("python2-unittest2" ,python2-unittest2)
9438 ,@(package-native-inputs base))))))
9439
9440 (define-public python2-functools32
9441 (package
9442 (name "python2-functools32")
9443 (version "3.2.3-2")
9444 (source
9445 (origin
9446 (method url-fetch)
9447 (uri (pypi-uri "functools32" version))
9448 (sha256
9449 (base32
9450 "0v8ya0b58x47wp216n1zamimv4iw57cxz3xxhzix52jkw3xks9gn"))))
9451 (build-system python-build-system)
9452 (arguments
9453 `(#:python ,python-2
9454 #:tests? #f)) ; no test target
9455 (home-page "https://github.com/MiCHiLU/python-functools32")
9456 (synopsis
9457 "Backport of the functools module from Python 3.2.3")
9458 (description
9459 "This package is a backport of the @code{functools} module from Python
9460 3.2.3 for use with older versions of Python and PyPy.")
9461 (license license:expat)))
9462
9463 (define-public python2-subprocess32
9464 (package
9465 (name "python2-subprocess32")
9466 (version "3.2.7")
9467 (source (origin
9468 (method url-fetch)
9469 (uri (pypi-uri "subprocess32" version))
9470 (sha256
9471 (base32
9472 "14350dhhlhyz5gqzi3lihn9m6lvskx5mcb20srx1kgsk9i50li8y"))
9473 (patches
9474 (search-patches "python2-subprocess32-disable-input-test.patch"))))
9475 (build-system python-build-system)
9476 (arguments
9477 `(#:python ,python-2
9478 #:phases
9479 (modify-phases %standard-phases
9480 (add-after 'unpack 'patch-/bin/sh
9481 (lambda _
9482 (substitute* '("subprocess32.py"
9483 "test_subprocess32.py")
9484 (("/bin/sh") (which "sh")))
9485 #t))
9486 (delete 'check)
9487 (add-after 'install 'check
9488 (lambda* (#:key inputs outputs #:allow-other-keys)
9489 ;; For some reason this package fails to import
9490 ;; _posixsubprocess.so when PYTHONPATH is set to the build
9491 ;; directory. Running tests after install is easier.
9492 (add-installed-pythonpath inputs outputs)
9493 (zero? (system* "python" "test_subprocess32.py")))))))
9494 (home-page "https://github.com/google/python-subprocess32")
9495 (synopsis "Backport of the subprocess module from Python 3.2")
9496 (description
9497 "This is a backport of the @code{subprocess} standard library module
9498 from Python 3.2 and 3.3 for use on Python 2. It includes bugfixes and some
9499 new features. On POSIX systems it is guaranteed to be reliable when used
9500 in threaded applications. It includes timeout support from Python 3.3 but
9501 otherwise matches 3.2’s API.")
9502 (license license:psfl)))
9503
9504 (define-public python2-futures
9505 (package
9506 (name "python2-futures")
9507 (version "3.0.5")
9508 (source
9509 (origin
9510 (method url-fetch)
9511 (uri (pypi-uri "futures" version))
9512 (sha256
9513 (base32
9514 "1pw1z4329xvlabdpwqa6b7v2fxf7hl64m4cgr22ckbym8m8m4hh5"))))
9515 (build-system python-build-system)
9516 (arguments `(#:python ,python-2))
9517 (home-page "https://github.com/agronholm/pythonfutures")
9518 (synopsis
9519 "Backport of the concurrent.futures package from Python 3.2")
9520 (description
9521 "The concurrent.futures module provides a high-level interface for
9522 asynchronously executing callables. This package backports the
9523 concurrent.futures package from Python 3.2")
9524 (license license:bsd-3)))
9525
9526 (define-public python-promise
9527 (package
9528 (name "python-promise")
9529 (version "0.4.2")
9530 (source
9531 (origin
9532 (method url-fetch)
9533 (uri (pypi-uri "promise" version))
9534 (sha256
9535 (base32
9536 "1k19ms8l3d5jzjh557rgkxb5sg4mqgfc315rn4hx1z3n8qq6lr3h"))))
9537 (build-system python-build-system)
9538 ;; Tests wants python-futures, which is a python2 only program, and
9539 ;; can't be found by python-promise at test time.
9540 (arguments `(#:tests? #f))
9541 (home-page "https://github.com/syrusakbary/promise")
9542 (synopsis "Promises/A+ implementation for Python")
9543 (description
9544 "Promises/A+ implementation for Python")
9545 (properties `((python2-variant . ,(delay python2-promise))))
9546 (license license:expat)))
9547
9548 (define-public python2-promise
9549 (let ((promise (package-with-python2
9550 (strip-python2-variant python-promise))))
9551 (package (inherit promise)
9552 (arguments (substitute-keyword-arguments (package-arguments promise)
9553 ((#:tests? _) #t)))
9554 (native-inputs
9555 `(("python2-futures" ,python2-futures)
9556 ("python2-pytest" ,python2-pytest)
9557 ,@(package-native-inputs promise))))))
9558
9559 (define-public python-urllib3
9560 (package
9561 (name "python-urllib3")
9562 (version "1.18.1")
9563 (source
9564 (origin
9565 (method url-fetch)
9566 (uri (pypi-uri "urllib3" version))
9567 (sha256
9568 (base32
9569 "1wb8aqnq53vzh2amrv8kc66f3h6fx217y0q62y6n30a64p2yqmam"))))
9570 (build-system python-build-system)
9571 (arguments `(#:tests? #f))
9572 (native-inputs
9573 `(;; some packages for tests
9574 ("python-nose" ,python-nose)
9575 ("python-mock" ,python-mock)
9576 ("python-tornado" ,python-tornado)))
9577 (propagated-inputs
9578 `(;; extra packages for https security
9579 ("python-certifi" ,python-certifi)
9580 ("python-ndg-httpsclient" ,python-ndg-httpsclient)
9581 ("python-pyasn1" ,python-pyasn1)
9582 ("python-pyopenssl" ,python-pyopenssl)))
9583 (home-page "https://urllib3.readthedocs.org/")
9584 (synopsis "HTTP library with thread-safe connection pooling")
9585 (description
9586 "Urllib3 supports features left out of urllib and urllib2 libraries. It
9587 can reuse the same socket connection for multiple requests, it can POST files,
9588 supports url redirection and retries, and also gzip and deflate decoding.")
9589 (license license:expat)))
9590
9591 (define-public python2-urllib3
9592 (package-with-python2 python-urllib3))
9593
9594 (define-public python-colorama
9595 (package
9596 (name "python-colorama")
9597 (version "0.3.7")
9598 (source
9599 (origin
9600 (method url-fetch)
9601 (uri (pypi-uri "colorama" version))
9602 (sha256
9603 (base32
9604 "0avqkn6362v7k2kg3afb35g4sfdvixjgy890clip4q174p9whhz0"))))
9605 (build-system python-build-system)
9606 (synopsis "Colored terminal text rendering for Python")
9607 (description "Colorama is a Python library for rendering colored terminal
9608 text.")
9609 (home-page "https://pypi.python.org/pypi/colorama")
9610 (license license:bsd-3)))
9611
9612 (define-public python2-colorama
9613 (package-with-python2 python-colorama))
9614
9615 (define-public python-rsa
9616 (package
9617 (name "python-rsa")
9618 (version "3.4.2")
9619 (source
9620 (origin
9621 (method url-fetch)
9622 (uri (pypi-uri "rsa" version))
9623 (sha256
9624 (base32
9625 "1dcxvszbikgzh99ybdc7jq0zb9wspy2ds8z9mjsqiyv3q884xpr5"))))
9626 (build-system python-build-system)
9627 (propagated-inputs
9628 `(("python-pyasn1" ,python-pyasn1)))
9629 (synopsis "Pure-Python RSA implementation")
9630 (description "Python-RSA is a pure-Python RSA implementation. It supports
9631 encryption and decryption, signing and verifying signatures, and key
9632 generation according to PKCS#1 version 1.5. It can be used as a Python
9633 library as well as on the command line.")
9634 (home-page "http://stuvel.eu/rsa")
9635 (license license:asl2.0)))
9636
9637 (define-public python2-rsa
9638 (package-with-python2 python-rsa))
9639
9640 (define-public python-pluggy
9641 (package
9642 (name "python-pluggy")
9643 (version "0.3.1")
9644 (source
9645 (origin
9646 (method url-fetch)
9647 (uri (pypi-uri "pluggy" version))
9648 (sha256
9649 (base32
9650 "18qfzfm40bgx672lkg8q9x5hdh76n7vax99aank7vh2nw21wg70m"))))
9651 (build-system python-build-system)
9652 (synopsis "Plugin and hook calling mechanism for Python")
9653 (description "Pluggy is an extraction of the plugin manager as used by
9654 Pytest but stripped of Pytest specific details.")
9655 (home-page "https://pypi.python.org/pypi/pluggy")
9656 (license license:expat)))
9657
9658 (define-public python2-pluggy
9659 (package-with-python2 python-pluggy))
9660
9661 (define-public python-tox
9662 (package
9663 (name "python-tox")
9664 (version "2.3.1")
9665 (source
9666 (origin
9667 (method url-fetch)
9668 (uri (pypi-uri "tox" version))
9669 (sha256
9670 (base32
9671 "1vj73ar4rimq3fwy5r2z3jv4g9qbh8rmpmncsc00g0k310acqzxz"))))
9672 (build-system python-build-system)
9673 (arguments
9674 ;; FIXME: Tests require pytest-timeout, which itself requires
9675 ;; pytest>=2.8.0 for installation.
9676 '(#:tests? #f))
9677 (propagated-inputs
9678 `(("python-pluggy" ,python-pluggy) ; >=0.3.0,<0.4.0
9679 ("python-py" ,python-py)
9680 ("python-virtualenv" ,python-virtualenv)))
9681 (native-inputs
9682 `(; FIXME: Missing: ("python-pytest-timeout" ,python-pytest-timeout)
9683 ("python-pytest" ,python-pytest))) ; >= 2.3.5
9684 (home-page "http://tox.testrun.org/")
9685 (synopsis "Virtualenv-based automation of test activities")
9686 (description "Tox is a generic virtualenv management and test command line
9687 tool. It can be used to check that a package installs correctly with
9688 different Python versions and interpreters, or run tests in each type of
9689 supported environment, or act as a frontend to continuous integration
9690 servers.")
9691 (license license:expat)))
9692
9693 (define-public python2-tox
9694 (package-with-python2 python-tox))
9695
9696 (define-public python-jmespath
9697 (package
9698 (name "python-jmespath")
9699 (version "0.9.0")
9700 (source
9701 (origin
9702 (method url-fetch)
9703 (uri (pypi-uri "jmespath" version))
9704 (sha256
9705 (base32
9706 "0g9xvl69y7nr3w7ag4fsp6sm4fqf6vrqjw7504x2hzrrsh3ampq8"))))
9707 (build-system python-build-system)
9708 (native-inputs
9709 `(("python-nose" ,python-nose)))
9710 (synopsis "JSON Matching Expressions")
9711 (description "JMESPath (pronounced “james path”) is a Python library that
9712 allows one to declaratively specify how to extract elements from a JSON
9713 document.")
9714 (home-page "https://github.com/jmespath/jmespath.py")
9715 (license license:expat)))
9716
9717 (define-public python2-jmespath
9718 (package-with-python2 python-jmespath))
9719
9720 (define-public python-botocore
9721 (package
9722 (name "python-botocore")
9723 (version "1.5.26")
9724 (source
9725 (origin
9726 (method url-fetch)
9727 (uri (pypi-uri "botocore" version))
9728 (sha256
9729 (base32
9730 "1b7l48hr88galrrc5q6k21z3sdadzxc87ppzs7k9fz4p1w8bfnvb"))))
9731 (build-system python-build-system)
9732 (arguments
9733 ;; FIXME: Many tests are failing.
9734 '(#:tests? #f))
9735 (propagated-inputs
9736 `(("python-dateutil" ,python-dateutil)
9737 ("python-docutils" ,python-docutils)
9738 ("python-jmespath" ,python-jmespath)))
9739 (native-inputs
9740 `(("python-mock" ,python-mock)
9741 ("python-nose" ,python-nose)
9742 ("behave" ,behave)
9743 ("python-tox" ,python-tox)
9744 ("python-wheel" ,python-wheel)))
9745 (home-page "https://github.com/boto/botocore")
9746 (synopsis "Low-level interface to AWS")
9747 (description "Botocore is a Python library that provides a low-level
9748 interface to the Amazon Web Services (AWS) API.")
9749 (license license:asl2.0)))
9750
9751 (define-public python2-botocore
9752 (package-with-python2 python-botocore))
9753
9754 (define-public awscli
9755 (package
9756 (name "awscli")
9757 (version "1.11.63")
9758 (source
9759 (origin
9760 (method url-fetch)
9761 (uri (pypi-uri name version))
9762 (sha256
9763 (base32
9764 "1r8aqv8w27k76lcsfk83w6qw9lz8gk2ibzwacp5wjhpp2gik911m"))))
9765 (build-system python-build-system)
9766 (propagated-inputs
9767 `(("python-colorama" ,python-colorama)
9768 ("python-botocore" ,python-botocore)
9769 ("python-s3transfer" ,python-s3transfer)
9770 ("python-docutils" ,python-docutils)
9771 ("python-pyyaml" ,python-pyyaml)
9772 ("python-rsa" ,python-rsa)))
9773 (arguments
9774 ;; FIXME: The 'pypi' release does not contain tests.
9775 '(#:tests? #f))
9776 (home-page "https://aws.amazon.com/cli/")
9777 (synopsis "Command line client for AWS")
9778 (description "AWS CLI provides a unified command line interface to the
9779 Amazon Web Services (AWS) API.")
9780 (license license:asl2.0)))
9781
9782 (define-public python-hypothesis
9783 (package
9784 (name "python-hypothesis")
9785 (version "3.1.0")
9786 (source (origin
9787 (method url-fetch)
9788 (uri (pypi-uri "hypothesis" version))
9789 (sha256
9790 (base32
9791 "0qyqq9akm4vshhn8cngjc1qykcvsn7cz6dlm6njfsgpbraqrmbbw"))))
9792 (build-system python-build-system)
9793 (native-inputs
9794 `(("python-flake8" ,python-flake8)
9795 ("python-pytest" ,python-pytest)))
9796 (synopsis "Library for property based testing")
9797 (description "Hypothesis is a library for testing your Python code against a
9798 much larger range of examples than you would ever want to write by hand. It’s
9799 based on the Haskell library, Quickcheck, and is designed to integrate
9800 seamlessly into your existing Python unit testing work flow.")
9801 (home-page "https://github.com/DRMacIver/hypothesis")
9802 (license license:mpl2.0)
9803 (properties `((python2-variant . ,(delay python2-hypothesis))))))
9804
9805 (define-public python2-hypothesis
9806 (let ((hypothesis (package-with-python2
9807 (strip-python2-variant python-hypothesis))))
9808 (package (inherit hypothesis)
9809 (native-inputs
9810 `(("python2-enum34" ,python2-enum34)
9811 ,@(package-native-inputs hypothesis))))))
9812
9813 (define-public python-pytest-subtesthack
9814 (package
9815 (name "python-pytest-subtesthack")
9816 (version "0.1.1")
9817 (source (origin
9818 (method url-fetch)
9819 (uri (pypi-uri "pytest-subtesthack" version))
9820 (sha256
9821 (base32
9822 "15kzcr5pchf3id4ikdvlv752rc0j4d912n589l4rifp8qsj19l1x"))))
9823 (build-system python-build-system)
9824 (propagated-inputs
9825 `(("python-pytest" ,python-pytest)))
9826 (synopsis "Set-up and tear-down fixtures for unit tests")
9827 (description "This plugin allows you to set up and tear down fixtures within
9828 unit test functions that use @code{py.test}. This is useful for using
9829 @command{hypothesis} inside py.test, as @command{hypothesis} will call the test
9830 function multiple times, without setting up or tearing down fixture state as is
9831 normally the case.")
9832 (home-page "https://github.com/untitaker/pytest-subtesthack/")
9833 (license license:unlicense)))
9834
9835 (define-public python2-pytest-subtesthack
9836 (package-with-python2 python-pytest-subtesthack))
9837
9838 (define-public python-xdo
9839 (package
9840 (name "python-xdo")
9841 (version "0.3")
9842 (source (origin
9843 (method url-fetch)
9844 (uri (string-append
9845 "http://http.debian.net/debian/pool/main/p/python-xdo/"
9846 "python-xdo_" version ".orig.tar.gz"))
9847 (sha256
9848 (base32
9849 "1vqh1n5yy5dhnq312kwrl90fnck4v26is3lq3lxdvcn60vv19da0"))))
9850 (build-system python-build-system)
9851 (arguments
9852 '(#:phases
9853 (modify-phases %standard-phases
9854 (add-before 'install 'patch-libxdo-path
9855 ;; Hardcode the path of dynamically loaded libxdo library.
9856 (lambda* (#:key inputs #:allow-other-keys)
9857 (let ((libxdo (string-append
9858 (assoc-ref inputs "xdotool")
9859 "/lib/libxdo.so")))
9860 (substitute* "xdo/_xdo.py"
9861 (("find_library\\(\"xdo\"\\)")
9862 (simple-format #f "\"~a\"" libxdo)))
9863 #t))))
9864 #:tests? #f)) ; no tests provided
9865 (propagated-inputs
9866 `(("python-six" ,python-six)))
9867 (inputs
9868 `(("xdotool" ,xdotool)
9869 ("libX11" ,libx11)))
9870 (home-page "https://tracker.debian.org/pkg/python-xdo")
9871 (synopsis "Python library for simulating X11 keyboard/mouse input")
9872 (description "Provides bindings to libxdo for manipulating X11 via simulated
9873 input. (Note that this is mostly a legacy library; you may wish to look at
9874 python-xdo for newer bindings.)")
9875 (license license:bsd-3)))
9876
9877 (define-public python2-xdo
9878 (package-with-python2 python-xdo))
9879
9880 (define-public python-wtforms
9881 (package
9882 (name "python-wtforms")
9883 (version "2.1")
9884 (source
9885 (origin
9886 (method url-fetch)
9887 (uri (pypi-uri "WTForms" version ".zip"))
9888 (sha256
9889 (base32
9890 "0vyl26y9cg409cfyj8rhqxazsdnd0jipgjw06civhrd53yyi1pzz"))))
9891 (build-system python-build-system)
9892 (arguments
9893 '(#:phases
9894 (modify-phases %standard-phases
9895 (add-after 'unpack 'remove-django-test
9896 ;; Don't fail the tests when the inputs for the optional tests cannot be found.
9897 (lambda _
9898 (substitute*
9899 "tests/runtests.py"
9900 (("'ext_django.tests', 'ext_sqlalchemy', 'ext_dateutil', 'locale_babel'") "")
9901 (("sys.stderr.write(\"### Disabled test '%s', dependency not found\n\" % name)") ""))
9902 #t)))))
9903 (native-inputs
9904 `(("unzip" ,unzip)))
9905 (home-page "http://wtforms.simplecodes.com/")
9906 (synopsis
9907 "Form validation and rendering library for Python web development")
9908 (description
9909 "WTForms is a flexible forms validation and rendering library
9910 for Python web development. It is very similar to the web form API
9911 available in Django, but is a standalone package.")
9912 (license license:bsd-3)))
9913
9914 (define-public python2-wtforms
9915 (package-with-python2 python-wtforms))
9916
9917 (define-public python-mako
9918 (package
9919 (name "python-mako")
9920 (version "1.0.6")
9921 (source
9922 (origin
9923 (method url-fetch)
9924 (uri (pypi-uri "Mako" version))
9925 (sha256
9926 (base32
9927 "03dyxgjknp4ffsv7vwfd28l5bbpzi0ylp20543wpg3iahyyrwma8"))))
9928 (build-system python-build-system)
9929 (propagated-inputs
9930 `(("python-markupsafe" ,python-markupsafe)))
9931 (native-inputs
9932 `(("python-mock" ,python-mock)
9933 ("python-nose" ,python-nose)
9934 ("python-pytest" ,python-pytest)))
9935 (home-page "http://www.makotemplates.org/")
9936 (synopsis "Templating language for Python")
9937 (description "Mako is a templating language for Python that compiles
9938 templates into Python modules.")
9939 (license license:expat)))
9940
9941 (define-public python2-mako
9942 (package-with-python2 python-mako))
9943
9944 (define-public python-waitress
9945 (package
9946 (name "python-waitress")
9947 (version "0.8.10")
9948 (source
9949 (origin
9950 (method url-fetch)
9951 (uri (pypi-uri "waitress" version))
9952 (sha256
9953 (base32
9954 "017n9ra6vvmq9d5sfhdzyzr1mg15x2hj2dhm4pdlw98c1ypw2h3w"))))
9955 (build-system python-build-system)
9956 (home-page "https://github.com/Pylons/waitress")
9957 (synopsis "Waitress WSGI server")
9958 (description "Waitress is meant to be a production-quality pure-Python WSGI
9959 server with very acceptable performance.")
9960 (license license:zpl2.1)))
9961
9962 (define-public python2-waitress
9963 (package-with-python2 python-waitress))
9964
9965 (define-public python-wsgiproxy2
9966 (package
9967 (name "python-wsgiproxy2")
9968 (version "0.4.2")
9969 (source
9970 (origin
9971 (method url-fetch)
9972 (uri (pypi-uri "WSGIProxy2" version ".zip"))
9973 (sha256
9974 (base32
9975 "13kf9bdxrc95y9vriaz0viry3ah11nz4rlrykcfvb8nlqpx3dcm4"))))
9976 (build-system python-build-system)
9977 (arguments
9978 '(;; Wsgiproxy2's test suite requires Restkit, which does not yet fully
9979 ;; support Python 3:
9980 ;; https://github.com/benoitc/restkit/issues/140
9981 #:tests? #f))
9982 (native-inputs
9983 `(("unzip" ,unzip)
9984 ("python-nose" ,python-nose)
9985 ("python-coverage" ,python-coverage)))
9986 (propagated-inputs
9987 `(("python-six" ,python-six)
9988 ("python-webob" ,python-webob)))
9989 (home-page
9990 "https://github.com/gawel/WSGIProxy2/")
9991 (synopsis "WSGI Proxy with various http client backends")
9992 (description "WSGI turns HTTP requests into WSGI function calls.
9993 WSGIProxy turns WSGI function calls into HTTP requests.
9994 It also includes code to sign requests and pass private data,
9995 and to spawn subprocesses to handle requests.")
9996 (license license:expat)))
9997
9998 (define-public python2-wsgiproxy2
9999 (package-with-python2 python-wsgiproxy2))
10000
10001 (define-public python-pastedeploy
10002 (package
10003 (name "python-pastedeploy")
10004 (version "1.5.2")
10005 (source
10006 (origin
10007 (method url-fetch)
10008 (uri (pypi-uri "PasteDeploy" version))
10009 (sha256
10010 (base32
10011 "1jz3m4hq8v6hyhfjz9425nd3nvn52cvbfipdcd72krjmla4qz1fm"))))
10012 (build-system python-build-system)
10013 (native-inputs
10014 `(("python-nose" ,python-nose)))
10015 (home-page "http://pythonpaste.org/deploy/")
10016 (synopsis
10017 "Load, configure, and compose WSGI applications and servers")
10018 (description
10019 "This tool provides code to load WSGI applications and servers from URIs;
10020 these URIs can refer to Python Eggs for INI-style configuration files. Paste
10021 Script provides commands to serve applications based on this configuration
10022 file.")
10023 (license license:expat)))
10024
10025 (define-public python2-pastedeploy
10026 (package-with-python2 python-pastedeploy))
10027
10028 (define-public python-paste
10029 (package
10030 (name "python-paste")
10031 (version "2.0.3")
10032 (source
10033 (origin
10034 (method url-fetch)
10035 (uri (pypi-uri "Paste" version))
10036 (sha256
10037 (base32
10038 "062jk0nlxf6lb2wwj6zc20rlvrwsnikpkh90y0dn8cjch93s6ii3"))
10039 (patches (search-patches "python-paste-remove-website-test.patch"
10040 "python-paste-remove-timing-test.patch"))))
10041 (build-system python-build-system)
10042 (native-inputs
10043 `(("python-nose" ,python-nose)))
10044 (propagated-inputs
10045 `(("python-six" ,python-six)))
10046 (home-page "http://pythonpaste.org")
10047 (synopsis
10048 "Python web development tools, focusing on WSGI")
10049 (description
10050 "Paste provides a variety of web development tools and middleware which
10051 can be nested together to build web applications. Paste's design closely
10052 follows ideas flowing from WSGI (Web Standard Gateway Interface).")
10053 (license license:expat)))
10054
10055 (define-public python2-paste
10056 (package-with-python2 python-paste))
10057
10058 (define-public python-pastescript
10059 (package
10060 (name "python-pastescript")
10061 (version "2.0.2")
10062 (source
10063 (origin
10064 (method url-fetch)
10065 (uri (pypi-uri "PasteScript" version))
10066 (sha256
10067 (base32
10068 "1h3nnhn45kf4pbcv669ik4faw04j58k8vbj1hwrc532k0nc28gy0"))))
10069 (build-system python-build-system)
10070 (native-inputs
10071 `(("python-nose" ,python-nose)))
10072 (propagated-inputs
10073 `(("python-paste" ,python-paste)
10074 ("python-pastedeploy" ,python-pastedeploy)))
10075 (home-page "http://pythonpaste.org/script/")
10076 (arguments
10077 '(;; Unfortunately, this requires the latest unittest2,
10078 ;; but that requires traceback2 which requires linecache2 which requires
10079 ;; unittest2. So we're skipping tests for now.
10080 ;; (Note: Apparently linetest2 only needs unittest2 for its tests,
10081 ;; so in theory we could get around this situation somehow.)
10082 #:tests? #f))
10083 (synopsis
10084 "Pluggable command line tool for serving web applications and more")
10085 (description
10086 "PasteScript is a plugin-friendly command line tool which provides a
10087 variety of features, from launching web applications to bootstrapping project
10088 layouts.")
10089 (license license:expat)))
10090
10091 (define-public python2-pastescript
10092 (package-with-python2 python-pastescript))
10093
10094 (define-public python-pyquery
10095 (package
10096 (name "python-pyquery")
10097 (version "1.2.17")
10098 (source
10099 (origin
10100 (method url-fetch)
10101 (uri (pypi-uri "pyquery" version))
10102 (sha256
10103 (base32
10104 "1xia20wm0vx5dk85kcwgh13bylz8qh47ffjxssd2586r60xi783a"))))
10105 (build-system python-build-system)
10106 (native-inputs
10107 `(("python-webob" ,python-webob)
10108 ("python-webtest" ,python-webtest)))
10109 (propagated-inputs
10110 `(("python-lxml" ,python-lxml)
10111 ("python-cssselect" ,python-cssselect)))
10112 (home-page "https://github.com/gawel/pyquery")
10113 (synopsis "Make jQuery-like queries on xml documents")
10114 (description "pyquery allows you to make jQuery queries on xml documents.
10115 The API is as much as possible the similar to jQuery. pyquery uses lxml for
10116 fast xml and html manipulation.")
10117 (license license:bsd-3)))
10118
10119 (define-public python2-pyquery
10120 (package-with-python2 python-pyquery))
10121
10122 (define-public python-webtest
10123 (package
10124 (name "python-webtest")
10125 (version "2.0.20")
10126 (source
10127 (origin
10128 (method url-fetch)
10129 (uri (pypi-uri "WebTest" version))
10130 (sha256
10131 (base32
10132 "0bv0qhdjakdsdgj4sk21gnpp8xp8bga4x03p6gjb83ihrsb7n4xv"))))
10133 (build-system python-build-system)
10134 (arguments
10135 `(;; Unfortunately we have to disable tests!
10136 ;; This release of WebTest is pinned to python-nose < 1.3,
10137 ;; but older versions of python-nose are plagued with the following
10138 ;; bug(s), which rears its ugly head during test execution:
10139 ;; https://github.com/nose-devs/nose/issues/759
10140 ;; https://github.com/nose-devs/nose/pull/811
10141 #:tests? #f))
10142 ;; Commented out code is no good, but in this case, once tests
10143 ;; are ready to be enabled again, we should put the following
10144 ;; in place:
10145 ;; (native-inputs
10146 ;; `(("python-nose" ,python-nose) ; technially < 1.3,
10147 ;; ; but see above comment
10148 ;; ("python-coverage" ,python-coverage)
10149 ;; ("python-mock" ,python-mock)
10150 ;; ("python-pastedeploy" ,python-pastedeploy)
10151 ;; ("python-wsgiproxy2" ,python-wsgiproxy2)
10152 ;; ("python-pyquery" ,python-pyquery)))
10153 (propagated-inputs
10154 `(("python-waitress" ,python-waitress)
10155 ("python-webob" ,python-webob)
10156 ("python-six" ,python-six)
10157 ("python-beautifulsoup4" ,python-beautifulsoup4)))
10158 (home-page "http://webtest.pythonpaste.org/")
10159 (synopsis "Helper to test WSGI applications")
10160 (description "Webtest allows you to test your Python web applications
10161 without starting an HTTP server. It supports anything that supports the
10162 minimum of WSGI.")
10163 (license license:expat)))
10164
10165 (define-public python2-webtest
10166 (package-with-python2 python-webtest))
10167
10168 (define-public python-anyjson
10169 (package
10170 (name "python-anyjson")
10171 (version "0.3.3")
10172 (source
10173 (origin
10174 (method url-fetch)
10175 (uri (pypi-uri "anyjson" version))
10176 (sha256
10177 (base32
10178 "1fjph4alvcscsl5d4b6qpv1yh31jy05jxi1l0xff7lws7j32v09p"))))
10179 (build-system python-build-system)
10180 (arguments
10181 `(;; We could possibly get tests working, but on Python 3 it's not so easy.
10182 ;; Very strangely, 2to3 is run *during setup.py install* (or bdist, or
10183 ;; whatever) so this transformation needs to be done before the tests
10184 ;; can be run. Maybe we could add a build step to transform beforehand
10185 ;; but it could be annoying/difficult.
10186 ;; We can enable tests for the Python 2 version, though, and do below.
10187 #:tests? #f))
10188 (home-page "http://bitbucket.org/runeh/anyjson/")
10189 (synopsis
10190 "Wraps best available JSON implementation in a common interface")
10191 (description
10192 "Anyjson loads whichever is the fastest JSON module installed
10193 and provides a uniform API regardless of which JSON implementation is used.")
10194 (license license:bsd-3)
10195 (properties `((python2-variant . ,(delay python2-anyjson))))))
10196
10197 (define-public python2-anyjson
10198 (let ((anyjson (package-with-python2
10199 (strip-python2-variant python-anyjson))))
10200 (package
10201 (inherit anyjson)
10202 (arguments `(;; Unlike the python 3 variant, we do run tests. See above!
10203 #:tests? #t
10204 ,@(package-arguments anyjson)))
10205 (native-inputs `(("python2-nose" ,python2-nose))))))
10206
10207 (define-public python-amqp
10208 (package
10209 (name "python-amqp")
10210 (version "1.4.9")
10211 (source
10212 (origin
10213 (method url-fetch)
10214 (uri (pypi-uri "amqp" version))
10215 (sha256
10216 (base32
10217 "06n6q0kxhjnbfz3vn8x9yz09lwmn1xi9d6wxp31h5jbks0b4vsid"))))
10218 (build-system python-build-system)
10219 (native-inputs
10220 `(("python-nose" ,python-nose)
10221 ("python-mock" ,python-mock)))
10222 (home-page "https://github.com/celery/py-amqp")
10223 (synopsis
10224 "Low-level AMQP client for Python (fork of amqplib)")
10225 (description
10226 "This is a fork of amqplib which was originally written by Barry Pederson.
10227 It is maintained by the Celery project, and used by kombu as a pure python
10228 alternative when librabbitmq is not available.")
10229 (license license:lgpl2.1+)
10230 (properties `((python2-variant . ,(delay python2-amqp))))))
10231
10232 (define-public python2-amqp
10233 (let ((amqp (package-with-python2
10234 (strip-python2-variant python-amqp))))
10235 (package
10236 (inherit amqp)
10237 (arguments `(;; Tries to run coverage tests with nose-cover3, which seems
10238 ;; unmaintained. Weirdly, does not do this on the python 3
10239 ;; version?
10240 #:tests? #f
10241 ,@(package-arguments amqp))))))
10242
10243 (define-public python-kombu
10244 (package
10245 (name "python-kombu")
10246 (version "3.0.37")
10247 (source
10248 (origin
10249 (method url-fetch)
10250 (uri (pypi-uri "kombu" version))
10251 (sha256
10252 (base32
10253 "0l16chb314gpq2v7fh94a22c30lcv6w3ylmhsa60bldlcq6a0r70"))))
10254 (build-system python-build-system)
10255 (native-inputs
10256 `(("python-mock" ,python-mock)
10257 ("python-nose" ,python-nose)))
10258 (propagated-inputs
10259 `(("python-anyjson" ,python-anyjson)
10260 ("python-amqp" ,python-amqp)
10261 ("python-redis" ,python-redis)))
10262 (home-page "http://kombu.readthedocs.org")
10263 (synopsis "Message passing library for Python")
10264 (description "The aim of Kombu is to make messaging in Python as easy as
10265 possible by providing an idiomatic high-level interface for the AMQ protocol,
10266 and also provide proven and tested solutions to common messaging problems.
10267 AMQP is the Advanced Message Queuing Protocol, an open standard protocol for
10268 message orientation, queuing, routing, reliability and security, for which the
10269 RabbitMQ messaging server is the most popular implementation.")
10270 (license license:bsd-3)
10271 (properties `((python2-variant . ,(delay python2-kombu))))))
10272
10273 (define-public python2-kombu
10274 (let ((kombu (package-with-python2
10275 (strip-python2-variant python-kombu))))
10276 (package
10277 (inherit kombu)
10278 (arguments `(;; FIXME: 'TestTransport.test_del_sync' fails on python2.
10279 ;; It works fine on the python3 variant.
10280 #:tests? #f
10281 ,@(package-arguments kombu)))
10282 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10283 ,@(package-native-inputs kombu))))))
10284
10285 (define-public python-billiard
10286 (package
10287 (name "python-billiard")
10288 (version "3.3.0.23")
10289 (source
10290 (origin
10291 (method url-fetch)
10292 (uri (pypi-uri "billiard" version))
10293 (sha256
10294 (base32
10295 "02wxsc6bhqvzh8j6w758kvgqbnj14l796mvmrcms8fgfamd2lak9"))))
10296 (build-system python-build-system)
10297 (native-inputs
10298 `(("python-nose" ,python-nose)))
10299 (home-page "https://github.com/celery/billiard")
10300 (synopsis
10301 "Python multiprocessing fork with improvements and bugfixes")
10302 (description
10303 "Billiard is a fork of the Python 2.7 multiprocessing package. The
10304 multiprocessing package itself is a renamed and updated version of R Oudkerk's
10305 pyprocessing package. This standalone variant is intended to be compatible with
10306 Python 2.4 and 2.5, and will draw its fixes/improvements from python-trunk.")
10307 (license license:bsd-3)
10308 (properties `((python2-variant . ,(delay python2-billiard))))))
10309
10310 (define-public python2-billiard
10311 (let ((billiard (package-with-python2
10312 (strip-python2-variant python-billiard))))
10313 (package
10314 (inherit billiard)
10315 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10316 ("python2-mock" ,python2-mock)
10317 ,@(package-native-inputs billiard))))))
10318
10319 (define-public python-celery
10320 (package
10321 (name "python-celery")
10322 (version "3.1.24")
10323 (source
10324 (origin
10325 (method url-fetch)
10326 (uri (pypi-uri "celery" version))
10327 (sha256
10328 (base32
10329 "0yh2prhdnx2dgkb67a5drj12hh2zvzx5f611p7mqqg01ydghif4r"))))
10330 (build-system python-build-system)
10331 (arguments
10332 `(#:phases
10333 (modify-phases %standard-phases
10334 ;; These tests break with Python 3.5:
10335 ;; https://github.com/celery/celery/issues/2897#issuecomment-253066295
10336 (replace 'check
10337 (lambda _
10338 (zero?
10339 (system* "nosetests" "--exclude=^test_safe_to_remove.*")))))))
10340 (native-inputs
10341 `(("python-nose" ,python-nose)))
10342 (propagated-inputs
10343 `(("python-pytz" ,python-pytz)
10344 ("python-billiard" ,python-billiard)
10345 ("python-kombu" ,python-kombu)))
10346 (home-page "http://celeryproject.org")
10347 (synopsis "Distributed Task Queue")
10348 (description "Celery is an asynchronous task queue/job queue based on
10349 distributed message passing. It is focused on real-time operation, but
10350 supports scheduling as well. The execution units, called tasks, are executed
10351 concurrently on a single or more worker servers using multiprocessing,
10352 Eventlet, or gevent. Tasks can execute asynchronously (in the background) or
10353 synchronously (wait until ready).")
10354 (license license:bsd-3)
10355 (properties `((python2-variant . ,(delay python2-celery))))))
10356
10357 (define-public python2-celery
10358 (let ((celery (package-with-python2
10359 (strip-python2-variant python-celery))))
10360 (package
10361 (inherit celery)
10362 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10363 ("python2-mock" ,python2-mock)
10364 ,@(package-native-inputs celery))))))
10365
10366 (define-public python-translitcodec
10367 (package
10368 (name "python-translitcodec")
10369 (version "0.4.0")
10370 (source
10371 (origin
10372 (method url-fetch)
10373 (uri (pypi-uri "translitcodec" version))
10374 (sha256
10375 (base32
10376 "10x6pvblkzky1zhjs8nmx64nb9jdzxad4bxhq4iwv0j4z2aqjnki"))))
10377 (build-system python-build-system)
10378 (arguments
10379 `(#:tests? #f)) ; no tests provided
10380 (home-page
10381 "https://github.com/claudep/translitcodec")
10382 (synopsis
10383 "Unicode to 8-bit charset transliteration codec")
10384 (description
10385 "This package contains codecs for transliterating ISO 10646 texts into
10386 best-effort representations using smaller coded character sets (ASCII,
10387 ISO 8859, etc.).")
10388 (license license:expat)))
10389
10390 (define-public python2-translitcodec
10391 (package-with-python2 python-translitcodec))
10392
10393 (define-public python-editor
10394 (package
10395 (name "python-editor")
10396 (version "0.5")
10397 (source
10398 (origin
10399 (method url-fetch)
10400 (uri (pypi-uri "python-editor" version))
10401 (sha256
10402 (base32
10403 "1ypnpgvzpkbwsg4rdvy4sy51j28b5xq9v8pnkwxncn07vqz06p7n"))))
10404 (build-system python-build-system)
10405 (home-page
10406 "https://github.com/fmoo/python-editor")
10407 (synopsis
10408 "Programmatically open an editor, capture the result")
10409 (description
10410 "python-editor is a library that provides the editor module for
10411 programmatically interfacing with your system's $EDITOR.")
10412 (license license:asl2.0)))
10413
10414 (define-public python2-editor
10415 (package-with-python2 python-editor))
10416
10417 (define-public python-sphinxcontrib-programoutput
10418 (package
10419 (name "python-sphinxcontrib-programoutput")
10420 (version "0.10")
10421 (source (origin
10422 (method url-fetch)
10423 (uri (pypi-uri "sphinxcontrib-programoutput" version))
10424 (sha256
10425 (base32
10426 "153hhnlbx4688zj9wd64819ps5znc2jlyp5crkgzvn5hxgy99vpx"))))
10427 (build-system python-build-system)
10428 (arguments
10429 ;; FIXME: Many tests are failing and the upstream is gone.
10430 '(#:tests? #f))
10431 (propagated-inputs
10432 `(("python-sphinx" ,python-sphinx)))
10433 (synopsis "Sphinx extension to include program output")
10434 (description "A Sphinx extension to literally insert the output of arbitrary
10435 commands into documents, helping you to keep your command examples up to date.")
10436 (home-page "https://github.com/lunaryorn/sphinxcontrib-programoutput")
10437 (license license:bsd-2)))
10438
10439 (define-public python2-sphinxcontrib-programoutput
10440 (package-with-python2 python-sphinxcontrib-programoutput))
10441
10442 (define-public python-sphinx-repoze-autointerface
10443 (package
10444 (name "python-sphinx-repoze-autointerface")
10445 (version "0.8")
10446 (source (origin
10447 (method url-fetch)
10448 (uri (pypi-uri "repoze.sphinx.autointerface" version))
10449 (sha256
10450 (base32
10451 "08ycivzf7bh4a1zcyp31hbyqs1b2c9r26raa3vxjwwmbfqr3iw4f"))))
10452 (build-system python-build-system)
10453 (arguments '(#:tests? #f)) ; No tests.
10454 (propagated-inputs
10455 `(("python-sphinx" ,python-sphinx)
10456 ("python-zope-interface" ,python-zope-interface)))
10457 (synopsis "Auto-generate Sphinx API docs from Zope interfaces")
10458 (description "This package defines an extension for the Sphinx documentation
10459 system. The extension allows generation of API documentation by
10460 introspection of @code{zope.interface} instances in code.")
10461 (home-page "https://github.com/repoze/repoze.sphinx.autointerface")
10462 (license license:repoze)))
10463
10464 (define-public python2-sphinx-repoze-autointerface
10465 (package-with-python2 python-sphinx-repoze-autointerface))
10466
10467 (define-public python-psycopg2
10468 (package
10469 (name "python-psycopg2")
10470 (version "2.6.2")
10471 (source
10472 (origin
10473 (method url-fetch)
10474 (uri (pypi-uri "psycopg2" version))
10475 (sha256
10476 (base32
10477 "0p60z2gwfcal30y2w8gprflchp1kcg9qblc5rn782p4wxl90wjbh"))))
10478 (build-system python-build-system)
10479 (arguments
10480 ;; Tests would require a postgresql database "psycopg2_test"
10481 ;; and a running postgresql database management service.
10482 `(#:tests? #f)) ; TODO re-enable after providing a test-db.
10483 (inputs
10484 `(("postgresql" ,postgresql))) ; libpq
10485 (home-page "http://initd.org/psycopg/")
10486 (synopsis "Python PostgreSQL adapter")
10487 (description
10488 "psycopg2 is a thread-safe PostgreSQL adapter that implements DB-API 2.0. ")
10489 (license license:lgpl3+)))
10490
10491 (define-public python2-psycopg2
10492 (package-with-python2 python-psycopg2))
10493
10494 (define-public python-vobject
10495 (package
10496 (name "python-vobject")
10497 (version "0.9.5")
10498 (source (origin
10499 (method url-fetch)
10500 (uri (pypi-uri "vobject" version))
10501 (sha256
10502 (base32
10503 "0hqjgf3ay1m5w1c0k00g5yfpdz1zni5qnr5rh9b8fg9hjvhwlmhg"))))
10504 (build-system python-build-system)
10505 (arguments
10506 '(;; The test suite relies on some non-portable Windows interfaces.
10507 #:tests? #f))
10508 (propagated-inputs
10509 `(("python-dateutil" ,python-dateutil)
10510 ("python-pyicu" ,python-pyicu)))
10511 (synopsis "Parse and generate vCard and vCalendar files")
10512 (description "Vobject is intended to be a full featured Python package for
10513 parsing and generating vCard and vCalendar files. Currently, iCalendar files
10514 are supported and well tested. vCard 3.0 files are supported, and all data
10515 should be imported, but only a few components are understood in a sophisticated
10516 way.")
10517 (home-page "http://eventable.github.io/vobject/")
10518 (license license:asl2.0)))
10519
10520 (define-public python2-vobject
10521 (package-with-python2 python-vobject))
10522
10523 (define-public python-munkres
10524 (package
10525 (name "python-munkres")
10526 (version "1.0.8")
10527 (source (origin
10528 (method url-fetch)
10529 (uri (pypi-uri "munkres" version))
10530 (sha256
10531 (base32
10532 "0mbspx4zv8id4x6pim6ybsa1xh96qwpbqj7skbqz4c9c9nf1lpqq"))))
10533 (build-system python-build-system)
10534 (arguments
10535 '(#:tests? #f)) ; no test suite
10536 (home-page "http://software.clapper.org/munkres/")
10537 (synopsis "Implementation of the Munkres algorithm")
10538 (description "The Munkres module provides an implementation of the Munkres
10539 algorithm (also called the Hungarian algorithm or the Kuhn-Munkres algorithm),
10540 useful for solving the Assignment Problem.")
10541 (license license:bsd-3)))
10542
10543 (define-public python2-munkres
10544 (package-with-python2 python-munkres))
10545
10546 (define-public python-flask
10547 (package
10548 (name "python-flask")
10549 (version "0.11.1")
10550 (source (origin
10551 (method url-fetch)
10552 (uri (pypi-uri "Flask" version))
10553 (sha256
10554 (base32
10555 "03kbfll4sj3v5z7r31c7bhfpi11r1np076d4p1k2kg4yzcmkywdl"))))
10556 (build-system python-build-system)
10557 (propagated-inputs
10558 `(("python-itsdangerous" ,python-itsdangerous)
10559 ("python-jinja2" ,python-jinja2)
10560 ("python-click" ,python-click)
10561 ("python-werkzeug" ,python-werkzeug)))
10562 (home-page "https://github.com/mitsuhiko/flask/")
10563 (synopsis "Microframework based on Werkzeug, Jinja2 and good intentions")
10564 (description "Flask is a micro web framework based on the Werkzeug toolkit
10565 and Jinja2 template engine. It is called a micro framework because it does not
10566 presume or force a developer to use a particular tool or library.")
10567 (license license:bsd-3)))
10568
10569 (define-public python2-flask
10570 (package-with-python2 python-flask))
10571
10572 (define-public python-flask-wtf
10573 (package
10574 (name "python-flask-wtf")
10575 (version "0.13.1")
10576 (source
10577 (origin
10578 (method url-fetch)
10579 (uri (pypi-uri "Flask-WTF" version))
10580 (sha256
10581 (base32
10582 "04l5743j2dici46038sqlzvf0xzpg8rf7s9ld2x24xv7f4idg990"))))
10583 (build-system python-build-system)
10584 (arguments
10585 '(#:phases
10586 (modify-phases %standard-phases
10587 (add-before 'check 'drop-failing-test
10588 (lambda _
10589 ;; FIXME: This file tries resolving an external server, which
10590 ;; fails. Try to patch out the offending section instead of
10591 ;; deleting the whole thing.
10592 (delete-file "tests/test_recaptcha.py")
10593 #t)))))
10594 (propagated-inputs
10595 `(("python-flask-babel" ,python-flask-babel)
10596 ("python-babel" ,python-babel)
10597 ("python-wtforms" ,python-wtforms)))
10598 (native-inputs
10599 `(("python-nose" ,python-nose)))
10600 (home-page "https://github.com/lepture/flask-wtf")
10601 (synopsis "Simple integration of Flask and WTForms")
10602 (description "Flask-WTF integrates Flask and WTForms, including CSRF, file
10603 upload, and reCAPTCHA.")
10604 (license license:bsd-3)))
10605
10606 (define-public python2-flask-wtf
10607 (package-with-python2 python-flask-wtf))
10608
10609 (define-public python-flask-multistatic
10610 (package
10611 (name "python-flask-multistatic")
10612 (version "1.0")
10613 (source
10614 (origin
10615 (method url-fetch)
10616 (uri (pypi-uri "flask-multistatic" version))
10617 (sha256
10618 (base32
10619 "0p4v50rwv64wcd0zlq7rzl4waprwr4hj19s3cgf1isywa7jcisgm"))))
10620 (build-system python-build-system)
10621 (propagated-inputs
10622 `(("python-flask" ,python-flask)))
10623 (home-page "https://pagure.io/flask-multistatic")
10624 (synopsis "Flask plugin to allow overriding static files")
10625 (description "@code{flask-multistatic} is a flask plugin that adds support
10626 for overriding static files.")
10627 (license license:gpl3+)))
10628
10629 (define-public python2-flask-multistatic
10630 (package-with-python2 python-flask-multistatic))
10631
10632 (define-public python-cookies
10633 (package
10634 (name "python-cookies")
10635 (version "2.2.1")
10636 (source (origin
10637 (method url-fetch)
10638 (uri (pypi-uri "cookies" version))
10639 (sha256
10640 (base32
10641 "13pfndz8vbk4p2a44cfbjsypjarkrall71pgc97glk5fiiw9idnn"))))
10642 (build-system python-build-system)
10643 (arguments
10644 `(;; test are broken: https://gitlab.com/sashahart/cookies/issues/3
10645 #:tests? #f))
10646 (native-inputs
10647 `(("python-pytest" ,python2-pytest)))
10648 (synopsis "HTTP cookie parser and renderer")
10649 (description "A RFC 6265-compliant HTTP cookie parser and renderer in
10650 Python.")
10651 (home-page "https://gitlab.com/sashahart/cookies")
10652 (license license:expat)))
10653
10654 (define-public python2-cookies
10655 (package-with-python2 python-cookies))
10656
10657 (define-public python-responses
10658 (package
10659 (name "python-responses")
10660 (version "0.5.1")
10661 (source (origin
10662 (method url-fetch)
10663 (uri (pypi-uri "responses" version))
10664 (sha256
10665 (base32
10666 "1spcfxixyk9k7pk82jm6zqkwk031s95lh8q0mz7539jrb7269bcc"))))
10667 (build-system python-build-system)
10668 (arguments
10669 `(;; Test suite is not distributed:
10670 ;; https://github.com/getsentry/responses/issues/38
10671 #:tests? #f))
10672 (native-inputs
10673 `(("python-mock" ,python-mock)))
10674 (propagated-inputs
10675 `(("python-requests" ,python-requests)
10676 ("python-cookies" ,python-cookies)
10677 ("python-six" ,python-six)))
10678 (home-page "https://github.com/getsentry/responses")
10679 (synopsis "Utility for mocking out the `requests` Python library")
10680 (description "A utility library for mocking out the `requests` Python
10681 library.")
10682 (license license:asl2.0)))
10683
10684 (define-public python2-responses
10685 (package-with-python2 python-responses))
10686
10687 (define-public python-whoosh
10688 (package
10689 (name "python-whoosh")
10690 (version "2.7.4")
10691 (source
10692 (origin
10693 (method url-fetch)
10694 (uri (pypi-uri "Whoosh" version))
10695 (sha256
10696 (base32
10697 "10qsqdjpbc85fykc1vgcs8xwbgn4l2l52c8d83xf1q59pwyn79bw"))))
10698 (build-system python-build-system)
10699 (native-inputs
10700 `(("python-pytest" ,python-pytest)))
10701 (home-page "http://bitbucket.org/mchaput/whoosh")
10702 (synopsis "Full text indexing, search, and spell checking library")
10703 (description
10704 "Whoosh is a fast, pure-Python full text indexing, search, and spell
10705 checking library.")
10706 (license license:bsd-2)))
10707
10708 (define-public python2-whoosh
10709 (let ((whoosh (package-with-python2 (strip-python2-variant python-whoosh))))
10710 (package (inherit whoosh)
10711 (propagated-inputs
10712 `(("python2-backport-ssl-match-hostname"
10713 ,python2-backport-ssl-match-hostname)
10714 ,@(package-propagated-inputs whoosh))))))
10715
10716 (define-public python-pathlib
10717 (package
10718 (name "python-pathlib")
10719 (version "1.0.1")
10720 (source (origin
10721 (method url-fetch)
10722 (uri (pypi-uri "pathlib" version))
10723 (sha256
10724 (base32
10725 "17zajiw4mjbkkv6ahp3xf025qglkj0805m9s41c45zryzj6p2h39"))))
10726 (build-system python-build-system)
10727 ;; The tests depend on the internal "test" module, which does not provide
10728 ;; a stable interface.
10729 (arguments `(#:tests? #f))
10730 (home-page "https://pathlib.readthedocs.org/")
10731 (synopsis "Object-oriented file system paths")
10732 (description "Pathlib offers a set of classes to handle file system paths.
10733 It offers the following advantages over using string objects:
10734
10735 @enumerate
10736 @item No more cumbersome use of os and os.path functions. Everything can
10737 be done easily through operators, attribute accesses, and method calls.
10738 @item Embodies the semantics of different path types. For example,
10739 comparing Windows paths ignores casing.
10740 @item Well-defined semantics, eliminating any inconsistencies or
10741 ambiguities (forward vs. backward slashes, etc.).
10742 @end enumerate
10743
10744 Note: In Python 3.4, pathlib is now part of the standard library. For other
10745 Python versions please consider python-pathlib2 instead, which tracks the
10746 standard library module. This module (python-pathlib) isn't maintained
10747 anymore.")
10748 (license license:expat)))
10749
10750 (define-public python2-pathlib
10751 (package-with-python2 python-pathlib))
10752
10753 (define-public python2-pathlib2
10754 (package
10755 (name "python2-pathlib2")
10756 (version "2.1.0")
10757 (source (origin
10758 (method url-fetch)
10759 (uri (pypi-uri "pathlib2" version))
10760 (sha256
10761 (base32
10762 "0p050msg5c8d0kadv702jnfshaxrb0il765cpkgnhn6mq5hakcyy"))))
10763 (build-system python-build-system)
10764 ;; We only need the the Python 2 variant, since for Python 3 our minimum
10765 ;; version is 3.4 which already includes this package as part of the
10766 ;; standard library.
10767 (arguments
10768 `(#:python ,python-2))
10769 (native-inputs
10770 `(("python2-six" ,python2-six)))
10771 (home-page "http://pypi.python.org/pypi/pathlib2/")
10772 (synopsis "Object-oriented file system paths - backport of standard
10773 pathlib module")
10774 (description "The goal of pathlib2 is to provide a backport of standard
10775 pathlib module which tracks the standard library module, so all the newest
10776 features of the standard pathlib can be used also on older Python versions.
10777
10778 Pathlib offers a set of classes to handle file system paths. It offers the
10779 following advantages over using string objects:
10780
10781 @enumerate
10782 @item No more cumbersome use of os and os.path functions. Everything can
10783 be done easily through operators, attribute accesses, and method calls.
10784 @item Embodies the semantics of different path types. For example,
10785 comparing Windows paths ignores casing.
10786 @item Well-defined semantics, eliminating any inconsistencies or
10787 ambiguities (forward vs. backward slashes, etc.).
10788 @end enumerate")
10789 (license license:expat)))
10790
10791 (define-public python-jellyfish
10792 (package
10793 (name "python-jellyfish")
10794 (version "0.5.6")
10795 (source (origin
10796 (method url-fetch)
10797 (uri (pypi-uri "jellyfish" version))
10798 (sha256
10799 (base32
10800 "1j9rplb16ba2prjj6mip46z0w9pnhnqpwgiwi0x93vnas14rlyl8"))))
10801 (build-system python-build-system)
10802 (native-inputs
10803 `(("python-pytest" ,python-pytest)))
10804 (home-page "https://github.com/jamesturk/jellyfish")
10805 (synopsis "Approximate and phonetic matching of strings")
10806 (description "Jellyfish uses a variety of string comparison and phonetic
10807 encoding algorithms to do fuzzy string matching.")
10808 (license license:bsd-2)
10809 (properties `((python2-variant . ,(delay python2-jellyfish))))))
10810
10811 (define-public python2-jellyfish
10812 (let ((jellyfish (package-with-python2
10813 (strip-python2-variant python-jellyfish))))
10814 (package (inherit jellyfish)
10815 (native-inputs `(("python2-unicodecsv" ,python2-unicodecsv)
10816 ,@(package-native-inputs jellyfish))))))
10817
10818 (define-public python2-unicodecsv
10819 (package
10820 (name "python2-unicodecsv")
10821 (version "0.14.1")
10822 (source (origin
10823 (method url-fetch)
10824 ;; The test suite is not included in the PyPi release.
10825 ;; https://github.com/jdunck/python-unicodecsv/issues/19
10826 (uri (string-append "https://github.com/jdunck/python-unicodecsv/"
10827 "archive/" version ".tar.gz"))
10828 (file-name (string-append name "-" version ".tar.gz"))
10829 (sha256
10830 (base32
10831 "087nqanfcyp6mlfbbr5lva5f3w6iz1bybls9xlrb8icmc474wh4w"))))
10832 (build-system python-build-system)
10833 (arguments
10834 `(;; It supports Python 3, but Python 3 can already do Unicode CSV.
10835 #:python ,python-2))
10836 (native-inputs
10837 `(("python2-unittest2" ,python2-unittest2)))
10838 (home-page "https://github.com/jdunck/python-unicodecsv")
10839 (synopsis "Unicode CSV module for Python 2")
10840 (description "Unicodecsv is a drop-in replacement for Python 2.7's CSV
10841 module, adding support for Unicode strings.")
10842 (license license:bsd-2)))
10843
10844 (define-public python-rarfile
10845 (package
10846 (name "python-rarfile")
10847 (version "2.8")
10848 (source (origin
10849 (method url-fetch)
10850 (uri (pypi-uri "rarfile" version))
10851 (sha256
10852 (base32
10853 "0qfad483kcbga0bn4qmcz953xjk16r52fahiy46zzn56v80y89ra"))))
10854 (build-system python-build-system)
10855 (arguments
10856 '(#:phases
10857 (modify-phases %standard-phases
10858 (replace 'check
10859 ;; Many tests fail, but the installation proceeds.
10860 (lambda _ (zero? (system* "make" "-C" "test" "test")))))))
10861 (native-inputs
10862 `(("which" ,which))) ; required for tests
10863 (propagated-inputs
10864 `(("libarchive" ,libarchive)))
10865 (home-page "https://github.com/markokr/rarfile")
10866 (synopsis "RAR archive reader for Python")
10867 (description "This is Python module for RAR archive reading. The interface
10868 is made as zipfile like as possible.")
10869 (license license:isc)))
10870
10871 (define-public python2-rarfile
10872 (package-with-python2 python-rarfile))
10873
10874 (define-public python-magic
10875 (package
10876 (name "python-magic")
10877 (version "0.4.3")
10878 (source
10879 (origin
10880 (method url-fetch)
10881 (uri (string-append "https://github.com/ahupp/python-magic/archive/"
10882 version ".tar.gz"))
10883 (sha256
10884 (base32
10885 "17bgy92i7sb021f2s4mw1dcvpm6p1mi9jihridwy1pyn8mzvpjgk"))
10886 (file-name (string-append name "-" version "-checkout"))))
10887 (build-system python-build-system)
10888 (arguments
10889 ;; The tests are unreliable, so don't run them. The tests fail
10890 ;; under Python3 because they were written for Python2 and
10891 ;; contain import statements that do not work in Python3. One of
10892 ;; the tests fails under Python2 because its assertions are
10893 ;; overly stringent; it relies on comparing output strings which
10894 ;; are brittle and can change depending on the version of
10895 ;; libmagic being used and the system on which the test is
10896 ;; running. In my case, under GuixSD 0.10.0, only one test
10897 ;; failed, and it seems to have failed only because the version
10898 ;; of libmagic that is packaged in Guix outputs a slightly
10899 ;; different (but not wrong) string than the one that the test
10900 ;; expected.
10901 '(#:tests? #f
10902 #:phases (modify-phases %standard-phases
10903 ;; Replace a specific method call with a hard-coded
10904 ;; path to the necessary libmagic.so file in the
10905 ;; store. If we don't do this, then the method call
10906 ;; will fail to find the libmagic.so file, which in
10907 ;; turn will cause any application using
10908 ;; python-magic to fail.
10909 (add-before 'build 'hard-code-path-to-libmagic
10910 (lambda* (#:key inputs #:allow-other-keys)
10911 (let ((file (assoc-ref inputs "file")))
10912 (substitute* "magic.py"
10913 (("ctypes.util.find_library\\('magic'\\)")
10914 (string-append "'" file "/lib/libmagic.so'")))
10915 #t)))
10916 (add-before 'install 'disable-egg-compression
10917 (lambda _
10918 (let ((port (open-file "setup.cfg" "a")))
10919 (display "\n[easy_install]\nzip_ok = 0\n"
10920 port)
10921 (close-port port)
10922 #t))))))
10923 (inputs
10924 ;; python-magic needs to be able to find libmagic.so.
10925 `(("file" ,file)))
10926 (home-page "https://github.com/ahupp/python-magic")
10927 (synopsis "File type identification using libmagic")
10928 (description
10929 "This module uses ctypes to access the libmagic file type
10930 identification library. It makes use of the local magic database and
10931 supports both textual and MIME-type output. Note that this module and
10932 the python-file module both provide a \"magic.py\" file; these two
10933 modules, which are different and were developed separately, both serve
10934 the same purpose: to provide Python bindings for libmagic.")
10935 (license license:expat)))
10936
10937 (define-public python2-magic
10938 (package-with-python2 python-magic))
10939
10940 (define-public python2-s3cmd
10941 (package
10942 (name "python2-s3cmd")
10943 (version "1.6.1")
10944 (source
10945 (origin
10946 (method url-fetch)
10947 (uri (string-append "mirror://sourceforge/s3tools/s3cmd/" version "/"
10948 "s3cmd-" version ".tar.gz"))
10949 (sha256
10950 (base32
10951 "0ki1rzhm5icvi9ry5jswi4b22yqwyj0d2wsqsgilwx6qhi7pjxa6"))))
10952 (build-system python-build-system)
10953 (arguments
10954 ;; s3cmd is written for python2 only and contains no tests.
10955 `(#:python ,python-2
10956 #:tests? #f))
10957 (propagated-inputs
10958 `(("python2-dateutil" ,python2-dateutil)
10959 ;; The python-file package also provides a magic.py module.
10960 ;; This is an unfortunate state of affairs; however, s3cmd
10961 ;; fails to install if it cannot find specifically the
10962 ;; python-magic package. Thus we include it, instead of using
10963 ;; python-file. Ironically, s3cmd sometimes works better
10964 ;; without libmagic bindings at all:
10965 ;; https://github.com/s3tools/s3cmd/issues/198
10966 ("python2-magic" ,python2-magic)))
10967 (home-page "http://s3tools.org/s3cmd")
10968 (synopsis "Command line tool for S3-compatible storage services")
10969 (description
10970 "S3cmd is a command line tool for uploading, retrieving and managing data
10971 in storage services that are compatible with the Amazon Simple Storage
10972 Service (S3) protocol, including S3 itself. It supports rsync-like backup,
10973 GnuPG encryption, and more. It also supports management of Amazon's
10974 CloudFront content delivery network.")
10975 (license license:gpl2+)))
10976
10977 (define-public python-pkgconfig
10978 (package
10979 (name "python-pkgconfig")
10980 (version "1.1.0")
10981 (source
10982 (origin
10983 (method url-fetch)
10984 (uri (pypi-uri "pkgconfig" version))
10985 (sha256
10986 (base32
10987 "1pw0kmvc57sjmaxi6c54fqsnihqj6hvhc9y1vaz36axafzqam7bh"))))
10988 (build-system python-build-system)
10989 (native-inputs
10990 `(("python-nose" ,python-nose)))
10991 (inputs
10992 `(("pkg-config" ,pkg-config)))
10993 (arguments
10994 `(;; Tests fail with "ValueError: _type_ 'v' not supported" on Python 3,
10995 ;; and on Python 2 they need the dl module deprecated since Python 2.6.
10996 #:tests? #f
10997 ;; Hard-code the path to pkg-config.
10998 #:phases
10999 (modify-phases %standard-phases
11000 (add-before
11001 'build 'patch
11002 (lambda _
11003 (substitute* "pkgconfig/pkgconfig.py"
11004 (("cmd = 'pkg-config")
11005 (string-append "cmd = '" (which "pkg-config"))))
11006 #t)))))
11007 (home-page "https://github.com/matze/pkgconfig")
11008 (synopsis "Python interface for pkg-config")
11009 (description "This module provides a Python interface to pkg-config. It
11010 can be used to find all pkg-config packages, check if a package exists,
11011 check if a package meets certain version requirements, query CFLAGS and
11012 LDFLAGS and parse the output to build extensions with setup.py.")
11013 (license license:expat)))
11014
11015 (define-public python2-pkgconfig
11016 (package-with-python2 python-pkgconfig))
11017
11018 (define-public python-bz2file
11019 (package
11020 (name "python-bz2file")
11021 (version "0.98")
11022 (source
11023 (origin
11024 (method url-fetch)
11025 (uri (pypi-uri "bz2file" version))
11026 (sha256
11027 (base32
11028 "126s53fkpx04f33a829yqqk8fj4png3qwg4m66cvlmhmwc8zihb4"))))
11029 (build-system python-build-system)
11030 (arguments
11031 `(#:tests? #f)) ; Tests use deprecated python modules.
11032 (home-page "https://github.com/nvawda/bz2file")
11033 (synopsis "Read and write bzip2-compressed files")
11034 (description
11035 "Bz2file is a Python library for reading and writing bzip2-compressed
11036 files. It contains a drop-in replacement for the I/O interface in the
11037 standard library's @code{bz2} module, including features from the latest
11038 development version of CPython that are not available in older releases.")
11039 (license license:asl2.0)
11040 (properties `((python2-variant . ,(delay python2-bz2file))))))
11041
11042 (define-public python2-bz2file
11043 (let ((base (package-with-python2
11044 (strip-python2-variant python-bz2file))))
11045 (package
11046 (inherit base)
11047 (arguments
11048 `(#:python ,python-2
11049 #:phases
11050 (modify-phases %standard-phases
11051 ;; 'python setup.py test' does not work as of 0.98.
11052 ;; There is only the one test file, so we run it directly.
11053 (replace 'check
11054 (lambda _ (zero? (system* "python"
11055 "test_bz2file.py"))))))))))
11056
11057 (define-public python-future
11058 (package
11059 (name "python-future")
11060 (version "0.16.0")
11061 (source
11062 (origin
11063 (method url-fetch)
11064 (uri (pypi-uri "future" version))
11065 (sha256
11066 (base32
11067 "1nzy1k4m9966sikp0qka7lirh8sqrsyainyf8rk97db7nwdfv773"))))
11068 (build-system python-build-system)
11069 ;; Many tests connect to the network or are otherwise flawed.
11070 ;; https://github.com/PythonCharmers/python-future/issues/210
11071 (arguments
11072 `(#:tests? #f))
11073 (home-page "http://python-future.org")
11074 (synopsis "Single-source support for Python 3 and 2")
11075 (description
11076 "@code{python-future} is the missing compatibility layer between Python 2 and
11077 Python 3. It allows you to use a single, clean Python 3.x-compatible codebase
11078 to support both Python 2 and Python 3 with minimal overhead.")
11079 (license license:expat)))
11080
11081 (define-public python2-future
11082 (package-with-python2 python-future))
11083
11084 (define-public python-cysignals
11085 (package
11086 (name "python-cysignals")
11087 (version "1.1.0")
11088 (source
11089 (origin
11090 (method url-fetch)
11091 (uri (pypi-uri "cysignals" version ".tar.bz2"))
11092 (sha256
11093 (base32
11094 "14cbyd9znlz6cxy1s3g6v6dv5jj45hn27pywkidd9b1zanaysqc6"))))
11095 (build-system python-build-system)
11096 (native-inputs
11097 `(("python-cython" ,python-cython)
11098 ("python-sphinx" ,python-sphinx)))
11099 (inputs
11100 `(("pari-gp" ,pari-gp)))
11101 (arguments
11102 `(#:modules ((guix build python-build-system)
11103 ((guix build gnu-build-system) #:prefix gnu:)
11104 (guix build utils))
11105 ;; FIXME: Tests are executed after installation and currently fail
11106 ;; when not installing into standard locations; the author is working
11107 ;; on a fix.
11108 #:tests? #f
11109 #:phases
11110 (modify-phases %standard-phases
11111 (add-before
11112 'build 'configure
11113 (assoc-ref gnu:%standard-phases 'configure)))))
11114 (home-page
11115 "https://github.com/sagemath/cysignals")
11116 (synopsis
11117 "Handling of interrupts and signals for Cython")
11118 (description
11119 "The cysignals package provides mechanisms to handle interrupts (and
11120 other signals and errors) in Cython code, using two related approaches,
11121 for mixed Cython/Python code or external C libraries and pure Cython code,
11122 respectively.")
11123 (license license:lgpl3+)))
11124
11125 (define-public python2-cysignals
11126 (package-with-python2 python-cysignals))
11127
11128 (define-public python2-shedskin
11129 (package
11130 (name "python2-shedskin")
11131 (version "0.9.4")
11132 (source
11133 (origin
11134 (method url-fetch)
11135 (uri (string-append "https://github.com/shedskin/shedskin/"
11136 "releases/download/v" version
11137 "/shedskin-" version ".tgz"))
11138 (sha256
11139 (base32
11140 "0nzwrzgw1ga8rw6f0ryq7zr9kkiavd1cqz5hzxkcbicl1dk7kz41"))))
11141 (build-system python-build-system)
11142 (arguments
11143 `(#:python ,python-2
11144 #:phases (modify-phases %standard-phases
11145 (add-after 'unpack 'fix-resulting-include-libs
11146 (lambda* (#:key inputs #:allow-other-keys)
11147 (let ((libgc (assoc-ref inputs "libgc"))
11148 (pcre (assoc-ref inputs "pcre")))
11149 (substitute* "shedskin/makefile.py"
11150 (("variable == 'CCFLAGS':[ ]*")
11151 (string-append "variable == 'CCFLAGS':\n"
11152 " line += ' -I " pcre "/include"
11153 " -I " libgc "/include'"))
11154 (("variable == 'LFLAGS':[ ]*")
11155 (string-append "variable == 'LFLAGS':\n"
11156 " line += ' -L" pcre "/lib"
11157 " -L " libgc "/lib'")))
11158 #t))))))
11159 (inputs `(("pcre" ,pcre)
11160 ("libgc" ,libgc)))
11161 (home-page "https://shedskin.github.io/")
11162 (synopsis "Experimental Python-2 to C++ Compiler")
11163 (description (string-append "This is an experimental compiler for a subset of
11164 Python. It generates C++ code and a Makefile."))
11165 (license (list license:gpl3 license:bsd-3 license:expat))))
11166
11167 (define-public python2-rope
11168 (package
11169 (name "python2-rope")
11170 (version "0.10.3")
11171 (source
11172 (origin
11173 (method url-fetch)
11174 (uri (pypi-uri "rope" version))
11175 (sha256
11176 (base32
11177 "18k5znhpwvrfck3yp0jmhd5j8r0f0s8bk1zh5yhs2cfgmfhbwigb"))))
11178 (arguments
11179 ;; Rope is currently python-2 only.
11180 ;; https://github.com/python-rope/rope/issues/57
11181 `(#:python ,python-2))
11182 (build-system python-build-system)
11183 (native-inputs
11184 `(("python2-unittest2" ,python2-unittest2)))
11185 (home-page "https://github.com/python-rope/rope")
11186 (synopsis "Refactoring library for Python")
11187 (description "Rope is a refactoring library for Python. It facilitates
11188 the renaming, moving and extracting of attributes, functions, modules, fields
11189 and parameters in Python 2 source code. These refactorings can also be applied
11190 to occurrences in strings and comments.")
11191 (license license:gpl2)))
11192
11193 (define-public python-py3status
11194 (package
11195 (name "python-py3status")
11196 (version "3.1")
11197 (source
11198 (origin
11199 (method url-fetch)
11200 (uri (pypi-uri "py3status" version))
11201 (sha256
11202 (base32
11203 "0i283z1pivmir61z8kbiycigc94l61v33ygzkhczf1ifq7cppyds"))))
11204 (build-system python-build-system)
11205 (arguments
11206 '(#:tests? #f)) ; TODO: Requires many libraries not in Guix.
11207 (home-page "https://github.com/ultrabug/py3status")
11208 (synopsis "Extensible i3status wrapper written in Python")
11209 (description "py3status is an i3status wrapper which extends i3status
11210 functionality in a modular way, allowing you to extend your panel with your
11211 own code, responding to click events and updating clock every second.")
11212 (license license:bsd-3)))
11213
11214 (define-public python-tblib
11215 (package
11216 (name "python-tblib")
11217 (version "1.3.0")
11218 (source (origin
11219 (method url-fetch)
11220 (uri (pypi-uri "tblib" version))
11221 (sha256 (base32
11222 "02iahfkfa927hb4jq2bak36ldihwapzacfiq5lyxg8llwn98a1yi"))))
11223 (build-system python-build-system)
11224 (arguments
11225 `(#:phases
11226 (modify-phases %standard-phases
11227 (replace 'check
11228 (lambda _
11229 ;; Upstream runs tests after installation and the package itself
11230 ;; resides in a subdirectory. Extend PYTHONPATH so it will be
11231 ;; found.
11232 (setenv "PYTHONPATH"
11233 (string-append (getcwd) "/build/lib:"
11234 (getenv "PYTHONPATH")))
11235 (zero? (system* "py.test" "-vv" "tests" "README.rst")))))))
11236 (native-inputs
11237 `(("python-pytest" ,python-pytest)
11238 ("python-six" ,python-six)))
11239 (home-page "https://github.com/ionelmc/python-tblib")
11240 (synopsis "Traceback serialization library")
11241 (description
11242 "Traceback serialization allows you to:
11243
11244 @enumerate
11245 @item Pickle tracebacks and raise exceptions with pickled tracebacks in
11246 different processes. This allows better error handling when running code over
11247 multiple processes (imagine multiprocessing, billiard, futures, celery etc).
11248
11249 @item Parse traceback strings and raise with the parsed tracebacks.
11250 @end enumerate\n")
11251 (license license:bsd-3)))
11252
11253 (define-public python2-tblib
11254 (package-with-python2 python-tblib))
11255
11256 (define-public python-sqlparse
11257 (package
11258 (name "python-sqlparse")
11259 (version "0.1.19")
11260 (source (origin
11261 (method url-fetch)
11262 (uri (pypi-uri "sqlparse" version))
11263 (sha256
11264 (base32
11265 "1s2fvaxgh9kqzrd6iwy5h7i61ckn05plx9np13zby93z3hdbx5nq"))))
11266 (build-system python-build-system)
11267 (arguments
11268 `(#:phases
11269 (modify-phases %standard-phases
11270 (replace 'check
11271 (lambda* _
11272 ;; setup.py-integrated 2to3 only affects the build files, but
11273 ;; py.test is using the source files. So we need to convert them
11274 ;; manually.
11275 (when (zero? (system* "python3"))
11276 (system* "2to3" "--no-diff" "-wn" "sqlparse" "tests"))
11277 (zero? (system* "py.test")))))))
11278 (native-inputs
11279 `(("python-pytest" ,python-pytest)))
11280 (home-page "https://github.com/andialbrecht/sqlparse")
11281 (synopsis "Non-validating SQL parser")
11282 (description "Sqlparse is a non-validating SQL parser for Python. It
11283 provides support for parsing, splitting and formatting SQL statements.")
11284 (license license:bsd-3)))
11285
11286 (define-public python2-sqlparse
11287 (package-with-python2 python-sqlparse))
11288
11289 (define-public python-greenlet
11290 (package
11291 (name "python-greenlet")
11292 (version "0.4.11")
11293 (source (origin
11294 (method url-fetch)
11295 (uri (pypi-uri "greenlet" version))
11296 (sha256
11297 (base32
11298 "1xhik26j4f3kc4qw9xmj0c567rb5h1zryb4ijwqnqwwjvfhbv59h"))))
11299 (build-system python-build-system)
11300 (home-page "https://greenlet.readthedocs.io/")
11301 (synopsis "Lightweight in-process concurrent programming")
11302 (description
11303 "Greenlet package is a spin-off of Stackless, a version of CPython
11304 that supports micro-threads called \"tasklets\". Tasklets run
11305 pseudo-concurrently (typically in a single or a few OS-level threads) and
11306 are synchronized with data exchanges on \"channels\".")
11307 (license (list license:psfl license:expat))))
11308
11309 (define-public python2-greenlet
11310 (package-with-python2 python-greenlet))
11311
11312 (define-public python-gevent
11313 (package
11314 (name "python-gevent")
11315 (version "1.1.1")
11316 (source (origin
11317 (method url-fetch)
11318 (uri (pypi-uri "gevent" version))
11319 (sha256
11320 (base32
11321 "1smf3kvidpdiyi2c81alal74p2zm0clrm6xbyy6y1k9a3f2vkrbf"))
11322 (modules '((guix build utils)))
11323 (snippet
11324 '(begin
11325 ;; unbunding libev and c-ares
11326 (for-each delete-file-recursively '("libev" "c-ares"))
11327 ;; fixing testsuite
11328 (call-with-output-file "greentest/__init__.py" noop)
11329 (substitute* "greentest/testrunner.py"
11330 (("import util") "from . import util")
11331 (("from util import log") "from .util import log"))))))
11332 (build-system python-build-system)
11333 (propagated-inputs
11334 `(("python-greenlet" ,python-greenlet)))
11335 (native-inputs
11336 `(("python-six" ,python-six)))
11337 (inputs
11338 `(("c-ares" ,c-ares)
11339 ("libev" ,libev)))
11340 (home-page "http://www.gevent.org/")
11341 (synopsis "Coroutine-based network library")
11342 (description
11343 "gevent is a coroutine-based Python networking library that uses greenlet
11344 to provide a high-level synchronous API on top of the libev event loop.")
11345 (license license:expat)))
11346
11347 (define-public python2-gevent
11348 (package-with-python2 python-gevent))
11349
11350 (define-public python-geventhttpclient
11351 (package
11352 (name "python-geventhttpclient")
11353 (version "1.3.1")
11354 (source (origin
11355 (method url-fetch)
11356 (uri (pypi-uri "geventhttpclient" version))
11357 (sha256
11358 (base32
11359 "07d0q3wzmml75227r6y6mrl5a0zpf4v9gj0ni5rhbyzmaj4az1xx"))
11360 (modules '((guix build utils)))
11361 (snippet
11362 '(begin
11363 ;; Delete pre-compiled files.
11364 (for-each delete-file (find-files "src/geventhttpclient"
11365 ".*\\.pyc"))
11366 #t))))
11367 (build-system python-build-system)
11368 (arguments
11369 '(#:phases
11370 (modify-phases %standard-phases
11371 (add-after 'unpack 'delete-network-tests
11372 (lambda _
11373 (delete-file "src/geventhttpclient/tests/test_client.py")
11374 #t))
11375 (delete 'check)
11376 (add-after 'install 'check
11377 (lambda* (#:key inputs outputs #:allow-other-keys)
11378 (add-installed-pythonpath inputs outputs)
11379 (zero? (system* "py.test" "src/geventhttpclient/tests" "-v")))))))
11380 (native-inputs
11381 `(("python-pytest" ,python-pytest)))
11382 (propagated-inputs
11383 `(("python-certifi" ,python-certifi)
11384 ("python-gevent" ,python-gevent)
11385 ("python-six" ,python-six)))
11386 (home-page "https://github.com/gwik/geventhttpclient")
11387 (synopsis "HTTP client library for gevent")
11388 (description "@code{python-geventhttpclient} is a high performance,
11389 concurrent HTTP client library for python using @code{gevent}.")
11390 (license license:expat)))
11391
11392 (define-public python2-geventhttpclient
11393 (package-with-python2 python-geventhttpclient))
11394
11395 (define-public python-fastimport
11396 (package
11397 (name "python-fastimport")
11398 (version "0.9.6")
11399 (source
11400 (origin
11401 (method url-fetch)
11402 (uri (pypi-uri "fastimport" version))
11403 (sha256
11404 (base32 "1aqjsin4rmqm7ln4j0p73fzxifws6c6ikgyhav7r137m2ixsxl43"))))
11405 (build-system python-build-system)
11406 (home-page "https://github.com/jelmer/python-fastimport")
11407 (synopsis "VCS fastimport parser and generator in Python")
11408 (description "This package provides a parser for and generator of the Git
11409 @url{https://www.kernel.org/pub/software/scm/git/docs/git-fast-import.html,fastimport}
11410 format.")
11411 (license license:gpl2+)))
11412
11413 (define-public python2-fastimport
11414 (package-with-python2 python-fastimport))
11415
11416 (define-public python-twisted
11417 (package
11418 (name "python-twisted")
11419 (version "16.2.0")
11420 (source (origin
11421 (method url-fetch)
11422 (uri (pypi-uri "Twisted" version ".tar.bz2"))
11423 (sha256
11424 (base32
11425 "0ydxrp9myw1mvsz3qfzx5579y5llmqa82pxvqchgp5syczffi450"))))
11426 (build-system python-build-system)
11427 (arguments
11428 '(#:tests? #f)) ; FIXME: Some tests are failing.
11429 ;; #:phases
11430 ;; (modify-phases %standard-phases
11431 ;; (replace 'check
11432 ;; (lambda _
11433 ;; (zero? (system* "./bin/trial" "twisted")))))
11434 (propagated-inputs
11435 `(("python-zope-interface" ,python-zope-interface)))
11436 (home-page "https://twistedmatrix.com/")
11437 (synopsis "Asynchronous networking framework written in Python")
11438 (description
11439 "Twisted is an extensible framework for Python programming, with special
11440 focus on event-based network programming and multiprotocol integration.")
11441 (license license:expat)))
11442
11443 (define-public python2-twisted
11444 (package-with-python2 python-twisted))
11445
11446 (define-public python-pika
11447 (package
11448 (name "python-pika")
11449 (version "0.10.0")
11450 (source
11451 (origin
11452 (method url-fetch)
11453 (uri (pypi-uri "pika" version))
11454 (sha256
11455 (base32
11456 "0nb4h08di432lv7dy2v9kpwgk0w92f24sqc2hw2s9vwr5b8v8xvj"))))
11457 (build-system python-build-system)
11458 (native-inputs
11459 `(("python-pyev" ,python-pyev)
11460 ("python-tornado" ,python-tornado)
11461 ("python-twisted" ,python-twisted)))
11462 (home-page "https://pika.readthedocs.org")
11463 (synopsis "Pure Python AMQP Client Library")
11464 (description
11465 "Pika is a pure-Python implementation of the AMQP (Advanced Message Queuing
11466 Protocol) 0-9-1 protocol that tries to stay fairly independent of the underlying
11467 network support library.")
11468 (license license:bsd-3)))
11469
11470 (define-public python2-pika
11471 (package-with-python2 python-pika))
11472
11473 (define-public python-ply
11474 (package
11475 (name "python-ply")
11476 (version "3.9")
11477 (source
11478 (origin
11479 (method url-fetch)
11480 (uri (pypi-uri "ply" version))
11481 (sha256
11482 (base32
11483 "0gpl0yli3w03ipyqfrp3w5nf0iawhsq65anf5wwm2wf5p502jzhd"))))
11484 (build-system python-build-system)
11485 (home-page "http://www.dabeaz.com/ply/")
11486 (synopsis "Python Lex & Yacc")
11487 (description "PLY is a @code{lex}/@code{yacc} implemented purely in Python.
11488 It uses LR parsing and does extensive error checking.")
11489 (license license:bsd-3)))
11490
11491 (define-public python2-ply
11492 (package-with-python2 python-ply))
11493
11494 (define-public python-tabulate
11495 (package
11496 (name "python-tabulate")
11497 (version "0.7.7")
11498 (source (origin
11499 (method url-fetch)
11500 (uri (pypi-uri "tabulate" version))
11501 (sha256
11502 (base32
11503 "1inqhspd4frxnp08c32yndr0lc4px1xfkqah184i5w09gkhvi843"))))
11504 (build-system python-build-system)
11505 (arguments
11506 ;; FIXME: The pypi release tarball is missing a 'test/common.py'
11507 ;; and the latest release is not tagged in the upstream repository.
11508 '(#:tests? #f))
11509 (home-page "https://bitbucket.org/astanin/python-tabulate")
11510 (synopsis "Pretty-print tabular data")
11511 (description
11512 "Tabulate is a library and command-line utility to pretty-print tabular
11513 data in Python.")
11514 (license license:expat)))
11515
11516 (define-public python2-tabulate
11517 (package-with-python2 python-tabulate))
11518
11519 (define-public python-kazoo
11520 (package
11521 (name "python-kazoo")
11522 (version "2.2.1")
11523 (source
11524 (origin
11525 (method url-fetch)
11526 (uri (pypi-uri "kazoo" version))
11527 (sha256
11528 (base32
11529 "10pb864if9qi2pq9lfb9m8f7z7ss6rml80gf1d9h64lap5crjnjj"))))
11530 (build-system python-build-system)
11531 (arguments '(#:tests? #f)) ; XXX: needs zookeeper
11532 (propagated-inputs
11533 `(("python-six" ,python-six)))
11534 (home-page "https://kazoo.readthedocs.org")
11535 (synopsis "High-level Zookeeper client library")
11536 (description
11537 "Kazoo is a Python client library for the Apache Zookeeper distributed
11538 application service. It is designed to be easy to use and to avoid common
11539 programming errors.")
11540 (license license:asl2.0)))
11541
11542 (define-public python2-kazoo
11543 (package-with-python2 python-kazoo))
11544
11545 (define-public python-pykafka
11546 (package
11547 (name "python-pykafka")
11548 (version "2.4.0")
11549 (source (origin
11550 (method url-fetch)
11551 (uri (string-append
11552 "https://pypi.python.org/packages/8b/3e/"
11553 "384eeff406b06315738b62483fd2126c6e4f544167116b17cc04ea7d2a59/"
11554 "pykafka-" version ".tar.gz"))
11555 (sha256
11556 (base32
11557 "1id6sr159p6aa13bxcqyr9gln8sqg1l0ddzns5iws8kk5q1p5cfv"))))
11558 (build-system python-build-system)
11559 (arguments '(#:tests? #f)) ; XXX: needs zookeeper, kafka, etc.
11560 (propagated-inputs
11561 `(("python-gevent" ,python-gevent)
11562 ("python-kazoo" ,python-kazoo)
11563 ("python-tabulate" ,python-tabulate)))
11564 (inputs
11565 `(("librdkafka" ,librdkafka)))
11566 (home-page "https://pykafka.readthedocs.io/")
11567 (synopsis "Apache Kafka client for Python")
11568 (description
11569 "PyKafka is a client for the Apache Kafka distributed messaging system.
11570 It includes Python implementations of Kafka producers and consumers, which
11571 are optionally backed by a C extension built on librdkafka.")
11572 (license license:asl2.0)))
11573
11574 (define-public python2-pykafka
11575 (package-with-python2 python-pykafka))
11576
11577 (define-public python-wcwidth
11578 (package
11579 (name "python-wcwidth")
11580 (version "0.1.7")
11581 (source
11582 (origin
11583 (method url-fetch)
11584 (uri (pypi-uri "wcwidth" version))
11585 (sha256
11586 (base32
11587 "0pn6dflzm609m4r3i8ik5ni9ijjbb5fa3vg1n7hn6vkd49r77wrx"))))
11588 (build-system python-build-system)
11589 (home-page "https://github.com/jquast/wcwidth")
11590 (synopsis "Measure number of terminal column cells of wide-character codes")
11591 (description "Wcwidth measures the number of terminal column cells of
11592 wide-character codes. It is useful for those implementing a terminal emulator,
11593 or programs that carefully produce output to be interpreted by one. It is a
11594 Python implementation of the @code{wcwidth} and @code{wcswidth} C functions
11595 specified in POSIX.1-2001 and POSIX.1-2008.")
11596 (license license:expat)))
11597
11598 (define-public python2-wcwidth
11599 (package-with-python2 python-wcwidth))
11600
11601 (define-public python2-jsonrpclib
11602 (package
11603 (name "python2-jsonrpclib")
11604 (version "0.1.7")
11605 (source (origin
11606 (method url-fetch)
11607 (uri (string-append
11608 "https://pypi.python.org/packages/source/j/jsonrpclib/"
11609 "jsonrpclib-" version ".tar.gz"))
11610 (sha256
11611 (base32
11612 "02vgirw2bcgvpcxhv5hf3yvvb4h5wzd1lpjx8na5psdmaffj6l3z"))))
11613 (build-system python-build-system)
11614 (arguments
11615 `(#:tests? #f
11616 #:python ,python-2))
11617 (home-page "https://github.com/joshmarshall/jsonrpclib/")
11618 (synopsis "Implementation of JSON-RPC specification for Python")
11619 (description
11620 "This library is an implementation of the JSON-RPC specification.
11621 It supports both the original 1.0 specification, as well as the
11622 new (proposed) 2.0 spec, which includes batch submission, keyword arguments,
11623 etc.")
11624 (license license:asl2.0)))
11625
11626 (define-public python-chai
11627 (package
11628 (name "python-chai")
11629 (version "1.1.1")
11630 (source (origin
11631 (method url-fetch)
11632 (uri (pypi-uri "chai" version))
11633 (sha256
11634 (base32
11635 "016kf3irrclpkpvcm7q0gmkfibq7jgy30a9v73pp42bq9h9a32bl"))))
11636 (build-system python-build-system)
11637 (home-page "https://github.com/agoragames/chai")
11638 (synopsis "Mocking framework for Python")
11639 (description
11640 "Chai provides an api for mocking, stubbing and spying your python
11641 objects, patterned after the Mocha library for Ruby.")
11642 (license license:bsd-3)))
11643
11644 (define-public python2-chai
11645 (package-with-python2 python-chai))
11646
11647 (define-public python-arrow
11648 (package
11649 (name "python-arrow")
11650 (version "0.8.0")
11651 (source (origin
11652 (method url-fetch)
11653 (uri (pypi-uri "arrow" version))
11654 (sha256
11655 (base32
11656 "1bz7hkdgpqcjs866y58z8jywpy7al0f4rxdr00bh2l5qddyw245j"))))
11657 (build-system python-build-system)
11658 (native-inputs
11659 `(;; For testing
11660 ("python-chai" ,python-chai)
11661 ("python-simplejson" ,python-simplejson)))
11662 (propagated-inputs
11663 `(("python-dateutil" ,python-dateutil)))
11664 (home-page "https://github.com/crsmithdev/arrow/")
11665 (synopsis "Dates and times for Python")
11666 (description
11667 "Arrow is a Python library to creating, manipulating, formatting and
11668 converting dates, times, and timestamps. It implements and updates the
11669 datetime type.")
11670 (license license:asl2.0)))
11671
11672 (define-public python2-arrow
11673 (package-with-python2 python-arrow))
11674
11675 (define-public python-inflection
11676 (package
11677 (name "python-inflection")
11678 (version "0.3.1")
11679 (source
11680 (origin (method url-fetch)
11681 (uri (pypi-uri "inflection" version))
11682 (sha256
11683 (base32
11684 "1jhnxgnw8y3mbzjssixh6qkc7a3afc4fygajhqrqalnilyvpzshq"))))
11685 (build-system python-build-system)
11686 (native-inputs
11687 `(("python-pytest" ,python-pytest)))
11688 (home-page "https://github.com/jpvanhal/inflection")
11689 (synopsis "Python string transformation library")
11690 (description
11691 "Inflection is a string transformation library. It singularizes
11692 and pluralizes English words, and transforms strings from CamelCase to
11693 underscored string.")
11694 (license license:expat)))
11695
11696 (define-public python2-inflection
11697 (package-with-python2 python-inflection))
11698
11699 (define-public python-pylev
11700 (package
11701 (name "python-pylev")
11702 (version "1.3.0")
11703 (source (origin
11704 (method url-fetch)
11705 (uri (pypi-uri "pylev" version))
11706 (sha256
11707 (base32
11708 "1hz1x9blsbxya1y9nnhnwwdnqmakxi9mc0jkwj0rn6b1h44i0f86"))))
11709 (build-system python-build-system)
11710 (home-page "https://github.com/toastdriven/pylev")
11711 (synopsis "Levenshtein distance implementation in Python")
11712 (description "Pure Python Levenshtein implementation, based off the
11713 Wikipedia code samples at
11714 @url{http://en.wikipedia.org/wiki/Levenshtein_distance}.")
11715 (license license:bsd-3)))
11716
11717 (define-public python2-pylev
11718 (package-with-python2 python-pylev))
11719
11720 (define-public python-cleo
11721 (package
11722 (name "python-cleo")
11723 (version "0.4.1")
11724 (source (origin
11725 (method url-fetch)
11726 (uri (pypi-uri "cleo" version))
11727 (sha256
11728 (base32
11729 "1k2dcl6mqpn5bljyl6w42rqyd9mb3y9kh2mg7m2x3kfjwvg0rpva"))))
11730 (build-system python-build-system)
11731 (native-inputs
11732 `(;; For testing
11733 ("python-mock" ,python-mock)
11734 ("python-pytest" ,python-pytest)))
11735 (propagated-inputs
11736 `(("python-psutil" ,python-psutil)
11737 ("python-pylev" ,python-pylev)))
11738 (home-page "https://github.com/sdispater/cleo")
11739 (synopsis "Command-line arguments library for Python")
11740 (description
11741 "Cleo allows you to create command-line commands with signature in
11742 docstring and colored output.")
11743 (license license:expat)))
11744
11745 (define-public python2-cleo
11746 (package-with-python2 python-cleo))
11747
11748 (define-public python-lazy-object-proxy
11749 (package
11750 (name "python-lazy-object-proxy")
11751 (version "1.2.2")
11752 (source (origin
11753 (method url-fetch)
11754 (uri (pypi-uri "lazy-object-proxy" version))
11755 (sha256
11756 (base32
11757 "0s22aqqkdscyh8sjspyyax7qa1aiz8p4midrnyf39717fhfczm6x"))))
11758 (build-system python-build-system)
11759 (home-page "https://github.com/ionelmc/python-lazy-object-proxy")
11760 (synopsis "Lazy object proxy for python")
11761 (description
11762 "Lazy object proxy is an object that wraps a callable but defers the call
11763 until the object is actually required, and caches the result of said call.")
11764 (license license:bsd-2)))
11765
11766 (define-public python2-lazy-object-proxy
11767 (package-with-python2 python-lazy-object-proxy))
11768
11769 (define-public python-dnspython
11770 (package
11771 (name "python-dnspython")
11772 (version "1.15.0")
11773 (source (origin
11774 (method url-fetch)
11775 (uri (string-append "http://www.dnspython.org/kits/"
11776 version "/dnspython-" version ".tar.gz"))
11777 (sha256
11778 (base32
11779 "0jr4v2pd90i6l1xxbss2m05psbjaxvyvvvpq44wycijpfgjqln8i"))))
11780 (build-system python-build-system)
11781 (arguments '(#:tests? #f)) ; XXX: requires internet access
11782 (home-page "http://www.dnspython.org")
11783 (synopsis "DNS toolkit for Python")
11784 (description
11785 "dnspython is a DNS toolkit for Python. It supports almost all record
11786 types. It can be used for queries, zone transfers, and dynamic updates.
11787 It supports TSIG authenticated messages and EDNS0.")
11788 (license license:expat)))
11789
11790 (define-public python2-dnspython
11791 (package-with-python2 python-dnspython))
11792
11793 (define-public python-email-validator
11794 (package
11795 (name "python-email-validator")
11796 (version "1.0.2")
11797 (source
11798 (origin (method url-fetch)
11799 (uri (pypi-uri "email_validator" version))
11800 (sha256
11801 (base32
11802 "1ja9149l9ck5n45a72h3is7v476hjny5ybxbcamx1nw6iplsm7k6"))))
11803 (build-system python-build-system)
11804 (arguments
11805 '(#:phases
11806 (modify-phases %standard-phases
11807 (add-before 'build 'use-dnspython
11808 (lambda _
11809 (substitute* "setup.py"
11810 (("dnspython3") "dnspython"))
11811 #t)))))
11812 (propagated-inputs
11813 `(("python-dnspython" ,python-dnspython)
11814 ("python-idna" ,python-idna)))
11815 (home-page "https://github.com/JoshData/python-email-validator")
11816 (synopsis "Email address validation library for Python")
11817 (description
11818 "This library validates email address syntax and deliverability.")
11819 (license license:cc0)))
11820
11821 (define-public python2-email-validator
11822 (package-with-python2 python-email-validator))
11823
11824 (define-public python-ukpostcodeparser
11825 (package
11826 (name "python-ukpostcodeparser")
11827 (version "1.0.3")
11828 (source (origin
11829 (method url-fetch)
11830 (uri (pypi-uri "UkPostcodeParser" version))
11831 (sha256
11832 (base32
11833 "1jwg9z4rz51mcka1821rwgycsd0mcicyp1kiwjfa2kvg8bm9p2qd"))))
11834 (build-system python-build-system)
11835 (home-page "https://github.com/hamstah/ukpostcodeparser")
11836 (synopsis "UK Postcode parser for Python")
11837 (description
11838 "This library provides the @code{parse_uk_postcode} function for
11839 parsing UK postcodes.")
11840 (license license:expat)))
11841
11842 (define-public python2-ukpostcodeparser
11843 (package-with-python2 python-ukpostcodeparser))
11844
11845 (define-public python-faker
11846 (package
11847 (name "python-faker")
11848 (version "0.7.9")
11849 (source (origin
11850 (method url-fetch)
11851 (uri (pypi-uri "Faker" version))
11852 (sha256
11853 (base32
11854 "1fh2p2yz0fsdr4fqwxgddwbvfb6qn6vp8yx0qwqzra27yq5d1wsm"))
11855 (patches
11856 (search-patches "python-faker-fix-build-32bit.patch"))
11857 (modules '((guix build utils)))
11858 (snippet
11859 '(begin
11860 (for-each delete-file (find-files "." "\\.pyc$"))
11861 #t))))
11862 (build-system python-build-system)
11863 (arguments
11864 '(#:phases
11865 (modify-phases %standard-phases
11866 (replace 'check
11867 (lambda _
11868 (zero? (system* "python" "-m" "unittest" "-v" "tests")))))))
11869 (native-inputs
11870 `(;; For testing
11871 ("python-email-validator" ,python-email-validator)
11872 ("python-mock" ,python-mock)
11873 ("python-ukpostcodeparser" ,python-ukpostcodeparser)))
11874 (propagated-inputs
11875 `(("python-dateutil" ,python-dateutil)
11876 ("python-six" ,python-six)))
11877 (home-page "https://github.com/joke2k/faker")
11878 (synopsis "Python package that generates fake data")
11879 (description
11880 "Faker is a Python package that generates fake data such as names,
11881 addresses, and phone numbers.")
11882 (license license:expat)
11883 (properties `((python2-variant . ,(delay python2-faker))))))
11884
11885 (define-public python2-faker
11886 (let ((base (package-with-python2 (strip-python2-variant
11887 python-faker))))
11888 (package
11889 (inherit base)
11890 (propagated-inputs
11891 `(("python2-ipaddress" ,python2-ipaddress)
11892 ,@(package-propagated-inputs base))))))
11893
11894 (define-public python-fake-factory
11895 (package
11896 (name "python-fake-factory")
11897 (version "0.7.2")
11898 (source (origin
11899 (method url-fetch)
11900 (uri (pypi-uri "fake-factory" version))
11901 (sha256
11902 (base32
11903 "0vs0dkmg0dlaxf8w6q2i3k0i03gmp56ablldv7ci9x3nbadkn71g"))
11904 (patches
11905 (search-patches
11906 "python-fake-factory-fix-build-32bit.patch"))))
11907 (build-system python-build-system)
11908 (arguments
11909 '(#:phases
11910 (modify-phases %standard-phases
11911 (replace 'check
11912 (lambda _
11913 (zero? (system* "python" "-m" "unittest" "-v" "faker.tests")))))))
11914 (native-inputs
11915 `(;; For testing
11916 ("python-email-validator" ,python-email-validator)
11917 ("python-mock" ,python-mock)
11918 ("python-ukpostcodeparser" ,python-ukpostcodeparser)))
11919 (propagated-inputs
11920 `(("python-dateutil" ,python-dateutil)
11921 ("python-six" ,python-six)))
11922 (home-page "https://github.com/joke2k/faker")
11923 (synopsis "Python package that generates fake data")
11924 (description
11925 "Faker is a Python package that generates fake data such as names,
11926 addresses, and phone numbers.")
11927 (license license:expat)
11928 (properties `((python2-variant . ,(delay python2-fake-factory))
11929 (superseded . ,python-faker)))))
11930
11931 (define-public python2-fake-factory
11932 (let ((base (package-with-python2 (strip-python2-variant
11933 python-fake-factory))))
11934 (package
11935 (inherit base)
11936 (properties `((superseded . ,python2-faker)))
11937 (propagated-inputs
11938 `(("python2-ipaddress" ,python2-ipaddress)
11939 ,@(package-propagated-inputs base))))))
11940
11941 (define-public python-pyaml
11942 (package
11943 (name "python-pyaml")
11944 (version "15.8.2")
11945 (source (origin
11946 (method url-fetch)
11947 (uri (pypi-uri "pyaml" version))
11948 (sha256
11949 (base32
11950 "1f5m28vkh4ksq3d80d8mmd2z8wxvc3mgy2pmrv2751dm2xgznm4w"))))
11951 (build-system python-build-system)
11952 (native-inputs
11953 `(("python-unidecode" ,python-unidecode)))
11954 (propagated-inputs
11955 `(("python-pyyaml" ,python-pyyaml)))
11956 (home-page "https://github.com/mk-fg/pretty-yaml")
11957 (synopsis "YAML pretty-print library for Python")
11958 (description
11959 "pyaml is a PyYAML based python module to produce pretty and readable
11960 YAML-serialized data.")
11961 (license (license:non-copyleft "http://www.wtfpl.net/txt/copying/"))))
11962
11963 (define-public python2-pyaml
11964 (package-with-python2 python-pyaml))
11965
11966 (define-public python-flexmock
11967 (package
11968 (name "python-flexmock")
11969 (version "0.10.2")
11970 (source (origin
11971 (method url-fetch)
11972 (uri (pypi-uri "flexmock" version))
11973 (sha256
11974 (base32
11975 "0arc6njvs6i9v9hgvzk5m50296g7zy5m9d7pyb43vdsdgxrci5gy"))))
11976 (build-system python-build-system)
11977 (home-page "https://flexmock.readthedocs.org")
11978 (synopsis "Testing library for Python")
11979 (description
11980 "flexmock is a testing library for Python that makes it easy to create
11981 mocks, stubs and fakes.")
11982 (license license:bsd-3)))
11983
11984 (define-public python2-flexmock
11985 (package-with-python2 python-flexmock))
11986
11987 (define-public python-orator
11988 (package
11989 (name "python-orator")
11990 (version "0.8.2")
11991 (source (origin
11992 (method url-fetch)
11993 (uri (pypi-uri "orator" version))
11994 (sha256
11995 (base32
11996 "1li49irsqha17nrda4nsb48biyy0rarp9pphf0jpqwm5zr8hv569"))))
11997 (build-system python-build-system)
11998 (arguments '(#:tests? #f)) ; no tests
11999 (propagated-inputs
12000 `(("python-arrow" ,python-arrow)
12001 ("python-blinker" ,python-blinker)
12002 ("python-cleo" ,python-cleo)
12003 ("python-faker" ,python-faker)
12004 ("python-inflection" ,python-inflection)
12005 ("python-lazy-object-proxy" ,python-lazy-object-proxy)
12006 ("python-pyaml" ,python-pyaml)
12007 ("python-simplejson" ,python-simplejson)
12008 ("python-wrapt" ,python-wrapt)))
12009 (home-page "https://orator-orm.com/")
12010 (synopsis "ActiveRecord ORM for Python")
12011 (description
12012 "Orator provides a simple ActiveRecord-like Object Relational Mapping
12013 implementation for Python.")
12014 (license license:expat)
12015 (properties `((python2-variant . ,(delay python2-orator))))))
12016
12017 (define-public python2-orator
12018 (let ((base (package-with-python2 (strip-python2-variant python-orator))))
12019 (package
12020 (inherit base)
12021 (propagated-inputs
12022 `(("python2-ipaddress" ,python2-ipaddress)
12023 ,@(package-propagated-inputs base))))))
12024
12025 (define-public python-prompt-toolkit
12026 (package
12027 (name "python-prompt-toolkit")
12028 (version "1.0.9")
12029 (source
12030 (origin
12031 (method url-fetch)
12032 (uri (pypi-uri "prompt_toolkit" version ".tar.gz"))
12033 (sha256
12034 (base32
12035 "172r15k9kwdw2lnajvpz1632dd16nqz1kcal1p0lq5ywdarj6rfd"))))
12036 (build-system python-build-system)
12037 (arguments
12038 '(#:tests? #f)) ; The test suite uses some Windows-specific data types.
12039 (propagated-inputs
12040 `(("python-wcwidth" ,python-wcwidth)
12041 ("python-six" ,python-six)
12042 ("python-pygments" ,python-pygments)))
12043 (home-page "https://github.com/jonathanslenders/python-prompt-toolkit")
12044 (synopsis "Library for building command line interfaces in Python")
12045 (description
12046 "Prompt-Toolkit is a library for building interactive command line
12047 interfaces in Python. It's like GNU Readline but it also features syntax
12048 highlighting while typing, out-of-the-box multi-line input editing, advanced
12049 code completion, incremental search, support for Chinese double-width
12050 characters, mouse support, and auto suggestions.")
12051 (license license:bsd-3)))
12052
12053 (define-public python2-prompt-toolkit
12054 (package-with-python2 python-prompt-toolkit))
12055
12056 (define-public python-jedi
12057 (package
12058 (name "python-jedi")
12059 (version "0.9.0")
12060 (source
12061 (origin
12062 (method url-fetch)
12063 (uri (pypi-uri "jedi" version))
12064 (sha256
12065 (base32
12066 "0c8x962ynpx001fdvp07m2q5jk4igkxbj3rmnydavphvlgxijk1v"))))
12067 (build-system python-build-system)
12068 (arguments
12069 ;; FIXME: One test fails (use "py.test" instead of 'setup.py test').
12070 '(#:tests? #f))
12071 (native-inputs
12072 `(("python-pytest" ,python-pytest)))
12073 (home-page "https://github.com/davidhalter/jedi")
12074 (synopsis
12075 "Autocompletion for Python that can be used for text editors")
12076 (description
12077 "Jedi is an autocompletion tool for Python that can be used for text editors.")
12078 (license license:expat)))
12079
12080 (define-public python2-jedi
12081 (package-with-python2 python-jedi))
12082
12083 (define-public ptpython
12084 (package
12085 (name "ptpython")
12086 (version "0.34")
12087 (source (origin
12088 (method url-fetch)
12089 (uri (pypi-uri "ptpython" version))
12090 (sha256
12091 (base32
12092 "1mmbiyzf0n8hm7z2a562x7w5cbl6jc0zsk6vp40q1z4cyblv1k13"))))
12093 (build-system python-build-system)
12094 (arguments
12095 '(#:tests? #f)) ; FIXME: No tests in pypi tarball.
12096 (propagated-inputs
12097 `(("python-docopt" ,python-docopt)
12098 ("python-jedi" ,python-jedi)
12099 ("python-prompt-toolkit" ,python-prompt-toolkit)
12100 ("python-pygments" ,python-pygments)))
12101 (home-page "https://github.com/jonathanslenders/ptpython")
12102 (synopsis "Python Read-Eval-Print-Loop with nice IDE-like features")
12103 (description
12104 "ptpython is a Python read-eval-print loop with IDE-like features.
12105 It supports syntax highlighting, multiline editing, autocompletion, mouse,
12106 color schemes, bracketed paste, Vi and Emacs keybindings, Chinese characters
12107 etc.")
12108 (license license:bsd-3)
12109 (properties `((python2-variant . ,(delay ptpython-2))))))
12110
12111 (define-public ptpython-2
12112 (let ((base (package-with-python2 (strip-python2-variant ptpython))))
12113 (package
12114 (inherit base)
12115 (name "ptpython2"))))
12116
12117 (define-public python-requests-oauthlib
12118 (package
12119 (name "python-requests-oauthlib")
12120 (version "0.6.2")
12121 (source
12122 (origin
12123 (method url-fetch)
12124 (uri (pypi-uri "requests-oauthlib" version))
12125 (sha256
12126 (base32
12127 "0ykff67sjcl227c23g0rxzfx34rr5bf21kwv0z3zmgk0lfmch7hn"))))
12128 (build-system python-build-system)
12129 (arguments
12130 `(#:phases
12131 (modify-phases %standard-phases
12132 ;; removes tests that require network access
12133 (add-before 'check 'pre-check
12134 (lambda _
12135 (delete-file "tests/test_core.py")
12136 #t)))))
12137 (native-inputs
12138 `(("python-requests-mock" ,python-requests-mock)
12139 ("python-mock" ,python-mock)))
12140 (propagated-inputs
12141 `(("python-oauthlib" ,python-oauthlib)
12142 ("python-requests" ,python-requests)))
12143 (home-page
12144 "https://github.com/requests/requests-oauthlib")
12145 (synopsis
12146 "OAuthlib authentication support for Requests")
12147 (description
12148 "Requests-OAuthlib uses the Python Requests and OAuthlib libraries to
12149 provide an easy-to-use Python interface for building OAuth1 and OAuth2 clients.")
12150 (license license:isc)))
12151
12152 (define-public python2-requests-oauthlib
12153 (package-with-python2 python-requests-oauthlib))
12154
12155 (define-public python-stem
12156 (package
12157 (name "python-stem")
12158 (version "1.5.4")
12159 (source
12160 (origin
12161 (method url-fetch)
12162 (uri (pypi-uri "stem" version))
12163 (sha256
12164 (base32
12165 "1j7pnblrn0yr6jmxvsq6y0ihmxmj5x50jl2n2606w67f6wq16j9n"))))
12166 (build-system python-build-system)
12167 (arguments
12168 `(#:phases
12169 (modify-phases %standard-phases
12170 (replace 'check
12171 (lambda _
12172 (zero? (system* "./run_tests.py" "--unit")))))))
12173 (native-inputs
12174 `(("python-mock" ,python-mock)
12175 ("python-pep8" ,python-pep8)
12176 ("python-pyflakes" ,python-pyflakes)))
12177 (home-page "https://stem.torproject.org/")
12178 (synopsis
12179 "Python controller library that allows applications to interact with Tor")
12180 (description
12181 "Stem is a Python controller library for Tor. With it you can use Tor's
12182 control protocol to script against the Tor process and read descriptor data
12183 relays publish about themselves.")
12184 (license license:lgpl3)))
12185
12186 (define-public python2-stem
12187 (package-with-python2 python-stem))
12188
12189 (define-public python-pyserial
12190 (package
12191 (name "python-pyserial")
12192 (version "3.1.1")
12193 (source
12194 (origin
12195 (method url-fetch)
12196 (uri (pypi-uri "pyserial" version))
12197 (sha256
12198 (base32
12199 "0k1nfdrxxkdlv4zgaqsdv8li0pj3gbh2pyxw8q2bsg6f9490amyn"))))
12200 (build-system python-build-system)
12201 (arguments
12202 '(#:tests? #f)) ; FIXME: 3/49 tests are failing.
12203 ;; #:phases
12204 ;; (modify-phases %standard-phases
12205 ;; (replace 'check
12206 ;; (lambda _
12207 ;; (zero? (system* "python" "test/run_all_tests.py" "loop://")))))))
12208 (home-page
12209 "https://github.com/pyserial/pyserial")
12210 (synopsis "Python Serial Port Bindings")
12211 (description "@code{pyserial} provide serial port bindings for Python. It
12212 supports different byte sizes, stop bits, parity and flow control with RTS/CTS
12213 and/or Xon/Xoff. The port is accessed in RAW mode.")
12214 (license license:bsd-3)))
12215
12216 (define-public python2-pyserial
12217 (package-with-python2 python-pyserial))
12218
12219 (define-public python-kivy
12220 (package
12221 (name "python-kivy")
12222 (version "1.9.1")
12223 (source
12224 (origin
12225 (method url-fetch)
12226 (uri (pypi-uri "kivy" version))
12227 (file-name (string-append name "-" version ".tar.gz"))
12228 (sha256
12229 (base32
12230 "0zk3g1j1z0lzcm9d0k1lprrs95zr8n8k5pdg3p5qlsn26jz4bg19"))))
12231 (build-system python-build-system)
12232 (arguments
12233 `(#:tests? #f ; Tests require many optional packages
12234 #:phases
12235 (modify-phases %standard-phases
12236 (replace 'build (lambda _ (zero? (system* "make" "force"))))
12237 (add-after 'patch-generated-file-shebangs 'set-sdl-paths
12238 (lambda* (#:key inputs #:allow-other-keys)
12239 (setenv "KIVY_SDL2_PATH"
12240 (string-append (assoc-ref inputs "sdl-union")
12241 "/include/SDL2"))
12242 #t)))))
12243 (native-inputs
12244 `(("pkg-config" ,pkg-config)
12245 ("python-cython" ,python-cython)))
12246 (inputs
12247 `(("gstreamer" ,gstreamer)
12248 ("mesa" ,mesa)
12249 ("sdl-union"
12250 ,(sdl-union (list sdl2 sdl2-image sdl2-mixer sdl2-ttf)))))
12251 (home-page "http://kivy.org")
12252 (synopsis
12253 "Multitouch application framework")
12254 (description
12255 "A software library for rapid development of
12256 hardware-accelerated multitouch applications.")
12257 (license license:expat)))
12258
12259 (define-public python2-kivy
12260 (package-with-python2 python-kivy))
12261
12262 (define-public python-kivy-next
12263 (let ((commit "a988c5e7a47da56263ff39514264a3de516ef2fe")
12264 (revision "1"))
12265 (package (inherit python-kivy)
12266 (name "python-kivy-next")
12267 (version (string-append "1.9.1-" revision "."
12268 (string-take commit 7)))
12269 (source
12270 (origin
12271 (method git-fetch)
12272 (uri (git-reference
12273 (url "https://github.com/kivy/kivy")
12274 (commit commit)))
12275 (file-name (string-append name "-" version "-checkout"))
12276 (sha256
12277 (base32
12278 "0jk92b4a8l7blkvkgkjihk171s0dfnq582cckff5srwc8kal5m0p")))))))
12279
12280 (define-public python2-kivy-next
12281 (package-with-python2 python-kivy-next))
12282
12283 (define-public python-binaryornot
12284 (package
12285 (name "python-binaryornot")
12286 (version "0.4.0")
12287 (source (origin
12288 (method url-fetch)
12289 (uri (pypi-uri "binaryornot" version))
12290 (sha256
12291 (base32
12292 "1j4f51dxic39mdwf6alj7gd769wy6mhk916v031wjali51xkh3xb"))))
12293 (build-system python-build-system)
12294 (propagated-inputs
12295 `(("python-chardet" ,python-chardet)
12296 ("python-hypothesis" ,python-hypothesis)))
12297 (home-page "https://github.com/audreyr/binaryornot")
12298 (synopsis "Package to check if a file is binary or text")
12299 (description "Ultra-lightweight pure Python package to check if a file is
12300 binary or text.")
12301 (license license:bsd-3)
12302 (properties `((python2-variant . ,(delay python2-binaryornot))))))
12303
12304 (define-public python2-binaryornot
12305 (let ((base (package-with-python2 (strip-python2-variant python-binaryornot))))
12306 (package (inherit base)
12307 (propagated-inputs
12308 `(("python2-enum34" ,python2-enum34)
12309 ,@(package-propagated-inputs base))))))
12310
12311 (define-public python-nltk
12312 (package
12313 (name "python-nltk")
12314 (version "3.2.1")
12315 (source (origin
12316 (method url-fetch)
12317 (uri (pypi-uri "nltk" version))
12318 (sha256
12319 (base32
12320 "0skxbhnymwlspjkzga0f7x1hg3y50fwpfghs8g8k7fh6f4nknlym"))))
12321 (build-system python-build-system)
12322 (arguments
12323 '(;; The tests require some extra resources to be downloaded.
12324 ;; TODO Try packaging these resources.
12325 #:tests? #f))
12326 (home-page "http://nltk.org/")
12327 (synopsis "Natural Language Toolkit")
12328 (description "It provides interfaces to over 50 corpora and lexical
12329 resources such as WordNet, along with a suite of text processing libraries
12330 for classification, tokenization, stemming, tagging, parsing, and semantic
12331 reasoning, wrappers for natural language processing libraries.")
12332 (license license:asl2.0)))
12333
12334 (define-public python2-nltk
12335 (package-with-python2 python-nltk))
12336
12337 (define-public python-pymongo
12338 (package
12339 (name "python-pymongo")
12340 (version "3.3.0")
12341 (source (origin
12342 (method url-fetch)
12343 (uri (pypi-uri "pymongo" version))
12344 (sha256
12345 (base32
12346 "07mra6w86wjqy4lx5fvimidjhhfzd562gfjn8grsnbv2q8pk0i9x"))))
12347 (build-system python-build-system)
12348 (propagated-inputs
12349 `(("python-certifi" ,python-certifi)))
12350 (home-page "https://github.com/mongodb/mongo-python-driver")
12351 (synopsis "Python driver for MongoDB")
12352 (description "Python driver for MongoDB.")
12353 (license license:asl2.0)))
12354
12355 (define-public python2-pymongo
12356 (package-with-python2 python-pymongo))
12357
12358 (define-public python-sh
12359 (package
12360 (name "python-sh")
12361 (version "1.11")
12362 (source (origin
12363 (method url-fetch)
12364 (uri (pypi-uri "sh" version))
12365 (sha256
12366 (base32
12367 "192r0mpv6dmkysjzhc43ddffiwb5g7c76bgr1mb1z2xz9awbj3sr"))))
12368 (build-system python-build-system)
12369 (arguments
12370 `(#:tests? #f)) ; no tests
12371 (home-page "https://github.com/amoffat/sh")
12372 (synopsis "Python subprocess interface")
12373 (description "Abstracts process invocation by providing a function
12374 interface for programs.")
12375 (license license:expat)))
12376
12377 (define-public python2-sh
12378 (package-with-python2 python-sh))
12379
12380 (define-public python-consul
12381 (package
12382 (name "python-consul")
12383 (version "0.6.1")
12384 (source
12385 (origin
12386 (method url-fetch)
12387 (uri (pypi-uri "python-consul" version))
12388 (sha256
12389 (base32
12390 "0rfyxcy4cr3x848vhx876ifalxd5ghq6l5x813m49h4vq2d4jiq8"))))
12391 (build-system python-build-system)
12392 (native-inputs
12393 `(("python-pytest" ,python-pytest)))
12394 (propagated-inputs
12395 `(("python-requests" ,python-requests)
12396 ("python-six" ,python-six)))
12397 (home-page "https://github.com/cablehead/python-consul")
12398 (synopsis "Python client for Consul")
12399 (description
12400 "Python client for @url{http://www.consul.io/,Consul}, a tool for service
12401 discovery, monitoring and configuration.")
12402 (license license:expat)))
12403
12404 (define-public python2-consul
12405 (package-with-python2 python-consul))
12406
12407 (define-public python-schematics
12408 (package
12409 (name "python-schematics")
12410 (version "1.1.1")
12411 (source
12412 (origin
12413 (method url-fetch)
12414 (uri (string-append
12415 "https://github.com/schematics/schematics/archive/v" version ".tar.gz"))
12416 (file-name (string-append name "-" version ".tar.gz"))
12417 (sha256
12418 (base32
12419 "19v1i69bf3bzarfxmbv0v6ivpcn758x3shvbiy9l2hy0lvqwnp6l"))))
12420 (build-system python-build-system)
12421 (propagated-inputs
12422 `(("python-six" ,python-six)))
12423 (arguments
12424 `(#:tests? #f)) ; requires a bunch of not very nice packages with fixed
12425 ; version requirements (eg python-coveralls)
12426 (home-page "https://github.com/schematics/schematics")
12427 (synopsis "Python Data Structures for Humans")
12428 (description "Python Data Structures for Humans.")
12429 (license license:bsd-3)))
12430
12431 (define-public python2-schematics
12432 (package-with-python2 python-schematics))
12433
12434 (define-public python-publicsuffix
12435 (package
12436 (name "python-publicsuffix")
12437 (version "1.1.0")
12438 (source (origin
12439 (method url-fetch)
12440 (uri (pypi-uri "publicsuffix" version))
12441 (sha256
12442 (base32
12443 "1adx520249z2cy7ykwjr1k190mn2888wqn9jf8qm27ly4qymjxxf"))))
12444 (build-system python-build-system)
12445 (arguments
12446 `(#:tests? #f)) ; tests use the internet
12447 (home-page "https://www.tablix.org/~avian/git/publicsuffix.git")
12448 (synopsis "Get suffix for a domain name")
12449 (description "Get a public suffix for a domain name using the Public Suffix
12450 List.")
12451 (license license:expat)))
12452
12453 (define-public python2-publicsuffix
12454 (package-with-python2 python-publicsuffix))
12455
12456 (define-public python-publicsuffix2
12457 (package
12458 (name "python-publicsuffix2")
12459 (version "2.20160818")
12460 (source
12461 (origin
12462 (method url-fetch)
12463 (uri (pypi-uri "publicsuffix2" version ".tar.bz2"))
12464 (sha256
12465 (base32
12466 "1bb55yka9vkn7i6y1kjzxa516kh6v4gsrxa90w5wdz5p5n968r68"))))
12467 (build-system python-build-system)
12468 (arguments
12469 '(#:tests? #f)) ; The test suite requires network access.
12470 (home-page "https://github.com/pombredanne/python-publicsuffix2")
12471 (synopsis "Get a public suffix for a domain name using the Public Suffix List")
12472 (description "Get a public suffix for a domain name using the Public Suffix
12473 List. Forked from and using the same API as the publicsuffix package.")
12474 (license (list license:expat license:mpl2.0))))
12475
12476 (define-public python2-publicsuffix2
12477 (package-with-python2 python-publicsuffix2))
12478
12479 (define-public python-url
12480 (package
12481 (name "python-url")
12482 (version "0.2.0")
12483 (source (origin
12484 (method url-fetch)
12485 (uri (pypi-uri "url" version))
12486 (sha256
12487 (base32
12488 "0v879yadcz9qxfl41ak6wkga1kimp9cflla9ddz03hjjvgkqy5ki"))))
12489 (build-system python-build-system)
12490 (propagated-inputs
12491 `(("python-publicsuffix" ,python-publicsuffix)))
12492 (native-inputs
12493 `(("python-coverage" ,python-coverage)
12494 ("python-nose" ,python-nose)))
12495 (arguments
12496 `(#:tests? #f)) ; FIXME: tests fail with "ImportError: No module named 'tests'"
12497 (home-page "https://github.com/seomoz/url-py")
12498 (synopsis "URL Parsing")
12499 (description "Library for parsing urls.")
12500 (license license:expat)
12501 (properties `((python2-variant . ,(delay python2-url))))))
12502
12503 (define-public python2-url
12504 (let ((base (package-with-python2 (strip-python2-variant python-url))))
12505 (package (inherit base)
12506 (propagated-inputs
12507 `(("python2-publicsuffix" ,python2-publicsuffix))))))
12508
12509 (define-public python-freezegun
12510 (package
12511 (name "python-freezegun")
12512 (version "0.3.8")
12513 (source
12514 (origin
12515 (method url-fetch)
12516 (uri (pypi-uri "freezegun" version))
12517 (sha256
12518 (base32
12519 "1sf38d3ibv1jhhvr52x7dhrsiyqk1hm165dfv8w8wh0fhmgxg151"))))
12520 (build-system python-build-system)
12521 (native-inputs
12522 `(("python-mock" ,python-mock)
12523 ("python-nose" ,python-nose)
12524 ("python-coverage" ,python-coverage)))
12525 (propagated-inputs
12526 `(("python-six" ,python-six)
12527 ("python-dateutil" ,python-dateutil)))
12528 (arguments
12529 `(#:phases (modify-phases %standard-phases
12530 ;; The tests are normally executed via `make test`, but the PyPi
12531 ;; package does not include the Makefile.
12532 (replace 'check
12533 (lambda _
12534 (zero? (system* "nosetests" "./tests/")))))))
12535 (home-page "https://github.com/spulec/freezegun")
12536 (synopsis "Test utility for mocking the datetime module")
12537 (description
12538 "FreezeGun is a library that allows your python tests to travel through
12539 time by mocking the datetime module.")
12540 (license license:asl2.0)))
12541
12542 (define-public python2-freezegun
12543 (package-with-python2 python-freezegun))
12544
12545
12546 (define-public python-odfpy
12547 (package
12548 (name "python-odfpy")
12549 (version "1.3.3")
12550 (source (origin
12551 (method url-fetch)
12552 (uri (pypi-uri "odfpy" version))
12553 (sha256
12554 (base32
12555 "1a6ms0w9zfhhkqhvrnynwwbxrivw6hgjc0s5k7j06npc7rq0blxw"))))
12556 (arguments
12557 `(#:modules ((srfi srfi-1)
12558 (guix build python-build-system)
12559 (guix build utils))
12560 #:phases
12561 (modify-phases %standard-phases
12562 (replace 'check
12563 ;; The test runner invokes python2 and python3 for test*.py.
12564 ;; To avoid having both in inputs, we replicate it here.
12565 (lambda _
12566 (every (lambda (test-file)
12567 (zero? (system* "python" test-file)))
12568 (find-files "tests" "^test.*\\.py$")))))))
12569 (build-system python-build-system)
12570 (home-page "https://github.com/eea/odfpy")
12571 (synopsis "Python API and tools to manipulate OpenDocument files")
12572 (description "Collection of libraries and utility programs written in
12573 Python to manipulate OpenDocument 1.2 files.")
12574 (license
12575 ;; The software is mainly dual GPL2+ and ASL2.0, but includes a
12576 ;; number of files with other licenses.
12577 (list license:gpl2+ license:asl2.0 license:lgpl2.1+ license:cc-by-sa3.0))))
12578
12579 (define-public python2-odfpy
12580 (package-with-python2 python-odfpy))
12581
12582 (define-public python-cachecontrol
12583 (package
12584 (name "python-cachecontrol")
12585 (version "0.11.6")
12586 (source
12587 (origin
12588 (method url-fetch)
12589 ;; Pypi does not have tests.
12590 (uri (string-append
12591 "https://github.com/ionrock/cachecontrol/archive/v"
12592 version ".tar.gz"))
12593 (file-name (string-append name "-" version ".tar.gz"))
12594 (sha256
12595 (base32
12596 "0yj60d0f69a2l8p7y86k4zhzzm6rnxpq74sfl240pry9l0lfw2vw"))))
12597 (build-system python-build-system)
12598 (arguments
12599 `(#:phases
12600 (modify-phases %standard-phases
12601 (replace 'check
12602 (lambda _
12603 ;; Drop test that requires internet access.
12604 (delete-file "tests/test_regressions.py")
12605 (setenv "PYTHONPATH"
12606 (string-append (getcwd) "/build/lib:"
12607 (getenv "PYTHONPATH")))
12608 (zero? (system* "py.test" "-vv")))))))
12609 (native-inputs
12610 `(("python-pytest" ,python-pytest)
12611 ("python-redis" ,python-redis)
12612 ("python-webtest" ,python-webtest)
12613 ("python-mock" ,python-mock)))
12614 (propagated-inputs
12615 `(("python-requests" ,python-requests)
12616 ("python-lockfile" ,python-lockfile)))
12617 (home-page "https://github.com/ionrock/cachecontrol")
12618 (synopsis "The httplib2 caching algorithms for use with requests")
12619 (description "CacheControl is a port of the caching algorithms in
12620 @code{httplib2} for use with @code{requests} session objects.")
12621 (license license:asl2.0)))
12622
12623 (define-public python2-cachecontrol
12624 (package-with-python2 python-cachecontrol))
12625
12626 (define-public python-lit
12627 (package
12628 (name "python-lit")
12629 (version "0.5.0")
12630 (source
12631 (origin
12632 (method url-fetch)
12633 (uri (pypi-uri "lit" version))
12634 (sha256
12635 (base32
12636 "135m2b9cwih85g66rjggavck328z7lj37srgpq3jxszbg0g2b91y"))))
12637 (build-system python-build-system)
12638 (home-page "http://llvm.org/")
12639 (synopsis "LLVM Software Testing Tool")
12640 (description "@code{lit} is a portable tool for executing LLVM and Clang
12641 style test suites, summarizing their results, and providing indication of
12642 failures.")
12643 (license license:ncsa)))
12644
12645 (define-public python2-lit
12646 (package-with-python2 python-lit))
12647
12648 (define-public python-pytest-pep8
12649 (package
12650 (name "python-pytest-pep8")
12651 (version "1.0.6")
12652 (source (origin
12653 (method url-fetch)
12654 (uri (pypi-uri "pytest-pep8" version))
12655 (sha256
12656 (base32
12657 "06032agzhw1i9d9qlhfblnl3dw5hcyxhagn7b120zhrszbjzfbh3"))))
12658 (build-system python-build-system)
12659 (arguments
12660 `(#:tests? #f)) ; Fails with recent pytest and pep8. See upstream issues #8 and #12.
12661 (native-inputs
12662 `(("python-pytest" ,python-pytest)))
12663 (propagated-inputs
12664 `(("python-pep8" ,python-pep8)))
12665 (home-page "https://bitbucket.org/pytest-dev/pytest-pep8")
12666 (synopsis "Py.test plugin to check PEP8 requirements")
12667 (description "Pytest plugin for checking PEP8 compliance.")
12668 (license license:expat)))
12669
12670 (define-public python2-pytest-pep8
12671 (package-with-python2 python-pytest-pep8))
12672
12673 (define-public python-pytest-flakes
12674 (package
12675 (name "python-pytest-flakes")
12676 (version "1.0.1")
12677 (source (origin
12678 (method url-fetch)
12679 (uri (pypi-uri "pytest-flakes" version))
12680 (sha256
12681 (base32
12682 "0flag3n33kbhyjrhzmq990rvg4yb8hhhl0i48q9hw0ll89jp28lw"))))
12683 (build-system python-build-system)
12684 (arguments
12685 `(#:phases
12686 (modify-phases %standard-phases
12687 (delete 'check)
12688 (add-after 'install 'check
12689 (lambda* (#:key outputs inputs #:allow-other-keys)
12690 ;; It's easier to run tests after install.
12691 ;; Make installed package available for running the tests
12692 (add-installed-pythonpath inputs outputs)
12693 (zero? (system* "py.test" "-vv")))))))
12694 (native-inputs
12695 `(("python-coverage" ,python-coverage)
12696 ("python-pytest" ,python-pytest)
12697 ("python-pytest-cache" ,python-pytest-cache)
12698 ("python-pytest-pep8" ,python-pytest-pep8)))
12699 (propagated-inputs
12700 `(("python-pyflakes" ,python-pyflakes)))
12701 (home-page "https://github.com/fschulze/pytest-flakes")
12702 (synopsis "Py.test plugin to check source code with pyflakes")
12703 (description "Pytest plugin for checking Python source code with pyflakes.")
12704 (license license:expat)))
12705
12706 (define-public python2-pytest-flakes
12707 (package-with-python2 python-pytest-flakes))
12708
12709 (define-public python-natsort
12710 (package
12711 (name "python-natsort")
12712 (version "5.0.2")
12713 (source (origin
12714 (method url-fetch)
12715 (uri (pypi-uri "natsort" version))
12716 (sha256
12717 (base32
12718 "0bh6j0l8iapjnsgg3bs6q075cnzjl6zw1vlgqyv3qrygm2cxypkn"))))
12719 (build-system python-build-system)
12720 (arguments
12721 `(#:phases
12722 (modify-phases %standard-phases
12723 (add-before 'check 'set-cachedir
12724 ;; Tests require write access to $HOME by default
12725 (lambda _ (setenv "PYTHON_EGG_CACHE" "/tmp") #t)))))
12726 (native-inputs
12727 `(("python-hypothesis" ,python-hypothesis)
12728 ("python-pytest-cache" ,python-pytest-cache)
12729 ("python-pytest-cov" ,python-pytest-cov)
12730 ("python-pytest-flakes" ,python-pytest-flakes)
12731 ("python-pytest-pep8" ,python-pytest-pep8)))
12732 (propagated-inputs ; TODO: Add python-fastnumbers.
12733 `(("python-pyicu" ,python-pyicu)))
12734 (home-page "https://github.com/SethMMorton/natsort")
12735 (synopsis "Natural sorting for python and shell")
12736 (description
12737 "Natsort lets you apply natural sorting on lists instead of
12738 lexicographical. If you use the built-in @code{sorted} method in python
12739 on a list such as @code{['a20', 'a9', 'a1', 'a4', 'a10']}, it would be
12740 returned as @code{['a1', 'a10', 'a20', 'a4', 'a9']}. Natsort provides a
12741 function @code{natsorted} that identifies numbers and sorts them separately
12742 from strings. It can also sort version numbers, real numbers, mixed types
12743 and more, and comes with a shell command @command{natsort} that exposes this
12744 functionality in the command line.")
12745 (license license:expat)
12746 (properties `((python2-variant . ,(delay python2-natsort))))))
12747
12748 (define-public python2-natsort
12749 (let ((base (package-with-python2 (strip-python2-variant python-natsort))))
12750 (package (inherit base)
12751 (native-inputs
12752 `(("python2-pathlib" ,python2-pathlib)
12753 ("python2-mock" ,python2-mock)
12754 ("python2-enum34" ,python2-enum34)
12755 ,@(package-native-inputs base))))))
12756
12757 (define-public python-glances
12758 (package
12759 (name "python-glances")
12760 (version "2.7.1")
12761 (source
12762 (origin
12763 (method url-fetch)
12764 (uri (pypi-uri "Glances" version))
12765 (sha256
12766 (base32
12767 "11jbq40g8alsbirnd4kiagznqg270247i0m8qhi48ldf2i5xppxg"))))
12768 (build-system python-build-system)
12769 (propagated-inputs
12770 `(("python-psutil" ,python-psutil)))
12771 (home-page
12772 "https://github.com/nicolargo/glances")
12773 (synopsis
12774 "A cross-platform curses-based monitoring tool")
12775 (description
12776 "Glances is a curses-based monitoring tool for a wide variety of platforms.
12777 Glances uses the PsUtil library to get information from your system. It monitors
12778 CPU, load, memory, network bandwidth, disk I/O, disk use, and more.")
12779 (license license:lgpl3+)))
12780
12781 (define-public python2-glances
12782 (package-with-python2 python-glances))
12783
12784 (define-public python-graphql-core
12785 (package
12786 (name "python-graphql-core")
12787 (version "0.5.3")
12788 (source
12789 (origin
12790 (method url-fetch)
12791 (uri (pypi-uri "graphql-core" version))
12792 (sha256
12793 (base32
12794 "0rsaarx2sj4xnw9966rhh4haiqaapm4lm2mfqm48ywd51j5vh1a0"))))
12795 (build-system python-build-system)
12796 (arguments
12797 `(#:tests? #f ; Tests require the unpackaged pytest-benchmark.
12798 #:phases
12799 (modify-phases %standard-phases
12800 (add-after 'unpack 'patch-hardcoded-version
12801 (lambda _ (substitute*
12802 "setup.py"
12803 (("'gevent==1.1rc1'") "'gevent'"))
12804 #t)))))
12805 (native-inputs
12806 `(("python-gevent" ,python-gevent)
12807 ("python-mock" ,python-mock)
12808 ("python-pytest-mock" ,python-pytest-mock)))
12809 (propagated-inputs
12810 `(("python-promise" ,python-promise)
12811 ("python-six" ,python-six)))
12812 (home-page "https://github.com/graphql-python/graphql-core")
12813 (synopsis "GraphQL implementation for Python")
12814 (description
12815 "GraphQL implementation for Python. GraphQL is a data query language and
12816 runtime designed and used to request and deliver data to mobile and web apps.
12817 This library is a port of @url{https://github.com/graphql/graphql-js,graphql-js}
12818 to Python.")
12819 (license license:expat)))
12820
12821 (define-public python2-graphql-core
12822 (package-with-python2 python-graphql-core))
12823
12824 (define-public python-graphql-relay
12825 (package
12826 (name "python-graphql-relay")
12827 (version "0.4.5")
12828 (source
12829 (origin
12830 (method url-fetch)
12831 (uri (pypi-uri "graphql-relay" version))
12832 (sha256
12833 (base32
12834 "1nv5dxcj59zv31qvl8bd142njmxcmymny2dz3br1l2cpbljbf5i7"))))
12835 (build-system python-build-system)
12836 (native-inputs
12837 `(("python-pytest" ,python-pytest)))
12838 (propagated-inputs
12839 `(("python-graphql-core" ,python-graphql-core)
12840 ("python-promise" ,python-promise)
12841 ("python-six" ,python-six)))
12842 (home-page "https://github.com/graphql-python/graphql-relay-py")
12843 (synopsis "Relay implementation for Python")
12844 (description
12845 "This is a library to allow the easy creation of Relay-compliant servers
12846 using the GraphQL Python reference implementation of a GraphQL server. It
12847 should be noted that the code is a exact port of the original
12848 @url{https://github.com/graphql/graphql-relay-js,graphql-relay js implementation}
12849 from Facebook.")
12850 (license license:expat)))
12851
12852 (define-public python2-graphql-relay
12853 (package-with-python2 python-graphql-relay))
12854
12855 (define-public python-graphene
12856 (package
12857 (name "python-graphene")
12858 (version "0.10.2")
12859 (source
12860 (origin
12861 (method url-fetch)
12862 (uri (pypi-uri "graphene" version))
12863 (sha256
12864 (base32
12865 "09zhac7igh9ixdz0ay6csy35b40l1jwbf2wrbxmgxwfhy51iy06q"))))
12866 (build-system python-build-system)
12867 (native-inputs
12868 `(("python-django-filter" ,python-django-filter)
12869 ("python-mock" ,python-mock)
12870 ("python-psycopg2" ,python-psycopg2)
12871 ("python-pytest-django" ,python-pytest-django)
12872 ("python-sqlalchemy-utils" ,python-sqlalchemy-utils)))
12873 (propagated-inputs
12874 `(("python-graphql-core" ,python-graphql-core)
12875 ("python-graphql-relay" ,python-graphql-relay)
12876 ("python-iso8601" ,python-iso8601)
12877 ("python-promise" ,python-promise)
12878 ("python-six" ,python-six)))
12879 (home-page "http://graphene-python.org/")
12880 (synopsis "GraphQL Framework for Python")
12881 (description
12882 "Graphene is a Python library for building GraphQL schemas/types.
12883 A GraphQL schema describes your data model, and provides a GraphQL server
12884 with an associated set of resolve methods that know how to fetch data.")
12885 (properties `((python2-variant . ,(delay python2-graphene))))
12886 (license license:expat)))
12887
12888 (define-public python2-graphene
12889 (let ((base (package-with-python2
12890 (strip-python2-variant python-graphene))))
12891 (package (inherit base)
12892 (native-inputs
12893 `(("python2-sqlalchemy" ,python2-sqlalchemy)
12894 ,@(package-native-inputs base))))))
12895
12896 (define-public python-nautilus
12897 (package
12898 (name "python-nautilus")
12899 (version "0.4.9")
12900 (source
12901 (origin
12902 (method url-fetch)
12903 (uri (pypi-uri "nautilus" version))
12904 (sha256
12905 (base32
12906 "01hwzjc1zshk4vvxrcghm398fpy4jls66dyz06g07mrwqif8878p"))))
12907 (build-system python-build-system)
12908 (arguments `(#:tests? #f)) ; fails to import test modules
12909 (propagated-inputs
12910 `(("python-bcrypt" ,python-bcrypt)
12911 ("python-click" ,python-click)
12912 ("python-consul" ,python-consul)
12913 ("python-graphene" ,python-graphene)
12914 ("python-jinja2" ,python-jinja2)
12915 ("python-peewee" ,python-peewee)
12916 ("python-pika" ,python-pika)
12917 ("python-tornado" ,python-tornado)
12918 ("python-wtforms" ,python-wtforms)))
12919 (native-inputs
12920 `(("python-nose2" ,python-nose2)))
12921 (home-page "https://github.com/AlecAivazis/nautilus")
12922 (synopsis "Library for creating microservice applications")
12923 (description
12924 "Nautilus is a framework for flux based microservices that looks to
12925 provide extendible implementations of common aspects of a cloud so that you can
12926 focus on building massively scalable web applications.")
12927 (license license:expat)))
12928
12929 (define-public python-snowballstemmer
12930 (package
12931 (name "python-snowballstemmer")
12932 (version "1.2.1")
12933 (source (origin
12934 (method url-fetch)
12935 (uri (pypi-uri "snowballstemmer" version))
12936 (sha256
12937 (base32
12938 "0a0idq4y5frv7qsg2x62jd7rd272749xk4x99misf5rcifk2d7wi"))))
12939 (build-system python-build-system)
12940 (arguments
12941 `(;; No tests exist
12942 #:tests? #f))
12943 (home-page "https://github.com/shibukawa/snowball_py")
12944 (synopsis "Snowball stemming library collection for Python")
12945 (description "This package provides 16 word stemmer algorithms generated
12946 from Snowball algorithms. It includes the 15 original ones plus the Poerter
12947 English stemmer.")
12948 (license license:bsd-3)))
12949
12950 (define-public python2-snowballstemmer
12951 (package-with-python2 python-snowballstemmer))
12952
12953 (define-public python-sphinx-cloud-sptheme
12954 (package
12955 (name "python-sphinx-cloud-sptheme")
12956 (version "1.8.0")
12957 (source (origin
12958 (method url-fetch)
12959 (uri (pypi-uri "cloud_sptheme" version))
12960 (sha256
12961 (base32
12962 "1dniqb6a39yh786f86c4jn666rwnyi1jvzn4616zhcchb7sfdshd"))))
12963 (build-system python-build-system)
12964 ;; FIXME: The 'pypi' release archive does not contain tests.
12965 (arguments '(#:tests? #f))
12966 (native-inputs
12967 `(("python-sphinx" ,python-sphinx)))
12968 (home-page "https://bitbucket.org/ecollins/cloud_sptheme")
12969 (synopsis "'Cloud' theme for Sphinx documenter")
12970 (description "This package contains the \"Cloud\" theme for Sphinx and some
12971 related extensions.")
12972 (license license:bsd-3)))
12973
12974 (define-public python2-sphinx-cloud-sptheme
12975 (package-with-python2 python-sphinx-cloud-sptheme))
12976
12977 (define-public python-sphinx-alabaster-theme
12978 (package
12979 (name "python-sphinx-alabaster-theme")
12980 (version "0.7.9")
12981 (source (origin
12982 (method url-fetch)
12983 (uri (pypi-uri "alabaster" version))
12984 (sha256
12985 (base32
12986 "027anxzcb951gjlcc43y3rbn9qrw36d16vj9wd2smv5410xx9bs7"))))
12987 (build-system python-build-system)
12988 (propagated-inputs
12989 `(("python-pygments" ,python-pygments)))
12990 (home-page "https://alabaster.readthedocs.io/")
12991 (synopsis "Configurable sidebar-enabled Sphinx theme")
12992 (description "Alabaster is a visually (c)lean, responsive, configurable
12993 theme for the Sphinx documentation system. It's the default theme of Sphinx.")
12994 (license license:bsd-3)))
12995
12996 (define-public python2-sphinx-alabaster-theme
12997 (package-with-python2 python-sphinx-alabaster-theme))
12998
12999 (define-public python-betamax
13000 (package
13001 (name "python-betamax")
13002 (version "0.8.0")
13003 (source
13004 (origin
13005 (method url-fetch)
13006 (uri (pypi-uri "betamax" version))
13007 (sha256
13008 (base32
13009 "18f8v5gng3j773jlbbzx4rg1i4y2zw3m2l1zpmbvp8bh5a2q1i42"))))
13010 (build-system python-build-system)
13011 (arguments
13012 '(;; Many tests fail because they require networking.
13013 #:tests? #f))
13014 (propagated-inputs
13015 `(("python-requests" ,python-requests)))
13016 (home-page "https://github.com/sigmavirus24/betamax")
13017 (synopsis "Record HTTP interactions with python-requests")
13018 (description "Betamax will record your test suite's HTTP interactions and
13019 replay them during future tests. It is designed to work with python-requests.")
13020 (license license:expat)))
13021
13022 (define-public python2-betamax
13023 (package-with-python2 python-betamax))
13024
13025 (define-public python-s3transfer
13026 (package
13027 (name "python-s3transfer")
13028 (version "0.1.10")
13029 (source (origin
13030 (method url-fetch)
13031 (uri (pypi-uri "s3transfer" version))
13032 (sha256
13033 (base32
13034 "1h8g9bknvxflxkpbnxyfxmk8pvgykbbk9ljdvhqh6z4vjc2926ms"))))
13035 (build-system python-build-system)
13036 (arguments
13037 `(#:phases
13038 (modify-phases %standard-phases
13039 (replace 'check
13040 (lambda _
13041 ;; 7 of the 'integration' tests require network access or login
13042 ;; credentials.
13043 (zero? (system* "nosetests" "--exclude=integration")))))))
13044 (native-inputs
13045 `(("python-docutils" ,python-docutils)
13046 ("python-mock" ,python-mock)
13047 ("python-nose" ,python-nose)))
13048 (propagated-inputs
13049 `(("python-botocore" ,python-botocore)))
13050 (synopsis "Amazon S3 Transfer Manager")
13051 (description "S3transfer is a Python library for managing Amazon S3
13052 transfers.")
13053 (home-page "https://github.com/boto/s3transfer")
13054 (license license:asl2.0)
13055 (properties `((python2-variant . ,(delay python2-s3transfer))))))
13056
13057 (define-public python2-s3transfer
13058 (let ((base (package-with-python2 (strip-python2-variant python-s3transfer))))
13059 (package
13060 (inherit base)
13061 (native-inputs
13062 `(("python2-futures" ,python2-futures)
13063 ,@(package-native-inputs base))))))
13064
13065 (define-public python-setproctitle
13066 (package
13067 (name "python-setproctitle")
13068 (version "1.1.10")
13069 (source
13070 (origin
13071 (method url-fetch)
13072 (uri (pypi-uri "setproctitle" version))
13073 (sha256
13074 (base32
13075 "163kplw9dcrw0lffq1bvli5yws3rngpnvrxrzdw89pbphjjvg0v2"))))
13076 (build-system python-build-system)
13077 (arguments
13078 '(#:phases
13079 (modify-phases %standard-phases
13080 (add-before 'check 'patch-Makefile
13081 ;; Stricly this is only required for the python2 variant.
13082 ;; But adding a phase in an inherited package seems to be
13083 ;; cumbersum. So we patch even for python3.
13084 (lambda _
13085 (let ((nose (assoc-ref %build-inputs "python2-nose")))
13086 (when nose
13087 (substitute* "Makefile"
13088 (("\\$\\(PYTHON\\) [^ ]which nosetests[^ ] ")
13089 (string-append nose "/bin/nosetests "))))
13090 #t)))
13091 (replace 'check
13092 (lambda _
13093 (setenv "PYTHON" (or (which "python3") (which "python")))
13094 (setenv "PYCONFIG" (or (which "python3-config")
13095 (which "python-config")))
13096 (setenv "CC" "gcc")
13097 ;; No need to extend PYTHONPATH to find the built package, since
13098 ;; the Makefile will build anyway
13099 (zero? (system* "make" "check")))))))
13100 (native-inputs
13101 `(("procps" ,procps))) ; required for tests
13102 (home-page
13103 "https://github.com/dvarrazzo/py-setproctitle")
13104 (synopsis
13105 "Setproctitle implementation for Python to customize the process title")
13106 (description "The library allows a process to change its title (as displayed
13107 by system tools such as ps and top).
13108
13109 Changing the title is mostly useful in multi-process systems, for
13110 example when a master process is forked: changing the children's title
13111 allows to identify the task each process is busy with. The technique
13112 is used by PostgreSQL and the OpenSSH Server for example.")
13113 (license license:bsd-3)
13114 (properties `((python2-variant . ,(delay python2-setproctitle))))))
13115
13116 (define-public python2-setproctitle
13117 (let ((base (package-with-python2
13118 (strip-python2-variant python-setproctitle))))
13119 (package
13120 (inherit base)
13121 (native-inputs `(("python2-nose" ,python2-nose)
13122 ,@(package-native-inputs base))))))
13123
13124 (define-public python-validictory
13125 (package
13126 (name "python-validictory")
13127 (version "1.0.1")
13128 (source
13129 (origin
13130 (method url-fetch)
13131 (uri (pypi-uri "validictory" version))
13132 (sha256
13133 (base32
13134 "1zf1g9sw47xzp5f80bd94pb42j9yqv82lcrgcvdwr6nkaphfi37q"))))
13135 (build-system python-build-system)
13136 (arguments
13137 '(#:phases
13138 (modify-phases %standard-phases
13139 (add-after 'unpack 'bootstrap
13140 ;; Move the tests out of the package directory to avoid
13141 ;; packaging them.
13142 (lambda* _
13143 (rename-file "validictory/tests" "tests")
13144 (delete-file "tests/__init__.py")))
13145 (replace 'check
13146 (lambda _
13147 ;; Extend PYTHONPATH so the built package will be found.
13148 (setenv "PYTHONPATH"
13149 (string-append (getcwd) "/build/lib:"
13150 (getenv "PYTHONPATH")))
13151 (zero? (system* "py.test" "-vv" )))))))
13152 (native-inputs
13153 `(("python-pytest" ,python-pytest)))
13154 (home-page
13155 "https://github.com/jamesturk/validictory")
13156 (synopsis "General purpose Python data validator")
13157 (description "It allows validation of arbitrary Python data structures.
13158
13159 The schema format is based on the JSON Schema
13160 proposal (http://json-schema.org), so combined with json the library is also
13161 useful as a validator for JSON data.")
13162 (license license:expat)))
13163
13164 (define-public python2-validictory
13165 (package-with-python2 python-validictory))
13166
13167 (define-public python-aniso8601
13168 (package
13169 (name "python-aniso8601")
13170 (version "1.1.0")
13171 (source
13172 (origin
13173 (method url-fetch)
13174 (uri (pypi-uri "aniso8601" version))
13175 (sha256
13176 (base32
13177 "1k5mjg9iqbjfslb5prrsfz7dhlvi6s35p1jxq8dm87w1b7dn5i2g"))))
13178 (build-system python-build-system)
13179 (propagated-inputs
13180 `(("python-dateutil" ,python-dateutil)))
13181 (home-page
13182 "https://bitbucket.org/nielsenb/aniso8601")
13183 (synopsis
13184 "Python library for parsing ISO 8601 strings")
13185 (description
13186 "This package contains a library for parsing ISO 8601 datetime strings.")
13187 (license license:bsd-3)))
13188
13189 (define-public python-flask-restful
13190 (package
13191 (name "python-flask-restful")
13192 (version "0.3.5")
13193 (source
13194 (origin
13195 (method url-fetch)
13196 (uri (pypi-uri "Flask-RESTful" version))
13197 (sha256
13198 (base32
13199 "0hjcmdb56b7z4bkw848lxfkyrpnkwzmqn2dgnlv12mwvjpzsxr6c"))))
13200 (build-system python-build-system)
13201 (propagated-inputs
13202 `(("python-aniso8601" ,python-aniso8601)
13203 ("python-flask" ,python-flask)
13204 ("python-pycrypto" ,python-pycrypto)
13205 ("python-pytz" ,python-pytz)))
13206 (native-inputs
13207 `(;; Optional dependency of Flask. Tests need it.
13208 ("python-blinker" ,python-blinker)
13209 ("python-mock" ,python-mock) ; For tests
13210 ("python-nose" ,python-nose) ; For tests
13211 ("python-sphinx" ,python-sphinx)))
13212 (home-page
13213 "https://www.github.com/flask-restful/flask-restful/")
13214 (synopsis
13215 "Flask module for creating REST APIs")
13216 (description
13217 "This package contains a Flask module for creating REST APIs.")
13218 (license license:bsd-3)))
13219
13220 (define-public python-flask-basicauth
13221 (package
13222 (name "python-flask-basicauth")
13223 (version "0.2.0")
13224 (source
13225 (origin
13226 (method url-fetch)
13227 (uri (pypi-uri "Flask-BasicAuth" version))
13228 (sha256
13229 (base32
13230 "1zq1spkjr4sjdnalpp8wl242kdqyk6fhbnhr8hi4r4f0km4bspnz"))))
13231 (build-system python-build-system)
13232 (propagated-inputs
13233 `(("python-flask" ,python-flask)))
13234 (home-page
13235 "https://github.com/jpvanhal/flask-basicauth")
13236 (synopsis
13237 "HTTP basic access authentication for Flask")
13238 (description
13239 "This package provides HTTP basic access authentication for Flask.")
13240 (license license:bsd-3)))
13241
13242 (define-public python-flask-sqlalchemy
13243 (package
13244 (name "python-flask-sqlalchemy")
13245 (version "2.1")
13246 (source
13247 (origin
13248 (method url-fetch)
13249 (uri (pypi-uri "Flask-SQLAlchemy" version))
13250 (sha256
13251 (base32
13252 "1i9ps5d5snih9xlqhrvmi3qfiygkmqzxh92n25kj4pf89kj4s965"))))
13253 (build-system python-build-system)
13254 (propagated-inputs
13255 `(("python-flask" ,python-flask)
13256 ("python-sqlalchemy" ,python-sqlalchemy)))
13257 (home-page
13258 "https://github.com/mitsuhiko/flask-sqlalchemy")
13259 (synopsis
13260 "Module adding SQLAlchemy support to your Flask application")
13261 (description
13262 "This package adds SQLAlchemy support to your Flask application.")
13263 (license license:bsd-3)))
13264
13265 (define-public python-pyev
13266 (package
13267 (name "python-pyev")
13268 (version "0.9.0")
13269 (source
13270 (origin
13271 (method url-fetch)
13272 (uri (pypi-uri "pyev" version))
13273 (sha256
13274 (base32
13275 "0rf603lc0s6zpa1nb25vhd8g4y337wg2wyz56i0agsdh7jchl0sx"))))
13276 (build-system python-build-system)
13277 (arguments
13278 `(#:tests? #f ; no test suite
13279 #:phases
13280 (modify-phases %standard-phases
13281 (add-after 'unpack 'patch
13282 (lambda* (#:key inputs #:allow-other-keys)
13283 (let ((libev (string-append (assoc-ref inputs "libev")
13284 "/lib/libev.so.4")))
13285 (substitute* "setup.py"
13286 (("libev_dll_name = find_library\\(\\\"ev\\\"\\)")
13287 (string-append "libev_dll_name = \"" libev "\"")))))))))
13288 (inputs
13289 `(("libev" ,libev)))
13290 (home-page "http://pythonhosted.org/pyev/")
13291 (synopsis "Python libev interface")
13292 (description "Pyev provides a Python interface to libev.")
13293 (license license:gpl3)))
13294
13295 (define-public python2-pyev
13296 (package-with-python2 python-pyev))
13297
13298 (define-public python-imagesize
13299 (package
13300 (name "python-imagesize")
13301 (version "0.7.1")
13302 (source
13303 (origin
13304 (method url-fetch)
13305 (uri (pypi-uri "imagesize" version))
13306 (sha256
13307 (base32
13308 "0qk07k0z4241lkzzjji7z4da04pcvg7bfc4xz1934zlqhwmwdcha"))))
13309 (build-system python-build-system)
13310 (arguments
13311 '(;; Test files are not distributed on PyPi:
13312 ;; https://github.com/shibukawa/imagesize_py/issues/7
13313 #:tests? #f))
13314 (home-page "https://github.com/shibukawa/imagesize_py")
13315 (synopsis "Gets image size of files in variaous formats in Python")
13316 (description
13317 "This package allows determination of image size from
13318 PNG, JPEG, JPEG2000 and GIF files in pure Python.")
13319 (license license:expat)))
13320
13321 (define-public python2-imagesize
13322 (package-with-python2 python-imagesize))
13323
13324 (define-public python-axolotl-curve25519
13325 (package
13326 (name "python-axolotl-curve25519")
13327 (version "0.1")
13328 (source
13329 (origin
13330 (method git-fetch)
13331 (uri (git-reference
13332 (url "git://github.com/tgalal/python-axolotl-curve25519")
13333 (commit "e4a9c4de0eae27223200579c58d1f8f6d20637e2")))
13334 (file-name (string-append name "-" version "-checkout"))
13335 (sha256
13336 (base32
13337 "0agap5q0hmvf6cwzjqc05kw53pjgf6942pcivpazksmg1vk400ra"))))
13338 (build-system python-build-system)
13339 (arguments
13340 `(;; Prevent creation of the egg. This works around
13341 ;; https://debbugs.gnu.org/cgi/bugreport.cgi?bug=20765
13342 #:configure-flags '("--root=/")))
13343 (home-page "https://github.com/tgalal/python-axolotl-curve25519")
13344 (synopsis "Python wrapper for curve25519 library")
13345 (description "This is a python wrapper for the curve25519 library
13346 with ed25519 signatures. The C code was pulled from
13347 libaxolotl-android. At the moment this wrapper is meant for use by
13348 python-axolotl.")
13349 (license (list license:gpl3 ; Most files
13350 license:bsd-3)))) ; curve/curve25519-donna.c
13351
13352 (define-public python2-axolotl-curve25519
13353 (package-with-python2 python-axolotl-curve25519))
13354
13355 (define-public python-axolotl
13356 (package
13357 (name "python-axolotl")
13358 (version "0.1.35")
13359 (source
13360 (origin
13361 (method url-fetch)
13362 (uri (string-append
13363 "https://github.com/tgalal/python-axolotl/archive/"
13364 version ".tar.gz"))
13365 (file-name (string-append name "-" version ".tar.gz"))
13366 (sha256
13367 (base32 "1z8d89p7v40p4bwywjm9h4z28fdvra79ddw06azlkrfjbl7dxmz8"))))
13368 (build-system python-build-system)
13369 (arguments
13370 `(#:phases
13371 (modify-phases %standard-phases
13372 ;; Don't install tests
13373 (add-before 'install 'remove-tests
13374 (lambda _
13375 (for-each delete-file-recursively
13376 '("axolotl/tests" "build/lib/axolotl/tests"))
13377 #t)))))
13378 (propagated-inputs
13379 `(("python-axolotl-curve25519" ,python-axolotl-curve25519)
13380 ("python-dateutil" ,python-dateutil)
13381 ("python-protobuf" ,python-protobuf)
13382 ("python-pycrypto" ,python-pycrypto)))
13383 (home-page "https://github.com/tgalal/python-axolotl")
13384 (synopsis "Python port of libaxolotl-android")
13385 (description "This is a python port of libaxolotl-android. This
13386 is a ratcheting forward secrecy protocol that works in synchronous and
13387 asynchronous messaging environments.")
13388 (license license:gpl3)))
13389
13390 (define-public python2-axolotl
13391 (package-with-python2 python-axolotl))
13392
13393 (define-public python-termstyle
13394 (package
13395 (name "python-termstyle")
13396 (version "0.1.11")
13397 (source
13398 (origin
13399 (method url-fetch)
13400 (uri (pypi-uri "termstyle" version))
13401 (sha256
13402 (base32
13403 "17wzkkcqy5zc0g68xlad3kcv66iw14d2pwqc0h9420gak0vbhx7g"))))
13404 (build-system python-build-system)
13405 (arguments
13406 '(#:phases
13407 (modify-phases %standard-phases
13408 (replace 'check
13409 (lambda _
13410 (zero? (system* "python" "test3.py")))))))
13411 (home-page "https://github.com/gfxmonk/termstyle")
13412 (synopsis "Console text coloring for Python")
13413 (description "This package provides console text coloring for Python.")
13414 (license license:bsd-3)))
13415
13416 (define-public python-rednose
13417 (package
13418 (name "python-rednose")
13419 (version "1.2.1")
13420 (source
13421 (origin
13422 (method url-fetch)
13423 (uri (pypi-uri "rednose" version))
13424 (sha256
13425 (base32
13426 "0b0bsna217lr1nykyhl5fgjly15zhdvqd4prg4wy1zrgfv7al6m0"))))
13427 (build-system python-build-system)
13428 (arguments
13429 `(#:phases
13430 (modify-phases %standard-phases
13431 (add-after 'unpack 'fix-deps
13432 (lambda _
13433 ;; See <https://github.com/JBKahn/rednose/issues/12>
13434 (substitute* "setup.py"
13435 (("python-termstyle") "termstyle"))
13436 #t)))))
13437 (propagated-inputs
13438 `(("python-colorama" ,python-colorama)
13439 ("python-termstyle" ,python-termstyle)))
13440 (native-inputs
13441 `(("python-six" ,python-six)
13442 ("python-nose" ,python-nose)))
13443 (home-page "https://github.com/JBKahn/rednose")
13444 (synopsis "Colored output for Python nosetests")
13445 (description "This package provides colored output for the
13446 @command{nosetests} command of the Python Nose unit test framework.")
13447 (license license:bsd-3)))
13448
13449 (define-public python2-rednose
13450 (package-with-python2 python-rednose))
13451
13452 (define-public python-flask-restplus
13453 (package
13454 (name "python-flask-restplus")
13455 (version "0.9.2")
13456 (source
13457 (origin
13458 (method url-fetch)
13459 (uri (pypi-uri "flask-restplus" version))
13460 (sha256
13461 (base32
13462 "11his6ii5brpkhld0d5bwzjjw4q3vmplpd6fmgzjrvvklsbk0cf4"))))
13463 (build-system python-build-system)
13464 (arguments
13465 '(#:tests? #f)) ; FIXME: 35/882 tests failing.
13466 ;; #:phases
13467 ;; (modify-phases %standard-phases
13468 ;; (replace 'check
13469 ;; (lambda _
13470 ;; (zero? (system* "nosetests")))))))
13471 (propagated-inputs
13472 `(("python-aniso8601" ,python-aniso8601)
13473 ("python-flask" ,python-flask)
13474 ("python-jsonschema" ,python-jsonschema)
13475 ("python-pytz" ,python-pytz)
13476 ("python-six" ,python-six)))
13477 (native-inputs
13478 `(("python-tzlocal" ,python-tzlocal)
13479 ("python-blinker" ,python-blinker)
13480 ("python-nose" ,python-nose)
13481 ("python-rednose" ,python-rednose)))
13482 (home-page "https://github.com/noirbizarre/flask-restplus")
13483 (synopsis "Framework for documented API development with Flask")
13484 (description "This package provides a framework for API development with
13485 the Flask web framework in Python. It is similar to package
13486 @code{python-flask-restful} but supports the @code{python-swagger}
13487 documentation builder.")
13488 (license license:expat)))
13489
13490 (define-public python-sadisplay
13491 (package
13492 (name "python-sadisplay")
13493 (version "0.4.6")
13494 (source
13495 (origin
13496 (method url-fetch)
13497 (uri (pypi-uri "sadisplay" version))
13498 (sha256
13499 (base32
13500 "0zqad2fl7q26p090qmqgmxbm6iwgf9zij1w8da1g3wdgjj72ql05"))))
13501 (build-system python-build-system)
13502 (propagated-inputs
13503 `(("python-sqlalchemy" ,python-sqlalchemy)))
13504 (native-inputs
13505 `(("python-nose" ,python-nose)))
13506 (home-page "https://bitbucket.org/estin/sadisplay")
13507 (synopsis "SQLAlchemy schema displayer")
13508 (description "This package provides a program to build Entity
13509 Relationship diagrams from a SQLAlchemy model (or directly from the
13510 database).")
13511 (license license:bsd-3)))
13512
13513 (define-public python2-sadisplay
13514 (package-with-python2 python-sadisplay))
13515
13516 (define-public python-flask-restful-swagger
13517 (package
13518 (name "python-flask-restful-swagger")
13519 (version "0.19")
13520 (source
13521 (origin
13522 (method url-fetch)
13523 (uri (pypi-uri "flask-restful-swagger" version))
13524 (sha256
13525 (base32
13526 "16msl8hd5xjmj833bpy264v98cpl5hkw5bgl5gf5vgndxbv3rm6v"))))
13527 (build-system python-build-system)
13528 (propagated-inputs
13529 `(("python-flask-restful" ,python-flask-restful)))
13530 (home-page "https://github.com/rantav/flask-restful-swagger")
13531 (synopsis "Extract Swagger specs from Flask-Restful projects")
13532 (description "This package lets you extract Swagger API documentation
13533 specs from your Flask-Restful projects.")
13534 (license license:expat)))
13535
13536 (define-public python2-flask-restful-swagger
13537 (package-with-python2 python-flask-restful-swagger))
13538
13539 (define-public python-argcomplete
13540 (package
13541 (name "python-argcomplete")
13542 (version "1.7.0")
13543 (source
13544 (origin
13545 (method url-fetch)
13546 (uri (pypi-uri "argcomplete" version))
13547 (sha256
13548 (base32
13549 "11bwiw6j0nilgz81xnw6f1npyga3prp8asjqrm87cdr3ria5l03x"))))
13550 (build-system python-build-system)
13551 (native-inputs
13552 `(("python-pexpect" ,python-pexpect)
13553 ("tcsh" ,tcsh)))
13554 (home-page "https://github.com/kislyuk/argcomplete")
13555 (synopsis "Shell tab completion for Python argparse")
13556 (description "argcomplete provides extensible command line tab completion
13557 of arguments and options for Python scripts using @code{argparse}. It's
13558 particularly useful for programs with many options or sub-parsers that can
13559 dynamically suggest completions; for example, when browsing resources over the
13560 network.")
13561 (license license:asl2.0)))
13562
13563 (define-public python2-argcomplete
13564 (package-with-python2 python-argcomplete))
13565
13566 (define-public python-xopen
13567 (package
13568 (name "python-xopen")
13569 (version "0.1.1")
13570 (source
13571 (origin
13572 (method url-fetch)
13573 (uri (pypi-uri "xopen" version))
13574 (sha256
13575 (base32
13576 "1wx6mylzcsyhjl19ycb83qq6iqpmr927lz62njfsar6ldsj0qcni"))
13577 (file-name (string-append name "-" version ".tar.gz"))))
13578 (build-system python-build-system)
13579 (home-page "https://github.com/marcelm/xopen/")
13580 (synopsis "Open compressed files transparently")
13581 (description "This module provides an @code{xopen} function that works like
13582 Python's built-in @code{open} function, but can also deal with compressed files.
13583 Supported compression formats are gzip, bzip2 and, xz, and are automatically
13584 recognized by their file extensions. The focus is on being as efficient as
13585 possible on all supported Python versions.")
13586 (license license:expat)))
13587
13588 (define-public python2-xopen
13589 (package-with-python2 python-xopen))
13590
13591 (define-public python2-cheetah
13592 (package
13593 (name "python2-cheetah")
13594 (version "2.4.4")
13595 (source
13596 (origin
13597 (method url-fetch)
13598 (uri (pypi-uri "Cheetah" version))
13599 (sha256
13600 (base32
13601 "0l5mm4lnysjkzpjr95q5ydm9xc8bv43fxmr79ypybrf1y0lq4c5y"))))
13602 (build-system python-build-system)
13603 (arguments
13604 `(#:python ,python-2))
13605 (propagated-inputs
13606 `(("python2-markdown" ,python2-markdown)))
13607 (home-page "https://pythonhosted.org/Cheetah/")
13608 (synopsis "Template engine")
13609 (description "Cheetah is a text-based template engine and Python code
13610 generator.
13611
13612 Cheetah can be used as a standalone templating utility or referenced as
13613 a library from other Python applications. It has many potential uses,
13614 but web developers looking for a viable alternative to ASP, JSP, PHP and
13615 PSP are expected to be its principle user group.
13616
13617 Features:
13618 @enumerate
13619 @item Generates HTML, SGML, XML, SQL, Postscript, form email, LaTeX, or any other
13620 text-based format.
13621 @item Cleanly separates content, graphic design, and program code.
13622 @item Blends the power and flexibility of Python with a simple template language
13623 that non-programmers can understand.
13624 @item Gives template writers full access to any Python data structure, module,
13625 function, object, or method in their templates.
13626 @item Makes code reuse easy by providing an object-orientated interface to
13627 templates that is accessible from Python code or other Cheetah templates.
13628 One template can subclass another and selectively reimplement sections of it.
13629 @item Provides a simple, yet powerful, caching mechanism that can dramatically
13630 improve the performance of a dynamic website.
13631 @item Compiles templates into optimized, yet readable, Python code.
13632 @end enumerate")
13633 (license (license:x11-style "file://LICENSE"))))
13634
13635 (define-public python-dulwich
13636 (package
13637 (name "python-dulwich")
13638 (version "0.16.3")
13639 (source
13640 (origin
13641 (method url-fetch)
13642 (uri (list (string-append "https://www.dulwich.io/releases/"
13643 "dulwich-" version ".tar.gz")
13644 (pypi-uri "dulwich" version)))
13645 (sha256
13646 (base32 "0fl47vzfgc3w3rmhn8naii905cjqcp0vc68iyvymxp7567hh6als"))))
13647 (build-system python-build-system)
13648 (arguments
13649 `(#:phases
13650 (modify-phases %standard-phases
13651 (add-before 'check 'fix-tests
13652 (lambda* (#:key inputs #:allow-other-keys)
13653 ;; The tests use Popen with a custom environment which doesn't
13654 ;; include PATH.
13655 (substitute* "dulwich/tests/compat/utils.py"
13656 (("'git'") (string-append "'"
13657 (which "git")
13658 "'")))
13659 (substitute* '("dulwich/tests/test_repository.py"
13660 "dulwich/tests/test_hooks.py")
13661 (("#!/bin/sh") (string-append "#!" (which "sh"))))
13662 (setenv "TEST_RUNNER" "unittest")
13663 (setenv "PYTHONHASHSEED" "random")
13664 #t)))))
13665 (propagated-inputs
13666 `(("python-fastimport" ,python-fastimport)))
13667 (native-inputs
13668 `(("python-mock" ,python-mock)
13669 ("python-geventhttpclient" ,python-geventhttpclient)
13670 ("git" ,git)))
13671 (home-page "https://www.dulwich.io/")
13672 (synopsis "Git implementation in Python")
13673 (description "Dulwich is an implementation of the Git file formats and
13674 protocols written in pure Python.")
13675 ;; Can be used with either license.
13676 (license (list license:asl2.0 license:gpl2+))))
13677
13678 (define-public python2-dulwich
13679 (package-with-python2 python-dulwich))
13680
13681 (define-public python-pbkdf2
13682 (package
13683 (name "python-pbkdf2")
13684 (version "1.3")
13685 (source
13686 (origin
13687 (method url-fetch)
13688 (uri (pypi-uri "pbkdf2" version))
13689 (sha256
13690 (base32
13691 "0yb99rl2mbsaamj571s1mf6vgniqh23v98k4632150hjkwv9fqxc"))))
13692 (build-system python-build-system)
13693 (arguments
13694 '(#:phases
13695 (modify-phases %standard-phases
13696 (replace 'check
13697 (lambda _
13698 (setenv "PYTHONPATH"
13699 (string-append (getcwd) "/build/lib:"
13700 (getenv "PYTHONPATH")))
13701 (zero? (system* "python" "test/test_pbkdf2.py")))))))
13702 (propagated-inputs
13703 `(("python-pycrypto" ,python-pycrypto))) ; optional
13704 (home-page "http://www.dlitz.net/software/python-pbkdf2/")
13705 (synopsis "Password-based key derivation")
13706 (description "This module implements the password-based key derivation
13707 function, PBKDF2, specified in RSA PKCS#5 v2.0.
13708
13709 PKCS#5 v2.0 Password-Based Key Derivation is a key derivation function which
13710 is part of the RSA Public Key Cryptography Standards series. The provided
13711 implementation takes a password or a passphrase and a salt value (and
13712 optionally a iteration count, a digest module, and a MAC module) and provides
13713 a file-like object from which an arbitrarly-sized key can be read.")
13714 (license license:expat)))
13715
13716 (define-public python2-pbkdf2
13717 (package-with-python2 python-pbkdf2))
13718
13719 (define-public python-qrcode
13720 (package
13721 (name "python-qrcode")
13722 (version "5.3")
13723 (source
13724 (origin
13725 (method url-fetch)
13726 (uri (pypi-uri "qrcode" version))
13727 (sha256
13728 (base32
13729 "0kljfrfq0c2rmxf8am57333ia41kd0snbm2rnqbdy816hgpcq5a1"))))
13730 (build-system python-build-system)
13731 (arguments
13732 ;; FIXME: Tests require packaging 'pymaging'.
13733 '(#:tests? #f))
13734 (propagated-inputs
13735 `(("python-lxml" ,python-lxml) ; for SVG output
13736 ("python-pillow" ,python-pillow) ; for PNG output
13737 ("python-six" ,python-six)))
13738 (home-page "https://github.com/lincolnloop/python-qrcode")
13739 (synopsis "QR Code image generator")
13740 (description "This package provides a pure Python QR Code generator
13741 module. It uses the Python Imaging Library (PIL) to allow for the generation
13742 of QR Codes.
13743
13744 In addition this package provides a command line tool to generate QR codes and
13745 either write these QR codes to a file or do the output as ascii art at the
13746 console.")
13747 (license license:bsd-3)))
13748
13749 (define-public python2-qrcode
13750 (package-with-python2 python-qrcode))
13751
13752 ;; SlowAES isn't compatible with Python 3.
13753 (define-public python2-slowaes
13754 (package
13755 (name "python2-slowaes")
13756 (version "0.1a1")
13757 (source
13758 (origin
13759 (method url-fetch)
13760 (uri (pypi-uri "slowaes" version))
13761 (sha256
13762 (base32
13763 "02dzajm83a7lqgxf6r3hgj64wfmcxz8gs4nvgxpvj5n19kjqlrc3"))))
13764 (build-system python-build-system)
13765 (arguments `(#:python ,python-2))
13766 (home-page "http://code.google.com/p/slowaes/")
13767 (synopsis "Implementation of AES in Python")
13768 (description "This package contains an implementation of AES in Python.
13769 This implementation is slow (hence the project name) but still useful when
13770 faster ones are not available.")
13771 (license license:asl2.0)))
13772
13773 (define-public python-rst2ansi
13774 (package
13775 (name "python-rst2ansi")
13776 (version "0.1.5")
13777 (source
13778 (origin
13779 (method url-fetch)
13780 (uri (pypi-uri "rst2ansi" version))
13781 (sha256
13782 (base32
13783 "0vzy6gd60l79ff750scl0sz48r1laalkl6md6dwzah4dcadgn5qv"))))
13784 (build-system python-build-system)
13785 (propagated-inputs
13786 `(("python-docutils" ,python-docutils)))
13787 (home-page "https://github.com/Snaipe/python-rst-to-ansi")
13788 (synopsis "Convert RST to ANSI-decorated console output")
13789 (description
13790 "Python module dedicated to rendering RST (reStructuredText) documents
13791 to ansi-escaped strings suitable for display in a terminal.")
13792 (license license:expat)))
13793
13794 (define-public python-ansi2html
13795 (package
13796 (name "python-ansi2html")
13797 (version "1.2.0")
13798 (source
13799 (origin
13800 (method url-fetch)
13801 (uri (pypi-uri "ansi2html" version))
13802 (sha256
13803 (base32
13804 "1wa00zffprb78w1mqq90dk47czz1knanys2a40zbw2vyapd5lp9y"))))
13805 (build-system python-build-system)
13806 (native-inputs
13807 `(("python-mock" ,python-mock)
13808 ("python-nose" ,python-nose)))
13809 (propagated-inputs
13810 `(("python-six" ,python-six)))
13811 (home-page "http://github.com/ralphbean/ansi2html")
13812 (synopsis "Convert ANSI-decorated console output to HTML")
13813 (description
13814 "@command{ansi2html} is a Python library and command line utility for
13815 convering text with ANSI color codes to HTML or LaTeX.")
13816 (license license:gpl3+)))
13817
13818 (define-public python2-ansi2html
13819 (package-with-python2 python-ansi2html))
13820
13821 (define-public python-ddt
13822 (package
13823 (name "python-ddt")
13824 (version "1.1.1")
13825 (source
13826 (origin
13827 (method url-fetch)
13828 (uri (pypi-uri "ddt" version))
13829 (sha256
13830 (base32
13831 "1c00ikkxr7lha97c81k938bzhgd4pbwamkjn0h4nkhr3xk00zp6n"))))
13832 (build-system python-build-system)
13833 (native-inputs
13834 `(("python-mock" ,python-mock)
13835 ("python-nose" ,python-nose)))
13836 (propagated-inputs
13837 `(("python-six" ,python-six)
13838 ("python-pyyaml" ,python-pyyaml)))
13839 (home-page "https://github.com/txels/ddt")
13840 (synopsis "Data-Driven Tests")
13841 (description
13842 "DDT (Data-Driven Tests) allows you to multiply one test case by running
13843 it with different test data, and make it appear as multiple test cases.")
13844 (license license:expat)))
13845
13846 (define-public python2-ddt
13847 (package-with-python2 python-ddt))
13848
13849 (define-public python-pycosat
13850 (package
13851 (name "python-pycosat")
13852 (version "0.6.1")
13853 (source
13854 (origin
13855 (method url-fetch)
13856 (uri (pypi-uri "pycosat" version))
13857 (sha256
13858 (base32
13859 "1kl3wh1f47rc712n4bmwplbx3fqz3x9i1b587jrbpmvdva4c8f6l"))))
13860 ;; TODO: Unundle picosat. http://fmv.jku.at/picosat/
13861 (build-system python-build-system)
13862 (home-page "https://github.com/ContinuumIO/pycosat")
13863 (synopsis "Bindings to picosat (a SAT solver)")
13864 (description
13865 "This package provides efficient Python bindings to @code{picosat} on
13866 the C level. When importing pycosat, the @code{picosat} solver becomes part
13867 of the Python process itself. @code{picosat} is a @dfn{Boolean Satisfiability
13868 Problem} (SAT) solver.")
13869 (license license:expat)))
13870
13871 (define-public python2-pycosat
13872 (package-with-python2 python-pycosat))
13873
13874 (define-public python2-ruamel.ordereddict
13875 (package
13876 (name "python2-ruamel.ordereddict")
13877 (version "0.4.9")
13878 (source
13879 (origin
13880 (method url-fetch)
13881 (uri (pypi-uri "ruamel.ordereddict" version))
13882 (sha256
13883 (base32
13884 "1xmkl8v9l9inm2pyxgc1fm5005yxm7fkd5gv74q7lj1iy5qc8n3h"))))
13885 (build-system python-build-system)
13886 (arguments
13887 `(#:python ,python-2
13888 #:phases
13889 (modify-phases %standard-phases
13890 (delete 'check)
13891 (add-after 'install 'check
13892 (lambda* (#:key inputs outputs #:allow-other-keys)
13893 (add-installed-pythonpath inputs outputs)
13894 (zero? (system* "python" "test/testordereddict.py")))))))
13895 (home-page "https://bitbucket.org/ruamel/ordereddict")
13896 (synopsis "Version of dict that keeps keys in insertion order")
13897 (description
13898 "This is an implementation of an ordered dictionary with @dfn{Key
13899 Insertion Order} (KIO: updates of values do not affect the position of the
13900 key), @dfn{Key Value Insertion Order} (KVIO, an existing key's position is
13901 removed and put at the back). The standard library module @code{OrderedDict},
13902 implemented later, implements a subset of @code{ordereddict} functionality.
13903 Sorted dictionaries are also provided. Currently only with @dfn{Key Sorted
13904 Order} (KSO, no sorting function can be specified, but a transform can be
13905 specified to apply on the key before comparison (e.g. @code{string.lower})).")
13906 (license license:expat)))
13907
13908 (define-public python-pypeg2
13909 (package
13910 (name "python-pypeg2")
13911 (version "2.15.2")
13912 (source
13913 (origin
13914 (method url-fetch)
13915 (uri (pypi-uri "pyPEG2" version))
13916 (sha256
13917 (base32
13918 "0v8ziaam2r637v94ra4dbjw6jzxz99gs5x4i585kgag1v204yb9b"))))
13919 (build-system python-build-system)
13920 (propagated-inputs `(("python-lxml" ,python-lxml)))
13921 (arguments
13922 ;;https://bitbucket.org/fdik/pypeg/issues/36/test-failures-on-py35
13923 '(#:tests? #f))
13924 (home-page "https://fdik.org/pyPEG/")
13925 (synopsis "Parsering Expression Grammars in Python")
13926 (description "PyPEG is an intrinsic parser interpreter framework for
13927 Python. It is based on Parsing Expression Grammars, PEG. With pyPEG you can
13928 parse many formal languages.")
13929 (license license:gpl2)))
13930
13931 (define-public python2-cliapp
13932 (package
13933 (name "python2-cliapp")
13934 (version "1.20160724")
13935 (source
13936 (origin
13937 (method url-fetch)
13938 (uri (string-append
13939 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/cliapp/snapshot/cliapp-"
13940 version ".tar.gz"))
13941 (sha256
13942 (base32
13943 "025cyi75vxyghbm4hav8dz4fzwksshddavy9g9fwr440awcvw74f"))))
13944 (build-system python-build-system)
13945 (arguments
13946 `(#:python ,python-2))
13947 (propagated-inputs
13948 `(("python2-pyaml" ,python2-pyaml)))
13949 (home-page "https://liw.fi/cliapp/")
13950 (synopsis "Python framework for command line programs")
13951 (description "@code{python2-cliapp} is a python framework for
13952 command line programs. It contains the typical stuff such programs
13953 need to do, such as parsing the command line for options, and
13954 iterating over input files.")
13955 (license license:gpl2+)))
13956
13957 (define-public python2-ttystatus
13958 (package
13959 (name "python2-ttystatus")
13960 (version "0.32")
13961 (source
13962 (origin
13963 (method url-fetch)
13964 (uri (string-append
13965 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/ttystatus/snapshot/ttystatus-"
13966 version ".tar.gz"))
13967 (sha256
13968 (base32
13969 "0b5g889jj23r2w1hi300cdldx6jvspanp0ybf5n1qvdvl150aamf"))))
13970 (build-system python-build-system)
13971 (arguments
13972 `(#:python ,python-2))
13973 (home-page "https://liw.fi/ttystatus/")
13974 (synopsis "Python library for showing progress reporting and
13975 status updates on terminals")
13976 (description "@code{python2-ttystatus} is a python library for
13977 showing progress reporting and status updates on terminals, for
13978 command line programs. Output is automatically adapted to the width
13979 of the terminal: truncated if it does not fit, and resized if the
13980 terminal size changes.")
13981 (license license:gpl3+)))
13982
13983 (define-public python2-tracing
13984 (package
13985 (name "python2-tracing")
13986 (version "0.10")
13987 (source
13988 (origin
13989 (method url-fetch)
13990 (uri (string-append
13991 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/python-tracing/snapshot/tracing-"
13992 version ".tar.gz"))
13993 (sha256
13994 (base32
13995 "06cw4zg42fsvqy372vi2whj26w56vzg5axhzwdjc2bgwf03garbw"))))
13996 (build-system python-build-system)
13997 (arguments
13998 `(#:python ,python-2))
13999 (home-page "https://liw.fi/tracing/")
14000 (synopsis "Python debug logging helper")
14001 (description "@code{python2-tracing} is a python library for
14002 logging debug messages. It provides a way to turn debugging messages
14003 on and off, based on the filename they occur in. It is much faster
14004 than using @code{logging.Filter} to accomplish the same thing, which
14005 matters when code is run in production mode. The actual logging still
14006 happens using the @code{logging} library.")
14007 (license license:gpl3+)))
14008
14009 (define-public python2-larch
14010 (package
14011 (name "python2-larch")
14012 (version "1.20151025")
14013 (source
14014 (origin
14015 (method url-fetch)
14016 (uri (string-append
14017 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/larch/snapshot/larch-"
14018 version ".tar.gz"))
14019 (sha256
14020 (base32
14021 "1p4knkkavlqymgciz2wbcnfrdgdbafhg14maplnk4vbw0q8xs663"))))
14022 (build-system python-build-system)
14023 (arguments
14024 `(#:python ,python-2))
14025 (propagated-inputs
14026 `(("python2-tracing" ,python2-tracing)))
14027 (home-page "https://liw.fi/larch/")
14028 (synopsis "Python copy-on-write B-tree library")
14029 (description "@code{python2-larch} is an implementation of
14030 particular kind of B-tree, based on research by Ohad Rodeh. See
14031 @url{http://liw.fi/larch/ohad-btrees-shadowing-clones.pdf} for details
14032 on the data structure.
14033
14034 The distinctive feature of this B-tree is that a node is never
14035 (conceptually) modified. Instead, all updates are done by
14036 copy-on-write. This makes it easy to clone a tree, and modify only the
14037 clone, while other processes access the original tree.")
14038 (license license:gpl3+)))
14039
14040 (define-public python-htmlmin
14041 (package
14042 (name "python-htmlmin")
14043 (version "0.1.10")
14044 (source
14045 (origin
14046 (method url-fetch)
14047 (uri (pypi-uri "htmlmin" version))
14048 (sha256
14049 (base32
14050 "0qxa93j3p1ak32qh8d9kshqv8v3z0hkc13dwbhp5cn7sn3xmsp6a"))))
14051 (arguments
14052 `(#:tests? #f)) ;htmlmin has no tests
14053 (build-system python-build-system)
14054 (home-page "https://htmlmin.readthedocs.org/en/latest/")
14055 (synopsis "HTML minifier")
14056 (description "@code{htmlmin} is an HTML minifier that just works.
14057 It comes with safe defaults and easily configurable options.")
14058 (license license:bsd-3)))
14059
14060 (define-public python2-htmlmin
14061 (package-with-python2 python-htmlmin))
14062
14063 (define-public python-flask-htmlmin
14064 (package
14065 (name "python-flask-htmlmin")
14066 (version "1.2")
14067 (source
14068 (origin
14069 (method url-fetch)
14070 (uri (pypi-uri "Flask-HTMLmin" version))
14071 (sha256
14072 (base32
14073 "1n6zlq72kakkw0z2jpq6nh74lfsmxybm4g053pwhc14fbr809348"))))
14074 (propagated-inputs
14075 `(("python-flask" ,python-flask)
14076 ("python-htmlmin" ,python-htmlmin)))
14077 (build-system python-build-system)
14078 (home-page "https://github.com/hamidfzm/Flask-HTMLmin")
14079 (synopsis "HTML response minifier for Flask")
14080 (description
14081 "Minify @code{text/html} MIME type responses when using @code{Flask}.")
14082 (license license:bsd-3)))
14083
14084 (define-public python2-flask-htmlmin
14085 (package-with-python2 python-flask-htmlmin))
14086
14087 (define-public python-flask-login
14088 (package
14089 (name "python-flask-login")
14090 (version "0.4.0")
14091 (source
14092 (origin
14093 (method url-fetch)
14094 (uri (string-append "https://github.com/maxcountryman/flask-login/archive/"
14095 version ".tar.gz"))
14096 (file-name (string-append name "-" version ".tar.gz"))
14097 (sha256
14098 (base32
14099 "1pdqp7a2gyb7k06xda004x0fi2w66s6kn2i0ndkqndmg12d83f9w"))))
14100 (arguments
14101 ;; Tests fail PEP8 compliance. See:
14102 ;; https://github.com/maxcountryman/flask-login/issues/340
14103 `(#:tests? #f))
14104 (build-system python-build-system)
14105 (home-page "https://github.com/maxcountryman/flask-login")
14106 (synopsis "User session management for Flask")
14107 (description
14108 "@code{Flask-Login} provides user session management for Flask. It
14109 handles the common tasks of logging in, logging out, and remembering your
14110 users' sessions over extended periods of time.")
14111 (license license:expat)))
14112
14113 (define-public python2-flask-login
14114 (package-with-python2 python-flask-login))
14115
14116 (define-public python-astroid
14117 (package
14118 (name "python-astroid")
14119 (version "1.5.3")
14120 (source
14121 (origin
14122 (method url-fetch)
14123 (uri (string-append
14124 "https://github.com/PyCQA/astroid/archive/astroid-"
14125 version ".tar.gz"))
14126 (sha256
14127 (base32
14128 "0isn5p7f9n48hmksgbrj7dkm9dyglnayzn5jngk37qywg8a74ngn"))))
14129 (build-system python-build-system)
14130 (propagated-inputs
14131 `(("python-lazy-object-proxy" ,python-lazy-object-proxy)
14132 ("python-six" ,python-six)
14133 ("python-wrapt" ,python-wrapt)))
14134 (arguments
14135 `(#:phases
14136 (modify-phases %standard-phases
14137 (replace 'check
14138 (lambda _
14139 (zero? (system* "python" "-m" "unittest" "discover"
14140 "-p" "unittest*.py")))))))
14141 (home-page "https://github.com/PyCQA/astroid")
14142 (synopsis "Common base representation of python source code for pylint and
14143 other projects")
14144 (description "@code{python-astroid} provides a common base representation
14145 of python source code for projects such as pychecker, pyreverse, pylint, etc.
14146
14147 It provides a compatible representation which comes from the _ast module. It
14148 rebuilds the tree generated by the builtin _ast module by recursively walking
14149 down the AST and building an extended ast. The new node classes have
14150 additional methods and attributes for different usages. They include some
14151 support for static inference and local name scopes. Furthermore, astroid
14152 builds partial trees by inspecting living objects.")
14153 (license license:lgpl2.1+)
14154 (properties `((python2-variant . ,(delay python2-astroid))))))
14155
14156 (define-public python2-astroid
14157 (let ((base (package-with-python2
14158 (strip-python2-variant python-astroid))))
14159 (package (inherit base)
14160 (propagated-inputs
14161 `(("python2-backports-functools-lru-cache"
14162 ,python2-backports-functools-lru-cache)
14163 ("python2-enum34" ,python2-enum34)
14164 ("python2-singledispatch" ,python2-singledispatch)
14165 ,@(package-propagated-inputs base))))))
14166
14167 (define-public python-isort
14168 (package
14169 (name "python-isort")
14170 (version "4.2.5")
14171 (source
14172 (origin
14173 (method url-fetch)
14174 (uri (string-append
14175 "https://github.com/timothycrosley/isort/archive/"
14176 version ".tar.gz"))
14177 (file-name (string-append name "-" version ".tar.gz"))
14178 (sha256
14179 (base32
14180 "0zsrgkb0krn5476yncy5dd56k7dk34zqb4bnlvwy44ixgilyjmfh"))))
14181 (build-system python-build-system)
14182 (native-inputs
14183 `(("python-mock" ,python-mock)
14184 ("python-pytest" ,python-pytest)))
14185 (home-page "https://github.com/timothycrosley/isort")
14186 (synopsis "Python utility/library to sort python imports")
14187 (description "@code{python-isort} is a python utility/library to sort
14188 imports alphabetically, and automatically separated into sections. It
14189 provides a command line utility, a python library and plugins for various
14190 editors.")
14191 (license license:expat)))
14192
14193 (define-public python2-isort
14194 (package-with-python2 python-isort))
14195
14196 (define-public python2-backports-functools-lru-cache
14197 (package
14198 (name "python2-backports-functools-lru-cache")
14199 (version "1.3")
14200 (source
14201 (origin
14202 (method url-fetch)
14203 ;; only the pypi tarballs contain the necessary metadata
14204 (uri (pypi-uri "backports.functools_lru_cache" version))
14205 (sha256
14206 (base32
14207 "158ysf2hb0q4p4695abfiym9x1ywg0dgh8a3apd7gqaaxjy22jj4"))))
14208 (build-system python-build-system)
14209 (native-inputs
14210 `(("python2-setuptools-scm" ,python2-setuptools-scm)))
14211 (arguments
14212 `(#:python ,python-2))
14213 (home-page "https://github.com/jaraco/backports.functools_lru_cache")
14214 (synopsis "Backport of functools.lru_cache from Python 3.3")
14215 (description "@code{python2-backports-functools-lru-cache} is a backport
14216 of @code{functools.lru_cache} from python 3.3.")
14217 (license license:expat)))
14218
14219 (define-public python-configparser
14220 (package
14221 (name "python-configparser")
14222 (version "3.5.0")
14223 (source
14224 (origin
14225 (method url-fetch)
14226 (uri (string-append
14227 "https://bitbucket.org/ambv/configparser/get/"
14228 version ".tar.bz2"))
14229 (file-name (string-append name "-" version ".tar.gz"))
14230 (sha256
14231 (base32
14232 "0waq40as14abwzbb321hfz4vr1fi363nscy32ga14qvfygrg96wa"))))
14233 (build-system python-build-system)
14234 (home-page "http://docs.python.org/py3k/library/configparser.html")
14235 (synopsis "Backport of configparser from python 3.5")
14236 (description "@code{python-configparser} is a backport of
14237 @code{configparser} from Python 3.5 so that it can be used directly
14238 in other versions.")
14239 (license license:expat)))
14240
14241 (define-public python2-configparser
14242 (package-with-python2 python-configparser))
14243
14244 (define-public python2-coverage-test-runner
14245 (package
14246 (name "python2-coverage-test-runner")
14247 (version "1.11")
14248 (source
14249 (origin
14250 (method url-fetch)
14251 (uri (string-append
14252 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/"
14253 "coverage-test-runner/snapshot/coverage-test-runner-"
14254 version ".tar.gz"))
14255 (sha256
14256 (base32
14257 "0y1m7z3dl63kmhcmydl1mwg0hacnf6ghrx9dah17j9iasssfa3g7"))))
14258 (build-system python-build-system)
14259 (arguments
14260 `(#:python ,python-2
14261 #:phases
14262 (modify-phases %standard-phases
14263 (replace 'check
14264 (lambda _
14265 (zero? (system* "./testrun")))))))
14266 (propagated-inputs
14267 `(("python2-coverage" ,python2-coverage)))
14268 (home-page "https://liw.fi/coverage-test-runner/")
14269 (synopsis "Python module for running unit tests")
14270 (description "@code{CoverageTestRunner} is a python module for running
14271 unit tests and failing them if the unit test module does not exercise all
14272 statements in the module it tests.")
14273 (license license:gpl3+)))
14274
14275 (define-public python-pylint
14276 (package
14277 (name "python-pylint")
14278 (version "1.7.2")
14279 (source
14280 (origin
14281 (method url-fetch)
14282 (uri (string-append
14283 "https://github.com/PyCQA/pylint/archive/pylint-"
14284 version ".tar.gz"))
14285 (sha256
14286 (base32
14287 "0mzn1czhf1mgr2wiqfihb274sja02h899b85kywdpivppa9nwrmp"))))
14288 (build-system python-build-system)
14289 (native-inputs
14290 `(("python-pytest" ,python-pytest)
14291 ("python-pytest-runner" ,python-pytest-runner)
14292 ("python-tox" ,python-tox)))
14293 (propagated-inputs
14294 `(("python-astroid" ,python-astroid)
14295 ("python-isort" ,python-isort)
14296 ("python-mccabe" ,python-mccabe)
14297 ("python-six" ,python-six)))
14298 (arguments
14299 `(#:phases
14300 (modify-phases %standard-phases
14301 (replace 'check
14302 (lambda _
14303 ;; Somehow, tests for python2-pylint
14304 ;; fail if run from the build directory
14305 (let ((work "/tmp/work"))
14306 (mkdir-p work)
14307 (setenv "PYTHONPATH"
14308 (string-append (getenv "PYTHONPATH") ":" work))
14309 (copy-recursively "." work)
14310 (with-directory-excursion "/tmp"
14311 (zero? (system* "python" "-m" "unittest" "discover"
14312 "-s" (string-append work "/pylint/test")
14313 "-p" "*test_*.py")))))))))
14314 (home-page "https://github.com/PyCQA/pylint")
14315 (synopsis "Python source code analyzer which looks for coding standard
14316 errors")
14317 (description "Pylint is a Python source code analyzer which looks
14318 for programming errors, helps enforcing a coding standard and sniffs
14319 for some code smells (as defined in Martin Fowler's Refactoring book).
14320
14321 Pylint has many rules enabled by default, way too much to silence them
14322 all on a minimally sized program. It's highly configurable and handle
14323 pragmas to control it from within your code. Additionally, it is
14324 possible to write plugins to add your own checks.")
14325 (license license:gpl2+)))
14326
14327 (define-public python2-pylint
14328 (let ((pylint (package-with-python2 python-pylint)))
14329 (package (inherit pylint)
14330 (propagated-inputs
14331 `(("python2-backports-functools-lru-cache"
14332 ,python2-backports-functools-lru-cache)
14333 ("python2-configparser" ,python2-configparser)
14334 ,@(package-propagated-inputs pylint))))))
14335
14336 (define-public python-paramunittest
14337 (package
14338 (name "python-paramunittest")
14339 (version "0.2")
14340 (source
14341 (origin
14342 (method url-fetch)
14343 (uri (pypi-uri "ParamUnittest" version))
14344 (sha256
14345 (base32
14346 "0kp793hws5xv1wvycxq7jw2pwy36f35k39jg8hx5qikij5a0jid1"))))
14347 (build-system python-build-system)
14348 (home-page
14349 "https://github.com/rik0/ParamUnittest")
14350 (synopsis
14351 "Simple extension to have parametrized unit tests")
14352 (description
14353 "This package allows to create parametrized unit-tests that work with the standard
14354 unittest package. A parametrized test case is automatically converted to multiple test
14355 cases. Since they are TestCase subclasses, they work with other test suites that
14356 recognize TestCases.")
14357 (license license:bsd-2)))
14358
14359 (define-public python2-python-paramunittest
14360 (package-with-python2 python-paramunittest))
14361
14362 (define-public python-mando
14363 (package
14364 (name "python-mando")
14365 (version "0.5")
14366 (source
14367 (origin
14368 (method url-fetch)
14369 (uri (pypi-uri "mando" version))
14370 (sha256
14371 (base32
14372 "0q05h66439gqdmlk4jqm6xrwrzfdgs4mwk70barxhr2y83qbbdc0"))))
14373 (build-system python-build-system)
14374 (propagated-inputs
14375 `(("python-rst2ansi" ,python-rst2ansi)))
14376 (native-inputs
14377 `(("python-sphinx" ,python-sphinx-1.5.3)
14378 ("python-paramunittest" ,python-paramunittest)))
14379 (home-page "https://mando.readthedocs.org/")
14380 (synopsis
14381 "Wrapper around argparse, allowing creation of complete CLI applications")
14382 (description
14383 "This package is a wrapper around argparse, allowing you to write complete CLI
14384 applications in seconds while maintaining all the flexibility.")
14385 (license license:expat)))
14386
14387 (define-public python2-mando
14388 (package-with-python2 python-mando))
14389
14390 (define-public python-mando-0.3.1
14391 ;; python-radon (version 1.5.0) has a requirement
14392 ;; for mando<0.4,>=0.3
14393 (package
14394 (inherit python-mando)
14395 (name "python-mando")
14396 (version "0.3.1")
14397 (source
14398 (origin
14399 (method url-fetch)
14400 (uri (string-append "https://github.com/rubik/mando/archive/v"
14401 version
14402 ".tar.gz"))
14403 (sha256
14404 (base32
14405 "17jlkdpqw22z1nyml5ybslilqkzmnk0dxxjml8bfghav1l5hbwd2"))))))
14406
14407 (define-public python-fudge
14408 (package
14409 (name "python-fudge")
14410 ;; 0.9.6 is the latest version suitable for testing the "fabric" Python 2
14411 ;; package, which is currently the only use of this package.
14412 (version "0.9.6")
14413 (source
14414 (origin
14415 (method url-fetch)
14416 (uri (pypi-uri "fudge" version))
14417 (sha256
14418 (base32
14419 "185ia3vr3qk4f2s1a9hdxb8ci4qc0x0xidrad96pywg8j930qs9l"))))
14420 (build-system python-build-system)
14421 (arguments
14422 `(#:tests? #f)) ;XXX: Tests require the NoseJS Python package.
14423 (home-page "https://github.com/fudge-py/fudge")
14424 (synopsis "Replace real objects with fakes/mocks/stubs while testing")
14425 (description
14426 "Fudge is a Python module for using fake objects (mocks and stubs) to
14427 test real ones.
14428
14429 In readable Python code, you declare the methods available on your fake object
14430 and how they should be called. Then you inject that into your application and
14431 start testing. This declarative approach means you don’t have to record and
14432 playback actions and you don’t have to inspect your fakes after running code.
14433 If the fake object was used incorrectly then you’ll see an informative
14434 exception message with a traceback that points to the culprit.")
14435 (license license:expat)))
14436
14437 (define-public python2-fudge
14438 (package-with-python2 python-fudge))
14439
14440 (define-public python-oauth2client
14441 (package
14442 (name "python-oauth2client")
14443 (version "4.0.0")
14444 (source
14445 (origin
14446 (method url-fetch)
14447 (uri (pypi-uri "oauth2client" version))
14448 (sha256
14449 (base32
14450 "1irqqap2zibysf8dba8sklfqikia579srd0phm5n754ni0h59gl0"))))
14451 (build-system python-build-system)
14452 (arguments
14453 `(#:tests? #f))
14454 (propagated-inputs
14455 `(("python-httplib2" ,python-httplib2)
14456 ("python-pyasn1" ,python-pyasn1)
14457 ("python-pyasn1-modules" ,python-pyasn1-modules)
14458 ("python-rsa" ,python-rsa)
14459 ("python-six" ,python-six)))
14460 (home-page "http://github.com/google/oauth2client/")
14461 (synopsis "OAuth 2.0 client library")
14462 (description "@code{python-oauth2client} provides an OAuth 2.0 client
14463 library for Python")
14464 (license license:asl2.0)))
14465
14466 (define-public python-flask-oidc
14467 (package
14468 (name "python-flask-oidc")
14469 (version "1.1.1")
14470 (source
14471 (origin
14472 (method url-fetch)
14473 (uri (pypi-uri "flask-oidc" version))
14474 (sha256
14475 (base32
14476 "1ay5j0mf174bix7i67hclr95gv16z81fpx0dijvi0gydvdj3ddy2"))))
14477 (build-system python-build-system)
14478 (propagated-inputs
14479 `(("python-flask" ,python-flask)
14480 ("python-itsdangerous" ,python-itsdangerous)
14481 ("python-oauth2client" ,python-oauth2client)
14482 ("python-six" ,python-six)))
14483 (native-inputs
14484 `(("python-nose" ,python-nose)
14485 ("python-mock" ,python-mock)))
14486 (home-page "https://github.com/puiterwijk/flask-oidc")
14487 (synopsis "OpenID Connect extension for Flask")
14488 (description "@code{python-flask-oidc} provides an OpenID Connect extension
14489 for Flask.")
14490 (license license:bsd-2)))
14491
14492 (define-public python-mwclient
14493 (package
14494 (name "python-mwclient")
14495 (version "0.8.4")
14496 (source
14497 (origin
14498 (method url-fetch)
14499 ;; The PyPI version wouldn't contain tests.
14500 (uri (string-append "https://github.com/mwclient/mwclient/archive/"
14501 "v" version ".tar.gz"))
14502 (sha256
14503 (base32
14504 "1jj0yhilkjir00719fc7w133x7hdyhkxhk6xblla4asig45klsfv"))))
14505 (build-system python-build-system)
14506 (propagated-inputs
14507 `(("python-requests" ,python-requests)
14508 ("python-requests-oauthlib"
14509 ,python-requests-oauthlib)
14510 ("python-six" ,python-six)))
14511 (native-inputs
14512 `(("python-mock" ,python-mock)
14513 ("python-pytest" ,python-pytest)
14514 ("python-pytest-pep8" ,python-pytest-pep8)
14515 ("python-pytest-cache" ,python-pytest-cache)
14516 ("python-pytest-cov" ,python-pytest-cov)
14517 ("python-responses" ,python-responses)))
14518 (home-page "https://github.com/btongminh/mwclient")
14519 (synopsis "MediaWiki API client")
14520 (description "This package provides a MediaWiki API client.")
14521 (license license:expat)))
14522
14523 (define-public python2-mwclient
14524 (package-with-python2 python-mwclient))
14525
14526 (define-public python-pytest-warnings
14527 (package
14528 (name "python-pytest-warnings")
14529 (version "0.2.0")
14530 (source
14531 (origin
14532 (method url-fetch)
14533 (uri (pypi-uri "pytest-warnings" version))
14534 (sha256
14535 (base32
14536 "0gf2dpahpl5igb7jh1sr9acj3z3gp7zahqdqb69nk6wx01c8kc1g"))))
14537 (build-system python-build-system)
14538 (propagated-inputs
14539 `(("pytest" ,python-pytest-3.0)))
14540 (home-page "https://github.com/fschulze/pytest-warnings")
14541 (synopsis "Pytest plugin to list Python warnings in pytest report")
14542 (description
14543 "Python-pytest-warnings is a pytest plugin to list Python warnings in
14544 pytest report.")
14545 (license license:expat)))
14546
14547 (define-public python2-pytest-warnings
14548 (package-with-python2 python-pytest-warnings))
14549
14550 (define-public python-pytest-capturelog
14551 (package
14552 (name "python-pytest-capturelog")
14553 (version "0.7")
14554 (source
14555 (origin
14556 (method url-fetch)
14557 (uri (pypi-uri "pytest-capturelog" version ".tar.gz"))
14558 (sha256
14559 (base32
14560 "038049nyjl7di59ycnxvc9nydivc5m8np3hqq84j2iirkccdbs5n"))))
14561 (build-system python-build-system)
14562 (propagated-inputs
14563 `(("pytest" ,python-pytest-3.0)))
14564 (home-page "http://bitbucket.org/memedough/pytest-capturelog/overview")
14565 (synopsis "Pytest plugin to catch log messages")
14566 (description
14567 "Python-pytest-catchlog is a pytest plugin to catch log messages.")
14568 (license license:expat)))
14569
14570 (define-public python2-pytest-capturelog
14571 (package-with-python2 python-pytest-capturelog))
14572
14573 (define-public python-pytest-catchlog
14574 (package
14575 (name "python-pytest-catchlog")
14576 (version "1.2.2")
14577 (source
14578 (origin
14579 (method url-fetch)
14580 (uri (pypi-uri "pytest-catchlog" version ".zip"))
14581 (sha256
14582 (base32
14583 "1w7wxh27sbqwm4jgwrjr9c2gy384aca5jzw9c0wzhl0pmk2mvqab"))))
14584 (build-system python-build-system)
14585 (native-inputs
14586 `(("unzip" ,unzip)))
14587 (propagated-inputs
14588 `(("pytest" ,python-pytest-3.0)))
14589 (home-page "https://github.com/eisensheng/pytest-catchlog")
14590 (synopsis "Pytest plugin to catch log messages")
14591 (description
14592 "Python-pytest-catchlog is a pytest plugin to catch log messages. This is
14593 a fork of pytest-capturelog.")
14594 (license license:expat)))
14595
14596 (define-public python2-pytest-catchlog
14597 (package-with-python2 python-pytest-catchlog))
14598
14599 (define-public python-utils
14600 (package
14601 (name "python-utils")
14602 (version "2.1.0")
14603 (source (origin
14604 (method url-fetch)
14605 (uri (pypi-uri "python-utils" version))
14606 (sha256
14607 (base32
14608 "1mcsy6q5am4ya72rgkpb6kax6vv7c93cfkkas89xnpa4sj9zf28p"))))
14609 (build-system python-build-system)
14610 (native-inputs
14611 `(("pytest-runner" ,python-pytest-runner)
14612 ("pytest" ,python-pytest)
14613 ("six" ,python-six)))
14614 (home-page "https://github.com/WoLpH/python-utils")
14615 (synopsis "Convenient utilities not included with the standard Python install")
14616 (description
14617 "Python Utils is a collection of small Python functions and classes which
14618 make common patterns shorter and easier.")
14619 (license license:bsd-2)))
14620
14621 (define-public python2-utils
14622 (package-with-python2 python-utils))
14623
14624 (define-public python-webassets
14625 (package
14626 (name "python-webassets")
14627 (version "0.12.1")
14628 (source
14629 (origin
14630 (method url-fetch)
14631 (uri (pypi-uri "webassets" version))
14632 (sha256
14633 (base32
14634 "1nrqkpb7z46h2b77xafxihqv3322cwqv6293ngaky4j3ff4cing7"))))
14635 (build-system python-build-system)
14636 (native-inputs
14637 `(("python-jinja2" ,python-jinja2)
14638 ("python-mock" ,python-mock)
14639 ("python-nose" ,python-nose)
14640 ("python-pytest" ,python-pytest)))
14641 (home-page "https://github.com/miracle2k/webassets")
14642 (synopsis "Media asset management")
14643 (description "Merges, minifies and compresses Javascript and CSS files,
14644 supporting a variety of different filters, including YUI, jsmin, jspacker or
14645 CSS tidy. Also supports URL rewriting in CSS files.")
14646 (license license:bsd-2)))
14647
14648 (define-public python-sphinx-me
14649 (package
14650 (name "python-sphinx-me")
14651 (version "0.3")
14652 (source
14653 (origin
14654 (method url-fetch)
14655 (uri (pypi-uri "sphinx-me" version))
14656 (sha256
14657 (base32
14658 "06jzgp213zihnvpcy2y5jy3ykid3apc2ncp2pg6a2g05lhiziglq"))))
14659 (build-system python-build-system)
14660 (home-page "https://github.com/stephenmcd/sphinx-me")
14661 (synopsis "Create a Sphinx documentation shell")
14662 (description
14663 "Create a Sphinx documentation shell for your project and include the
14664 README file as the documentation index. It handles extracting the required
14665 meta data such as the project name, author and version from your project for
14666 use in your Sphinx docs.")
14667 (license license:bsd-2)))
14668
14669 (define-public python2-sphinx-me
14670 (package-with-python2 python-sphinx-me))
14671
14672 (define-public python-cssmin
14673 (package
14674 (name "python-cssmin")
14675 (version "0.2.0")
14676 (source
14677 (origin
14678 (method url-fetch)
14679 (uri (pypi-uri "cssmin" version))
14680 (sha256
14681 (base32
14682 "1dk723nfm2yf8cp4pj785giqlwv42l0kj8rk40kczvq1hk6g04p0"))))
14683 (build-system python-build-system)
14684 (home-page "https://github.com/zacharyvoase/cssmin")
14685 (synopsis "Python port of the YUI CSS Compressor")
14686 (description "Python port of the YUI CSS Compressor.")
14687 (license (list license:expat license:bsd-3))))
14688
14689 (define-public python2-cssmin
14690 (package-with-python2 python-cssmin))
14691
14692 (define-public python-diff-match-patch
14693 (package
14694 (name "python-diff-match-patch")
14695 (version "20121119")
14696 (source
14697 (origin
14698 (method url-fetch)
14699 (uri (pypi-uri "diff-match-patch" version))
14700 (sha256
14701 (base32
14702 "0k1f3v8nbidcmmrk65m7h8v41jqi37653za9fcs96y7jzc8mdflx"))))
14703 (build-system python-build-system)
14704 (home-page "https://code.google.com/p/google-diff-match-patch")
14705 (synopsis "Synchronize plain text")
14706 (description "Diff Match and Patch libraries offer robust algorithms to
14707 perform the operations required for synchronizing plain text.")
14708 (license license:asl2.0)))
14709
14710 (define-public python2-diff-match-patch
14711 (package-with-python2 python-diff-match-patch))
14712
14713 (define-public python-dirsync
14714 (package
14715 (name "python-dirsync")
14716 (version "2.2.2")
14717 (source
14718 (origin
14719 (method url-fetch)
14720 (uri (pypi-uri "dirsync" version ".zip"))
14721 (sha256
14722 (base32
14723 "1hcdvmkwd5512zbxpin0k7bx5bkgzy3swjx7d0kj1y45af6r75v2"))))
14724 (build-system python-build-system)
14725 (native-inputs
14726 `(("unzip" ,unzip)))
14727 (propagated-inputs
14728 `(("six" ,python-six)))
14729 (home-page "https://bitbucket.org/tkhyn/dirsync")
14730 (synopsis "Advanced directory tree synchronisation tool")
14731 (description "Advanced directory tree synchronisation tool.")
14732 (license license:expat)))
14733
14734 (define-public python2-dirsync
14735 (package-with-python2 python-dirsync))
14736
14737 (define-public python-nosexcover
14738 (package
14739 (name "python-nosexcover")
14740 (version "1.0.11")
14741 (source (origin
14742 (method url-fetch)
14743 (uri (pypi-uri "nosexcover" version))
14744 (sha256
14745 (base32
14746 "10xqr12qv62k2flxwqhh8cr00cjhn7sfjrm6p35gd1x5bmjkr319"))))
14747 (build-system python-build-system)
14748 (propagated-inputs
14749 `(("python-coverage" ,python-coverage)
14750 ("python-nose" ,python-nose)))
14751 (home-page "http://github.com/cmheisel/nose-xcover")
14752 (synopsis "Extends nose.plugins.cover to add Cobertura-style XML reports")
14753 (description "Nose-xcover is a companion to the built-in
14754 @code{nose.plugins.cover}. This plugin will write out an XML coverage report
14755 to a file named coverage.xml.
14756
14757 It will honor all the options you pass to the Nose coverage plugin,
14758 especially -cover-package.")
14759 (license license:expat)))
14760
14761 (define-public python2-nosexcover
14762 (package-with-python2 python-nosexcover))
14763
14764 (define-public python-elasticsearch
14765 (package
14766 (name "python-elasticsearch")
14767 (version "1.0.0")
14768 (source
14769 (origin
14770 (method url-fetch)
14771 (uri (pypi-uri "elasticsearch" version))
14772 (sha256
14773 (base32
14774 "1sdw1r05cw7ihnmng8ra9v968fj7bq6sji8i1dikymsnkcpgc69g"))))
14775 (build-system python-build-system)
14776 (native-inputs
14777 `(("python-mock" ,python-mock)
14778 ("python-nosexcover" ,python-nosexcover)
14779 ("python-pyaml" ,python-pyaml)
14780 ("python-requests" ,python-requests)))
14781 (propagated-inputs
14782 `(("urllib3" ,python-urllib3)))
14783 (arguments
14784 ;; tests require the test_elasticsearch module but it is not distributed.
14785 `(#:tests? #f))
14786 (home-page "https://github.com/elastic/elasticsearch-py")
14787 (synopsis "Low-level client for Elasticsearch")
14788 (description "Official low-level client for Elasticsearch. Its goal is to
14789 provide common ground for all Elasticsearch-related code in Python; because of
14790 this it tries to be opinion-free and very extendable.")
14791 (license license:expat)))
14792
14793 (define-public python2-elasticsearch
14794 (package-with-python2 python-elasticsearch))
14795
14796 (define-public python-levenshtein
14797 (package
14798 (name "python-levenshtein")
14799 (version "0.12.0")
14800 (source
14801 (origin
14802 (method url-fetch)
14803 (uri (pypi-uri "python-Levenshtein" version))
14804 (sha256
14805 (base32
14806 "1c9ybqcja31nghfcc8xxbbz9h60s9qi12b9hr4jyl69xbvg12fh3"))))
14807 (build-system python-build-system)
14808 (home-page "https://github.com/ztane/python-Levenshtein")
14809 (synopsis "Fast computation of Levenshtein distance and string similarity")
14810 (description
14811 "The Levenshtein Python C extension module contains functions for fast computation of
14812 @enumerate
14813 @item Levenshtein (edit) distance, and edit operations
14814 @item string similarity
14815 @item approximate median strings, and generally string averaging
14816 @item string sequence and set similarity
14817 @end enumerate
14818 It supports both normal and Unicode strings.")
14819 (license license:gpl2+)))
14820
14821 (define-public python2-levenshtein
14822 (package-with-python2 python-levenshtein))
14823
14824 (define-public python-scandir
14825 (package
14826 (name "python-scandir")
14827 (version "1.4")
14828 (source
14829 (origin
14830 (method url-fetch)
14831 (uri (pypi-uri "scandir" version))
14832 (sha256
14833 (base32 "0yjrgp0mxp3d8bjkq2m1ac2ys8n76wykksvgyjrnil9gr3fx7a5d"))))
14834 (build-system python-build-system)
14835 (home-page "https://github.com/benhoyt/scandir")
14836 (synopsis "Directory iteration function")
14837 (description
14838 "Directory iteration function like os.listdir(), except that instead of
14839 returning a list of bare filenames, it yields DirEntry objects that include
14840 file type and stat information along with the name. Using scandir() increases
14841 the speed of os.walk() by 2-20 times (depending on the platform and file
14842 system) by avoiding unnecessary calls to os.stat() in most cases.")
14843 (license license:bsd-3)))
14844
14845 (define-public python2-scandir
14846 (package-with-python2 python-scandir))
14847
14848 (define-public python2-stemming
14849 (package
14850 (name "python2-stemming")
14851 (version "1.0.1")
14852 (source
14853 (origin
14854 (method url-fetch)
14855 (uri (pypi-uri "stemming" version))
14856 (sha256
14857 (base32 "0ldwa24gnnxhniv0fhygkpc2mwgd93q10ag8rvzayv6hw418frsr"))))
14858 (build-system python-build-system)
14859 (arguments
14860 `(#:python ,python-2))
14861 (home-page "https://bitbucket.org/mchaput/stemming/overview")
14862 (synopsis "Python implementations of various stemming algorithms")
14863 (description
14864 "Python implementations of the Porter, Porter2, Paice-Husk, and Lovins
14865 stemming algorithms for English. These implementations are straightforward and
14866 efficient, unlike some Python versions of the same algorithms available on the
14867 Web. This package is an extraction of the stemming code included in the Whoosh
14868 search engine.")
14869 (license license:public-domain)))
14870
14871 (define-public python-factory-boy
14872 (package
14873 (name "python-factory-boy")
14874 (version "2.8.1")
14875 (source
14876 (origin
14877 (method url-fetch)
14878 (uri (pypi-uri "factory_boy" version))
14879 (sha256
14880 (base32 "1fvin6san5xsjh2c4y18caj2lnmwxlylyqm8mh1yc6rp38wlwr56"))))
14881 (build-system python-build-system)
14882 (arguments
14883 ;; Tests are not included in the tarball.
14884 `(#:tests? #f))
14885 (propagated-inputs
14886 `(("faker" ,python-faker)))
14887 (home-page "https://github.com/benhoyt/scandir")
14888 (synopsis "Versatile test fixtures replacement")
14889 (description
14890 "Factory_boy is a fixtures replacement based on thoughtbot’s factory_girl.
14891
14892 As a fixtures replacement tool, it aims to replace static, hard to maintain
14893 fixtures with easy-to-use factories for complex object.
14894
14895 Instead of building an exhaustive test setup with every possible combination
14896 of corner cases, factory_boy allows you to use objects customized for the
14897 current test, while only declaring the test-specific fields")
14898 (license license:expat)))
14899
14900 (define-public python2-factory-boy
14901 (package-with-python2 python-factory-boy))
14902
14903 (define-public python-translate-toolkit
14904 (package
14905 (name "python-translate-toolkit")
14906 (version "2.1.0")
14907 (source
14908 (origin
14909 (method url-fetch)
14910 (uri (pypi-uri "translate-toolkit" version ".tar.bz2"))
14911 (sha256
14912 (base32 "1vlkwrg83vb17jc36pmwh2b7jphwf390lz0jw8hakcg16qhwypvq"))))
14913 (build-system python-build-system)
14914 (native-inputs
14915 `(("python-pytest" ,python-pytest)
14916 ("python-sphinx" ,python-sphinx)))
14917 (propagated-inputs
14918 `(("python-babel" ,python-babel)
14919 ("python-beautifulsoup4" ,python-beautifulsoup4)
14920 ("python-chardet" ,python-chardet)
14921 ("python-diff-match-patch" ,python-diff-match-patch)
14922 ("python-levenshtein" ,python-levenshtein)
14923 ("python-lxml" ,python-lxml)
14924 ("python-six" ,python-six)
14925 ("python-vobject" ,python-vobject)
14926 ("python-pyyaml" ,python-pyyaml)))
14927 (arguments
14928 ;; TODO: tests are not run, because they end with
14929 ;; TypeError: parse() missing 2 required positional arguments: 'tree' and
14930 ;; 'parse_funcs'
14931 ;; during test setup.
14932 `(#:tests? #f))
14933 (home-page "http://toolkit.translatehouse.org")
14934 (synopsis "Tools and API for translation and localization engineering")
14935 (description
14936 "Tools and API for translation and localization engineering. It contains
14937 several utilities, as well as an API for building localization tools.")
14938 (license license:gpl2+)))
14939
14940 (define-public python2-translate-toolkit
14941 (package-with-python2 python-translate-toolkit))
14942
14943 (define-public python-mysqlclient
14944 (package
14945 (name "python-mysqlclient")
14946 (version "1.3.10")
14947 (source
14948 (origin
14949 (method url-fetch)
14950 (uri (pypi-uri "mysqlclient" version))
14951 (sha256
14952 (base32
14953 "0qkj570x4rbsblji6frvsvp2v1ap32dqzj1lq62zp9515ffsyaj5"))))
14954 (build-system python-build-system)
14955 (native-inputs
14956 `(("mariadb" ,mariadb)
14957 ("nose" ,python-nose)
14958 ("mock" ,python-mock)
14959 ("py.test" ,python-pytest)))
14960 (inputs
14961 `(("mysql" ,mysql)
14962 ("libz" ,zlib)
14963 ("openssl" ,openssl)))
14964 (home-page "https://github.com/PyMySQL/mysqlclient-python")
14965 (synopsis "MySQLdb is an interface to the popular MySQL database server for Python")
14966 (description "MySQLdb is an interface to the popular MySQL database server
14967 for Python. The design goals are:
14968 @enumerate
14969 @item Compliance with Python database API version 2.0 [PEP-0249],
14970 @item Thread-safety,
14971 @item Thread-friendliness (threads will not block each other).
14972 @end enumerate")
14973 (license license:gpl2)))
14974
14975 (define-public python2-mysqlclient
14976 (package-with-python2 python-mysqlclient))
14977
14978 (define-public python-hiredis
14979 (package
14980 (name "python-hiredis")
14981 (version "0.2.0")
14982 (source
14983 (origin
14984 (method url-fetch)
14985 (uri (pypi-uri "hiredis" version))
14986 (sha256
14987 (base32
14988 "1dfm2k9l9zar9nw9fwmm74zrgraxdxs04vx9li56fjcf289qx5fa"))))
14989 (build-system python-build-system)
14990 (arguments
14991 ;; no tests
14992 `(#:tests? #f))
14993 (home-page "https://github.com/redis/hiredis-py")
14994 (synopsis "Python extension that wraps protocol parsing code in hiredis")
14995 (description "Python-hiredis is a python extension that wraps protocol
14996 parsing code in hiredis. It primarily speeds up parsing of multi bulk replies.")
14997 (license license:bsd-3)))
14998
14999 (define-public python2-hiredis
15000 (package-with-python2 python-hiredis))
15001
15002 (define-public python-fakeredis
15003 (package
15004 (name "python-fakeredis")
15005 (version "0.8.2")
15006 (source
15007 (origin
15008 (method url-fetch)
15009 (uri (pypi-uri "fakeredis" version))
15010 (sha256
15011 (base32
15012 "0zncahj3byyasyfx9i7k991ph0n0lq8v3a21pqri5qxn9564bk9r"))))
15013 (build-system python-build-system)
15014 (arguments
15015 ;; no tests
15016 `(#:tests? #f))
15017 (home-page "https://github.com/jamesls/fakeredis")
15018 (synopsis "Fake implementation of redis API for testing purposes")
15019 (description "Fakeredis is a pure python implementation of the redis-py
15020 python client that simulates talking to a redis server. This was created for a
15021 single purpose: to write unittests. Setting up redis is not hard, but many time
15022 you want to write unittests that do not talk to an external server (such as
15023 redis). This module now allows tests to simply use this module as a reasonable
15024 substitute for redis.")
15025 (license license:bsd-3)))
15026
15027 (define-public python2-fakeredis
15028 (package-with-python2 python-fakeredis))
15029
15030 (define-public python-behave-web-api
15031 (package
15032 (name "python-behave-web-api")
15033 (version "1.0.6")
15034 (source
15035 (origin
15036 (method url-fetch)
15037 (uri (pypi-uri "behave-web-api" version))
15038 (sha256
15039 (base32
15040 "03kpq2xsy1gab3jy0dccbxlsg7vwfy4lagss0qldwmx3xz6b3i19"))))
15041 (build-system python-build-system)
15042 (arguments
15043 `(#:phases
15044 (modify-phases %standard-phases
15045 (add-after 'unpack 'fix-dependencies
15046 (lambda _
15047 (substitute* "setup.py"
15048 (("'wheel'") "") ; We don't use it.
15049 (("'ordereddict==1.1'") ""))))))) ; Python >= 2.7 has it built-in.
15050 (propagated-inputs
15051 `(("behave" ,behave)
15052 ("python-requests" ,python-requests)))
15053 (home-page "https://github.com/jefersondaniel/behave-web-api")
15054 (synopsis "Provides testing for JSON APIs with Behave for Python")
15055 (description "This package provides testing utility modules for testing
15056 JSON APIs with Behave.")
15057 (license license:expat)))
15058
15059 (define-public python2-behave-web-api
15060 (package-with-python2 python-behave-web-api))
15061
15062 (define-public python-flask-script
15063 (package
15064 (name "python-flask-script")
15065 (version "2.0.5")
15066 (source
15067 (origin
15068 (method url-fetch)
15069 (uri (pypi-uri "Flask-Script" version))
15070 (sha256
15071 (base32
15072 "0zqh2yq8zk7m9b4xw1ryqmrljkdigfb3hk5155a3b5hkfnn6xxyf"))))
15073 (build-system python-build-system)
15074 (propagated-inputs
15075 `(("python-flask" ,python-flask)
15076 ("python-argcomplete" ,python-argcomplete)
15077 ("python-werkzeug" ,python-werkzeug)))
15078 (native-inputs
15079 `(("python-pytest" ,python-pytest)))
15080 (home-page
15081 "http://github.com/smurfix/flask-script")
15082 (synopsis "Scripting support for Flask")
15083 (description "The Flask-Script extension provides support for writing
15084 external scripts in Flask. This includes running a development server,
15085 a customised Python shell, scripts to set up your database, cronjobs,
15086 and other command-line tasks that belong outside the web application
15087 itself.")
15088 (license license:bsd-3)))
15089
15090 (define-public python2-flask-script
15091 (package-with-python2 python-flask-script))
15092
15093 (define-public python-flask-migrate
15094 (package
15095 (name "python-flask-migrate")
15096 (version "2.0.3")
15097 (source
15098 (origin
15099 (method url-fetch)
15100 (uri (pypi-uri "Flask-Migrate" version))
15101 (sha256
15102 (base32
15103 "107x78lkqsnbg92dld3dkagg07jvchp3ib3y0sivc4ipz6n1y7rk"))))
15104 (build-system python-build-system)
15105 (propagated-inputs
15106 `(("python-flask" ,python-flask)
15107 ("python-alembic" ,python-alembic)
15108 ("python-sqlalchemy" ,python-sqlalchemy)
15109 ("python-flask-script" ,python-flask-script)
15110 ("python-flask-sqlalchemy" ,python-flask-sqlalchemy)))
15111 (home-page "http://github.com/miguelgrinberg/flask-migrate/")
15112 (synopsis "SQLAlchemy database migrations for Flask programs using
15113 Alembic")
15114 (description "This package contains SQLAlchemy database migration tools
15115 for Flask programs that are using @code{python-alembic}.")
15116 (license license:expat)))
15117
15118 (define-public python2-flask-migrate
15119 (package-with-python2 python-flask-migrate))
15120
15121 (define-public python-packaging
15122 (package
15123 (name "python-packaging")
15124 (version "16.8")
15125 (source
15126 (origin
15127 (method url-fetch)
15128 (uri (pypi-uri "packaging" version))
15129 (sha256
15130 (base32
15131 "17k1xbjshackwvbsnxqixbph8rbqhz4bf4g3al5xyzhavxgq6l2x"))))
15132 (build-system python-build-system)
15133 (native-inputs
15134 `(("python-pretend" ,python-pretend)
15135 ("python-pytest" ,python-pytest)))
15136 (propagated-inputs
15137 `(("python-pyparsing" ,python-pyparsing)
15138 ("python-six" ,python-six)))
15139 (home-page "https://github.com/pypa/packaging")
15140 (synopsis "Core utilities for Python packages")
15141 (description "Packaging is a Python module for dealing with Python packages.
15142 It offers an interface for working with package versions, names, and dependency
15143 information.")
15144 ;; From 'LICENSE': This software is made available under the terms of
15145 ;; *either* of the licenses found in LICENSE.APACHE or LICENSE.BSD.
15146 ;; Contributions to this software is made under the terms of *both* these
15147 ;; licenses.
15148 (license (list license:asl2.0 license:bsd-2))))
15149
15150 (define-public python2-packaging
15151 (package-with-python2 python-packaging))
15152
15153 (define-public python-sql
15154 (package
15155 (name "python-sql")
15156 (version "0.9")
15157 (source
15158 (origin
15159 (method url-fetch)
15160 (uri (pypi-uri "python-sql" version))
15161 (sha256
15162 (base32
15163 "0p6kaqj02vz0habmdx37zjk6hjxdfm8aw737zs059vvpr70ird87"))))
15164 (build-system python-build-system)
15165 (home-page "https://python-sql.tryton.org/")
15166 (synopsis "Library to write SQL queries in a pythonic way")
15167 (description "@code{python-sql} is a library to write SQL queries, that
15168 transforms idiomatic python function calls to well-formed SQL queries.")
15169 (license license:bsd-3)))
15170
15171 (define-public python2-sql
15172 (package-with-python2 python-sql))
15173
15174 (define-public python-genshi
15175 (package
15176 (name "python-genshi")
15177 (version "0.7")
15178 (source
15179 (origin
15180 (method url-fetch)
15181 (uri (string-append
15182 "https://ftp.edgewall.org/pub/genshi/Genshi-"
15183 version ".tar.gz"))
15184 (patches
15185 (search-patches
15186 ;; The first 4 patches are in the master branch upstream.
15187 ;; See this as a reference https://genshi.edgewall.org/ticket/582
15188 ;; The last 2 are NOT in any branch.
15189 ;; They were sent as attachments to a ticket opened at
15190 ;; https://genshi.edgewall.org/ticket/602#no1
15191 "python-genshi-stripping-of-unsafe-script-tags.patch"
15192 "python-genshi-disable-speedups-on-python-3.3.patch"
15193 "python-genshi-isstring-helper.patch"
15194 "python-genshi-add-support-for-python-3.4-AST.patch"
15195 "python-genshi-fix-tests-on-python-3.5.patch"
15196 "python-genshi-buildable-on-python-2.7.patch"))
15197 (sha256
15198 (base32
15199 "0lkkbp6fbwzv0zda5iqc21rr7rdldkwh3hfabfjl9i4bwq14858x"))))
15200 (build-system python-build-system)
15201 (home-page "https://genshi.edgewall.org/")
15202 (synopsis "Toolkit for generation of output for the web")
15203 (description "Genshi is a Python library that provides an integrated set
15204 of components for parsing, generating, and processing HTML, XML or other
15205 textual content for output generation on the web.")
15206 (license license:bsd-3)))
15207
15208 ;; The linter here claims that patch file names should start with the package
15209 ;; name. But, in this case the patches are inherited from python-genshi with
15210 ;; the "python-genshi-" prefix instead of "python2-genshi-".
15211 (define-public python2-genshi
15212 (package-with-python2 python-genshi))
15213
15214 (define-public python-relatorio
15215 (package
15216 (name "python-relatorio")
15217 (version "0.6.4")
15218 (source
15219 (origin
15220 (method url-fetch)
15221 (uri (pypi-uri "relatorio" version))
15222 (sha256
15223 (base32
15224 "0lincq79mzgazwd9gh41dybjh9c3n87r83pl8nk3j79aihyfk84z"))))
15225 (build-system python-build-system)
15226 (propagated-inputs
15227 `(("python-lxml" ,python-lxml)
15228 ("python-genshi" ,python-genshi)))
15229 (home-page "https://relatorio.tryton.org/")
15230 (synopsis "Templating library able to output ODT and PDF files")
15231 (description "Relatorio is a templating library which provides a way to
15232 easily output ODT, ODS, PNG, SVG and several other kinds of files. Support
15233 for more filetypes can be easily added by creating plugins for them.")
15234 (license license:gpl3+)))
15235
15236 (define-public python2-relatorio
15237 (package-with-python2 python-relatorio))
15238
15239 (define-public python-radon
15240 (package
15241 (name "python-radon")
15242 (version "1.5.0")
15243 (source
15244 (origin
15245 (method url-fetch)
15246 (uri (pypi-uri "radon" version))
15247 (sha256
15248 (base32
15249 "1h6jv36am0i827182a04ki6291lyx4kp957xfr5njgprj4nd0qsl"))))
15250 (build-system python-build-system)
15251 (propagated-inputs
15252 `(("python-colorama" ,python-colorama)
15253 ("python-flake8-polyfill" ,python-flake8-polyfill)
15254 ("python-mando" ,python-mando-0.3.1)))
15255 (native-inputs
15256 `(("python-flake8" ,python-flake8)
15257 ("python-tox" ,python-tox)
15258 ("python-pytest" ,python-pytest)
15259 ("python-paramunittest" ,python-paramunittest)))
15260 (home-page "https://radon.readthedocs.org/")
15261 (synopsis "Code Metrics in Python")
15262 (description "Radon is a Python tool which computes various code metrics.
15263 Supported metrics are:
15264 @itemize @bullet
15265 @item raw metrics: SLOC, comment lines, blank lines, &c.
15266 @item Cyclomatic Complexity (i.e. McCabe’s Complexity)
15267 @item Halstead metrics (all of them)
15268 @item the Maintainability Index (a Visual Studio metric)
15269 @end itemize")
15270 (license license:expat)))
15271
15272 (define-public python2-radon
15273 (package-with-python2 python-radon))
15274
15275 (define-public python-sure
15276 (package
15277 (name "python-sure")
15278 (version "1.4.6")
15279 (source
15280 (origin
15281 (method url-fetch)
15282 (uri (pypi-uri "sure" version))
15283 (sha256
15284 (base32
15285 "1iyqsy2d6radi88g1qf0lziy5b39h5cpb3g5jiqyb4xi46ig3x1z"))))
15286 (build-system python-build-system)
15287 (propagated-inputs
15288 `(("python-mock" ,python-mock)
15289 ("python-six" ,python-six)))
15290 (native-inputs
15291 `(("python-nose" ,python-nose)))
15292 (home-page "https://github.com/gabrielfalcao/sure")
15293 (synopsis "Automated testing library in python for python")
15294 (description
15295 "Sure is a python library that leverages a DSL for writing assertions.
15296 Sure is heavily inspired by @code{RSpec Expectations} and @code{should.js}.")
15297 (license license:gpl3+)))
15298
15299 (define-public python2-sure
15300 (package-with-python2 python-sure))
15301
15302 (define-public python2-couleur
15303 ;; This package does not seem to support python3 at all, hence,
15304 ;; only the python2 variant definition is provided.
15305 (package
15306 (name "python2-couleur")
15307 (version "0.6.2")
15308 (source
15309 (origin
15310 (method url-fetch)
15311 (uri (pypi-uri "couleur" version))
15312 (sha256
15313 (base32
15314 "1qqaxyqz74wvid0cr119dhcwz0h0if5b5by44zl49pd5z65v58k1"))))
15315 (build-system python-build-system)
15316 (arguments
15317 `(#:python ,python-2))
15318 (home-page "https://github.com/gabrielfalcao/couleur")
15319 (synopsis
15320 "ANSI terminal tool for python, colored shell and other handy fancy features")
15321 (description
15322 "@code{Couleur} provides python programs a way to use the ANSI features in a unix
15323 terminal such as coloured output in the shell, overwriting output, indentation, etc.")
15324 ;; README.md says ASL2.0, but all source code headers are LGPL3+.
15325 ;; https://github.com/gabrielfalcao/couleur/issues/11
15326 (license license:lgpl3+)))
15327
15328 (define-public python-misaka
15329 (package
15330 (name "python-misaka")
15331 (version "2.1.0")
15332 (source
15333 (origin
15334 (method url-fetch)
15335 (uri (pypi-uri "misaka" version))
15336 (sha256
15337 (base32
15338 "1yqrq3a5rracirmvk52n28nn6ckdaz897gnigv89a9gmyn87sqw7"))))
15339 (build-system python-build-system)
15340 (arguments
15341 `(;; Line 37 of setup.py calls self.run_command('develop')
15342 ;; in the 'check' phase. This command seems to be trying
15343 ;; to write to
15344 ;; /gnu/store/...-python-<version>/lib/python<version>/site-packages/
15345 ;; for which it does not have the permission to write.
15346 #:tests? #f))
15347 (propagated-inputs
15348 `(("python-cffi" ,python-cffi)))
15349 (home-page "https://github.com/FSX/misaka")
15350 (synopsis "Python binding for Hoedown")
15351 (description
15352 "@code{Misaka} is a CFFI-based binding for @code{Hoedown}, a fast markdown processing
15353 library written in C. It features a fast HTML renderer and functionality to make custom
15354 renderers (e.g. man pages or LaTeX).")
15355 (license license:expat)))
15356
15357 (define-public python2-misaka
15358 (package-with-python2 python-misaka))
15359
15360 (define-public python2-steadymark
15361 ;; This is forced into being a python2 only variant
15362 ;; due to its dependence on couleur that has no support
15363 ;; for python3
15364 (package
15365 (name "python2-steadymark")
15366 (version "0.7.3")
15367 (source
15368 (origin
15369 (method url-fetch)
15370 (uri (pypi-uri "steadymark" version))
15371 (sha256
15372 (base32
15373 "1640i9g8dycql3cc8j0bky0jkzj0q39blfbp4lsgpkprkfgcdk8v"))))
15374 (build-system python-build-system)
15375 (native-inputs
15376 `(("python-couleur" ,python2-couleur)
15377 ("python-sure" ,python2-sure)
15378 ("python-misaka" ,python2-misaka)))
15379 (arguments
15380 `(#:python ,python-2
15381 #:phases
15382 (modify-phases %standard-phases
15383 (add-before 'build 'patch-setup-py
15384 (lambda _
15385 ;; Update requirements from dependency==version
15386 ;; to dependency>=version
15387 (substitute* "setup.py"
15388 (("==") ">="))
15389 #t)))))
15390 (home-page "https://github.com/gabrielfalcao/steadymark")
15391 (synopsis "Markdown-based test runner for python")
15392 (description
15393 "@code{Steadymark} allows documentation to be written in github-flavoured
15394 markdown. The documentation may contain snippets of code surrounded by python
15395 code blocks and @code{Steadymark} will find these snippets and run them, making
15396 sure that there are no old malfunctional examples in the documentation examples.")
15397 (license license:expat)))
15398
15399 (define-public python-nose-randomly
15400 (package
15401 (name "python-nose-randomly")
15402 (version "1.2.5")
15403 (source
15404 (origin
15405 (method url-fetch)
15406 (uri (pypi-uri "nose-randomly" version))
15407 (sha256
15408 (base32
15409 "1cw9dlr1zh3w4i438kin7z0rm8092ki52hayisyc43h9pcplq7rn"))))
15410 (build-system python-build-system)
15411 (native-inputs
15412 `(("python-nose" ,python-nose)
15413 ("python-numpy" ,python-numpy)))
15414 (home-page "https://github.com/adamchainz/nose-randomly")
15415 (synopsis
15416 "Nose plugin to randomly order tests and control random.seed")
15417 (description
15418 "This is a @code{Nose} plugin to randomly order tests which can be quite
15419 powerful in discovering hidden flaws in the tests themselves, while helping to
15420 reduce inter-test dependencies. It also helps in controlling @code{random.seed},
15421 by resetting it to a repeatable number for each test, enabling the tests to
15422 create data based on random numbers and yet remain repeatable.")
15423 (license license:bsd-3)))
15424
15425 (define-public python2-nose-randomly
15426 (package-with-python2 python-nose-randomly))
15427
15428 (define-public python-jsonpointer
15429 (package
15430 (name "python-jsonpointer")
15431 (version "1.10")
15432 (source
15433 (origin
15434 (method url-fetch)
15435 (uri (pypi-uri "jsonpointer" version))
15436 (sha256
15437 (base32
15438 "1cg0gvgqjysydv6p45v4jywg1jb3v48c7m3cbpi57zgf6nndr9cz"))))
15439 (build-system python-build-system)
15440 (home-page "https://github.com/stefankoegl/python-json-pointer")
15441 (synopsis "Identify specific nodes in a JSON document")
15442 (description "@code{jsonpointer} allows you to access specific nodes
15443 by path in a JSON document (see RFC 6901).")
15444 (license license:bsd-3)))
15445
15446 (define-public python2-jsonpointer
15447 (package-with-python2 python-jsonpointer))
15448
15449 (define-public python-jsonpatch
15450 (package
15451 (name "python-jsonpatch")
15452 (version "1.16")
15453 (source
15454 (origin
15455 (method url-fetch)
15456 ;; pypi version lacks tests.js
15457 (uri (string-append "https://github.com/stefankoegl/python-json-patch/"
15458 "archive/v" version ".tar.gz"))
15459 (file-name (string-append name "-" version ".tar.gz"))
15460 (sha256
15461 (base32
15462 "085ykisl8v7mv9h7hvhdy3l2fjzs4214gx32r5k6nx4f76hbv6y5"))))
15463 (build-system python-build-system)
15464 (native-inputs
15465 `(("python-jsonpointer" ,python-jsonpointer)))
15466 (home-page "https://github.com/stefankoegl/python-json-patch")
15467 (synopsis "Applying JSON Patches in Python 2.6+ and 3.x")
15468 (description "@code{jsonpatch} is a library and program that allows
15469 applying JSON Patches according to RFC 6902.")
15470 (license license:bsd-3)))
15471
15472 (define-public python2-jsonpatch
15473 (package-with-python2 python-jsonpatch))
15474
15475 (define-public python-jsonpatch-0.4
15476 (package (inherit python-jsonpatch)
15477 (name "python-jsonpatch")
15478 (version "0.4")
15479 (source
15480 (origin
15481 (method url-fetch)
15482 (uri (string-append "https://github.com/stefankoegl/python-json-patch/"
15483 "archive/v" version ".tar.gz"))
15484 (file-name (string-append name "-" version ".tar.gz"))
15485 (sha256
15486 (base32
15487 "0j0cd9z9zyp8kppp464jxrfgrnbgkzl1yi10i5gsv8yz6d95929d"))))))
15488
15489 (define-public python2-jsonpatch-0.4
15490 (package-with-python2 python-jsonpatch-0.4))
15491
15492 (define-public python-rfc3987
15493 (package
15494 (name "python-rfc3987")
15495 (version "1.3.7")
15496 (source
15497 (origin
15498 (method url-fetch)
15499 (uri (pypi-uri "rfc3987" version))
15500 (sha256
15501 (base32
15502 "192pclzs2y0yaywqkrlvd0x73740q310kvqvm6jldhi619mq59wi"))))
15503 (build-system python-build-system)
15504 (home-page "http://pypi.python.org/pypi/rfc3987")
15505 (synopsis "Parsing and validation of URIs (RFC 3986) and IRIs (RFC 3987)")
15506 (description "@code{rfc3987} provides routines for parsing and
15507 validation of URIs (see RFC 3986) and IRIs (see RFC 3987).")
15508 (license license:gpl3+)))
15509
15510 (define-public python2-rfc3987
15511 (package-with-python2 python-rfc3987))
15512
15513 (define-public python-validate-email
15514 (package
15515 (name "python-validate-email")
15516 (version "1.3")
15517 (source
15518 (origin
15519 (method url-fetch)
15520 (uri (pypi-uri "validate_email" version))
15521 (sha256
15522 (base32
15523 "1bxffaf5yz2cph8ki55vdvdypbwkvn2xr1firlcy62vqbzf1jivq"))))
15524 (build-system python-build-system)
15525 (home-page "http://github.com/syrusakbary/validate_email")
15526 (synopsis "Verifies if an email address is valid and really exists")
15527 (description "@code{validate_email} can be used to verify if an email
15528 address is valid and really exists.")
15529 (license license:lgpl3+)))
15530
15531 (define-public python2-validate-email
15532 (package-with-python2 python-validate-email))
15533
15534 (define-public python-flex
15535 (package
15536 (name "python-flex")
15537 (version "6.10.0")
15538 (source
15539 (origin
15540 (method url-fetch)
15541 (uri (pypi-uri "flex" version))
15542 (sha256
15543 (base32
15544 "00pamnwla3khk8nyla7y28dq9jnh69swd7f4jfsl7sn1izs8n8zk"))))
15545 (build-system python-build-system)
15546 (propagated-inputs
15547 `(("python-click" ,python-click)
15548 ("python-iso8601" ,python-iso8601)
15549 ("python-jsonpointer" ,python-jsonpointer)
15550 ("python-pyyaml" ,python-pyyaml)
15551 ("python-requests" ,python-requests)
15552 ("python-rfc3987" ,python-rfc3987)
15553 ("python-six" ,python-six)
15554 ("python-validate-email" ,python-validate-email)))
15555 (home-page "https://github.com/pipermerriam/flex")
15556 (synopsis "Validates Swagger schemata")
15557 (description "@code{flex} can be used to validate Swagger schemata.")
15558 (license license:bsd-3)))
15559
15560 (define-public python2-flex
15561 (package-with-python2 python-flex))
15562
15563 (define-public python-marshmallow
15564 (package
15565 (name "python-marshmallow")
15566 (version "3.0.0b2")
15567 (source
15568 (origin
15569 (method url-fetch)
15570 (uri (pypi-uri "marshmallow" version))
15571 (sha256
15572 (base32
15573 "11bnpvfdbczr74177p295zbkdrax2cahvbj5bqhhlprgz2xxi5d9"))))
15574 (build-system python-build-system)
15575 (propagated-inputs
15576 `(("python-dateutil" ,python-dateutil)
15577 ("python-simplejson" ,python-simplejson)))
15578 (native-inputs
15579 `(("python-pytest-3.0" ,python-pytest-3.0)
15580 ("python-pytz" ,python-pytz)))
15581 (home-page "https://github.com/marshmallow-code/marshmallow")
15582 (synopsis "Convert complex datatypes to and from native
15583 Python datatypes.")
15584 (description "@code{marshmallow} provides a library for converting
15585 complex datatypes to and from native Python datatypes.")
15586 (license license:expat)))
15587
15588 (define-public python2-marshmallow
15589 (package-with-python2 python-marshmallow))
15590
15591 (define-public python-bottle
15592 (package
15593 (name "python-bottle")
15594 (version "0.12.13")
15595 (source
15596 (origin
15597 (method url-fetch)
15598 (uri (pypi-uri "bottle" version))
15599 (sha256
15600 (base32
15601 "0m9k2a7yxvggc4kw8fsvj381vgsvfcdshg5nzy6vwrxiw2p53drr"))))
15602 (build-system python-build-system)
15603 (home-page "http://bottlepy.org/")
15604 (synopsis "WSGI framework for small web-applications.")
15605 (description "@code{python-bottle} is a WSGI framework for small web-applications.")
15606 (license license:expat)))
15607
15608 (define-public python2-bottle
15609 (package-with-python2 python-bottle))
15610
15611 (define-public python-apispec
15612 (package
15613 (name "python-apispec")
15614 (version "0.22.0")
15615 (source
15616 (origin
15617 (method url-fetch)
15618 (uri (pypi-uri "apispec" version))
15619 (sha256
15620 (base32
15621 "0y3jxmgp2d24am3hxl40f5rw9abb0r8037sagax3dv64h4n1azwq"))))
15622 (build-system python-build-system)
15623 (propagated-inputs
15624 `(("python-pyyaml" ,python-pyyaml)))
15625 (native-inputs
15626 `(("python-pytest-3.0" ,python-pytest-3.0)
15627 ("python-flask" ,python-flask)
15628 ("python-marshmallow" ,python-marshmallow)
15629 ("python-tornado" ,python-tornado)
15630 ("python-bottle" ,python-bottle)
15631 ("python-mock" ,python-mock)))
15632 (home-page "https://github.com/marshmallow-code/apispec")
15633 (synopsis "Swagger 2.0 API specification generator")
15634 (description "@code{python-apispec} is a pluggable API specification
15635 generator. Currently supports the OpenAPI specification (f.k.a.
15636 Swagger 2.0).")
15637 (license license:expat)))
15638
15639 (define-public python2-apispec
15640 (package-with-python2 python-apispec))
15641
15642 (define-public python-flasgger
15643 (package
15644 (name "python-flasgger")
15645 (version "0.6.3")
15646 (source
15647 (origin
15648 (method url-fetch)
15649 (uri (string-append "https://github.com/rochacbruno/flasgger/archive/"
15650 version ".tar.gz"))
15651 (file-name (string-append name "-" version ".tar.gz"))
15652 (sha256
15653 (base32
15654 "1gqzlm0rb55fdpsy5ipkganlx9cnpi454fqyycr03jm22zql14ay"))))
15655 (build-system python-build-system)
15656 (arguments
15657 `(#:phases
15658 (modify-phases %standard-phases
15659 (replace 'check
15660 (lambda* (#:key inputs outputs #:allow-other-keys)
15661 (substitute* "Makefile"
15662 (("flake8 flasgger --ignore=F403")
15663 "flake8 flasgger --ignore=E731,F403"))
15664 (setenv "PYTHONPATH" (string-append (getcwd)
15665 ":"
15666 (getenv "PYTHONPATH")))
15667 (zero? (system* "py.test")))))))
15668 (propagated-inputs
15669 `(("python-flask" ,python-flask)
15670 ("python-pyyaml" ,python-pyyaml)
15671 ("python-jsonschema" ,python-jsonschema)
15672 ("python-mistune" ,python-mistune)
15673 ("python-six" ,python-six)))
15674 (native-inputs
15675 `(("python-decorator" ,python-decorator)
15676 ("python-flake8" ,python-flake8)
15677 ("python-flask-restful" ,python-flask-restful)
15678 ("python-flex" ,python-flex)
15679 ("python-pytest-3.0" ,python-pytest-3.0)
15680 ("python-pytest-cov" ,python-pytest-cov)
15681 ("python-marshmallow" ,python-marshmallow)
15682 ("python-apispec" ,python-apispec)))
15683 (home-page "https://github.com/rochacbruno/flasgger/")
15684 (synopsis "Extract Swagger specs from your Flask project")
15685 (description "@code{python-flasgger} allows extracting Swagger specs
15686 from your Flask project. It is a fork of Flask-Swagger.")
15687 (license license:expat)))
15688
15689 (define-public python2-flasgger
15690 (package-with-python2 python-flasgger))
15691
15692 (define-public python-swagger-spec-validator
15693 (package
15694 (name "python-swagger-spec-validator")
15695 (version "2.1.0")
15696 (source
15697 (origin
15698 (method url-fetch)
15699 (uri (pypi-uri "swagger-spec-validator" version))
15700 (sha256
15701 (base32
15702 "13hkpn2lycwr0468yqhjb3kwszqf7hjwlq61w7vdxq1caz31k4nw"))))
15703 (build-system python-build-system)
15704 (propagated-inputs
15705 `(("python-jsonschema" ,python-jsonschema)
15706 ("python-six" ,python-six)))
15707 (home-page
15708 "http://github.com/Yelp/swagger_spec_validator")
15709 (synopsis "Validation of Swagger specifications")
15710 (description "@code{swagger_spec_validator} provides a library for
15711 validating Swagger API specifications.")
15712 (license license:asl2.0)))
15713
15714 (define-public python2-swagger-spec-validator
15715 (package-with-python2 python-swagger-spec-validator))
15716
15717 (define-public python-apache-libcloud
15718 (package
15719 (name "python-apache-libcloud")
15720 (version "2.0.0")
15721 (source
15722 (origin
15723 (method url-fetch)
15724 (uri (pypi-uri "apache-libcloud" version))
15725 (sha256
15726 (base32
15727 "1a71z02ckcxld72k4qgmdnkjan52c4wczncs3p2mp5yafh7dsan7"))))
15728 (build-system python-build-system)
15729 (arguments
15730 `(#:phases
15731 (modify-phases %standard-phases
15732 (add-after 'unpack 'patch-ssh
15733 (lambda* (#:key inputs #:allow-other-keys)
15734 (substitute* "libcloud/compute/ssh.py"
15735 (("'ssh'") (string-append "'" (assoc-ref inputs "openssh")
15736 "/bin/ssh" "'")))
15737 #t))
15738 (add-after 'unpack 'patch-tests
15739 (lambda _
15740 (substitute* "./libcloud/test/test_file_fixtures.py"
15741 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-923>.
15742 (("def _ascii") "def _raw_data(self, method, url, body, headers):
15743 return (httplib.OK,
15744 \"1234abcd\",
15745 {\"test\": \"value\"},
15746 httplib.responses[httplib.OK])
15747 def _ascii"))
15748 (substitute* "libcloud/test/compute/test_ssh_client.py"
15749 (("class ShellOutSSHClientTests")
15750 "@unittest.skip(\"Guix container doesn't have ssh service\")
15751 class ShellOutSSHClientTests")
15752 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-924>.
15753 (("'.xf0.x90.x8d.x88'") "b'\\xF0\\x90\\x8D\\x88'")
15754 (("'.xF0', '.x90', '.x8D', '.x88'")
15755 "b'\\xF0', b'\\x90', b'\\x8D', b'\\x88'"))
15756 #t)))))
15757 (inputs
15758 `(("openssh" ,openssh)))
15759 (propagated-inputs
15760 `(("python-paramiko" ,python-paramiko)
15761 ("python-requests" ,python-requests)))
15762 (native-inputs
15763 `(("python-lockfile" ,python-lockfile)
15764 ("python-mock" ,python-mock)
15765 ("python-requests-mock" ,python-requests-mock)))
15766 (home-page "https://libcloud.apache.org/")
15767 (synopsis "Unified Cloud API")
15768 (description "@code{libcloud} is a Python library for interacting with
15769 many of the popular cloud service providers using a unified API.")
15770 (license license:asl2.0)))
15771
15772 (define-public python2-apache-libcloud
15773 (package-with-python2 python-apache-libcloud))
15774
15775 (define-public python-smmap2
15776 (package
15777 (name "python-smmap2")
15778 (version "2.0.3")
15779 (source
15780 (origin
15781 (method url-fetch)
15782 (uri (pypi-uri "smmap2" version))
15783 (sha256
15784 (base32
15785 "1hvn28p3zvxa98sbi9lrqvv2ps4q284j4jq9a619zw0m7yv0sly7"))))
15786 (build-system python-build-system)
15787 (native-inputs
15788 `(("python-nosexcover" ,python-nosexcover)))
15789 (home-page "https://github.com/Byron/smmap")
15790 (synopsis "Python sliding window memory map manager")
15791 (description "@code{smmap2} is a pure Python implementation of a sliding
15792 window memory map manager.")
15793 (license license:bsd-3)))
15794
15795 (define-public python2-smmap2
15796 (package-with-python2 python-smmap2))
15797
15798 (define-public python-regex
15799 (package
15800 (name "python-regex")
15801 (version "2017.06.07")
15802 (source (origin
15803 (method url-fetch)
15804 (uri (pypi-uri "regex" version))
15805 (sha256
15806 (base32
15807 "06r6b7yigikbj3a72whl85r2b64pj1r0ypmw9yalmkm0wnxq8mz4"))))
15808 (build-system python-build-system)
15809 (home-page "https://bitbucket.org/mrabarnett/mrab-regex")
15810 (synopsis "Alternative regular expression module")
15811 (description "This regular expression implementation is backwards-
15812 compatible with the standard @code{re} module, but offers additional
15813 functionality like full case-folding for case-insensitive matches in Unicode.")
15814 (license license:psfl)))
15815
15816 (define-public python2-regex
15817 (package-with-python2 python-regex))
15818
15819 (define-public python2-pyopengl
15820 (package
15821 (name "python2-pyopengl")
15822 (version "3.1.0")
15823 (source
15824 (origin
15825 (method url-fetch)
15826 (uri (pypi-uri "PyOpenGL" version))
15827 (sha256
15828 (base32
15829 "1byxjj6a8rwzhxhjqlc588zdad2qwxdd7vlam2653ylll31waiwv"))))
15830 (arguments
15831 `(#:python ,python-2))
15832 (build-system python-build-system)
15833 (home-page "http://pyopengl.sourceforge.net")
15834 (synopsis "Standard OpenGL bindings for Python")
15835 (description
15836 "PyOpenGL is the most common cross platform Python binding to OpenGL and
15837 related APIs. The binding is created using the standard @code{ctypes}
15838 library.")
15839 (license license:bsd-3)))
15840
15841 (define-public python-rencode
15842 (package
15843 (name "python-rencode")
15844 (version "1.0.3")
15845 (source
15846 (origin
15847 (method url-fetch)
15848 (uri (pypi-uri "rencode" version))
15849 (sha256
15850 (base32
15851 "08if5yax1xn5yfp8p3765ccjmfcv9di7i4m5jckgnwvdsgznwkbj"))))
15852 (build-system python-build-system)
15853 (native-inputs `(("pkg-config" ,pkg-config)
15854 ("python-cython", python-cython)))
15855 (home-page "https://github.com/aresch/rencode")
15856 (synopsis "Serialization of heterogeneous data structures")
15857 (description
15858 "The @code{rencode} module is a data structure serialization library,
15859 similar to @code{bencode} from the BitTorrent project. For complex,
15860 heterogeneous data structures with many small elements, r-encoding stake up
15861 significantly less space than b-encodings. This version of rencode is a
15862 complete rewrite in Cython to attempt to increase the performance over the
15863 pure Python module.")
15864 (license license:bsd-3)))
15865
15866 (define-public python2-rencode
15867 (package-with-python2 python-rencode))