gnu: Add python-networkx2.
[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, 2017 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, 2017 Kyle Meyer <kyle@kyleam.com>
19 ;;; Copyright © 2015, 2016 Chris Marusich <cmmarusich@gmail.com>
20 ;;; Copyright © 2016 Danny Milosavljevic <dannym+a@scratchpost.org>
21 ;;; Copyright © 2016 Lukas Gradl <lgradl@openmailbox.org>
22 ;;; Copyright © 2016 Hartmut Goebel <h.goebel@crazy-compilers.com>
23 ;;; Copyright © 2016 Daniel Pimentel <d4n1@d4n1.org>
24 ;;; Copyright © 2016 Sou Bunnbu <iyzsong@gmail.com>
25 ;;; Copyright © 2016, 2017 Troy Sankey <sankeytms@gmail.com>
26 ;;; Copyright © 2016, 2017 ng0 <ng0@infotropique.org>
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 <kkebreau@posteo.net>
45 ;;; Copyright © 2017 Rutger Helling <rhelling@mykolab.com>
46 ;;; Copyright © 2017 Muriithi Frederick Muriuki <fredmanglis@gmail.com>
47 ;;; Copyright © 2017 Brendan Tildesley <brendan.tildesley@openmailbox.org>
48 ;;;
49 ;;; This file is part of GNU Guix.
50 ;;;
51 ;;; GNU Guix is free software; you can redistribute it and/or modify it
52 ;;; under the terms of the GNU General Public License as published by
53 ;;; the Free Software Foundation; either version 3 of the License, or (at
54 ;;; your option) any later version.
55 ;;;
56 ;;; GNU Guix is distributed in the hope that it will be useful, but
57 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
58 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
59 ;;; GNU General Public License for more details.
60 ;;;
61 ;;; You should have received a copy of the GNU General Public License
62 ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
63
64 (define-module (gnu packages python)
65 #:use-module ((guix licenses) #:prefix license:)
66 #:use-module (gnu packages)
67 #:use-module (gnu packages algebra)
68 #:use-module (gnu packages adns)
69 #:use-module (gnu packages attr)
70 #:use-module (gnu packages backup)
71 #:use-module (gnu packages bash)
72 #:use-module (gnu packages check)
73 #:use-module (gnu packages compression)
74 #:use-module (gnu packages crypto)
75 #:use-module (gnu packages databases)
76 #:use-module (gnu packages django)
77 #:use-module (gnu packages file)
78 #:use-module (gnu packages fontutils)
79 #:use-module (gnu packages gcc)
80 #:use-module (gnu packages ghostscript)
81 #:use-module (gnu packages gl)
82 #:use-module (gnu packages glib)
83 #:use-module (gnu packages graphviz)
84 #:use-module (gnu packages graphics)
85 #:use-module (gnu packages gstreamer)
86 #:use-module (gnu packages gtk)
87 #:use-module (gnu packages icu4c)
88 #:use-module (gnu packages image)
89 #:use-module (gnu packages imagemagick)
90 #:use-module (gnu packages libevent)
91 #:use-module (gnu packages libffi)
92 #:use-module (gnu packages linux)
93 #:use-module (gnu packages man)
94 #:use-module (gnu packages maths)
95 #:use-module (gnu packages multiprecision)
96 #:use-module (gnu packages networking)
97 #:use-module (gnu packages ncurses)
98 #:use-module (gnu packages openstack)
99 #:use-module (gnu packages password-utils)
100 #:use-module (gnu packages pcre)
101 #:use-module (gnu packages perl)
102 #:use-module (gnu packages pkg-config)
103 #:use-module (gnu packages protobuf)
104 #:use-module (gnu packages qt)
105 #:use-module (gnu packages readline)
106 #:use-module (gnu packages sdl)
107 #:use-module (gnu packages search)
108 #:use-module (gnu packages shells)
109 #:use-module (gnu packages ssh)
110 #:use-module (gnu packages statistics)
111 #:use-module (gnu packages tex)
112 #:use-module (gnu packages texinfo)
113 #:use-module (gnu packages tls)
114 #:use-module (gnu packages version-control)
115 #:use-module (gnu packages video)
116 #:use-module (gnu packages web)
117 #:use-module (gnu packages base)
118 #:use-module (gnu packages xml)
119 #:use-module (gnu packages xorg)
120 #:use-module (gnu packages xdisorg)
121 #:use-module (gnu packages tcl)
122 #:use-module (gnu packages bdw-gc)
123 #:use-module (guix packages)
124 #:use-module (guix download)
125 #:use-module (guix git-download)
126 #:use-module (guix utils)
127 #:use-module (guix build-system gnu)
128 #:use-module (guix build-system cmake)
129 #:use-module (guix build-system python)
130 #:use-module (guix build-system trivial)
131 #:use-module (srfi srfi-1))
132
133 (define-public python-2.7
134 (package
135 (name "python")
136 (version "2.7.13")
137 (source
138 (origin
139 (method url-fetch)
140 (uri (string-append "https://www.python.org/ftp/python/"
141 version "/Python-" version ".tar.xz"))
142 (sha256
143 (base32
144 "0cgpk3zk0fgpji59pb4zy9nzljr70qzgv1vpz5hq5xw2d2c47m9m"))
145 (patches (search-patches "python-2.7-search-paths.patch"
146 "python-2-deterministic-build-info.patch"
147 "python-2.7-site-prefixes.patch"
148 "python-2.7-source-date-epoch.patch"
149 "python-2.7-getentropy-on-old-kernels.patch"))
150 (modules '((guix build utils)))
151 ;; suboptimal to delete failing tests here, but if we delete them in the
152 ;; arguments then we need to make sure to strip out that phase when it
153 ;; gets inherited by python and python-minimal.
154 (snippet
155 '(begin
156 (for-each delete-file
157 '("Lib/test/test_compileall.py"
158 "Lib/test/test_ctypes.py" ; fails on mips64el
159 "Lib/test/test_distutils.py"
160 "Lib/test/test_import.py"
161 "Lib/test/test_shutil.py"
162 "Lib/test/test_socket.py"
163 "Lib/test/test_subprocess.py"))
164 #t))))
165 (outputs '("out"
166 "tk")) ;tkinter; adds 50 MiB to the closure
167 (build-system gnu-build-system)
168 (arguments
169 `(;; 356 tests OK.
170 ;; 6 tests failed:
171 ;; test_compileall test_distutils test_import test_shutil test_socket
172 ;; test_subprocess
173 ;; 39 tests skipped:
174 ;; test_aepack test_al test_applesingle test_bsddb test_bsddb185
175 ;; test_bsddb3 test_cd test_cl test_codecmaps_cn test_codecmaps_hk
176 ;; test_codecmaps_jp test_codecmaps_kr test_codecmaps_tw test_curses
177 ;; test_dl test_gdb test_gl test_imageop test_imgfile test_ioctl
178 ;; test_kqueue test_linuxaudiodev test_macos test_macostools
179 ;; test_msilib test_ossaudiodev test_scriptpackages test_smtpnet
180 ;; test_socketserver test_startfile test_sunaudiodev test_timeout
181 ;; test_tk test_ttk_guionly test_urllib2net test_urllibnet
182 ;; test_winreg test_winsound test_zipfile64
183 ;; 4 skips unexpected on linux2:
184 ;; test_bsddb test_bsddb3 test_gdb test_ioctl
185 #:test-target "test"
186 #:configure-flags
187 (list "--enable-shared" ;allow embedding
188 "--with-system-ffi" ;build ctypes
189 "--with-ensurepip=install" ;install pip and setuptools
190 "--enable-unicode=ucs4"
191 (string-append "LDFLAGS=-Wl,-rpath="
192 (assoc-ref %outputs "out") "/lib"))
193
194 #:modules ((ice-9 ftw) (ice-9 match)
195 (guix build utils) (guix build gnu-build-system))
196 #:phases
197 (modify-phases %standard-phases
198 (add-before
199 'configure 'patch-lib-shells
200 (lambda _
201 ;; Filter for existing files, since some may not exist in all
202 ;; versions of python that are built with this recipe.
203 (substitute* (filter file-exists?
204 '("Lib/subprocess.py"
205 "Lib/popen2.py"
206 "Lib/distutils/tests/test_spawn.py"
207 "Lib/test/test_subprocess.py"))
208 (("/bin/sh") (which "sh")))
209
210 ;; Use zero as the timestamp in .pyc files so that builds are
211 ;; deterministic. TODO: Remove it when this variable is set in
212 ;; gnu-build-system.scm.
213 (setenv "SOURCE_DATE_EPOCH" "1")
214 #t))
215 (add-before 'configure 'do-not-record-configure-flags
216 (lambda* (#:key configure-flags #:allow-other-keys)
217 ;; Remove configure flags from the installed '_sysconfigdata.py'
218 ;; and 'Makefile' so we don't end up keeping references to the
219 ;; build tools.
220 ;;
221 ;; Preserve at least '--with-system-ffi' since otherwise the
222 ;; thing tries to build libffi, fails, and we end up with a
223 ;; Python that lacks ctypes.
224 (substitute* "configure"
225 (("^CONFIG_ARGS=.*$")
226 (format #f "CONFIG_ARGS='~a'\n"
227 (if (member "--with-system-ffi" configure-flags)
228 "--with-system-ffi"
229 ""))))
230 #t))
231 (add-before
232 'check 'pre-check
233 (lambda _
234 ;; 'Lib/test/test_site.py' needs a valid $HOME
235 (setenv "HOME" (getcwd))
236 #t))
237 (add-after
238 'unpack 'set-source-file-times-to-1980
239 ;; XXX One of the tests uses a ZIP library to pack up some of the
240 ;; source tree, and fails with "ZIP does not support timestamps
241 ;; before 1980". Work around this by setting the file times in the
242 ;; source tree to sometime in early 1980.
243 (lambda _
244 (let ((circa-1980 (* 10 366 24 60 60)))
245 (ftw "." (lambda (file stat flag)
246 (utime file circa-1980 circa-1980)
247 #t))
248 #t)))
249 (add-after 'install 'remove-tests
250 ;; Remove 25 MiB of unneeded unit tests. Keep test_support.*
251 ;; because these files are used by some libraries out there.
252 (lambda* (#:key outputs #:allow-other-keys)
253 (let ((out (assoc-ref outputs "out")))
254 (match (scandir (string-append out "/lib")
255 (lambda (name)
256 (string-prefix? "python" name)))
257 ((pythonX.Y)
258 (let ((testdir (string-append out "/lib/" pythonX.Y
259 "/test")))
260 (with-directory-excursion testdir
261 (for-each delete-file-recursively
262 (scandir testdir
263 (match-lambda
264 ((or "." "..") #f)
265 (file
266 (not
267 (string-prefix? "test_support."
268 file))))))
269 (call-with-output-file "__init__.py" (const #t))
270 #t)))))))
271 (add-before 'strip 'make-libraries-writable
272 (lambda* (#:key outputs #:allow-other-keys)
273 ;; Make .so files writable so they can be stripped.
274 (let ((out (assoc-ref outputs "out")))
275 (for-each (lambda (file)
276 (chmod file #o755))
277 (find-files (string-append out "/lib")
278 "\\.so"))
279 #t)))
280 (add-after 'install 'move-tk-inter
281 (lambda* (#:key outputs #:allow-other-keys)
282 ;; When Tkinter support is built move it to a separate output so
283 ;; that the main output doesn't contain a reference to Tcl/Tk.
284 (let ((out (assoc-ref outputs "out"))
285 (tk (assoc-ref outputs "tk")))
286 (when tk
287 (match (find-files out "tkinter.*\\.so")
288 ((tkinter.so)
289 ;; The .so is in OUT/lib/pythonX.Y/lib-dynload, but we
290 ;; want it under TK/lib/pythonX.Y/site-packages.
291 (let* ((len (string-length out))
292 (target (string-append
293 tk "/"
294 (string-drop
295 (dirname (dirname tkinter.so))
296 len)
297 "/site-packages")))
298 (install-file tkinter.so target)
299 (delete-file tkinter.so)))))
300 #t))))))
301 (inputs
302 `(("bzip2" ,bzip2)
303 ("gdbm" ,gdbm)
304 ("libffi" ,libffi) ; for ctypes
305 ("sqlite" ,sqlite) ; for sqlite extension
306 ("openssl" ,openssl)
307 ("readline" ,readline)
308 ("zlib" ,zlib)
309 ("tcl" ,tcl)
310 ("tk" ,tk))) ; for tkinter
311 (native-inputs
312 `(("pkg-config" ,pkg-config)))
313 (native-search-paths
314 (list (search-path-specification
315 (variable "PYTHONPATH")
316 (files '("lib/python2.7/site-packages")))))
317 (home-page "https://www.python.org")
318 (synopsis "High-level, dynamically-typed programming language")
319 (description
320 "Python is a remarkably powerful dynamic programming language that
321 is used in a wide variety of application domains. Some of its key
322 distinguishing features include: clear, readable syntax; strong
323 introspection capabilities; intuitive object orientation; natural
324 expression of procedural code; full modularity, supporting hierarchical
325 packages; exception-based error handling; and very high level dynamic
326 data types.")
327 (license license:psfl)))
328
329 ;; Current 2.x version.
330 (define-public python-2 python-2.7)
331
332 (define-public python-3.5
333 (package (inherit python-2)
334 (version "3.5.3")
335 (source (origin
336 (method url-fetch)
337 (uri (string-append "https://www.python.org/ftp/python/"
338 version "/Python-" version ".tar.xz"))
339 (patches (search-patches
340 "python-fix-tests.patch"
341 "python-3.5-fix-tests.patch"
342 "python-3.5-getentropy-on-old-kernels.patch"
343 "python-3-deterministic-build-info.patch"
344 "python-3-search-paths.patch"))
345 (patch-flags '("-p0"))
346 (sha256
347 (base32
348 "1c6v1n9nz4mlx9mw1125fxpmbrgniqdbbx9hnqx44maqazb2mzpf"))
349 (snippet
350 '(begin
351 (for-each delete-file
352 '("Lib/ctypes/test/test_win32.py" ; fails on aarch64
353 "Lib/test/test_fcntl.py"))
354 #t))))
355 (arguments (substitute-keyword-arguments (package-arguments python-2)
356 ((#:tests? _) #t)))
357 (native-search-paths
358 (list (search-path-specification
359 (variable "PYTHONPATH")
360 (files (list (string-append "lib/python"
361 (version-major+minor version)
362 "/site-packages"))))))))
363
364 ;; Current 3.x version.
365 (define-public python-3 python-3.5)
366
367 ;; Current major version.
368 (define-public python python-3)
369
370 ;; Minimal variants of Python, mostly used to break the cycle between Tk and
371 ;; Python (Tk -> libxcb -> Python.)
372
373 (define-public python2-minimal
374 (package (inherit python-2)
375 (name "python-minimal")
376 (outputs '("out"))
377
378 ;; Keep zlib, which is used by 'pip' (via the 'zipimport' module), which
379 ;; is invoked upon 'make install'. 'pip' also expects 'ctypes' and thus
380 ;; libffi.
381 (inputs `(("libffi" ,libffi)
382 ("zlib" ,zlib)))))
383
384 (define-public python-minimal
385 (package (inherit python)
386 (name "python-minimal")
387 (outputs '("out"))
388
389 ;; Build fails due to missing ctypes without libffi.
390 ;; OpenSSL is a mandatory dependency of Python 3.x, for urllib;
391 ;; zlib is required by 'zipimport', used by pip.
392 (inputs `(("libffi" ,libffi)
393 ("openssl" ,openssl)
394 ("zlib" ,zlib)))))
395
396 (define* (wrap-python3 python
397 #:optional
398 (name (string-append (package-name python) "-wrapper")))
399 (package (inherit python)
400 (name name)
401 (source #f)
402 (build-system trivial-build-system)
403 (outputs '("out"))
404 (inputs `(("bash" ,bash)))
405 (propagated-inputs `(("python" ,python)))
406 (arguments
407 `(#:modules ((guix build utils))
408 #:builder
409 (begin
410 (use-modules (guix build utils))
411 (let ((bin (string-append (assoc-ref %outputs "out") "/bin"))
412 (python (string-append (assoc-ref %build-inputs "python") "/bin/")))
413 (mkdir-p bin)
414 (for-each
415 (lambda (old new)
416 (symlink (string-append python old)
417 (string-append bin "/" new)))
418 `("python3" ,"pydoc3" ,"idle3" ,"pip3")
419 `("python" ,"pydoc" ,"idle" ,"pip"))
420 ;; python-config outputs search paths based upon its location,
421 ;; use a bash wrapper to avoid changing its outputs.
422 (let ((bash (string-append (assoc-ref %build-inputs "bash")
423 "/bin/bash"))
424 (old (string-append python "python3-config"))
425 (new (string-append bin "/python-config")))
426 (with-output-to-file new
427 (lambda ()
428 (format #t "#!~a~%" bash)
429 (format #t "exec \"~a\" \"$@\"~%" old)
430 (chmod new #o755)
431 #t)))))))
432 (synopsis "Wrapper for the Python 3 commands")
433 (description
434 "This package provides wrappers for the commands of Python@tie{}3.x such
435 that they can be invoked under their usual name---e.g., @command{python}
436 instead of @command{python3}.")))
437
438 (define-public python-wrapper (wrap-python3 python))
439 (define-public python-minimal-wrapper (wrap-python3 python-minimal))
440
441 (define-public python-psutil
442 (package
443 (name "python-psutil")
444 (version "4.3.0")
445 (source
446 (origin
447 (method url-fetch)
448 (uri (pypi-uri "psutil" version))
449 (sha256
450 (base32
451 "1w4r09fvn6kd80m5mx4ws1wz100brkaq6hzzpwrns8cgjzjpl6c6"))))
452 (build-system python-build-system)
453 (arguments
454 ;; FIXME: some tests does not return and times out.
455 '(#:tests? #f))
456 (home-page "https://www.github.com/giampaolo/psutil")
457 (synopsis "Library for retrieving information on running processes")
458 (description
459 "psutil (Python system and process utilities) is a library for retrieving
460 information on running processes and system utilization (CPU, memory, disks,
461 network) in Python. It is useful mainly for system monitoring, profiling and
462 limiting process resources and management of running processes. It implements
463 many functionalities offered by command line tools such as: ps, top, lsof,
464 netstat, ifconfig, who, df, kill, free, nice, ionice, iostat, iotop, uptime,
465 pidof, tty, taskset, pmap.")
466 (license license:bsd-3)))
467
468 (define-public python2-psutil
469 (package-with-python2 python-psutil))
470
471 (define-public python-passlib
472 (package
473 (name "python-passlib")
474 (version "1.7.1")
475 (source
476 (origin
477 (method url-fetch)
478 (uri (pypi-uri "passlib" version))
479 (sha256
480 (base32
481 "1q2khqpj9rlcgdmkypjdq1kswvhjf72bq0zk2cv669cc2dj8z51x"))))
482 (build-system python-build-system)
483 (native-inputs
484 `(("python-nose" ,python-nose)))
485 (propagated-inputs
486 `(("python-py-bcrypt" ,python-py-bcrypt)))
487 (arguments
488 `(#:phases
489 (modify-phases %standard-phases
490 (add-before 'check 'set-PYTHON_EGG_CACHE
491 ;; some tests require access to "$HOME/.cython"
492 (lambda* _ (setenv "PYTHON_EGG_CACHE" "/tmp") #t)))))
493 (home-page "https://bitbucket.org/ecollins/passlib")
494 (synopsis
495 "Comprehensive password hashing framework")
496 (description
497 "Passlib is a password hashing library for Python 2 & 3, which provides
498 cross-platform implementations of over 30 password hashing algorithms, as well
499 as a framework for managing existing password hashes. It's designed to be
500 useful for a wide range of tasks, from verifying a hash found in /etc/shadow,
501 to providing full-strength password hashing for multi-user application.")
502 (license license:bsd-3)))
503
504 (define-public python2-passlib
505 (package-with-python2 python-passlib))
506
507 (define-public python-py-bcrypt
508 (package
509 (name "python-py-bcrypt")
510 (version "0.4")
511 (source
512 (origin
513 (method url-fetch)
514 (uri (string-append
515 "https://pypi.python.org/packages/source/p/py-bcrypt/py-bcrypt-"
516 version
517 ".tar.gz"))
518 (sha256
519 (base32
520 "0y6smdggwi5s72v6p1nn53dg6w05hna3d264cq6kas0lap73p8az"))))
521 (build-system python-build-system)
522 (home-page "https://code.google.com/p/py-bcrypt")
523 (synopsis
524 "Bcrypt password hashing and key derivation")
525 (description
526 "A python wrapper of OpenBSD's Blowfish password hashing code. This
527 system hashes passwords using a version of Bruce Schneier's Blowfish block
528 cipher with modifications designed to raise the cost of off-line password
529 cracking and frustrate fast hardware implementation. The computation cost of
530 the algorithm is parametised, so it can be increased as computers get faster.
531 The intent is to make a compromise of a password database less likely to
532 result in an attacker gaining knowledge of the plaintext passwords (e.g. using
533 John the Ripper).")
534 ;; "sha2.c" is under BSD-3;
535 ;; "blowfish.c" and "bcrypt.c" are under BSD-4;
536 ;; the rest is under ISC.
537 (license (list license:isc license:bsd-3 license:bsd-4))))
538
539 (define-public python2-py-bcrypt
540 (package-with-python2 python-py-bcrypt))
541
542
543 (define-public python-paramiko
544 (package
545 (name "python-paramiko")
546 (version "2.1.2")
547 (source
548 (origin
549 (method url-fetch)
550 (uri (pypi-uri "paramiko" version))
551 (sha256
552 (base32
553 "04734n0wy3hxk6rij4fr29in5jmr70nxpc7pqi2ksbjysfz4kbjz"))))
554 (build-system python-build-system)
555 (arguments
556 '(#:phases
557 (modify-phases %standard-phases
558 (replace 'check
559 (lambda _
560 (zero? (system* "python" "test.py")))))))
561 (propagated-inputs
562 `(("python-pyasn1" ,python-pyasn1)
563 ("python-cryptography" ,python-cryptography)))
564 (home-page "http://www.paramiko.org/")
565 (synopsis "SSHv2 protocol library")
566 (description "Paramiko is a python implementation of the SSHv2 protocol,
567 providing both client and server functionality. While it leverages a Python C
568 extension for low level cryptography (PyCrypto), Paramiko itself is a pure
569 Python interface around SSH networking concepts.")
570 (license license:lgpl2.1+)))
571
572 (define-public python2-paramiko
573 (package-with-python2 python-paramiko))
574
575
576 (define-public python-httplib2
577 (package
578 (name "python-httplib2")
579 (version "0.9.2")
580 (source
581 (origin
582 (method url-fetch)
583 (uri (pypi-uri "httplib2" version))
584 (sha256
585 (base32
586 "126rsryvw9vhbf3qmsfw9lf4l4xm2srmgs439lgma4cpag4s3ay3"))))
587 (build-system python-build-system)
588 (home-page "https://github.com/jcgregorio/httplib2")
589 (synopsis "Comprehensive HTTP client library")
590 (description
591 "A comprehensive HTTP client library supporting many features left out of
592 other HTTP libraries.")
593 (license license:expat)))
594
595 (define-public python2-httplib2
596 (package-with-python2 python-httplib2))
597
598 (define-public python-ecdsa
599 (package
600 (name "python-ecdsa")
601 (version "0.13")
602 (source
603 (origin
604 (method url-fetch)
605 (uri (string-append
606 "https://pypi.python.org/packages/source/e/ecdsa/ecdsa-"
607 version
608 ".tar.gz"))
609 (sha256
610 (base32
611 "1yj31j0asmrx4an9xvsaj2icdmzy6pw0glfpqrrkrphwdpi1xkv4"))))
612 (build-system python-build-system)
613 (inputs
614 `(("openssl" ,openssl)))
615 (home-page
616 "https://github.com/warner/python-ecdsa")
617 (synopsis
618 "ECDSA cryptographic signature library (pure python)")
619 (description
620 "This is an easy-to-use implementation of ECDSA cryptography (Elliptic
621 Curve Digital Signature Algorithm), implemented purely in Python. With this
622 library, you can quickly create keypairs (signing key and verifying key), sign
623 messages, and verify the signatures. The keys and signatures are very short,
624 making them easy to handle and incorporate into other protocols.")
625 (license license:expat)))
626
627 (define-public python2-ecdsa
628 (package-with-python2 python-ecdsa))
629
630 (define-public python-ccm
631 (package
632 (name "python-ccm")
633 (version "2.1.6")
634 (source
635 (origin
636 (method url-fetch)
637 (uri (pypi-uri "ccm" version))
638 (sha256
639 (base32
640 "177dfxsmk3k4cih6fh6v8d91bh4nqx7ns6pc07w7m7i3cvdx3c8n"))))
641 (build-system python-build-system)
642 (propagated-inputs
643 `(("python-pyyaml" ,python-pyyaml)
644 ;; Not listed in setup.py, but used in ccmlib/node.py for full
645 ;; functionality
646 ("python-psutil" ,python-psutil)
647 ("python-six" ,python-six)))
648 (home-page "https://github.com/pcmanus/ccm")
649 (synopsis "Cassandra Cluster Manager for Apache Cassandra clusters on
650 localhost")
651 (description "Cassandra Cluster Manager is a development tool for testing
652 local Cassandra clusters. It creates, launches and removes Cassandra clusters
653 on localhost.")
654 (license license:asl2.0)))
655
656 (define-public python2-ccm
657 (package-with-python2 python-ccm))
658
659 (define-public python-pytz
660 (package
661 (name "python-pytz")
662 (version "2017.2")
663 (source
664 (origin
665 (method url-fetch)
666 (uri (pypi-uri "pytz" version ".zip"))
667 (sha256
668 (base32
669 "12cmd3j46d2gcw08bspvp6s9icfcvx88zjz52n1bli9dyvl5dh7m"))))
670 (build-system python-build-system)
671 (native-inputs
672 `(("unzip" ,unzip)))
673 (home-page "http://pythonhosted.org/pytz")
674 (synopsis "Python timezone library")
675 (description "This library brings the Olson tz database into Python. It
676 allows accurate and cross platform timezone calculations using Python 2.4 or
677 higher. It also solves the issue of ambiguous times at the end of daylight
678 saving time. Almost all of the Olson timezones are supported.")
679 (license license:expat)))
680
681 (define-public python2-pytz
682 (package-with-python2 python-pytz))
683
684 (define-public python-clyent
685 (package
686 (name "python-clyent")
687 (version "1.2.1")
688 (source
689 (origin
690 (method url-fetch)
691 (uri (pypi-uri "clyent" version))
692 (sha256
693 (base32
694 "1r9987qmy1pz3hq54160bapqsywpq14waw4w9x3ly8hmq7kpgfbj"))))
695 (build-system python-build-system)
696 (native-inputs
697 `(("python-mock" ,python-mock)))
698 (home-page "https://github.com/binstar/clyent")
699 (synopsis "Command line client library")
700 (description "Clyent is a Python command line utiliy library. It is used
701 by @code{binstar}, @code{binstar-build} and @code{chalmers}.")
702 (license license:bsd-3)))
703
704 (define-public python2-clyent
705 (package-with-python2 python-clyent))
706
707 (define-public python-babel
708 (package
709 (name "python-babel")
710 (version "2.3.4")
711 (source
712 (origin
713 (method url-fetch)
714 (uri (pypi-uri "Babel" version))
715 (sha256
716 (base32
717 "0x98qqqw35xllpcama013a9788ly84z8dm1w2wwfpxh2710c8df5"))))
718 (build-system python-build-system)
719 (propagated-inputs
720 `(("python-pytz" ,python-pytz)))
721 (arguments `(#:tests? #f)) ; no test target
722 (home-page "http://babel.pocoo.org/")
723 (synopsis
724 "Tools for internationalizing Python applications")
725 (description
726 "Babel is composed of two major parts:
727 - tools to build and work with gettext message catalogs
728 - a Python interface to the CLDR (Common Locale Data Repository), providing
729 access to various locale display names, localized number and date formatting,
730 etc. ")
731 (license license:bsd-3)))
732
733 (define-public python2-babel
734 (package-with-python2 python-babel))
735
736 (define-public python2-backport-ssl-match-hostname
737 (package
738 (name "python2-backport-ssl-match-hostname")
739 (version "3.5.0.1")
740 (source
741 (origin
742 (method url-fetch)
743 (uri (string-append
744 "https://pypi.python.org/packages/source/b/"
745 "backports.ssl_match_hostname/backports.ssl_match_hostname-"
746 version ".tar.gz"))
747 (sha256
748 (base32
749 "1wndipik52cyqy0677zdgp90i435pmvwd89cz98lm7ri0y3xjajh"))))
750 (build-system python-build-system)
751 (arguments
752 `(#:python ,python-2
753 #:tests? #f)) ; no test target
754 (home-page "https://bitbucket.org/brandon/backports.ssl_match_hostname")
755 (synopsis "Backport of ssl.match_hostname() function from Python 3.5")
756 (description
757 "This backport brings the ssl.match_hostname() function to users of
758 earlier versions of Python. The function checks the hostname in the
759 certificate returned by the server to which a connection has been established,
760 and verifies that it matches the intended target hostname.")
761 (license license:psfl)))
762
763 (define-public python-hdf4
764 (package
765 (name "python-hdf4")
766 (version "0.9")
767 (source
768 (origin
769 (method url-fetch)
770 (uri (pypi-uri name version))
771 (sha256
772 (base32
773 "1hjiyrxvxk9817qyqky3nar4y3fs4z8wxz0n884zzb5wi6skrjks"))))
774 (build-system python-build-system)
775 (native-inputs `(("nose" ,python-nose)))
776 (propagated-inputs `(("numpy" ,python-numpy)))
777 (inputs
778 `(("hdf4" ,hdf4)
779 ("libjpeg" ,libjpeg)
780 ("zlib" ,zlib)))
781 (arguments
782 `(#:phases
783 (modify-phases %standard-phases
784 (replace 'check
785 (lambda _
786 ;; The 'runexamples' script sets PYTHONPATH to CWD, then goes
787 ;; on to import numpy. Somehow this works on their CI system.
788 ;; Let's just manage PYTHONPATH here instead.
789 (substitute* "runexamples.sh"
790 (("export PYTHONPATH=.*") ""))
791 (setenv "PYTHONPATH"
792 (string-append (getcwd) ":"
793 (getenv "PYTHONPATH")))
794 (and (zero? (system* "./runexamples.sh"))
795 (zero? (system* "nosetests" "-v"))))))))
796 (home-page "https://github.com/fhs/python-hdf4")
797 (synopsis "Python interface to the NCSA HDF4 library")
798 (description
799 "Python-HDF4 is a python wrapper around the NCSA HDF version 4 library,
800 which implements the SD (Scientific Dataset), VS (Vdata) and V (Vgroup) API’s.
801 NetCDF files can also be read and modified. Python-HDF4 is a fork of
802 @url{http://hdfeos.org/software/pyhdf.php,pyhdf}.")
803 (license license:expat)))
804
805 (define-public python2-hdf4
806 (package-with-python2 python-hdf4))
807
808 (define-public python-h5py
809 (package
810 (name "python-h5py")
811 (version "2.7.0")
812 (source
813 (origin
814 (method url-fetch)
815 (uri (pypi-uri "h5py" version))
816 (sha256
817 (base32
818 "0433sdv6xc9p7v1xs1gvbxp7p152ywi3nplgjb258q9fvw9469br"))))
819 (build-system python-build-system)
820 (arguments
821 `(#:tests? #f ; no test target
822 #:phases
823 (modify-phases %standard-phases
824 (add-after 'unpack 'fix-hdf5-paths
825 (lambda* (#:key inputs #:allow-other-keys)
826 (let ((prefix (assoc-ref inputs "hdf5")))
827 (substitute* "setup_build.py"
828 (("\\['/opt/local/lib', '/usr/local/lib'\\]")
829 (string-append "['" prefix "/lib" "']"))
830 (("'/opt/local/include', '/usr/local/include'")
831 (string-append "'" prefix "/include" "'")))
832 (substitute* "setup_configure.py"
833 (("\\['/usr/local/lib', '/opt/local/lib'\\]")
834 (string-append "['" prefix "/lib" "']")))
835 #t))))))
836 (propagated-inputs
837 `(("python-six" ,python-six)
838 ("python-numpy" ,python-numpy)))
839 (inputs
840 `(("hdf5" ,hdf5)))
841 (native-inputs
842 `(("python-cython" ,python-cython)
843 ("python-pkgconfig" ,python-pkgconfig)))
844 (home-page "http://www.h5py.org/")
845 (synopsis "Read and write HDF5 files from Python")
846 (description
847 "The h5py package provides both a high- and low-level interface to the
848 HDF5 library from Python. The low-level interface is intended to be a
849 complete wrapping of the HDF5 API, while the high-level component supports
850 access to HDF5 files, datasets and groups using established Python and NumPy
851 concepts.")
852 (license license:bsd-3)))
853
854 (define-public python2-h5py
855 (package-with-python2 python-h5py))
856
857 (define-public python-netcdf4
858 (package
859 (name "python-netcdf4")
860 (version "1.2.9")
861 (source
862 (origin
863 (method url-fetch)
864 (uri (pypi-uri "netCDF4" version))
865 (sha256
866 (base32
867 "1h6jq338amlbk0ilzvjyl7cck80i0bah9a5spn9in71vy2qxm7i5"))))
868 (build-system python-build-system)
869 (native-inputs
870 `(("python-cython" ,python-cython)))
871 (propagated-inputs
872 `(("python-numpy" ,python-numpy)))
873 (inputs
874 `(("netcdf" ,netcdf)
875 ("hdf4" ,hdf4)
876 ("hdf5" ,hdf5)))
877 (arguments
878 '(#:phases
879 (modify-phases %standard-phases
880 (replace 'check
881 (lambda _
882 (setenv "NO_NET" "1") ; disable opendap tests
883 (with-directory-excursion "test"
884 (setenv "PYTHONPATH" ; find and add the library we just built
885 (string-append
886 (car (find-files "../build" "lib.*"
887 #:directories? #:t
888 #:fail-on-error? #:t))
889 ":" (getenv "PYTHONPATH")))
890 (zero? (system* "python" "run_all.py"))))))))
891 (home-page
892 "https://github.com/Unidata/netcdf4-python")
893 (synopsis "Python/numpy interface to the netCDF library")
894 (description "Netcdf4-python is a Python interface to the netCDF C
895 library. netCDF version 4 has many features not found in earlier
896 versions of the library and is implemented on top of HDF5. This module
897 can read and write files in both the new netCDF 4 and the old netCDF 3
898 format, and can create files that are readable by HDF5 clients. The
899 API is modelled after @code{Scientific.IO.NetCDF}, and should be familiar
900 to users of that module.")
901 ;; The software is mainly ISC, but includes some files covered
902 ;; by the Expat license.
903 (license (list license:isc license:expat))))
904
905 (define-public python2-netcdf4
906 (package-with-python2 python-netcdf4))
907
908 (define-public python-lockfile
909 (package
910 (name "python-lockfile")
911 (version "0.12.2")
912 (source
913 (origin
914 (method url-fetch)
915 (uri (string-append "https://pypi.python.org/packages/source/l/lockfile/"
916 "lockfile-" version ".tar.gz"))
917 (sha256
918 (base32
919 "16gpx5hm73ah5n1079ng0vy381hl802v606npkx4x8nb0gg05vba"))))
920 (build-system python-build-system)
921 (arguments '(#:test-target "check"))
922 (native-inputs
923 `(("python-pbr" ,python-pbr)))
924 (home-page "https://launchpad.net/pylockfile")
925 (synopsis "Platform-independent file locking module")
926 (description
927 "The lockfile package exports a LockFile class which provides a simple
928 API for locking files.")
929 (license license:expat)))
930
931 (define-public python2-lockfile
932 (package-with-python2 python-lockfile))
933
934 (define-public python-mock
935 (package
936 (name "python-mock")
937 (version "1.0.1")
938 (source
939 (origin
940 (method url-fetch)
941 (uri (pypi-uri "mock" version))
942 (sha256
943 (base32
944 "0kzlsbki6q0awf89rc287f3aj8x431lrajf160a70z0ikhnxsfdq"))))
945 (build-system python-build-system)
946 (arguments '(#:test-target "check"))
947 (home-page "https://github.com/testing-cabal/mock")
948 (synopsis "Python mocking and patching library for testing")
949 (description
950 "Mock is a library for testing in Python. It allows you to replace parts
951 of your system under test with mock objects and make assertions about how they
952 have been used.")
953 (license license:expat)))
954
955 (define-public python2-mock
956 (package-with-python2 python-mock))
957
958 ;;; Some packages (notably, certbot and python-acme) rely on this newer version
959 ;;; of python-mock. However, a large number of packages fail to build with
960 ;;; mock@2, so we add a new variable for now. Also, there may be a dependency
961 ;;; cycle between mock and six, so we avoid creating python2-mock@2 for now.
962 (define-public python-mock-2
963 (package
964 (inherit python-mock)
965 (version "2.0.0")
966 (source
967 (origin
968 (method url-fetch)
969 (uri (pypi-uri "mock" version))
970 (sha256
971 (base32
972 "1flbpksir5sqrvq2z0dp8sl4bzbadg21sj4d42w3klpdfvgvcn5i"))))
973 (propagated-inputs
974 `(("python-pbr" ,python-pbr-minimal)
975 ,@(package-propagated-inputs python-mock)))))
976
977 (define-public python-setuptools
978 (package
979 (name "python-setuptools")
980 (version "31.0.0")
981 (source
982 (origin
983 (method url-fetch)
984 (uri (pypi-uri "setuptools" version))
985 (sha256
986 (base32
987 "0ypybh4hx3bv4vhg2dc74xpj1g56ggnaffm87k4abhwjwq6wq608"))
988 (modules '((guix build utils)))
989 (snippet
990 '(begin
991 ;; Remove included binaries which are used to build self-extracting
992 ;; installers for Windows.
993 ;; TODO: Find some way to build them ourself so we can include them.
994 (for-each delete-file (find-files "setuptools" "^(cli|gui).*\\.exe$"))
995 #t))))
996 (build-system python-build-system)
997 ;; FIXME: Tests require pytest, which itself relies on setuptools.
998 ;; One could bootstrap with an internal untested setuptools.
999 (arguments
1000 `(#:tests? #f))
1001 (home-page "https://pypi.python.org/pypi/setuptools")
1002 (synopsis
1003 "Library designed to facilitate packaging Python projects")
1004 (description
1005 "Setuptools is a fully-featured, stable library designed to facilitate
1006 packaging Python projects, where packaging includes:
1007 Python package and module definitions,
1008 distribution package metadata,
1009 test hooks,
1010 project installation,
1011 platform-specific details,
1012 Python 3 support.")
1013 ;; TODO: setuptools now bundles the following libraries:
1014 ;; packaging, pyparsing, six and appdirs. How to unbundle?
1015 (license (list license:psfl ; setuptools itself
1016 license:expat ; six, appdirs, pyparsing
1017 license:asl2.0 ; packaging is dual ASL2/BSD-2
1018 license:bsd-2))))
1019
1020 (define-public python2-setuptools
1021 (package-with-python2 python-setuptools))
1022
1023 (define-public python-uniseg
1024 (package
1025 (name "python-uniseg")
1026 (version "0.7.1")
1027 (source
1028 (origin
1029 (method url-fetch)
1030 (uri (string-append "https://bitbucket.org/emptypage/uniseg-python/"
1031 "get/rel-" version ".tar.gz"))
1032 (file-name (string-append name "-" version ".tar.gz"))
1033 (sha256
1034 (base32
1035 "1df4gddnj2a0v8z35wb2ra5vvh1f1qyxs8fgd25c8g64031mna6x"))))
1036 (build-system python-build-system)
1037 (arguments
1038 '(#:tests? #f)) ; The test suite requires network access.
1039 (home-page
1040 "https://bitbucket.org/emptypage/uniseg-python")
1041 (synopsis
1042 "Python library to determine Unicode text segmentations")
1043 (description
1044 "Uniseg is a Python package used to determine Unicode text segmentations.
1045 Supported segmentations include:
1046 @enumerate
1047 @item @dfn{Code point} (any value in the Unicode codespace)
1048 @item @dfn{Grapheme cluster} (user-perceived character made of a single or
1049 multiple Unicode code points, e.g. \"G\" + acute-accent)
1050 @item Word break
1051 @item Sentence break
1052 @item Line break
1053 @end enumerate")
1054 (license license:expat)))
1055
1056 (define-public python2-uniseg
1057 (package-with-python2 python-uniseg))
1058
1059 ;;; Pycrypto is abandoned upstream:
1060 ;;;
1061 ;;; https://github.com/dlitz/pycrypto/issues/173
1062 ;;;
1063 ;;; TODO Remove this package from GNU Guix.
1064 (define-public python-pycrypto
1065 (package
1066 (name "python-pycrypto")
1067 (version "2.6.1")
1068 (source
1069 (origin
1070 (method url-fetch)
1071 (uri (pypi-uri "pycrypto" version))
1072 (patches (search-patches "python-pycrypto-CVE-2013-7459.patch"))
1073 (sha256
1074 (base32
1075 "0g0ayql5b9mkjam8hym6zyg6bv77lbh66rv1fyvgqb17kfc1xkpj"))))
1076 (build-system python-build-system)
1077 (inputs
1078 `(("python" ,python)
1079 ("gmp" ,gmp)))
1080 (arguments
1081 `(#:phases
1082 (modify-phases %standard-phases
1083 (add-before 'build 'set-build-env
1084 ;; pycrypto runs an autoconf configure script behind the scenes
1085 (lambda _ (setenv "CONFIG_SHELL" (which "bash")) #t)))))
1086 (home-page "http://www.pycrypto.org/")
1087 (synopsis "Cryptographic modules for Python")
1088 (description
1089 "Pycrypto is a collection of both secure hash functions (such as SHA256
1090 and RIPEMD160), and various encryption algorithms (AES, DES, RSA, ElGamal,
1091 etc.). The package is structured to make adding new modules easy.")
1092 (license license:public-domain)))
1093
1094 (define-public python2-pycrypto
1095 (let ((pycrypto (package-with-python2 python-pycrypto)))
1096 (package (inherit pycrypto)
1097 (inputs
1098 `(("python" ,python-2)
1099 ,@(alist-delete
1100 "python"
1101 (package-inputs pycrypto)))))))
1102
1103 (define-public python-humanfriendly
1104 (package
1105 (name "python-humanfriendly")
1106 (version "4.4.1")
1107 (source
1108 (origin
1109 (method url-fetch)
1110 (uri (pypi-uri "humanfriendly" version))
1111 (sha256
1112 (base32
1113 "0pisgizjql86785jchfjv217g0lsgk114g2lja5j4y3lsc3b9szi"))))
1114 (build-system python-build-system)
1115 (arguments
1116 `(;; XXX: Tests depend on coloredlogs, which in turn depends on humanfriendly.
1117 #:tests? #f))
1118 (propagated-inputs
1119 `(("python-monotonic" ,python-monotonic)))
1120 (home-page "https://humanfriendly.readthedocs.io")
1121 (synopsis "Human-friendly input and output in Python")
1122 (description
1123 "The functions and classes in @code{humanfriendly} can be used to make
1124 text interfaces more user-friendly. It includes tools to parse and format
1125 numbers, file sizes, and timespans, timers for long-running operations, menus
1126 to allow the user to choose from a list of options, and terminal interaction
1127 helpers.")
1128 (license license:expat)))
1129
1130 (define-public python2-humanfriendly
1131 (package-with-python2 python-humanfriendly))
1132
1133 (define-public python-capturer
1134 (package
1135 (name "python-capturer")
1136 (version "2.4")
1137 (source
1138 (origin
1139 (method url-fetch)
1140 (uri (pypi-uri "capturer" version))
1141 (sha256
1142 (base32
1143 "05d6ji4j8ipiq0br7bwam38qc6hd9l1djmfxlzrxx19ziyjl4089"))))
1144 (build-system python-build-system)
1145 (arguments
1146 `(#:tests? #f))
1147 (propagated-inputs
1148 `(("python-humanfriendly" ,python-humanfriendly)))
1149 (home-page "https://capturer.readthedocs.io")
1150 (synopsis "Capture stdout and stderr streams of the current process")
1151 (description
1152 "The capturer package makes it easy to capture the stdout and stderr
1153 streams of the current process and subprocesses. Output can be relayed
1154 to the terminal in real time but is also available to the Python program
1155 for additional processing.")
1156 (license license:expat)))
1157
1158 (define-public python2-capturer
1159 (package-with-python2 python-capturer))
1160
1161 (define-public python-verboselogs
1162 (package
1163 (name "python-verboselogs")
1164 (version "1.7")
1165 (source
1166 (origin
1167 (method url-fetch)
1168 (uri (pypi-uri "verboselogs" version))
1169 (sha256
1170 (base32
1171 "09z4d1jiasn7k1hs5af2ckmnrd0i1d1m04bhfjhv7z6svzfdwgg3"))))
1172 (build-system python-build-system)
1173 (native-inputs
1174 `(("python-mock" ,python-mock)
1175 ("python-astroid" ,python-astroid)
1176 ("python-pylint" ,python-pylint)))
1177 (home-page "https://verboselogs.readthedocs.io")
1178 (synopsis "Verbose logging level for Python's logging module")
1179 (description
1180 "The @code{verboselogs} package extends Python's @code{logging} module to
1181 add the log levels NOTICE, SPAM, SUCCESS and VERBOSE.")
1182 (license license:expat)))
1183
1184 (define-public python2-verboselogs
1185 (package-with-python2 python-verboselogs))
1186
1187 (define-public python-coloredlogs
1188 (package
1189 (name "python-coloredlogs")
1190 (version "7.3")
1191 (source
1192 (origin
1193 (method url-fetch)
1194 (uri (pypi-uri "coloredlogs" version))
1195 (sha256
1196 (base32
1197 "1blcann6dyg5dhps9pg12rn0q0rjrlajpmmil0gy0j4cbvnl2il9"))))
1198 (build-system python-build-system)
1199 (arguments
1200 `(;Tests require some updated modules
1201 #:tests? #f))
1202 (propagated-inputs
1203 `(("python-capturer" ,python-capturer)))
1204 (home-page "https://coloredlogs.readthedocs.io")
1205 (synopsis "Colored stream handler for Python's logging module")
1206 (description
1207 "The @code{coloredlogs} package enables colored terminal output for
1208 Python's logging module. The @code{ColoredFormatter} class inherits from
1209 @code{logging.Formatter} and uses ANSI escape sequences to render your logging
1210 messages in color.")
1211 (license license:expat)))
1212
1213 (define-public python2-coloredlogs
1214 (package-with-python2 python-coloredlogs))
1215
1216 (define-public python-eventlet
1217 (package
1218 (name "python-eventlet")
1219 (version "0.20.1")
1220 (source
1221 (origin
1222 (method url-fetch)
1223 (uri (pypi-uri "eventlet" version))
1224 (sha256
1225 (base32
1226 "0f3q55mq4n021wb7qa53pz3ix6i2py64sap66vsaqm2scjw83m9s"))))
1227 (build-system python-build-system)
1228 (propagated-inputs
1229 `(("python-greenlet" ,python-greenlet)))
1230 (arguments
1231 ;; TODO: Requires unpackaged 'enum-compat'.
1232 '(#:tests? #f))
1233 (home-page "http://eventlet.net")
1234 (synopsis "Concurrent networking library for Python")
1235 (description
1236 "Eventlet is a concurrent networking library for Python that
1237 allows you to change how you run your code, not how you write it.
1238 It uses @code{epoll} or @code{libevent} for highly scalable non-blocking I/O.
1239 Coroutines ensure that the developer uses a blocking style of programming
1240 that is similar to threading, but provide the benefits of non-blocking I/O.
1241 The event dispatch is implicit, which means you can easily use @code{Eventlet}
1242 from the Python interpreter, or as a small part of a larger application.")
1243 (license license:expat)))
1244
1245 (define-public python2-eventlet
1246 (let ((base (package-with-python2
1247 (strip-python2-variant python-eventlet))))
1248 (package (inherit base)
1249 (propagated-inputs
1250 `(("python2-enum34" ,python2-enum34)
1251 ,@(package-propagated-inputs base))))))
1252
1253 (define-public python-keyring
1254 (package
1255 (name "python-keyring")
1256 (version "8.7")
1257 (source
1258 (origin
1259 (method url-fetch)
1260 (uri (pypi-uri "keyring" version))
1261 (sha256
1262 (base32
1263 "0482rmi2x6p78wl2kz8qzyq21xz1sbbfwnv5x7dggar4vkwxhzfx"))))
1264 (build-system python-build-system)
1265 (native-inputs
1266 `(("python-setuptools-scm" ,python-setuptools-scm)))
1267 (propagated-inputs
1268 `(("python-pycrypto" ,python-pycrypto)))
1269 (arguments
1270 `(#:tests? #f)) ;TODO: tests require pytest
1271 (home-page "https://github.com/jaraco/keyring")
1272 (synopsis "Store and access your passwords safely")
1273 (description
1274 "The Python keyring lib provides a easy way to access the system keyring
1275 service from python. It can be used in any application that needs safe
1276 password storage.")
1277 ;; "MIT" and PSF dual license
1278 (license license:x11)))
1279
1280 (define-public python2-keyring
1281 (package-with-python2 python-keyring))
1282
1283 (define-public python-six
1284 (package
1285 (name "python-six")
1286 (version "1.10.0")
1287 (source
1288 (origin
1289 (method url-fetch)
1290 (uri (pypi-uri "six" version))
1291 (sha256
1292 (base32
1293 "0snmb8xffb3vsma0z67i0h0w2g2dy0p3gsgh9gi4i0kgc5l8spqh"))))
1294 (build-system python-build-system)
1295 (native-inputs
1296 `(("python-py" ,python-py)
1297 ("python-pytest" ,python-pytest)))
1298 (home-page "http://pypi.python.org/pypi/six/")
1299 (synopsis "Python 2 and 3 compatibility utilities")
1300 (description
1301 "Six is a Python 2 and 3 compatibility library. It provides utility
1302 functions for smoothing over the differences between the Python versions with
1303 the goal of writing Python code that is compatible on both Python versions.
1304 Six supports every Python version since 2.5. It is contained in only one
1305 Python file, so it can be easily copied into your project.")
1306 (license license:x11)))
1307
1308 (define-public python2-six
1309 (package-with-python2 python-six))
1310
1311 (define-public python-dateutil
1312 (package
1313 (name "python-dateutil")
1314 (version "2.6.0")
1315 (source
1316 (origin
1317 (method url-fetch)
1318 (uri (pypi-uri "python-dateutil" version))
1319 (sha256
1320 (base32
1321 "1lhq0hxjc3cfha101q02ld5ijlpfyjn2w1yh7wvpiy367pgzi8k2"))))
1322 (build-system python-build-system)
1323 (propagated-inputs
1324 `(("python-six" ,python-six)))
1325 (home-page "https://dateutil.readthedocs.io/en/stable/")
1326 (synopsis "Extensions to the standard datetime module")
1327 (description
1328 "The dateutil module provides powerful extensions to the standard
1329 datetime module, available in Python 2.3+.")
1330 (license license:bsd-3)))
1331
1332 (define-public python2-dateutil
1333 (package-with-python2 python-dateutil))
1334
1335 (define-public python-parsedatetime
1336 (package
1337 (name "python-parsedatetime")
1338 (version "2.4")
1339 (source
1340 (origin
1341 (method url-fetch)
1342 (uri (pypi-uri "parsedatetime" version))
1343 (sha256
1344 (base32
1345 "0jxqkjks7z9dn222cqgvskp4wr6d92aglinxq7pd2w4mzdc7r09x"))))
1346 (build-system python-build-system)
1347 (native-inputs
1348 `(("python-nose" ,python-nose)
1349 ("python-pyicu" ,python-pyicu)
1350 ("python-pytest" ,python-pytest)
1351 ("python-pytest-runner" ,python-pytest-runner)))
1352 (propagated-inputs
1353 `(("python-future" ,python-future)))
1354 (home-page "https://github.com/bear/parsedatetime/")
1355 (synopsis
1356 "Parse human-readable date/time text")
1357 (description
1358 "Parse human-readable date/time text.")
1359 (license license:asl2.0)))
1360
1361 (define-public python2-parsedatetime
1362 (package-with-python2 python-parsedatetime))
1363
1364 (define-public python-schedule
1365 (package
1366 (name "python-schedule")
1367 (version "0.4.3")
1368 (source
1369 (origin
1370 (method url-fetch)
1371 (uri (pypi-uri "schedule" version))
1372 (sha256
1373 (base32
1374 "0vplyjcbfrq50sphlwya749z8p2pcyi2nycw3518i0qpd9a6189i"))))
1375 (build-system python-build-system)
1376 (native-inputs
1377 `(("python-pytest" ,python-pytest)
1378 ("python-mock" ,python-mock)))
1379 (home-page "https://github.com/dbader/schedule")
1380 (synopsis "Schedule periodic function calls in Python")
1381 (description
1382 "Schedule is an in-process scheduler for periodic jobs that uses the
1383 builder pattern for configuration. Schedule lets you run Python functions (or
1384 any other callable) periodically at pre-determined intervals using a simple,
1385 human-friendly syntax.")
1386 (license license:expat)))
1387
1388 (define-public python2-schedule
1389 (package-with-python2 python-schedule))
1390
1391 (define-public python-pandas
1392 (package
1393 (name "python-pandas")
1394 (version "0.19.2")
1395 (source
1396 (origin
1397 (method url-fetch)
1398 (uri (pypi-uri "pandas" version))
1399 (sha256
1400 (base32 "0540cnbwy2hc4hv2sxfs8i47xi91qzvzxfn80dl785ibiicly3vg"))
1401 (patches
1402 (search-patches "python-pandas-skip-failing-tests.patch"))))
1403 (build-system python-build-system)
1404 (propagated-inputs
1405 `(("python-numpy" ,python-numpy)
1406 ("python-pytz" ,python-pytz)
1407 ("python-dateutil" ,python-dateutil)))
1408 (native-inputs
1409 `(("python-nose" ,python-nose)
1410 ("python-cython" ,python-cython)))
1411 (home-page "http://pandas.pydata.org")
1412 (synopsis "Data structures for data analysis, time series, and statistics")
1413 (description
1414 "Pandas is a Python package providing fast, flexible, and expressive data
1415 structures designed to make working with structured (tabular,
1416 multidimensional, potentially heterogeneous) and time series data both easy
1417 and intuitive. It aims to be the fundamental high-level building block for
1418 doing practical, real world data analysis in Python.")
1419 (license license:bsd-3)))
1420
1421 (define-public python2-pandas
1422 (package-with-python2 python-pandas))
1423
1424 (define-public python-tzlocal
1425 (package
1426 (name "python-tzlocal")
1427 (version "1.2.2")
1428 (source
1429 (origin
1430 (method url-fetch)
1431 (uri (pypi-uri "tzlocal" version))
1432 (sha256
1433 (base32
1434 "0paj7vlsb0np8b5sp4bv64wxv7qk2piyp7xg29pkhdjwsbls9fnb"))))
1435 (build-system python-build-system)
1436 (propagated-inputs
1437 `(("python-pytz" ,python-pytz)))
1438 (home-page "https://github.com/regebro/tzlocal")
1439 (synopsis
1440 "Local timezone information for Python")
1441 (description
1442 "Tzlocal returns a tzinfo object with the local timezone information.
1443 This module attempts to fix a glaring hole in pytz, that there is no way to
1444 get the local timezone information, unless you know the zoneinfo name, and
1445 under several distributions that's hard or impossible to figure out.")
1446 (license license:cc0)))
1447
1448 (define-public python2-pysqlite
1449 (package
1450 (name "python2-pysqlite")
1451 (version "2.8.3")
1452 (source
1453 (origin
1454 (method url-fetch)
1455 (uri (pypi-uri "pysqlite" version))
1456 (sha256
1457 (base32
1458 "1424gwq9sil2ffmnizk60q36vydkv8rxs6m7xs987kz8cdc37lqp"))))
1459 (build-system python-build-system)
1460 (inputs
1461 `(("sqlite" ,sqlite)))
1462 (arguments
1463 `(#:python ,python-2 ; incompatible with Python 3
1464 #:tests? #f)) ; no test target
1465 (home-page "https://github.com/ghaering/pysqlite")
1466 (synopsis "SQLite bindings for Python")
1467 (description
1468 "Pysqlite provides SQLite bindings for Python that comply to the
1469 Database API 2.0T.")
1470 (license license:zlib)))
1471
1472
1473 (define-public python2-mechanize
1474 (package
1475 (name "python2-mechanize")
1476 (version "0.2.5")
1477 (source
1478 (origin
1479 (method url-fetch)
1480 (uri (string-append "https://pypi.python.org/packages/source/m/mechanize/mechanize-"
1481 version ".tar.gz"))
1482 (sha256
1483 (base32
1484 "0rj7r166i1dyrq0ihm5rijfmvhs8a04im28lv05c0c3v206v4rrf"))))
1485 (build-system python-build-system)
1486 (arguments
1487 `(#:python ,python-2 ; apparently incompatible with Python 3
1488 #:tests? #f))
1489 ;; test fails with message
1490 ;; AttributeError: 'module' object has no attribute 'test_pullparser'
1491 ;; (python-3.3.2) or
1492 ;; AttributeError: 'module' object has no attribute 'test_urllib2_localnet'
1493 ;; (python-2.7.5).
1494 ;; The source code is from March 2011 and probably not up-to-date
1495 ;; with respect to python unit tests.
1496 (home-page "http://wwwsearch.sourceforge.net/mechanize/")
1497 (synopsis
1498 "Stateful programmatic web browsing in Python")
1499 (description
1500 "Mechanize implements stateful programmatic web browsing in Python,
1501 after Andy Lester’s Perl module WWW::Mechanize.")
1502 (license (license:non-copyleft
1503 "file://COPYING"
1504 "See COPYING in the distribution."))))
1505
1506
1507 (define-public python-simplejson
1508 (package
1509 (name "python-simplejson")
1510 (version "3.10.0")
1511 (source
1512 (origin
1513 (method url-fetch)
1514 (uri (pypi-uri "simplejson" version))
1515 (sha256
1516 (base32
1517 "1qhwsykjlb85igb4cfl6v6gkprzbbg8gyqdd7zscc8w3x0ifcfwm"))))
1518 (build-system python-build-system)
1519 (home-page "http://simplejson.readthedocs.org/en/latest/")
1520 (synopsis
1521 "Json library for Python")
1522 (description
1523 "JSON (JavaScript Object Notation) is a subset of JavaScript
1524 syntax (ECMA-262 3rd edition) used as a lightweight data interchange
1525 format.
1526
1527 Simplejson exposes an API familiar to users of the standard library marshal
1528 and pickle modules. It is the externally maintained version of the json
1529 library contained in Python 2.6, but maintains compatibility with Python 2.5
1530 and (currently) has significant performance advantages, even without using
1531 the optional C extension for speedups. Simplejson is also supported on
1532 Python 3.3+.")
1533 (license license:x11)))
1534
1535 (define-public python2-simplejson
1536 (package-with-python2 python-simplejson))
1537
1538
1539 (define-public python-pyicu
1540 (package
1541 (name "python-pyicu")
1542 (version "1.9.5")
1543 (source
1544 (origin
1545 (method url-fetch)
1546 (uri (pypi-uri "PyICU" version))
1547 (sha256
1548 (base32
1549 "16rmxy9y0qhqqna2v49i7nzwm09as699rbyvh4raw7w602w55c3k"))))
1550 (build-system python-build-system)
1551 (arguments
1552 '(#:phases
1553 (modify-phases %standard-phases
1554 (add-before 'check 'delete-failing-test
1555 (lambda _
1556 ;; XXX: These tests require locales that are unavailable
1557 ;; in the build environment.
1558 (delete-file "test/test_DateTimeParserGenerator.py")
1559 #t)))))
1560 (inputs
1561 `(("icu4c" ,icu4c)))
1562 (home-page "http://pyicu.osafoundation.org/")
1563 (synopsis "Python extension wrapping the ICU C++ API")
1564 (description
1565 "PyICU is a python extension wrapping the ICU C++ API.")
1566 (license license:x11)))
1567
1568 (define-public python2-pyicu
1569 (package-with-python2 python-pyicu))
1570
1571 (define-public python2-dogtail
1572 ;; Python 2 only, as it leads to "TabError: inconsistent use of tabs and
1573 ;; spaces in indentation" with Python 3.
1574 (package
1575 (name "python2-dogtail")
1576 (version "0.9.9")
1577 (source (origin
1578 (method url-fetch)
1579 (uri (pypi-uri "dogtail" version))
1580 (sha256
1581 (base32
1582 "0p5wfssvzr9w0bvhllzbbd8fnp4cca2qxcpcsc33dchrmh5n552x"))))
1583 (build-system python-build-system)
1584 (arguments `(#:python ,python-2
1585 #:tests? #f)) ; invalid command "test"
1586 ;; Currently no offical homepage.
1587 (home-page "https://pypi.python.org/pypi/dogtail/")
1588 (synopsis "GUI test tool and automation framework written in Python")
1589 (description
1590 "Dogtail is a GUI test tool and automation framework written in Python.
1591 It uses Accessibility (a11y) technologies to communicate with desktop
1592 applications. dogtail scripts are written in Python and executed like any
1593 other Python program.")
1594 (license license:gpl2+)))
1595
1596 (define-public python2-empy
1597 (package
1598 (name "python2-empy")
1599 (version "3.3")
1600 (source (origin
1601 (method url-fetch)
1602 (uri (string-append "http://www.alcyone.com/software/empy/empy-"
1603 version ".tar.gz"))
1604 (sha256
1605 (base32
1606 "01g8mmkfnvjdmlhsihwyx56lrg7r5m5d2fg6mnxsvy6g0dnl69f6"))))
1607 (build-system python-build-system)
1608 (arguments
1609 `(#:python ,python-2
1610 #:phases
1611 (modify-phases %standard-phases
1612 (replace 'check
1613 (lambda _
1614 (zero? (system* "./test.sh")))))))
1615 (home-page "http://www.alcyone.com/software/empy/")
1616 (synopsis "Templating system for Python")
1617 (description
1618 "EmPy is a system for embedding Python expressions and statements in
1619 template text; it takes an EmPy source file, processes it, and produces
1620 output. This is accomplished via expansions, which are special signals to the
1621 EmPy system and are set off by a special prefix (by default the at sign, @@).
1622 EmPy can expand arbitrary Python expressions and statements in this way, as
1623 well as a variety of special forms. Textual data not explicitly delimited in
1624 this way is sent unaffected to the output, allowing Python to be used in
1625 effect as a markup language. Also supported are callbacks via hooks,
1626 recording and playback via diversions, and dynamic, chainable filters. The
1627 system is highly configurable via command line options and embedded
1628 commands.")
1629 (license license:lgpl2.1+)))
1630
1631 (define-public python2-element-tree
1632 (package
1633 (name "python2-element-tree")
1634 (version "1.2.6")
1635 (source (origin
1636 (method url-fetch)
1637 (uri (string-append
1638 "http://effbot.org/media/downloads/elementtree-"
1639 version "-20050316.tar.gz"))
1640 (sha256
1641 (base32
1642 "016bphqnlg0l4vslahhw4r0aanw95bpypy65r1i1acyb2wj5z7dj"))))
1643 (build-system python-build-system)
1644 (arguments
1645 `(#:python ,python-2 ; seems to be part of Python 3
1646 #:tests? #f)) ; no 'test' sub-command
1647 (synopsis "Toolkit for XML processing in Python")
1648 (description
1649 "ElementTree is a Python library supporting lightweight XML processing.")
1650 (home-page "http://effbot.org/zone/element-index.htm")
1651 (license (license:x11-style
1652 "http://docs.python.org/2/license.html"
1653 "Like \"CWI LICENSE AGREEMENT FOR PYTHON 0.9.0 THROUGH 1.2\"."))))
1654
1655 (define-public python2-pybugz
1656 (package
1657 (name "python2-pybugz")
1658 (version "0.6.11")
1659 (source (origin
1660 (method url-fetch)
1661 (uri (string-append
1662 "http://bits.liquidx.net/projects/pybugz/pybugz-"
1663 version ".tar.gz"))
1664 (sha256
1665 (base32
1666 "17ni00p08gp5lkxlrrcnvi3x09fmajnlbz4da03qcgl9q21ym4jd"))
1667 (patches (search-patches "pybugz-stty.patch"
1668 "pybugz-encode-error.patch"))))
1669 (build-system python-build-system)
1670 (arguments
1671 `(#:python ,python-2 ; SyntaxError with Python 3
1672 #:tests? #f)) ; no 'test' sub-command
1673 (propagated-inputs
1674 `(("element-tree" ,python2-element-tree)))
1675 (synopsis "Python and command-line interface to Bugzilla")
1676 (description
1677 "PyBugz is a Python library and command-line tool to query the Bugzilla
1678 bug tracking system. It is meant as an aid to speed up interaction with the
1679 bug tracker.")
1680 (home-page "http://www.liquidx.net/pybugz/")
1681 (license license:gpl2)))
1682
1683 (define-public python-enum34
1684 (package
1685 (name "python-enum34")
1686 (version "1.1.6")
1687 (source
1688 (origin
1689 (method url-fetch)
1690 (uri (pypi-uri "enum34" version))
1691 (sha256
1692 (base32
1693 "1cgm5ng2gcfrkrm3hc22brl6chdmv67b9zvva9sfs7gn7dwc9n4a"))))
1694 (build-system python-build-system)
1695 (home-page "https://pypi.python.org/pypi/enum34")
1696 (synopsis "Backported Python 3.4 Enum")
1697 (description
1698 "Enum34 is the new Python stdlib enum module available in Python 3.4
1699 backported for previous versions of Python from 2.4 to 3.3.")
1700 (license license:bsd-3)))
1701
1702 (define-public python2-enum34
1703 (package-with-python2 python-enum34))
1704
1705 (define-public python-parse-type
1706 (package
1707 (name "python-parse-type")
1708 (version "0.3.4")
1709 (source
1710 (origin
1711 (method url-fetch)
1712 (uri (string-append "https://pypi.python.org/packages/source/p/"
1713 "parse_type/parse_type-" version ".tar.gz"))
1714 (sha256
1715 (base32
1716 "0iv1c34npr4iynwpgv1vkjx9rjd18a85ir8c01gc5f7wp8iv7l1x"))))
1717 (build-system python-build-system)
1718 (arguments
1719 `(#:phases
1720 (modify-phases %standard-phases
1721 (add-after 'unpack 'patch-tests
1722 (lambda _
1723 (substitute* "tests/test_parse_type_parse.py"
1724 ;; Newer Python versions don't have the problem this test tests.
1725 (("self[.]assertRaises[(]parse.TooManyFields, p.parse, ''[)]")
1726 ""))
1727 #t)))))
1728 (propagated-inputs
1729 `(("python-six" ,python-six)
1730 ("python-parse" ,python-parse)))
1731 (native-inputs
1732 `(("python-pytest" ,python-pytest)
1733 ("python-pytest-runner" ,python-pytest-runner)))
1734 (home-page "https://github.com/jenisys/parse_type")
1735 (synopsis "Extended parse module")
1736 (description
1737 "Parse_type extends the python parse module.")
1738 (properties
1739 `((python2-variant . ,(delay python2-parse-type))))
1740 (license license:bsd-3)))
1741
1742 (define-public python2-parse-type
1743 (let ((base (package-with-python2
1744 (strip-python2-variant python-parse-type))))
1745 (package (inherit base)
1746 (propagated-inputs
1747 `(("python2-enum34" ,python2-enum34)
1748 ,@(package-propagated-inputs base))))))
1749
1750 (define-public python-parse
1751 (package
1752 (name "python-parse")
1753 (version "1.6.6")
1754 (source
1755 (origin
1756 (method url-fetch)
1757 (uri (pypi-uri "parse" version))
1758 (sha256
1759 (base32
1760 "0y31i3mwgv35qn0kzzjn9q8jqfdqmbi6sr6yfvn8rq4lqjm5lhvi"))
1761 (patches (search-patches "python-parse-too-many-fields.patch"))))
1762 (build-system python-build-system)
1763 (arguments
1764 `(#:phases
1765 (modify-phases %standard-phases
1766 (replace 'check
1767 (lambda _ (zero? (system* "python" "test_parse.py")))))))
1768 (home-page "https://github.com/r1chardj0n3s/parse")
1769 (synopsis "Parse strings")
1770 (description
1771 "Parse strings using a specification based on the Python format()
1772 syntax.")
1773 (license license:x11)))
1774
1775 (define-public python-polib
1776 (package
1777 (name "python-polib")
1778 (version "1.0.8")
1779 (source (origin
1780 (method url-fetch)
1781 (uri (pypi-uri "polib" version))
1782 (sha256
1783 (base32
1784 "1pq2hbm3m2q0cjdszk8mc4qa1vl3wcblh5nfyirlfnzb2pcy7zss"))))
1785 (build-system python-build-system)
1786 (home-page "https://bitbucket.org/izi/polib/wiki/Home")
1787 (synopsis "Manipulate, create and modify gettext files")
1788 (description "Polib can manipulate any gettext format (po, pot and mo)
1789 files. It can be used to create po files from scratch or to modify
1790 existing ones.")
1791 (license license:expat)))
1792
1793 (define-public python2-polib
1794 (let ((base (package-with-python2 (strip-python2-variant python-polib))))
1795 (package
1796 (inherit base)
1797 (arguments `(,@(package-arguments base)
1798 ;; Tests don't work with python2.
1799 #:tests? #f)))))
1800
1801 (define-public scons
1802 (package
1803 (name "scons")
1804 (version "2.5.1")
1805 (source (origin
1806 (method url-fetch)
1807 (uri (string-append "mirror://sourceforge/scons/scons/" version
1808 "/scons-" version ".tar.gz"))
1809 (sha256
1810 (base32
1811 "1wji1z9jdkhnmm99apx6fhld9cs52rr56aigniyrcsmlwy52298b"))))
1812 (build-system python-build-system)
1813 (arguments
1814 ;; With Python 3.x, fails to build with a syntax error.
1815 `(#:python ,python-2
1816 #:use-setuptools? #f ; still relies on distutils
1817 #:tests? #f)) ; no 'python setup.py test' command
1818 (home-page "http://scons.org/")
1819 (synopsis "Software construction tool written in Python")
1820 (description
1821 "SCons is a software construction tool. Think of SCons as an improved,
1822 cross-platform substitute for the classic Make utility with integrated
1823 functionality similar to autoconf/automake and compiler caches such as ccache.
1824 In short, SCons is an easier, more reliable and faster way to build
1825 software.")
1826 (license license:x11)))
1827
1828 (define-public python-extras
1829 (package
1830 (name "python-extras")
1831 (version "0.0.3")
1832 (source
1833 (origin
1834 (method url-fetch)
1835 (uri (string-append
1836 "https://pypi.python.org/packages/source/e/extras/extras-"
1837 version ".tar.gz"))
1838 (sha256
1839 (base32
1840 "1h7zx4dfyclalg0fqnfjijpn0f793a9mx8sy3b27gd31nr6dhq3s"))))
1841 (build-system python-build-system)
1842 (arguments
1843 ;; error in setup.cfg: command 'test' has no such option 'buffer'
1844 '(#:tests? #f))
1845 (home-page "https://github.com/testing-cabal/extras")
1846 (synopsis "Useful extensions to the Python standard library")
1847 (description
1848 "Extras is a set of extensions to the Python standard library.")
1849 (license license:expat)))
1850
1851 (define-public python2-extras
1852 (package-with-python2 python-extras))
1853
1854 (define-public python-mimeparse
1855 (package
1856 (name "python-mimeparse")
1857 (version "0.1.4")
1858 (source
1859 (origin
1860 (method url-fetch)
1861 (uri (string-append
1862 "https://pypi.python.org/packages/source/p/python-mimeparse/python-mimeparse-"
1863 version ".tar.gz"))
1864 (sha256
1865 (base32
1866 "1hyxg09kaj02ri0rmwjqi86wk4nd1akvv7n0dx77azz76wga4s9w"))))
1867 (build-system python-build-system)
1868 (arguments
1869 '(#:tests? #f)) ; no setup.py test command
1870 (home-page
1871 "https://github.com/dbtsai/python-mimeparse")
1872 (synopsis "Python library for parsing MIME types")
1873 (description
1874 "Mimeparse provides basic functions for parsing MIME type names and
1875 matching them against a list of media-ranges.")
1876 (license license:expat)))
1877
1878 (define-public python2-mimeparse
1879 (package-with-python2 python-mimeparse))
1880
1881 (define-public python-nose
1882 (package
1883 (name "python-nose")
1884 (version "1.3.7")
1885 (source
1886 (origin
1887 (method url-fetch)
1888 (uri (pypi-uri "nose" version))
1889 (sha256
1890 (base32
1891 "164a43k7k2wsqqk1s6vavcdamvss4mz0vd6pwzv2h9n8rgwzxgzi"))))
1892 (build-system python-build-system)
1893 (arguments
1894 '(#:tests? #f)) ; FIXME: test suite fails
1895 (home-page "http://readthedocs.org/docs/nose/")
1896 (synopsis "Python testing library")
1897 (description
1898 "Nose extends the unittest library to make testing easier.")
1899 (license license:lgpl2.0+)))
1900
1901 (define-public python2-nose
1902 (package-with-python2 python-nose))
1903
1904 (define-public python-nose2
1905 (package
1906 (name "python-nose2")
1907 (version "0.6.5")
1908 (source
1909 (origin
1910 (method url-fetch)
1911 (uri (pypi-uri "nose2" version))
1912 (sha256
1913 (base32
1914 "1x4zjq1zlyrh8b9ba0cmafd3w94pxhid408kibyjd3s6h1lap6s7"))))
1915 (build-system python-build-system)
1916 (arguments `(#:tests? #f)) ; 'module' object has no attribute 'collector'
1917 (propagated-inputs
1918 `(("python-cov-core" ,python-cov-core)
1919 ("python-pytest-cov" ,python-pytest-cov)
1920 ("python-six" ,python-six)))
1921 (home-page "https://github.com/nose-devs/nose2")
1922 (synopsis "Next generation of nicer testing for Python")
1923 (description
1924 "Nose2 is the next generation of nicer testing for Python, based on the
1925 plugins branch of unittest2. Nose2 aims to improve on nose by providing a
1926 better plugin api, being easier for users to configure, and simplifying internal
1927 interfaces and processes.")
1928 (license license:bsd-2)))
1929
1930 (define-public python2-nose2
1931 (package-with-python2 python-nose2))
1932
1933 (define-public python-unittest2
1934 (package
1935 (name "python-unittest2")
1936 (version "0.5.1")
1937 (source
1938 (origin
1939 (method url-fetch)
1940 (uri (string-append
1941 "https://pypi.python.org/packages/source/u/unittest2py3k/unittest2py3k-"
1942 version ".tar.gz"))
1943 (sha256
1944 (base32
1945 "00yl6lskygcrddx5zspkhr0ibgvpknl4678kkm6s626539grq93q"))))
1946 (build-system python-build-system)
1947 (home-page "http://pypi.python.org/pypi/unittest2")
1948 (synopsis "Python unit testing library")
1949 (description
1950 "Unittest2 is a replacement for the unittest module in the Python
1951 standard library.")
1952 (license license:psfl)))
1953
1954 (define-public python2-unittest2
1955 (package (inherit python-unittest2)
1956 (name "python2-unittest2")
1957 (version "1.1.0")
1958 (source
1959 (origin
1960 (method url-fetch)
1961 (uri (string-append
1962 "https://pypi.python.org/packages/source/u/unittest2/unittest2-"
1963 version ".tar.gz"))
1964 (sha256
1965 (base32
1966 "0y855kmx7a8rnf81d3lh5lyxai1908xjp0laf4glwa4c8472m212"))
1967 (patches
1968 (search-patches "python2-unittest2-remove-argparse.patch"))))
1969 (propagated-inputs
1970 `(("python2-six" ,python2-six)
1971 ("python2-traceback2" ,python2-traceback2)))
1972 (arguments
1973 `(#:python ,python-2
1974 #:tests? #f)))) ; no setup.py test command
1975
1976 (define-public python-pafy
1977 (package
1978 (name "python-pafy")
1979 (version "0.5.3.1")
1980 (source
1981 (origin
1982 (method url-fetch)
1983 (uri (pypi-uri "pafy" version))
1984 (sha256
1985 (base32
1986 "1a7dxi95m1043rxx1r5x3ngb66nwlq6aqcasyqqjzmmmjps4zrim"))))
1987 (build-system python-build-system)
1988 (arguments
1989 `(#:tests? #f)) ; Currently pafy can not find itself in the tests
1990 (propagated-inputs
1991 ;; Youtube-dl is a python package which is imported in the file
1992 ;; "backend_youtube_dl.py", therefore it needs to be propagated.
1993 `(("youtube-dl" ,youtube-dl)))
1994 (home-page "https://np1.github.io/pafy/")
1995 (synopsis "Retrieve YouTube content and metadata")
1996 (description
1997 "@code{pafy} is a python library to retrieve YouTube content and metadata.")
1998 (license license:lgpl3+)))
1999
2000 (define-public python-py
2001 (package
2002 (name "python-py")
2003 (version "1.4.32")
2004 (source
2005 (origin
2006 (method url-fetch)
2007 (uri (pypi-uri "py" version))
2008 (sha256
2009 (base32
2010 "19s1pql9pq85h1qzsdwgyb8a3k1qgkvh33b02m8kfqhizz8rzf64"))))
2011 (build-system python-build-system)
2012 (arguments
2013 ;; FIXME: "ImportError: 'test' module incorrectly imported from
2014 ;; '/gnu/store/...-python-pytest-mimimal-3.0.5/lib/python3.5/site-packages'.
2015 ;; Expected '/tmp/guix-build-python-py-1.4.31.drv-0/py-1.4.31/py'.
2016 ;; Is this module globally installed?"
2017 '(#:tests? #f))
2018 (home-page "http://pylib.readthedocs.org/")
2019 (synopsis "Python library for parsing, I/O, instrospection, and logging")
2020 (description
2021 "Py is a Python library for file name parsing, .ini file parsing, I/O,
2022 code introspection, and logging.")
2023 (license license:expat)))
2024
2025 (define-public python2-py
2026 (package-with-python2 python-py))
2027
2028 (define-public python-pytest
2029 (package
2030 (name "python-pytest")
2031 (version "2.7.3")
2032 (source
2033 (origin
2034 (method url-fetch)
2035 (uri (string-append
2036 "https://pypi.python.org/packages/source/p/pytest/pytest-"
2037 version ".tar.gz"))
2038 (sha256
2039 (base32
2040 "1z4yi986f9n0p8qmzmn21m21m8j1x78hk3505f89baqm6pdw7afm"))
2041 (modules '((guix build utils)))
2042 (snippet
2043 ;; One of the tests involves the /usr directory, so it fails.
2044 '(substitute* "testing/test_argcomplete.py"
2045 (("def test_remove_dir_prefix\\(self\\):")
2046 "@pytest.mark.xfail\n def test_remove_dir_prefix(self):")))))
2047 (build-system python-build-system)
2048 (propagated-inputs
2049 `(("python-py" ,python-py)))
2050 (native-inputs
2051 `(;; Tests need the "regular" bash since 'bash-final' lacks `compgen`.
2052 ("bash" ,bash)
2053 ("python-nose" ,python-nose)
2054 ("python-mock" ,python-mock)))
2055 (home-page "http://pytest.org")
2056 (synopsis "Python testing library")
2057 (description
2058 "Pytest is a testing tool that provides auto-discovery of test modules
2059 and functions, detailed info on failing assert statements, modular fixtures,
2060 and many external plugins.")
2061 (license license:expat)))
2062
2063 (define-public python2-pytest
2064 (package-with-python2 python-pytest))
2065
2066 ;; Some packages require a newer pytest.
2067 (define-public python-pytest-3.0
2068 (package
2069 (inherit python-pytest)
2070 (name "python-pytest")
2071 (version "3.0.7")
2072 (source (origin
2073 (method url-fetch)
2074 (uri (pypi-uri "pytest" version))
2075 (sha256
2076 (base32
2077 "1asc4b2nd2a4f0g3r12y97rslq5wliji7b73wwkvdrm5s7mrc1mp"))))
2078 (arguments
2079 `(#:phases
2080 (modify-phases %standard-phases
2081 (add-before 'check 'disable-invalid-test
2082 (lambda _
2083 (substitute* "testing/test_argcomplete.py"
2084 (("def test_remove_dir_prefix" line)
2085 (string-append "@pytest.mark.skip"
2086 "(reason=\"Assumes that /usr exists.\")\n "
2087 line)))
2088 #t)))))
2089 (native-inputs
2090 `(("python-hypothesis" ,python-hypothesis)
2091 ,@(package-native-inputs python-pytest)))
2092 (properties `((python2-variant . ,(delay python2-pytest-3.0))))))
2093
2094 (define-public python2-pytest-3.0
2095 (let ((base (package-with-python2
2096 (strip-python2-variant python-pytest-3.0))))
2097 (package (inherit base)
2098 (native-inputs
2099 `(("python2-enum34" ,python2-enum34)
2100 ,@(package-native-inputs base))))))
2101
2102 (define-public python-pytest-cov
2103 (package
2104 (name "python-pytest-cov")
2105 (version "2.4.0")
2106 (source
2107 (origin
2108 (method url-fetch)
2109 (uri (pypi-uri "pytest-cov" version))
2110 (sha256
2111 (base32
2112 "03c2qc42r4bczyw93gd7n0qi1h1jfhw7fnbhi33c3vp1hs81gm2k"))))
2113 (build-system python-build-system)
2114 (arguments
2115 `(#:phases
2116 (modify-phases %standard-phases
2117 (replace 'check
2118 (lambda _
2119 ;; options taken from tox.ini
2120 ;; TODO: make "--restructuredtext" tests pass. They currently fail
2121 ;; with "Duplicate implicit target name"
2122 (zero? (system* "python" "./setup.py" "check"
2123 "--strict" "--metadata")))))))
2124 (propagated-inputs
2125 `(("python-coverage" ,python-coverage)
2126 ("python-pytest" ,python-pytest)))
2127 (home-page "https://github.com/pytest-dev/pytest-cov")
2128 (synopsis "Pytest plugin for measuring coverage")
2129 (description
2130 "Pytest-cov produces coverage reports. It supports centralised testing and
2131 distributed testing in both @code{load} and @code{each} modes. It also
2132 supports coverage of subprocesses.")
2133 (license license:expat)))
2134
2135 (define-public python2-pytest-cov
2136 (package-with-python2 python-pytest-cov))
2137
2138 (define-public python-pytest-runner
2139 (package
2140 (name "python-pytest-runner")
2141 (version "2.11.1")
2142 (source
2143 (origin
2144 (method url-fetch)
2145 (uri (pypi-uri "pytest-runner" version))
2146 (sha256
2147 (base32
2148 "1cw978kqqcq916b9gfns1qjqvg33c5ail5jhw9054dsynkm32flq"))))
2149 (build-system python-build-system)
2150 (arguments
2151 `(#:phases
2152 (modify-phases %standard-phases
2153 ;; The fancy way of setting the version with setuptools_scm does not
2154 ;; seem to work here.
2155 (add-after 'unpack 'set-version
2156 (lambda _
2157 (substitute* "docs/conf.py"
2158 (("version = setuptools_scm\\.get_version\\(root='\\.\\.')")
2159 (string-append "version = \"" ,version "\"")))
2160 #t)))))
2161 (native-inputs
2162 `(("python-pytest" ,python-pytest)
2163 ("python-setuptools-scm" ,python-setuptools-scm)))
2164 (home-page "https://github.com/pytest-dev/pytest-runner")
2165 (synopsis "Invoke py.test as a distutils command")
2166 (description
2167 "This package provides a @command{pytest-runner} command that
2168 @file{setup.py} files can use to run tests.")
2169 (license license:expat)))
2170
2171 (define-public python2-pytest-runner
2172 (package-with-python2 python-pytest-runner))
2173
2174 (define-public python-pytest-mock
2175 (package
2176 (name "python-pytest-mock")
2177 (version "1.2")
2178 (source
2179 (origin
2180 (method url-fetch)
2181 (uri (pypi-uri "pytest-mock" version ".zip"))
2182 (sha256
2183 (base32
2184 "03zxar5drzm7ksqyrwypjaza3cri6wqvpr6iam92djvg6znp32gp"))))
2185 (build-system python-build-system)
2186 (native-inputs
2187 `(("unzip" ,unzip)))
2188 (propagated-inputs
2189 `(("python-pytest" ,python-pytest)))
2190 (home-page "https://github.com/pytest-dev/pytest-mock/")
2191 (synopsis "Thin-wrapper around the mock package for easier use with py.test")
2192 (description
2193 "This plugin installs a @code{mocker} fixture which is a thin-wrapper
2194 around the patching API provided by the @code{mock} package, but with the
2195 benefit of not having to worry about undoing patches at the end of a test.
2196 The mocker fixture has the same API as @code{mock.patch}, supporting the
2197 same arguments.")
2198 (properties `((python2-variant . ,(delay python2-pytest-mock))))
2199 (license license:expat)))
2200
2201 (define-public python2-pytest-mock
2202 (let ((base (package-with-python2
2203 (strip-python2-variant python-pytest-mock))))
2204 (package (inherit base)
2205 (propagated-inputs
2206 `(("python2-mock" ,python2-mock)
2207 ,@(package-propagated-inputs base))))))
2208
2209 (define-public python-pytest-xdist
2210 (package
2211 (name "python-pytest-xdist")
2212 (version "1.14")
2213 (source
2214 (origin
2215 (method url-fetch)
2216 (uri (pypi-uri "pytest-xdist" version ".zip"))
2217 (sha256
2218 (base32
2219 "08rn2l39ds60xshs4js787l84pfckksqklfq2wq9x8ig2aci2pja"))
2220 (modules '((guix build utils)))
2221 (snippet
2222 '(begin
2223 ;; Remove pre-compiled .pyc files from source.
2224 (for-each delete-file-recursively
2225 (find-files "." "__pycache__" #:directories? #t))
2226 (for-each delete-file (find-files "." "\\.pyc$"))
2227 #t))))
2228 (build-system python-build-system)
2229 (arguments
2230 '(#:tests? #f)) ;FIXME: Some tests are failing.
2231 ;; #:phases
2232 ;; (modify-phases %standard-phases
2233 ;; (delete 'check)
2234 ;; (add-after 'install 'check
2235 ;; (lambda* (#:key inputs outputs #:allow-other-keys)
2236 ;; (add-installed-pythonpath inputs outputs)
2237 ;; (zero? (system* "py.test" "-v")))))
2238 (native-inputs
2239 `(("unzip" ,unzip)
2240 ("python-setuptools-scm" ,python-setuptools-scm)))
2241 (propagated-inputs
2242 `(("python-execnet" ,python-execnet)
2243 ("python-pytest" ,python-pytest)
2244 ("python-py" ,python-py)))
2245 (home-page
2246 "https://github.com/pytest-dev/pytest-xdist")
2247 (synopsis
2248 "Plugin for py.test with distributed testing and loop-on-failing modes")
2249 (description
2250 "The pytest-xdist plugin extends py.test with some unique test execution
2251 modes: parallelization, running tests in boxed subprocesses, the ability
2252 to run tests repeatedly when failed, and the ability to run tests on multiple
2253 Python interpreters or platforms. It uses rsync to copy the existing
2254 program code to a remote location, executes there, and then syncs the
2255 result back.")
2256 (license license:expat)))
2257
2258 (define-public python2-pytest-xdist
2259 (package-with-python2 python-pytest-xdist))
2260
2261 (define-public python-scripttest
2262 (package
2263 (name "python-scripttest")
2264 (version "1.3")
2265 (source
2266 (origin
2267 (method url-fetch)
2268 (uri (string-append
2269 "https://pypi.python.org/packages/source/s/scripttest/scripttest-"
2270 version ".tar.gz"))
2271 (sha256
2272 (base32
2273 "0f4w84k8ck82syys7yg9maz93mqzc8p5ymis941x034v44jzq74m"))))
2274 (build-system python-build-system)
2275 (native-inputs
2276 `(("python-pytest" ,python-pytest)))
2277 (home-page "http://pythonpaste.org/scripttest/")
2278 (synopsis "Python library to test command-line scripts")
2279 (description "Scripttest is a Python helper library for testing
2280 interactive command-line applications. With it you can run a script in a
2281 subprocess and see the output as well as any file modifications.")
2282 (license license:expat)))
2283
2284 (define-public python2-scripttest
2285 (package-with-python2 python-scripttest))
2286
2287 (define-public python-testtools
2288 (package
2289 (name "python-testtools")
2290 (version "1.4.0")
2291 (source
2292 (origin
2293 (method url-fetch)
2294 (uri (pypi-uri "testtools" version))
2295 (sha256
2296 (base32
2297 "1vw8yljnd75d396hhw6s2hrf4cclzy845ifd5am0lxsl235z3i8c"))))
2298 (build-system python-build-system)
2299 (arguments
2300 `(#:phases
2301 (modify-phases %standard-phases
2302 (add-after 'unpack 'fix-module-imports
2303 (lambda _
2304 (substitute* "setup.py"
2305 (("'unittest2>=0.8.0',") ""))
2306 (substitute* '("testtools/testcase.py"
2307 "testtools/testsuite.py"
2308 "testtools/run.py"
2309 "testtools/tests/test_run.py"
2310 "testtools/tests/test_testsuite.py"
2311 "testtools/tests/test_deferredruntest.py")
2312 ;; unittest2 is a backport of Python2.7 features to Python 2.4.
2313 (("import unittest2 as unittest") "import unittest")
2314 (("import unittest2") "import unittest as unittest2")
2315 (("from unittest2 import") "from unittest import"))
2316 (substitute* "testtools/tests/test_testresult.py"
2317 ;; NUL in source code is not allowed (raises ValueError).
2318 (("\\x00\\x04") "\\x04"))
2319 #t)))))
2320 (propagated-inputs
2321 `(("python-mimeparse" ,python-mimeparse)
2322 ("python-extras" ,python-extras)))
2323 (home-page "https://github.com/testing-cabal/testtools")
2324 (synopsis
2325 "Extensions to the Python standard library unit testing framework")
2326 (description
2327 "Testtools extends the Python standard library unit testing framework to
2328 provide matchers, more debugging information, and cross-Python
2329 compatibility.")
2330 (license license:psfl)))
2331
2332 (define-public python2-testtools
2333 (package-with-python2 python-testtools))
2334
2335 (define-public python-testscenarios
2336 (package
2337 (name "python-testscenarios")
2338 (version "0.4")
2339 (source
2340 (origin
2341 (method url-fetch)
2342 (uri (string-append
2343 "https://pypi.python.org/packages/source/t/testscenarios/testscenarios-"
2344 version ".tar.gz"))
2345 (sha256
2346 (base32
2347 "1671jvrvqlmbnc42j7pc5y6vc37q44aiwrq0zic652pxyy2fxvjg"))))
2348 (build-system python-build-system)
2349 (propagated-inputs
2350 `(("python-testtools" ,python-testtools)))
2351 (home-page "https://launchpad.net/testscenarios")
2352 (synopsis "Pyunit extension for dependency injection")
2353 (description
2354 "Testscenarios provides clean dependency injection for Python unittest
2355 style tests.")
2356 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2357
2358 (define-public python2-testscenarios
2359 (package-with-python2 python-testscenarios))
2360
2361 (define-public python-testresources
2362 (package
2363 (name "python-testresources")
2364 (version "0.2.7")
2365 (source
2366 (origin
2367 (method url-fetch)
2368 (uri (string-append
2369 "https://pypi.python.org/packages/source/t/testresources/testresources-"
2370 version ".tar.gz"))
2371 (sha256
2372 (base32
2373 "0cbj3plbllyz42c4b5xxgwaa7mml54lakslrn4kkhinxhdri22md"))))
2374 (build-system python-build-system)
2375 (home-page "https://launchpad.net/testresources")
2376 (synopsis
2377 "Pyunit extension for managing test resources")
2378 (description
2379 "Testresources is an extension to Python's unittest to allow declarative
2380 use of resources by test cases.")
2381 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2382
2383 (define-public python2-testresources
2384 (package-with-python2 python-testresources))
2385
2386 (define-public python-subunit
2387 (package
2388 (name "python-subunit")
2389 (version "0.0.21")
2390 (source
2391 (origin
2392 (method url-fetch)
2393 (uri (string-append
2394 "https://pypi.python.org/packages/source/p/python-subunit/python-subunit-"
2395 version ".tar.gz"))
2396 (sha256
2397 (base32
2398 "1nkw9wfbvizmpajbj3in8ns07g7lwkiv8hip14jjlwk3cacls6jv"))))
2399 (build-system python-build-system)
2400 (propagated-inputs
2401 `(("python-extras" ,python-extras)
2402 ("python-mimeparse" ,python-mimeparse)))
2403 (native-inputs
2404 `(("python-testscenarios" ,python-testscenarios)))
2405 (home-page "http://launchpad.net/subunit")
2406 (synopsis "Python implementation of the subunit protocol")
2407 (description
2408 "Python-subunit is a Python implementation of the subunit test streaming
2409 protocol.")
2410 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2411
2412 (define-public python2-subunit
2413 (package-with-python2 python-subunit))
2414
2415 ;; Recent versions of python-fixtures and python-testrepository need
2416 ;; python-pbr for packaging, which itself needs these two packages for
2417 ;; testing.
2418 ;; To fix this circular dependency, we use a build of python-pbr, based on the
2419 ;; same source, just without any test dependencies and with tests disabled.
2420 ;; python-pbr-minmal is then used to package python-fixtures and
2421 ;; python-testrepository.
2422 ;; Strictly speaking we currently could remove the test-requirements from the
2423 ;; normal python-pbr package (and save this package) since test are disabled
2424 ;; there anyway. But this may change in future.
2425 (define python-pbr-minimal
2426 (package
2427 (name "python-pbr-minimal")
2428 (version "3.0.1")
2429 (source
2430 (origin
2431 (method url-fetch)
2432 (uri (pypi-uri "pbr" version))
2433 (sha256
2434 (base32
2435 "14fs5acnalnb3h62s7q7av239j541fk0n0z0lawh4h09b1s93s6p"))))
2436 (build-system python-build-system)
2437 (arguments
2438 `(#:tests? #f))
2439 (home-page "http://docs.openstack.org/developer/pbr/")
2440 (synopsis "Minimal build of python-pbr used for bootstrapping")
2441 (description
2442 "Used only for bootstrapping python2-pbr, you should not need this.")
2443 (license license:asl2.0)))
2444
2445 (define python2-pbr-minimal
2446 (package-with-python2 python-pbr-minimal))
2447
2448 (define-public python-pbr
2449 (package
2450 (inherit python-pbr-minimal)
2451 (name "python-pbr")
2452 (arguments
2453 `(#:tests? #f)) ;; Most tests seem to use the Internet.
2454 (propagated-inputs
2455 `(("git" ,git))) ;; pbr actually uses the "git" binary.
2456 (native-inputs
2457 `(("python-fixtures" ,python-fixtures)
2458 ;; discover, coverage, hacking, subunit
2459 ("python-mock" ,python-mock)
2460 ("python-six" ,python-six)
2461 ("python-sphinx" ,python-sphinx)
2462 ("python-testrepository" ,python-testrepository)
2463 ("python-testresources" ,python-testresources)
2464 ("python-testscenarios" ,python-testscenarios)
2465 ("python-testtools" ,python-testtools)
2466 ("python-virtualenv" ,python-virtualenv)))
2467 (synopsis "Enhance the default behavior of Python’s setuptools")
2468 (description
2469 "Python Build Reasonableness (PBR) is a library that injects some useful
2470 and sensible default behaviors into your setuptools run. It will set
2471 versions, process requirements files and generate AUTHORS and ChangeLog file
2472 from git information.
2473 ")))
2474
2475 (define-public python2-pbr
2476 (package-with-python2 python-pbr))
2477
2478 (define-public python-fixtures
2479 (package
2480 (name "python-fixtures")
2481 (version "1.4.0")
2482 (source
2483 (origin
2484 (method url-fetch)
2485 (uri (pypi-uri "fixtures" version))
2486 (sha256
2487 (base32
2488 "0djxvdwm8s60dbfn7bhf40x6g818p3b3mlwijm1c3bqg7msn271y"))))
2489 (build-system python-build-system)
2490 (arguments
2491 '(#:phases
2492 (modify-phases %standard-phases
2493 (replace 'check
2494 (lambda _
2495 (zero? (system* "python" "-m" "testtools.run"
2496 "fixtures.test_suite")))))))
2497 (propagated-inputs
2498 `(("python-six" ,python-six)))
2499 (native-inputs
2500 `(("python-mock" ,python-mock)
2501 ("python-pbr-minimal" ,python-pbr-minimal)
2502 ("python-testtools" ,python-testtools)))
2503 (home-page "https://launchpad.net/python-fixtures")
2504 (synopsis "Python test fixture library")
2505 (description
2506 "Fixtures provides a way to create reusable state, useful when writing
2507 Python tests.")
2508 (license (list license:bsd-3 license:asl2.0)))) ; at user's option
2509
2510 (define-public python2-fixtures
2511 (package-with-python2 python-fixtures))
2512
2513 (define-public python-testrepository
2514 (package
2515 (name "python-testrepository")
2516 (version "0.0.20")
2517 (source
2518 (origin
2519 (method url-fetch)
2520 (uri (string-append
2521 "https://pypi.python.org/packages/source/t/testrepository/testrepository-"
2522 version ".tar.gz"))
2523 (sha256
2524 (base32
2525 "1ssqb07c277010i6gzzkbdd46gd9mrj0bi0i8vn560n2k2y4j93m"))))
2526 (build-system python-build-system)
2527 (arguments
2528 ;; FIXME: Many tests are failing.
2529 '(#:tests? #f))
2530 (propagated-inputs
2531 `(("python-fixtures" ,python-fixtures)
2532 ("python-subunit" ,python-subunit)
2533 ("python-testtools" ,python-testtools)))
2534 (native-inputs
2535 `(("python-pbr-minimal" ,python-pbr-minimal) ;; same as for building fixture
2536 ("python-mimeparse" ,python-mimeparse)))
2537 (home-page "https://launchpad.net/testrepository")
2538 (synopsis "Database for Python test results")
2539 (description "Testrepository provides a database of test results which can
2540 be used as part of a developer's workflow to check things such as what tests
2541 have failed since the last commit or what tests are currently failing.")
2542 (license (list license:bsd-3 license:asl2.0)))) ; at user's option
2543
2544 (define-public python2-testrepository
2545 (package-with-python2 python-testrepository))
2546
2547 (define-public python-coverage
2548 (package
2549 (name "python-coverage")
2550 (version "4.1")
2551 (source
2552 (origin
2553 (method url-fetch)
2554 (uri (pypi-uri "coverage" version))
2555 (sha256
2556 (base32
2557 "01rbr4br4lsk0lwn8fb96zwd2xr4f0mg1w7iq3j11i8f5ig2nqs1"))))
2558 (build-system python-build-system)
2559 (arguments
2560 ;; FIXME: 95 tests failed, 539 passed, 6 skipped, 2 errors.
2561 '(#:tests? #f))
2562 (home-page "http://nedbatchelder.com/code/coverage")
2563 (synopsis "Code coverage measurement for Python")
2564 (description
2565 "Coverage measures code coverage, typically during test execution. It
2566 uses the code analysis tools and tracing hooks provided in the Python standard
2567 library to determine which lines are executable, and which have been
2568 executed.")
2569 (license license:bsd-3)))
2570
2571 (define-public python2-coverage
2572 (package-with-python2 python-coverage))
2573
2574 (define-public python-cov-core
2575 (package
2576 (name "python-cov-core")
2577 (version "1.15.0")
2578 (source
2579 (origin
2580 (method url-fetch)
2581 (uri (pypi-uri "cov-core" version))
2582 (sha256
2583 (base32
2584 "0k3np9ymh06yv1ib96sb6wfsxjkqhmik8qfsn119vnhga9ywc52a"))))
2585 (build-system python-build-system)
2586 (propagated-inputs
2587 `(("python-coverage" ,python-coverage)))
2588 (home-page "https://github.com/schlamar/cov-core")
2589 (synopsis "Coverage plugin core for pytest-cov, nose-cov and nose2-cov")
2590 (description
2591 "This is a library package for use by @code{pytest-cov}, @code{nose-cov}
2592 and @code{nose2-cov}. It is useful for developing coverage plugins for these
2593 testing frameworks.")
2594 (license license:expat)))
2595
2596 (define-public python2-cov-core
2597 (package-with-python2 python-cov-core))
2598
2599 (define-public python-discover
2600 (package
2601 (name "python-discover")
2602 (version "0.4.0")
2603 (source
2604 (origin
2605 (method url-fetch)
2606 (uri (string-append
2607 "https://pypi.python.org/packages/source/d/discover/discover-"
2608 version ".tar.gz"))
2609 (sha256
2610 (base32
2611 "0y8d0zwiqar51kxj8lzmkvwc3b8kazb04gk5zcb4nzg5k68zmhq5"))))
2612 (build-system python-build-system)
2613 (home-page "http://pypi.python.org/pypi/discover/")
2614 (synopsis
2615 "Python test discovery for unittest")
2616 (description
2617 "Discover provides test discovery for unittest, a feature that has been
2618 backported from Python 2.7 for Python 2.4+.")
2619 (license license:bsd-3)))
2620
2621 (define-public python2-discover
2622 (package-with-python2 python-discover))
2623
2624 (define-public behave
2625 (package
2626 (name "behave")
2627 (version "1.2.5")
2628 (source (origin
2629 (method url-fetch)
2630 (uri (pypi-uri "behave" version ".tar.bz2"))
2631 (sha256
2632 (base32
2633 "1iypp6z46r19n4xmgx6m1lwmlpfjh8vapq8izigrqlaarvp2y64c"))))
2634 (build-system python-build-system)
2635 (propagated-inputs
2636 `(("python-six" ,python-six)
2637 ("python-parse" ,python-parse)
2638 ("python-parse-type" ,python-parse-type)))
2639 (arguments `(#:tests? #f)) ;TODO: tests require nose>=1.3 and
2640 ;PyHamcrest>=1.8
2641 (home-page "https://github.com/behave/behave")
2642 (synopsis "Python behavior-driven development")
2643 (description
2644 "Behave is a tool for behavior-driven development in python.
2645 Behavior-driven development (or BDD) is an agile software development
2646 technique that encourages collaboration between developers, QA and
2647 non-technical or business participants in a software project. Behave uses
2648 tests written in a natural language style, backed up by Python code.")
2649 (license license:x11)))
2650
2651 (define-public python-exif-read
2652 (package
2653 (name "python-exif-read")
2654 (version "2.1.2")
2655 (source (origin
2656 (method url-fetch)
2657 (uri (pypi-uri "ExifRead" version))
2658 (sha256
2659 (base32
2660 "1b90jf6m9vxh9nanhpyvqdq7hmfx5iggw1l8kq10jrs6xgr49qkr"))))
2661 (build-system python-build-system)
2662 (arguments `(#:tests? #f)) ; no tests
2663 (home-page "https://github.com/ianare/exif-py")
2664 (synopsis "Python library to extract EXIF data from image files")
2665 (description
2666 "ExifRead is a Python library to extract EXIF data from tiff and jpeg
2667 files.")
2668 (license license:bsd-3)))
2669
2670 (define-public python2-exif-read
2671 (package-with-python2 python-exif-read))
2672
2673 (define-public python-pyld
2674 (package
2675 (name "python-pyld")
2676 (version "0.7.1")
2677 (source (origin
2678 (method url-fetch)
2679 (uri (pypi-uri "PyLD" version))
2680 (sha256
2681 (base32
2682 "1m0fs6897vxfkf7awah5i66i7b7smm5fnywf1w50fpzyfbfhr156"))))
2683 (build-system python-build-system)
2684 (arguments `(#:tests? #f)) ; no tests
2685 (home-page "https://github.com/digitalbazaar/pyld")
2686 (synopsis "Python implementation of the JSON-LD specification")
2687 (description
2688 "PyLD is an implementation of the JSON-LD specification.")
2689 (license license:bsd-3)))
2690
2691 (define-public python2-pyld
2692 (package-with-python2 python-pyld))
2693
2694 (define-public python-certifi
2695 (package
2696 (name "python-certifi")
2697 (version "2017.1.23")
2698 (source (origin
2699 (method url-fetch)
2700 (uri (pypi-uri "certifi" version))
2701 (sha256
2702 (base32
2703 "1klrzl3hgvcf2mjk00g0k3kk1p2z27vzwnxivwar4vhjmjvpz1w1"))))
2704 (build-system python-build-system)
2705 (home-page "https://certifi.io/")
2706 (synopsis "Python CA certificate bundle")
2707 (description
2708 "Certifi is a Python library that contains a CA certificate bundle, which
2709 is used by the Requests library to verify HTTPS requests.")
2710 (license license:asl2.0)))
2711
2712 (define-public python2-certifi
2713 (package-with-python2 python-certifi))
2714
2715 (define-public python-click
2716 (package
2717 (name "python-click")
2718 (version "6.7")
2719 (source
2720 (origin
2721 (method url-fetch)
2722 (uri (pypi-uri "click" version))
2723 (sha256
2724 (base32
2725 "02qkfpykbq35id8glfgwc38yc430427yd05z1wc5cnld8zgicmgi"))))
2726 (build-system python-build-system)
2727 (arguments
2728 `(#:phases
2729 (modify-phases %standard-phases
2730 (add-after 'unpack 'fix-paths
2731 (lambda* (#:key inputs #:allow-other-keys)
2732 (let ((glibc (assoc-ref inputs ,(if (%current-target-system)
2733 "cross-libc" "libc"))))
2734 (substitute* "click/_unicodefun.py"
2735 (("'locale'")
2736 (string-append "'" glibc "/bin/locale'"))))
2737 #t))
2738 (replace 'check
2739 (lambda _
2740 (zero? (system* "make" "test")))))))
2741 (native-inputs
2742 `(("python-pytest" ,python-pytest)))
2743 (home-page "http://click.pocoo.org")
2744 (synopsis "Command line library for Python")
2745 (description
2746 "Click is a Python package for creating command line interfaces in a
2747 composable way with as little code as necessary. Its name stands for
2748 \"Command Line Interface Creation Kit\". It's highly configurable but comes
2749 with sensible defaults out of the box.")
2750 (license license:bsd-3)))
2751
2752 (define-public python2-click
2753 (package-with-python2 python-click))
2754
2755 (define-public python-wheel
2756 (package
2757 (name "python-wheel")
2758 (version "0.30.0a0")
2759 (source
2760 (origin
2761 (method url-fetch)
2762 (uri (pypi-uri "wheel" version))
2763 (sha256
2764 (base32
2765 "1nm6mn8isny0hr86rhbfrpfj867c0phf001xgsd69xfp9ady1wwq"))))
2766 (build-system python-build-system)
2767 (native-inputs
2768 `(("python-jsonschema" ,python-jsonschema)
2769 ("python-pytest-cov" ,python-pytest-cov)))
2770 (home-page "https://bitbucket.org/pypa/wheel/")
2771 (synopsis "Format for built Python packages")
2772 (description
2773 "A wheel is a ZIP-format archive with a specially formatted filename and
2774 the @code{.whl} extension. It is designed to contain all the files for a PEP
2775 376 compatible install in a way that is very close to the on-disk format. Many
2776 packages will be properly installed with only the @code{Unpack} step and the
2777 unpacked archive preserves enough information to @code{Spread} (copy data and
2778 scripts to their final locations) at any later time. Wheel files can be
2779 installed with a newer @code{pip} or with wheel's own command line utility.")
2780 (license license:expat)
2781 (properties `((python2-variant . ,(delay python2-wheel))))))
2782
2783 (define-public python2-wheel
2784 (let ((wheel (package-with-python2
2785 (strip-python2-variant python-wheel))))
2786 (package (inherit wheel)
2787 (native-inputs `(("python2-functools32" ,python2-functools32)
2788 ,@(package-native-inputs wheel))))))
2789
2790
2791 (define-public python-requests
2792 (package
2793 (name "python-requests")
2794 (version "2.13.0")
2795 (source (origin
2796 (method url-fetch)
2797 (uri (pypi-uri "requests" version))
2798 (sha256
2799 (base32
2800 "1s0wg4any4dsv5l3hqjxqk2zgb7pdbqhy9rhc8kh3aigfq4ws8jp"))))
2801 ;; TODO: unbundle urllib3 and chardet.
2802 (build-system python-build-system)
2803 (arguments
2804 ;; FIXME: Some tests require network access.
2805 '(#:tests? #f))
2806 (home-page "http://python-requests.org/")
2807 (synopsis "Python HTTP library")
2808 (description
2809 "Requests is a Python HTTP client library. It aims to be easier to use
2810 than Python’s urllib2 library.")
2811 (license license:asl2.0)))
2812
2813 ;; Some software requires an older version of Requests, notably Docker
2814 ;; Compose.
2815 (define-public python-requests-2.7
2816 (package (inherit python-requests)
2817 (version "2.7.0")
2818 (source (origin
2819 (method url-fetch)
2820 (uri (pypi-uri "requests" version))
2821 (sha256
2822 (base32
2823 "0gdr9dxm24amxpbyqpbh3lbwxc2i42hnqv50sigx568qssv3v2ir"))))))
2824
2825 (define-public python2-requests
2826 (package-with-python2 python-requests))
2827
2828 (define-public python-vcversioner
2829 (package
2830 (name "python-vcversioner")
2831 (version "2.16.0.0")
2832 (source
2833 (origin
2834 (method url-fetch)
2835 (uri (pypi-uri "vcversioner" version))
2836 (sha256
2837 (base32
2838 "16z10sm78jd7ca3jbkgc3q5i8a8q7y1h21q1li21yy3rlhbhrrns"))))
2839 (build-system python-build-system)
2840 (synopsis "Python library for version number discovery")
2841 (description "Vcversioner is a Python library that inspects tagging
2842 information in a variety of version control systems in order to discover
2843 version numbers.")
2844 (home-page "https://github.com/habnabit/vcversioner")
2845 (license license:isc)))
2846
2847 (define-public python2-vcversioner
2848 (package-with-python2 python-vcversioner))
2849
2850 (define-public python-jsonschema
2851 (package
2852 (name "python-jsonschema")
2853 (version "2.5.1")
2854 (source (origin
2855 (method url-fetch)
2856 (uri
2857 (string-append
2858 "https://pypi.python.org/packages/source/j/jsonschema/jsonschema-"
2859 version ".tar.gz"))
2860 (sha256
2861 (base32
2862 "0hddbqjm4jq63y8jf44nswina1crjs16l9snb6m3vvgyg31klrrn"))))
2863 (build-system python-build-system)
2864 (arguments
2865 '(#:phases
2866 (modify-phases %standard-phases
2867 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
2868 (native-inputs
2869 `(("python-nose" ,python-nose)
2870 ("python-vcversioner" ,python-vcversioner)))
2871 (home-page "https://github.com/Julian/jsonschema")
2872 (synopsis "Implementation of JSON Schema for Python")
2873 (description
2874 "Jsonschema is an implementation of JSON Schema for Python.")
2875 (license license:expat)
2876 (properties `((python2-variant . ,(delay python2-jsonschema))))))
2877
2878 (define-public python2-jsonschema
2879 (let ((jsonschema (package-with-python2
2880 (strip-python2-variant python-jsonschema))))
2881 (package (inherit jsonschema)
2882 (native-inputs
2883 `(("python2-mock" ,python2-mock)
2884 ,@(package-native-inputs jsonschema)))
2885 (propagated-inputs
2886 `(("python2-functools32" ,python2-functools32))))))
2887
2888 (define-public python-schema
2889 (package
2890 (name "python-schema")
2891 (version "0.6.6")
2892 (source
2893 (origin
2894 (method url-fetch)
2895 (uri (pypi-uri "schema" version))
2896 (sha256
2897 (base32
2898 "1lw28j9w9vxyigg7vkfkvi6ic9lgjkdnfvnxdr7pklslqvzmk2vm"))))
2899 (build-system python-build-system)
2900 (native-inputs
2901 `(("python-pytest" ,python-pytest)))
2902 (home-page "https://github.com/keleshev/schema")
2903 (synopsis "Simple data validation library")
2904 (description
2905 "@code{python-schema} is a library for validating Python data
2906 structures, such as those obtained from config-files, forms, external
2907 services or command-line parsing, converted from JSON/YAML (or
2908 something else) to Python data-types.")
2909 (license license:psfl)))
2910
2911 (define-public python2-schema
2912 (package-with-python2 python-schema))
2913
2914 (define-public python-schema-0.5
2915 (package (inherit python-schema)
2916 (version "0.5.0")
2917 (source
2918 (origin
2919 (method url-fetch)
2920 (uri (pypi-uri "schema" version))
2921 (sha256
2922 (base32
2923 "10zqvpaky51kgb8nd42bk7jwl8cn2zvayxjpdc1wwmpybj92x67s"))))))
2924
2925 (define-public python2-schema-0.5
2926 (package-with-python2 python-schema-0.5))
2927
2928 (define-public python-kitchen
2929 (package
2930 (name "python-kitchen")
2931 (version "1.2.4")
2932 (source
2933 (origin
2934 (method url-fetch)
2935 (uri (pypi-uri "kitchen" version))
2936 (sha256
2937 (base32
2938 "0ggv3p4x8jvmmzhp0xm00h6pvh1g0gmycw71rjwagnrj8n23vxrq"))))
2939 (build-system python-build-system)
2940 (propagated-inputs
2941 `(("python-chardet" ,python-chardet)))
2942 (home-page "https://github.com/fedora-infra/kitchen")
2943 (synopsis "Python API for snippets")
2944 (description "@code{kitchen} module provides a python API for all sorts of
2945 little useful snippets of code that everybody ends up writing for their projects
2946 but never seem big enough to build an independent release. Use kitchen and stop
2947 cutting and pasting that code over and over.")
2948 (license (list license:lgpl2.1+
2949 ;; subprocess.py, test_subprocess.py,
2950 ;; kitchen/pycompat25/defaultdict.py:
2951 license:psfl))))
2952
2953 (define-public python2-kitchen
2954 (package-with-python2 python-kitchen))
2955
2956 (define-public python-unidecode
2957 (package
2958 (name "python-unidecode")
2959 (version "0.04.21")
2960 (source (origin
2961 (method url-fetch)
2962 (uri (pypi-uri "Unidecode" version))
2963 (sha256
2964 (base32
2965 "0lfhp9c5xrbpjvbpr12ji52g1lx04404bzzdg6pvabhzisw6l2i8"))))
2966 (build-system python-build-system)
2967 (home-page "https://pypi.python.org/pypi/Unidecode")
2968 (synopsis "ASCII transliterations of Unicode text")
2969 (description
2970 "Unidecode provides ASCII transliterations of Unicode text. Unidecode is
2971 useful when integrating with legacy code that doesn't support Unicode, or for
2972 ease of entry of non-Roman names on a US keyboard, or when constructing ASCII
2973 machine identifiers from human-readable Unicode strings that should still be
2974 somewhat intelligible.")
2975 (license license:gpl2+)))
2976
2977 (define-public python2-unidecode
2978 (package-with-python2 python-unidecode))
2979
2980 (define-public python-pyjwt
2981 (package
2982 (name "python-pyjwt")
2983 (version "1.5.3")
2984 (source
2985 (origin
2986 (method url-fetch)
2987 (uri (pypi-uri "PyJWT" version))
2988 (sha256
2989 (base32
2990 "1rxsg14i33vm2i6lz0my628108c81k43v10n4h3p0gx62xdyf2sh"))
2991 (modules '((guix build utils)))
2992 (snippet
2993 '(begin
2994 (for-each delete-file-recursively
2995 (find-files "." "\\.pyc$"))
2996 #t))))
2997 (build-system python-build-system)
2998 (native-inputs
2999 `(("python-pytest" ,python-pytest-3.0)
3000 ("python-pytest-cov" ,python-pytest-cov)
3001 ("python-pytest-runner" ,python-pytest-runner)))
3002 (home-page "https://github.com/progrium/pyjwt")
3003 (synopsis "JSON Web Token implementation in Python")
3004 (description
3005 "PyJWT is a JSON Web Token implementation written in Python.")
3006 (license license:expat)))
3007
3008 (define-public python2-pyjwt
3009 (package-with-python2 python-pyjwt))
3010
3011 (define-public python-pykka
3012 (package
3013 (name "python-pykka")
3014 (version "1.2.1")
3015 (source
3016 (origin
3017 (method url-fetch)
3018 (uri (pypi-uri "Pykka" version))
3019 (sha256
3020 (base32
3021 "049w3r0mdnnw7xv19jiq7rvls9k7xs73x05b4qs5d6z4vvmgyiz8"))))
3022 (build-system python-build-system)
3023 (native-inputs
3024 `(("python-mock" ,python-mock)
3025 ("python-nose" ,python-nose)
3026 ("python-gevent" ,python-gevent)
3027 ("python-eventlet" ,python-eventlet)))
3028 (home-page "https://www.pykka.org/")
3029 (synopsis "Pykka is a Python implementation of the actor model")
3030 (description
3031 "Pykka is a Python implementation of the actor model.
3032 The actor model introduces some simple rules to control the sharing
3033 of state and cooperation between execution units, which makes it
3034 easier to build concurrent applications.")
3035 (license license:asl2.0)))
3036
3037 (define-public python2-pykka
3038 (package-with-python2 python-pykka))
3039
3040 (define-public python-oauthlib
3041 (package
3042 (name "python-oauthlib")
3043 (version "1.0.3")
3044 (source (origin
3045 (method url-fetch)
3046 (uri (pypi-uri "oauthlib" version))
3047 (sha256
3048 (base32
3049 "1bfrj70vdjxjw74khbyh6f0dksv7p5rh2346jnlrffyacd3gwjzg"))))
3050 (build-system python-build-system)
3051 (native-inputs
3052 `(("python-nose" ,python-nose)
3053 ("python-mock" ,python-mock)
3054 ("python-cryptography" ,python-cryptography)
3055 ("python-pyjwt" ,python-pyjwt)
3056 ("python-blinker" ,python-blinker)))
3057 (home-page "https://github.com/idan/oauthlib")
3058 (synopsis "OAuth implementation for Python")
3059 (description
3060 "Oauthlib is a generic, spec-compliant, thorough implementation of the
3061 OAuth request-signing logic.")
3062 (license license:bsd-3)
3063 (properties `((python2-variant . ,(delay python2-oauthlib))))))
3064
3065 (define-public python2-oauthlib
3066 (let ((base (package-with-python2 (strip-python2-variant python-oauthlib))))
3067 (package
3068 (inherit base)
3069 (native-inputs `(("python2-unittest2" ,python2-unittest2)
3070 ,@(package-native-inputs base))))))
3071
3072 (define-public python-itsdangerous
3073 (package
3074 (name "python-itsdangerous")
3075 (version "0.24")
3076 (source
3077 (origin
3078 (method url-fetch)
3079 (uri (string-append
3080 "https://pypi.python.org/packages/source/i/itsdangerous/itsdangerous-"
3081 version ".tar.gz"))
3082 (sha256
3083 (base32
3084 "06856q6x675ly542ig0plbqcyab6ksfzijlyf1hzhgg3sgwgrcyb"))))
3085 (build-system python-build-system)
3086 (home-page "https://github.com/mitsuhiko/itsdangerous")
3087 (synopsis "Python library for passing data to/from untrusted environments")
3088 (description
3089 "Itsdangerous provides various helpers to pass trusted data to untrusted
3090 environments and back.")
3091 (license license:bsd-3)))
3092
3093 (define-public python2-itsdangerous
3094 (package-with-python2 python-itsdangerous))
3095
3096 (define-public python-pyyaml
3097 (package
3098 (name "python-pyyaml")
3099 (version "3.12")
3100 (source
3101 (origin
3102 (method url-fetch)
3103 (uri (pypi-uri "PyYAML" version))
3104 (sha256
3105 (base32
3106 "1aqjl8dk9amd4zr99n8v2qxzgmr2hdvqfma4zh7a41rj6336c9sr"))))
3107 (build-system python-build-system)
3108 (inputs
3109 `(("libyaml" ,libyaml)))
3110 (home-page "http://pyyaml.org/wiki/PyYAML")
3111 (synopsis "YAML parser and emitter for Python")
3112 (description
3113 "PyYAML is a YAML parser and emitter for Python. PyYAML features a
3114 complete YAML 1.1 parser, Unicode support, pickle support, capable extension
3115 API, and sensible error messages. PyYAML supports standard YAML tags and
3116 provides Python-specific tags that allow to represent an arbitrary Python
3117 object.")
3118 (license license:expat)))
3119
3120 (define-public python2-pyyaml
3121 (package-with-python2 python-pyyaml))
3122
3123 (define-public python-virtualenv
3124 (package
3125 (name "python-virtualenv")
3126 (version "15.0.3")
3127 (source
3128 (origin
3129 (method url-fetch)
3130 (uri (pypi-uri "virtualenv" version))
3131 (sha256
3132 (base32
3133 "07cbajzk8l05k5zhlw0b9wbf2is65bl9v6zrn2a0iyn57w6pd73d"))))
3134 (build-system python-build-system)
3135 (arguments
3136 `(#:phases
3137 (modify-phases %standard-phases
3138 (replace 'check
3139 (lambda _
3140 ;; Disable failing test. See upstream bug report
3141 ;; https://github.com/pypa/virtualenv/issues/957
3142 (substitute* "tests/test_virtualenv.py"
3143 (("skipif.*") "skipif(True, reason=\"Guix\")\n"))
3144 (zero? (system* "py.test")))))))
3145 (native-inputs
3146 `(("python-mock" ,python-mock)
3147 ("python-pytest" ,python-pytest)))
3148 (home-page "https://virtualenv.pypa.io/")
3149 (synopsis "Virtual Python environment builder")
3150 (description
3151 "Virtualenv is a tool to create isolated Python environments.")
3152 (license license:expat)))
3153
3154 (define-public python2-virtualenv
3155 (package-with-python2 python-virtualenv))
3156
3157 (define-public python-markupsafe
3158 (package
3159 (name "python-markupsafe")
3160 (version "0.23")
3161 (source
3162 (origin
3163 (method url-fetch)
3164 (uri (string-append
3165 "https://pypi.python.org/packages/source/M/MarkupSafe/MarkupSafe-"
3166 version ".tar.gz"))
3167 (sha256
3168 (base32
3169 "1hvip33wva3fnmvfp9x5klqri7hpl1hkgqmjbss18nmrb7zimv54"))))
3170 (build-system python-build-system)
3171 (home-page "https://github.com/mitsuhiko/markupsafe")
3172 (synopsis "XML/HTML/XHTML markup safe string implementation for Python")
3173 (description
3174 "Markupsafe provides an XML/HTML/XHTML markup safe string implementation
3175 for Python.")
3176 (license license:bsd-3)))
3177
3178 (define-public python2-markupsafe
3179 (package-with-python2 python-markupsafe))
3180
3181 (define-public python-jinja2
3182 (package
3183 (name "python-jinja2")
3184 (version "2.9.6")
3185 (source
3186 (origin
3187 (method url-fetch)
3188 (uri (pypi-uri "Jinja2" version))
3189 (sha256
3190 (base32
3191 "1zzrkywhziqffrzks14kzixz7nd4yh2vc0fb04a68vfd2ai03anx"))))
3192 (build-system python-build-system)
3193 (arguments
3194 `(#:phases
3195 (modify-phases %standard-phases
3196 ;; These files cannot be built with Python < 3.6. See
3197 ;; https://github.com/pallets/jinja/issues/655
3198 ;; FIXME: Remove this when the "python" package is upgraded.
3199 (add-after 'unpack 'delete-incompatible-files
3200 (lambda _
3201 (for-each delete-file
3202 '("jinja2/asyncsupport.py"
3203 "jinja2/asyncfilters.py"))
3204 #t)))))
3205 (propagated-inputs
3206 `(("python-markupsafe" ,python-markupsafe)))
3207 (home-page "http://jinja.pocoo.org/")
3208 (synopsis "Python template engine")
3209 (description
3210 "Jinja2 is a small but fast and easy to use stand-alone template engine
3211 written in pure Python.")
3212 (license license:bsd-3)))
3213
3214 (define-public python2-jinja2
3215 (package-with-python2 python-jinja2))
3216
3217 (define-public python-pystache
3218 (package
3219 (name "python-pystache")
3220 (version "0.5.4")
3221 (source (origin
3222 (method url-fetch)
3223 (uri (pypi-uri "pystache" version))
3224 (sha256
3225 (base32
3226 "0nmqsfmiw4arjxqkmf9z66ml950pcdjk6aq4gin4sywmzdjw5fzp"))))
3227 (build-system python-build-system)
3228 (arguments
3229 '(#:tests? #f)) ; FIXME: Python 3 tests are failing.
3230 (home-page "http://defunkt.io/pystache/")
3231 (synopsis "Python logic-less template engine")
3232 (description
3233 "Pystache is a Python implementation of the framework agnostic,
3234 logic-free templating system Mustache.")
3235 (license license:expat)
3236 (properties `((python2-variant . ,(delay python2-pystache))))))
3237
3238 (define-public python2-pystache
3239 (package (inherit (package-with-python2
3240 (strip-python2-variant python-pystache)))
3241 (arguments
3242 `(#:python ,python-2
3243 #:phases
3244 (modify-phases %standard-phases
3245 (replace 'check
3246 (lambda _
3247 (zero? (system* "python" "test_pystache.py")))))))))
3248
3249 (define-public python-joblib
3250 (package
3251 (name "python-joblib")
3252 (version "0.10.3")
3253 (source (origin
3254 (method url-fetch)
3255 (uri (pypi-uri "joblib" version))
3256 (sha256
3257 (base32
3258 "0787k919zlfmgymprz5bzv0v1df5bbirlf3awrghmjgvkrd9dci9"))
3259 (modules '((guix build utils)))
3260 (snippet
3261 '(begin
3262 ;; Remove pre-compiled .pyc files from source.
3263 (for-each delete-file-recursively
3264 (find-files "." "__pycache__" #:directories? #t))
3265 (for-each delete-file (find-files "." "\\.pyc$"))
3266 #t))))
3267 (build-system python-build-system)
3268 (arguments
3269 `(#:phases
3270 (modify-phases %standard-phases
3271 (add-before 'check 'disable-failing-tests
3272 (lambda _
3273 ;; This numpydoc tests fails for unknown reasons
3274 (delete-file "doc/sphinxext/numpydoc/tests/test_docscrape.py")
3275 ;; This numpydoc test depends on matplotlib, which is not a
3276 ;; required input.
3277 (delete-file "doc/sphinxext/numpydoc/tests/test_plot_directive.py")
3278 ;; These tests fail to execute sys.executable
3279 (substitute* "joblib/test/test_parallel.py"
3280 (("import nose" line)
3281 (string-append "from nose.plugins.skip import SkipTest\n" line))
3282 (("def test_nested_parallel_warnings" line)
3283 (string-append "@SkipTest\n" line))
3284 (("def test_parallel_with_interactively_defined_functions" line)
3285 (string-append "@SkipTest\n" line)))
3286 #t)))))
3287 ;; Provide nose to enable tests command
3288 (native-inputs
3289 `(("python-nose" ,python-nose)
3290 ("python-sphinx" ,python-sphinx)
3291 ("python-docutils" ,python-docutils)
3292 ("python-numpydoc" ,python-numpydoc)))
3293 (home-page "http://pythonhosted.org/joblib/")
3294 (synopsis "Using Python functions as pipeline jobs")
3295 (description
3296 "Joblib is a set of tools to provide lightweight pipelining in Python.
3297 In particular, joblib offers: transparent disk-caching of the output values
3298 and lazy re-evaluation (memoize pattern), easy simple parallel computing
3299 logging and tracing of the execution.")
3300 (license license:bsd-3)))
3301
3302 (define-public python2-joblib
3303 (package-with-python2 python-joblib))
3304
3305 (define-public python-docutils
3306 (package
3307 (name "python-docutils")
3308 (version "0.14")
3309 (source
3310 (origin
3311 (method url-fetch)
3312 (uri (pypi-uri "docutils" version))
3313 (sha256
3314 (base32
3315 "0x22fs3pdmr42kvz6c654756wja305qv6cx1zbhwlagvxgr4xrji"))))
3316 (build-system python-build-system)
3317 (arguments
3318 '(#:tests? #f)) ; no setup.py test command
3319 (home-page "http://docutils.sourceforge.net/")
3320 (synopsis "Python Documentation Utilities")
3321 (description
3322 "Docutils is a modular system for processing documentation into useful
3323 formats, such as HTML, XML, and LaTeX. For input Docutils supports
3324 reStructuredText.")
3325 ;; Most of the source code is public domain, but some source files are
3326 ;; licensed under the PFSL, BSD 2-clause, and GPLv3+ licenses.
3327 (license (list license:public-domain license:psfl license:bsd-2 license:gpl3+))))
3328
3329 (define-public python2-docutils
3330 (package-with-python2 python-docutils))
3331
3332 (define-public python-pygments
3333 (package
3334 (name "python-pygments")
3335 (version "2.2.0")
3336 (source
3337 (origin
3338 (method url-fetch)
3339 (uri (pypi-uri "Pygments" version))
3340 (sha256
3341 (base32
3342 "1k78qdvir1yb1c634nkv6rbga8wv4289xarghmsbbvzhvr311bnv"))))
3343 (build-system python-build-system)
3344 (arguments
3345 ;; FIXME: Tests require sphinx, which depends on this.
3346 '(#:tests? #f))
3347 (home-page "http://pygments.org/")
3348 (synopsis "Syntax highlighting")
3349 (description
3350 "Pygments is a syntax highlighting package written in Python.")
3351 (license license:bsd-2)))
3352
3353 (define-public python2-pygments
3354 (package-with-python2 python-pygments))
3355
3356 (define-public python-sphinxcontrib-websupport
3357 (package
3358 (name "python-sphinxcontrib-websupport")
3359 (version "1.0.1")
3360 (source (origin
3361 (method url-fetch)
3362 (uri (pypi-uri "sphinxcontrib-websupport" version))
3363 (sha256
3364 (base32
3365 "1f9f0wjpi9nhikbyaz6d19s7qvzdf1nq2g5dsh640fma4q9rd1bs"))))
3366 (build-system python-build-system)
3367 (propagated-inputs
3368 `(("python-mock" ,python-mock)
3369 ("python-pytest" ,python-pytest)
3370 ("python-xapian-bindings" ,python-xapian-bindings)))
3371 ;; Needed for running the test suite
3372 (native-inputs
3373 `(("python-six" ,python-six)
3374 ("python-jinja2" ,python-jinja2)
3375 ("python-docutils" ,python-docutils)
3376 ("python-sphinx" ,python-sphinx)
3377 ("python-sqlalchemy" ,python-sqlalchemy)
3378 ("python-whoosh" ,python-whoosh)))
3379 (home-page "http://sphinx-doc.org/")
3380 (synopsis "Sphinx API for web applications")
3381 (description "This package provides a Python API to easily integrate
3382 Sphinx documentation into your web application. It provides tools to
3383 integrate Sphinx documents in web templates and to handle searches.")
3384 (license license:bsd-3)))
3385
3386 (define-public python-sphinx
3387 (package
3388 (name "python-sphinx")
3389 (version "1.5.1")
3390 (source
3391 (origin
3392 (method url-fetch)
3393 (uri (pypi-uri "Sphinx" version))
3394 (sha256
3395 (base32
3396 "1i8p9idnli4gr0y4x67yakbdk5w6a0xjzhrg6bg51y9d1fi7fslf"))))
3397 (build-system python-build-system)
3398 (arguments
3399 `(#:phases
3400 (modify-phases %standard-phases
3401 (replace 'check
3402 (lambda _
3403 ;; Requires Internet access.
3404 (delete-file "tests/test_build_linkcheck.py")
3405 (zero? (system* "make" "test")))))))
3406 (propagated-inputs
3407 `(("python-imagesize" ,python-imagesize)
3408 ("python-sphinx-alabaster-theme"
3409 ,python-sphinx-alabaster-theme)
3410 ("python-babel" ,python-babel)
3411 ("python-snowballstemmer" ,python-snowballstemmer)
3412 ("python-docutils" ,python-docutils)
3413 ("python-jinja2" ,python-jinja2)
3414 ("python-pygments" ,python-pygments)
3415 ("python-requests" ,python-requests)
3416 ("python-six" ,python-six)))
3417 (native-inputs
3418 `(("graphviz" ,graphviz)
3419 ("python-html5lib" ,python-html5lib)
3420 ("python-mock" ,python-mock)
3421 ("python-nose" ,python-nose)))
3422 (home-page "http://sphinx-doc.org/")
3423 (synopsis "Python documentation generator")
3424 (description "Sphinx is a tool that makes it easy to create documentation
3425 for Python projects or other documents consisting of multiple reStructuredText
3426 sources.")
3427 (license license:bsd-3)
3428 (properties `((python2-variant . ,(delay python2-sphinx))))))
3429
3430 (define-public python-sphinx-1.6
3431 (package (inherit python-sphinx)
3432 (name "python-sphinx")
3433 (version "1.6.3")
3434 (source (origin
3435 (method url-fetch)
3436 (uri (pypi-uri "Sphinx" version))
3437 (sha256
3438 (base32
3439 "1rj6f3i8hmrx2qlkshi5kp5xcy98dlynwlyl05yvflj5f66dp2xg"))))
3440 (arguments
3441 `(#:phases
3442 (modify-phases %standard-phases
3443 (replace 'check
3444 (lambda _
3445 ;; Requires Internet access.
3446 (delete-file "tests/test_build_linkcheck.py")
3447 (substitute* "tests/test_build_latex.py"
3448 (("@pytest.mark.sphinx\\('latex', testroot='images'\\)")
3449 "@pytest.mark.skip()"))
3450 (zero? (system* "make" "test")))))))
3451 (propagated-inputs
3452 `(("python-sphinxcontrib-websupport" ,python-sphinxcontrib-websupport)
3453 ,@(package-propagated-inputs python-sphinx)))
3454 (native-inputs
3455 `(("python-pytest" ,python-pytest-3.0)
3456 ("imagemagick" ,imagemagick) ; for "convert"
3457 ,@(package-native-inputs python-sphinx)))
3458 (properties '())))
3459
3460 (define-public python-sphinx-1.5.3
3461 (package
3462 (inherit python-sphinx)
3463 (name "python-sphinx")
3464 (version "1.5.3")
3465 (source
3466 (origin
3467 (method url-fetch)
3468 (uri (pypi-uri "Sphinx" version))
3469 (sha256
3470 (base32
3471 "0kw1axswbvaavr8ggyf4qr6hnisnrzlbkkcdada69vk1x9xjassg"))))
3472 (native-inputs
3473 `(("python-pytest" ,python-pytest-3.0)
3474 ,@(package-native-inputs python-sphinx)))))
3475
3476 (define-public python2-sphinx
3477 (let ((base (package-with-python2 (strip-python2-variant python-sphinx))))
3478 (package
3479 (inherit base)
3480 (native-inputs `(("python2-mock" ,python2-mock)
3481 ("python2-enum34" ,python2-enum34)
3482 ,@(package-native-inputs base)))
3483 (propagated-inputs `(("python2-pytz" ,python2-pytz)
3484 ,@(package-propagated-inputs base))))))
3485
3486 (define-public python-sphinx-rtd-theme
3487 (package
3488 (name "python-sphinx-rtd-theme")
3489 (version "0.2.4")
3490 (source
3491 (origin
3492 (method url-fetch)
3493 (uri (pypi-uri "sphinx_rtd_theme" version))
3494 (sha256
3495 (base32
3496 "05rlhjzdyapr2w74jjs7mrm8hi69qskcr5vya9f9drpsys7lpxrd"))))
3497 (build-system python-build-system)
3498 (arguments '(#:tests? #f)) ; No tests.
3499 (propagated-inputs
3500 `(("python-sphinx" ,python-sphinx)))
3501 (home-page "https://github.com/snide/sphinx_rtd_theme/")
3502 (synopsis "ReadTheDocs.org theme for Sphinx")
3503 (description "A theme for Sphinx used by ReadTheDocs.org.")
3504 (license license:expat)))
3505
3506 (define-public python2-sphinx-rtd-theme
3507 (package-with-python2 python-sphinx-rtd-theme))
3508
3509 (define-public python-guzzle-sphinx-theme
3510 (package
3511 (name "python-guzzle-sphinx-theme")
3512 (version "0.7.11")
3513 (source
3514 (origin
3515 (method url-fetch)
3516 (uri (pypi-uri "guzzle_sphinx_theme" version))
3517 (sha256
3518 (base32
3519 "1rnkzrrsbnifn3vsb4pfaia3nlvgvw6ndpxp7lzjrh23qcwid34v"))))
3520 (build-system python-build-system)
3521 (propagated-inputs
3522 `(("python-sphinx" ,python-sphinx)))
3523 (home-page "https://github.com/guzzle/guzzle_sphinx_theme")
3524 (synopsis "Sphinx theme used by Guzzle")
3525 (description "This package provides guzzle_sphinx_theme, a theme for the
3526 Sphinx documentation system, used by @uref{http://docs.guzzlephp.org, Guzzle}
3527 and several other projects.")
3528 (license license:expat)))
3529
3530 (define-public python2-guzzle-sphinx-theme
3531 (package-with-python2 python-guzzle-sphinx-theme))
3532
3533 (define-public python-rst.linker
3534 (package
3535 (name "python-rst.linker")
3536 (version "1.7")
3537 (source
3538 (origin
3539 (method url-fetch)
3540 (uri (pypi-uri "rst.linker" version))
3541 (sha256
3542 (base32
3543 "0bh4lnj2p1nh0wf5pgxgfbrp27xhb1rinahkb5j7s3qprq6qn0sr"))))
3544 (build-system python-build-system)
3545 (propagated-inputs
3546 `(("python-dateutil" ,python-dateutil)
3547 ("python-six" ,python-six)))
3548 (native-inputs
3549 `(("python-setuptools-scm" ,python-setuptools-scm)))
3550 ;; Test would require path.py, which would introduce a cyclic dependence.
3551 (arguments `(#:tests? #f))
3552 ;; Note: As of version 1.7 the documentation is not worth building.
3553 (home-page "https://github.com/jaraco/rst.linker")
3554 (synopsis "Sphinx plugin to add links and timestamps")
3555 (description "rst.linker allows to automatically replace text by a
3556 reStructuredText external reference or timestamps. It's primary purpose is to
3557 augment the changelog, but it can be used for other documents, too.")
3558 (license license:expat)))
3559
3560 (define-public python2-rst.linker
3561 (package-with-python2 python-rst.linker))
3562
3563 (define-public python-feedgenerator
3564 (package
3565 (name "python-feedgenerator")
3566 (version "1.9")
3567 (source
3568 (origin
3569 (method url-fetch)
3570 (uri (pypi-uri "feedgenerator" version))
3571 (sha256
3572 (base32
3573 "01mirwkm7xfx539hmvj7g9da1j51gw5lsx74dr0glizskjm5vq2s"))
3574 (modules '((guix build utils)))
3575 (snippet
3576 '(begin
3577 ;; Remove pre-compiled .pyc files from source.
3578 (for-each delete-file-recursively
3579 (find-files "." "__pycache__" #:directories? #t))
3580 (for-each delete-file (find-files "." "\\.pyc$"))
3581 #t))))
3582 (build-system python-build-system)
3583 (propagated-inputs
3584 `(("python-pytz" ,python-pytz)
3585 ("python-six" ,python-six)))
3586 (home-page "https://github.com/getpelican/feedgenerator")
3587 (synopsis
3588 "Standalone version of Django's Atom/RSS feed generator")
3589 (description
3590 "Feedgenerator-py3k is a standalone version of Django's feedgenerator,
3591 which can produce feeds in RSS 2.0, RSS 0.91, and Atom formats.")
3592 (license license:bsd-3)))
3593
3594 (define-public python2-feedgenerator
3595 (package-with-python2 python-feedgenerator))
3596
3597 (define-public python-blinker
3598 (package
3599 (name "python-blinker")
3600 (version "1.4")
3601 (source
3602 (origin
3603 (method url-fetch)
3604 (uri (pypi-uri "blinker" version))
3605 (sha256
3606 (base32
3607 "1dpq0vb01p36jjwbhhd08ylvrnyvcc82yxx3mwjx6awrycjyw6j7"))))
3608 (build-system python-build-system)
3609 (home-page "http://pythonhosted.org/blinker/")
3610 (synopsis "Fast, simple object-to-object and broadcast signaling")
3611 (description
3612 "Blinker provides a fast dispatching system that allows any number of
3613 interested parties to subscribe to events, or \"signals\".")
3614 (license license:expat)))
3615
3616 (define-public python2-blinker
3617 (package-with-python2 python-blinker))
3618
3619 (define-public pelican
3620 (package
3621 (name "pelican")
3622 (version "3.6.3")
3623 (source
3624 (origin
3625 (method url-fetch)
3626 (uri (pypi-uri "pelican" version))
3627 (sha256
3628 (base32
3629 "1hn94rb4q3zmcq16in055xikal4dba5hfx3zznq7warllcgc9f8k"))))
3630 (build-system python-build-system)
3631 (propagated-inputs
3632 `(("python-feedgenerator" ,python-feedgenerator)
3633 ("python-jinja2" ,python-jinja2)
3634 ("python-pygments" ,python-pygments)
3635 ("python-docutils" ,python-docutils)
3636 ("python-pytz" ,python-pytz)
3637 ("python-blinker" ,python-blinker)
3638 ("python-unidecode" ,python-unidecode)
3639 ("python-six" ,python-six)
3640 ("python-dateutil" ,python-dateutil)))
3641 (home-page "http://getpelican.com/")
3642 (arguments
3643 `(;; XXX Requires a lot more packages to do unit tests :P
3644 #:tests? #f
3645 #:phases (modify-phases %standard-phases
3646 (add-before
3647 'install 'adjust-requires
3648 ;; Since feedgenerator is installed from git, it doesn't
3649 ;; conform to the version requirements.
3650 ;;
3651 ;; We *do have* "feedgenerator >= 1.6", but strip off the
3652 ;; version requirement so setuptools doesn't get confused.
3653 (lambda _
3654 (substitute* "setup.py"
3655 (("['\"]feedgenerator.*?['\"]")
3656 "'feedgenerator'")))))))
3657 (synopsis "Python-based static site publishing system")
3658 (description
3659 "Pelican is a tool to generate a static blog from reStructuredText,
3660 Markdown input files, and more. Pelican uses Jinja2 for templating
3661 and is very extensible.")
3662 (license license:agpl3+)))
3663
3664 (define-public python-scikit-learn
3665 (package
3666 (name "python-scikit-learn")
3667 (version "0.19.0")
3668 (source
3669 (origin
3670 (method url-fetch)
3671 (uri (string-append
3672 "https://github.com/scikit-learn/scikit-learn/archive/"
3673 version ".tar.gz"))
3674 (file-name (string-append name "-" version ".tar.gz"))
3675 (sha256
3676 (base32
3677 "0g7q4ri75mj93wpa9bp83a3jmrf3dm5va9h7k4zkbcxr6bgqka15"))))
3678 (build-system python-build-system)
3679 (arguments
3680 `(#:phases
3681 (modify-phases %standard-phases
3682 (delete 'check)
3683 (add-after 'install 'check
3684 ;; Running tests from the source directory requires
3685 ;; an "inplace" build with paths relative to CWD.
3686 ;; http://scikit-learn.org/stable/developers/advanced_installation.html#testing
3687 ;; Use the installed version instead.
3688 (lambda* (#:key inputs outputs #:allow-other-keys)
3689 (add-installed-pythonpath inputs outputs)
3690 ;; some tests require access to "$HOME"
3691 (setenv "HOME" "/tmp")
3692 ;; Step out of the source directory just to be sure.
3693 (chdir "..")
3694 (zero? (system* "nosetests" "-v" "sklearn")))))))
3695 (inputs
3696 `(("openblas" ,openblas)))
3697 (native-inputs
3698 `(("python-nose" ,python-nose)
3699 ("python-cython" ,python-cython)))
3700 (propagated-inputs
3701 `(("python-numpy" ,python-numpy)
3702 ("python-scipy" ,python-scipy)))
3703 (home-page "http://scikit-learn.org/")
3704 (synopsis "Machine Learning in Python")
3705 (description
3706 "Scikit-learn provides simple and efficient tools for data
3707 mining and data analysis.")
3708 (license license:bsd-3)))
3709
3710 (define-public python2-scikit-learn
3711 (package-with-python2 python-scikit-learn))
3712
3713 (define-public python-scikit-image
3714 (package
3715 (name "python-scikit-image")
3716 (version "0.11.3")
3717 (source
3718 (origin
3719 (method url-fetch)
3720 (uri (string-append
3721 "https://pypi.python.org/packages/source/s/scikit-image/scikit-image-"
3722 version ".tar.gz"))
3723 (sha256
3724 (base32 "0jz416fqvpahqyffw8plmszzfj669w8wvf3y9clnr5lr6a7md3kn"))))
3725 (build-system python-build-system)
3726 (arguments
3727 ;; TODO: Some tests require running X11 server. Disable them?
3728 '(#:tests? #f))
3729 ;; See DEPENDS.txt for the list of build and run time requiremnts
3730 (propagated-inputs
3731 `(("python-matplotlib" ,python-matplotlib)
3732 ("python-networkx" ,python-networkx)
3733 ("python-scipy" ,python-scipy)
3734 ("python-pillow" ,python-pillow)))
3735 (native-inputs
3736 `(("python-numpy" ,python-numpy)
3737 ("python-cython" ,python-cython)
3738 ("python-six" ,python-six)))
3739 (home-page "http://scikit-image.org/")
3740 (synopsis "Image processing in Python")
3741 (description
3742 "Scikit-image is a collection of algorithms for image processing.")
3743 (license license:bsd-3)))
3744
3745 (define-public python2-scikit-image
3746 (package-with-python2 python-scikit-image))
3747
3748 (define-public python-redis
3749 (package
3750 (name "python-redis")
3751 (version "2.10.5")
3752 (source
3753 (origin
3754 (method url-fetch)
3755 (uri (pypi-uri "redis" version))
3756 (sha256
3757 (base32 "0csmrkxb29x7xs9b51zplwkkq2hwnbh9jns1g85dykn5rxmaxysx"))))
3758 (build-system python-build-system)
3759 ;; Tests require a running Redis server
3760 (arguments '(#:tests? #f))
3761 ;; As long as we are not running test, we do not need this input :-)
3762 ;;(native-inputs
3763 ;; `(("python-pytest" ,python-pytest)))
3764 (home-page "https://github.com/andymccurdy/redis-py")
3765 (synopsis "Redis Python client")
3766 (description
3767 "This package provides a Python interface to the Redis key-value store.")
3768 (license license:expat)))
3769
3770 (define-public python2-redis
3771 (package-with-python2 python-redis))
3772
3773 (define-public python-rq
3774 (package
3775 (name "python-rq")
3776 (version "0.7.1")
3777 (source
3778 (origin
3779 (method url-fetch)
3780 (uri (pypi-uri "rq" version))
3781 (sha256
3782 (base32 "0gaq5pnh0zy46r8jvygi0ifbvz3pq6i7xla78ijcgjw0x77qzsdh"))))
3783 (build-system python-build-system)
3784 (propagated-inputs
3785 `(("python-click" ,python-click)
3786 ("python-redis" ,python-redis)))
3787 (home-page "http://python-rq.org/")
3788 (synopsis "Simple job queues for Python")
3789 (description
3790 "RQ (Redis Queue) is a simple Python library for queueing jobs and
3791 processing them in the background with workers. It is backed by Redis and it
3792 is designed to have a low barrier to entry.")
3793 (license license:bsd-2)))
3794
3795 (define-public python2-rq
3796 (package-with-python2 python-rq))
3797
3798 (define-public python-cython
3799 (package
3800 (name "python-cython")
3801 (version "0.27")
3802 (source
3803 (origin
3804 (method url-fetch)
3805 (uri (pypi-uri "Cython" version))
3806 (sha256
3807 (base32
3808 "02y0pp1nx77b8s1mpxc6da2dccl6wd31pp4ksi9via479qcvacmr"))))
3809 (build-system python-build-system)
3810 ;; we need the full python package and not just the python-wrapper
3811 ;; because we need libpython3.3m.so
3812 (inputs
3813 `(("python" ,python)))
3814 (arguments
3815 `(#:phases
3816 (modify-phases %standard-phases
3817 (add-before 'check 'set-HOME
3818 ;; some tests require access to "$HOME/.cython"
3819 (lambda _ (setenv "HOME" "/tmp") #t))
3820 (replace 'check
3821 (lambda _ (zero? (system* "python" "runtests.py" "-vv")))))))
3822 (home-page "http://cython.org/")
3823 (synopsis "C extensions for Python")
3824 (description "Cython is an optimising static compiler for both the Python
3825 programming language and the extended Cython programming language. It makes
3826 writing C extensions for Python as easy as Python itself.")
3827 (license license:asl2.0)
3828 (properties `((python2-variant . ,(delay python2-cython))))))
3829
3830 (define-public python2-cython
3831 (package (inherit (package-with-python2
3832 (strip-python2-variant python-cython)))
3833 (name "python2-cython")
3834 (inputs
3835 `(("python-2" ,python-2))))) ; this is not automatically changed
3836
3837 ;; The RPython toolchain currently does not support Python 3.
3838 (define-public python2-rpython
3839 (package
3840 (name "python2-rpython")
3841 (version "0.1.4")
3842 (source
3843 (origin
3844 (method url-fetch)
3845 (uri (pypi-uri "rpython" version))
3846 (sha256
3847 (base32
3848 "07pps06fq4c4wmi5ii0sgh9zgwniz5y7frqhm28g3a154l163fxc"))))
3849 (build-system python-build-system)
3850 (arguments `(#:python ,python-2))
3851 (native-inputs
3852 `(("python2-pytest" ,python2-pytest))) ; needed for running tests
3853 (home-page "https://rpython.readthedocs.org")
3854 (synopsis "Framework for implementing interpreters and virtual machines")
3855 (description "RPython is a translation and support framework for
3856 producing implementations of dynamic languages, emphasizing a clean separation
3857 between language specification and implementation aspects.")
3858 (license license:expat)))
3859
3860 ;; NOTE: when upgrading numpy please make sure that python-pandas and
3861 ;; python-scipy still build, as these three packages are often used together.
3862 (define-public python-numpy
3863 (package
3864 (name "python-numpy")
3865 (version "1.12.0")
3866 (source
3867 (origin
3868 (method url-fetch)
3869 (uri (string-append
3870 "https://github.com/numpy/numpy/archive/v" version ".tar.gz"))
3871 (file-name (string-append name "-" version ".tar.gz"))
3872 (sha256
3873 (base32
3874 "025d4j4aakcp8w5i5diqh812cbbjgac7jszx1j56ivrbi1i8vv7d"))))
3875 (build-system python-build-system)
3876 (inputs
3877 `(("openblas" ,openblas)
3878 ("lapack" ,lapack)))
3879 (native-inputs
3880 `(("python-cython" ,python-cython)
3881 ("python-nose" ,python-nose)
3882 ("gfortran" ,gfortran)))
3883 (arguments
3884 `(#:phases
3885 (modify-phases %standard-phases
3886 (add-before 'build 'set-environment-variables
3887 (lambda* (#:key inputs #:allow-other-keys)
3888 (call-with-output-file "site.cfg"
3889 (lambda (port)
3890 (format port
3891 "[openblas]
3892 libraries = openblas
3893 library_dirs = ~a/lib
3894 include_dirs = ~a/include
3895
3896 # backslash-n to make emacs happy
3897 \n[lapack]
3898 lapack_libs = lapack
3899 library_dirs = ~a/lib
3900 include_dirs = ~a/include
3901 "
3902 (assoc-ref inputs "openblas")
3903 (assoc-ref inputs "openblas")
3904 (assoc-ref inputs "lapack")
3905 (assoc-ref inputs "lapack"))))
3906 ;; Make /gnu/store/...-bash-.../bin/sh the default shell, instead of
3907 ;; /bin/sh.
3908 (substitute* "numpy/distutils/exec_command.py"
3909 (("(os.environ.get\\('SHELL', ')(/bin/sh'\\))" match match-start match-end)
3910 (string-append match-start (assoc-ref inputs "bash") match-end)))
3911 ;; Use "gcc" executable, not "cc".
3912 (substitute* "numpy/distutils/system_info.py"
3913 (("c = distutils\\.ccompiler\\.new_compiler\\(\\)")
3914 "c = distutils.ccompiler.new_compiler(); c.set_executables(compiler='gcc',compiler_so='gcc',linker_exe='gcc',linker_so='gcc -shared')"))
3915 #t))
3916 ;; Tests can only be run after the library has been installed and not
3917 ;; within the source directory.
3918 (delete 'check)
3919 (add-after 'install 'check
3920 (lambda* (#:key outputs inputs #:allow-other-keys)
3921 ;; Make installed package available for running the tests
3922 (add-installed-pythonpath inputs outputs)
3923 (with-directory-excursion "/tmp"
3924 (zero? (system* "python" "-c"
3925 "import numpy; numpy.test(verbose=2)"))))))))
3926 (home-page "http://www.numpy.org/")
3927 (synopsis "Fundamental package for scientific computing with Python")
3928 (description "NumPy is the fundamental package for scientific computing
3929 with Python. It contains among other things: a powerful N-dimensional array
3930 object, sophisticated (broadcasting) functions, tools for integrating C/C++
3931 and Fortran code, useful linear algebra, Fourier transform, and random number
3932 capabilities.")
3933 (license license:bsd-3)))
3934
3935 (define-public python2-numpy
3936 (package-with-python2 python-numpy))
3937
3938 (define-public python-numpy-next
3939 (package (inherit python-numpy)
3940 (name "python-numpy-next")
3941 (version "1.13.1")
3942 (source
3943 (origin
3944 (method url-fetch)
3945 (uri (pypi-uri "numpy" version ".zip"))
3946 (sha256
3947 (base32
3948 "1fsgkhh1vdkhmlz8vmdgxnj9n9yaanckxxzz9s0b4p08fqvjic69"))))
3949 (native-inputs
3950 `(("unzip" ,unzip)
3951 ("python-cython" ,python-cython)
3952 ("python-nose" ,python-nose)
3953 ("gfortran" ,gfortran)))))
3954
3955 (define-public python2-numpy-next
3956 (package-with-python2 python-numpy-next))
3957
3958 (define-public python-munch
3959 (package
3960 (name "python-munch")
3961 (version "2.0.4")
3962 (source
3963 (origin
3964 (method url-fetch)
3965 (uri (pypi-uri "munch" version))
3966 (sha256
3967 (base32
3968 "1cmqg91xnqx8gvnh4pmp0bfl1dfcm65d5p9mg73zz8pkjhx6h80l"))))
3969 (build-system python-build-system)
3970 (home-page "https://github.com/Infinidat/munch")
3971 (synopsis "Dot-accessible dictionary")
3972 (description "Munch is a dot-accessible dictionary similar to JavaScript
3973 objects.")
3974 (license license:expat)))
3975
3976 (define-public python2-munch
3977 (package-with-python2 python-munch))
3978
3979 (define-public python-colormath
3980 (package
3981 (name "python-colormath")
3982 (version "2.1.1")
3983 (source
3984 (origin
3985 (method url-fetch)
3986 (uri (pypi-uri "colormath" version))
3987 (sha256
3988 (base32
3989 "01wp5xwm0a89wdm1dc9rr1ij90idzdiiipxdj1yslhqzkhnjnfh0"))))
3990 (build-system python-build-system)
3991 (propagated-inputs
3992 `(("python-networkx" ,python-networkx)
3993 ("python-numpy" ,python-numpy)))
3994 (home-page "https://github.com/gtaylor/python-colormath")
3995 (synopsis "Color math and conversion library")
3996 (description
3997 "This is a Python library for color math and conversions.")
3998 (license license:bsd-3)))
3999
4000 (define-public python2-colormath
4001 (package-with-python2 python-colormath))
4002
4003 (define-public python-spectra
4004 (package
4005 (name "python-spectra")
4006 (version "0.0.8")
4007 (source
4008 (origin
4009 (method url-fetch)
4010 (uri (pypi-uri "spectra" version))
4011 (sha256
4012 (base32
4013 "0n87kzhpkml2s2q91rdkl8wz2kkv5b0bkrgww45lxa5vq34qh6w5"))))
4014 (build-system python-build-system)
4015 (arguments
4016 `(#:phases
4017 (modify-phases %standard-phases
4018 (replace 'check
4019 (lambda _
4020 (zero? (system* "nosetests" "-v")))))))
4021 (propagated-inputs
4022 `(("python-colormath" ,python-colormath)))
4023 (native-inputs
4024 `(("python-nose" ,python-nose)))
4025 (home-page "http://github.com/jsvine/spectra")
4026 (synopsis "Color scales and color conversion")
4027 (description
4028 "This package provides a Python library intended to make color math,
4029 color scales, and color space conversion easy. It has support for:
4030
4031 @enumerate
4032 @item Color scales
4033 @item Color ranges
4034 @item Color blending
4035 @item Brightening/darkening colors
4036 @item Saturating/desaturating colors
4037 @item Conversion to/from multiple color spaces.
4038 @end enumerate\n")
4039 (license license:expat)))
4040
4041 (define-public python2-spectra
4042 (package-with-python2 python-spectra))
4043
4044 (define-public python2-fastlmm
4045 (package
4046 (name "python2-fastlmm")
4047 (version "0.2.21")
4048 (source
4049 (origin
4050 (method url-fetch)
4051 (uri (pypi-uri "fastlmm" version ".zip"))
4052 (sha256
4053 (base32
4054 "1q8c34rpmwkfy3r4d5172pzdkpfryj561897z9r3x22gq7813x1m"))))
4055 (build-system python-build-system)
4056 (arguments
4057 `(#:python ,python-2)) ; only Python 2.7 is supported
4058 (propagated-inputs
4059 `(("python2-numpy" ,python2-numpy)
4060 ("python2-scipy" ,python2-scipy)
4061 ("python2-matplotlib" ,python2-matplotlib)
4062 ("python2-pandas" ,python2-pandas)
4063 ("python2-scikit-learn" ,python2-scikit-learn)
4064 ("python2-pysnptools" ,python2-pysnptools)))
4065 (native-inputs
4066 `(("unzip" ,unzip)
4067 ("python2-cython" ,python2-cython)
4068 ("python2-mock" ,python2-mock)
4069 ("python2-nose" ,python2-nose)))
4070 (home-page "http://research.microsoft.com/en-us/um/redmond/projects/mscompbio/fastlmm/")
4071 (synopsis "Perform genome-wide association studies on large data sets")
4072 (description
4073 "FaST-LMM, which stands for Factored Spectrally Transformed Linear Mixed
4074 Models, is a program for performing both single-SNP and SNP-set genome-wide
4075 association studies (GWAS) on extremely large data sets.")
4076 (license license:asl2.0)))
4077
4078 (define-public python-numpy-documentation
4079 (package
4080 (name "python-numpy-documentation")
4081 (version (package-version python-numpy))
4082 (source (package-source python-numpy))
4083 (build-system python-build-system)
4084 (native-inputs
4085 `(("python-matplotlib" ,python-matplotlib)
4086 ("python-numpy" ,python-numpy)
4087 ("pkg-config" ,pkg-config)
4088 ("python-sphinx" ,python-sphinx)
4089 ("python-numpydoc" ,python-numpydoc)
4090 ("texlive" ,(texlive-union (list texlive-fonts-amsfonts
4091 texlive-fonts-ec
4092 texlive-generic-ifxetex
4093 texlive-generic-pdftex
4094 texlive-latex-amsfonts
4095 texlive-latex-capt-of
4096 texlive-latex-cmap
4097 texlive-latex-environ
4098 texlive-latex-eqparbox
4099 texlive-latex-etoolbox
4100 texlive-latex-expdlist
4101 texlive-latex-fancyhdr
4102 texlive-latex-fancyvrb
4103 texlive-latex-fncychap
4104 texlive-latex-float
4105 texlive-latex-framed
4106 texlive-latex-geometry
4107 texlive-latex-graphics
4108 texlive-latex-hyperref
4109 texlive-latex-mdwtools
4110 texlive-latex-multirow
4111 texlive-latex-oberdiek
4112 texlive-latex-parskip
4113 texlive-latex-preview
4114 texlive-latex-tabulary
4115 texlive-latex-threeparttable
4116 texlive-latex-titlesec
4117 texlive-latex-trimspaces
4118 texlive-latex-ucs
4119 texlive-latex-upquote
4120 texlive-latex-url
4121 texlive-latex-varwidth
4122 texlive-latex-wrapfig)))
4123 ("texinfo" ,texinfo)
4124 ("perl" ,perl)
4125 ("scipy-sphinx-theme"
4126 ,(origin ; The build script expects scipy-sphinx-theme as a git submodule
4127 (method git-fetch)
4128 (uri (git-reference
4129 (url "https://github.com/scipy/scipy-sphinx-theme.git")
4130 (commit "c466764e2231ba132c09826b5b138fffa1cfcec3")))
4131 (sha256
4132 (base32
4133 "0q2y87clwlsgc7wvlsn9pzyssybcq10plwhq2w1ydykfsyyqbmkl"))))
4134 ,@(package-native-inputs python-numpy)))
4135 (arguments
4136 `(#:tests? #f ; we're only generating the documentation
4137 #:phases
4138 (modify-phases %standard-phases
4139 (delete 'build)
4140 (replace 'install
4141 (lambda* (#:key inputs outputs #:allow-other-keys)
4142 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
4143 (doc (string-append
4144 data "/doc/" ,name "-"
4145 ,(package-version python-numpy)))
4146 (info-reader (string-append data "/info"))
4147 (html (string-append doc "/html"))
4148 (scipy-sphinx-theme "scipy-sphinx-theme")
4149 (sphinx-theme-checkout (assoc-ref inputs scipy-sphinx-theme))
4150 (pyver ,(string-append "PYVER=")))
4151
4152 ;; FIXME: this is needed to for texlive-union to generate
4153 ;; fonts, which are not found.
4154 (setenv "HOME" "/tmp")
4155
4156 (with-directory-excursion "doc"
4157 (copy-recursively sphinx-theme-checkout scipy-sphinx-theme)
4158 (mkdir-p html)
4159 (system* "make" "html" pyver)
4160 (system* "make" "latex" "PAPER=a4" pyver)
4161 (system* "make" "-C" "build/latex"
4162 "all-pdf" "PAPER=a4" pyver)
4163 ;; FIXME: Generation of the info file fails.
4164 ;; (system* "make" "info" pyver)
4165 ;; (mkdir-p info)
4166 ;; (copy-file "build/texinfo/numpy.info"
4167 ;; (string-append info "/numpy.info"))
4168 (for-each (lambda (file)
4169 (copy-file (string-append "build/latex" file)
4170 (string-append doc file)))
4171 '("/numpy-ref.pdf" "/numpy-user.pdf"))
4172 (with-directory-excursion "build/html"
4173 (for-each (lambda (file)
4174 (let* ((dir (dirname file))
4175 (tgt-dir (string-append html "/" dir)))
4176 (unless (equal? "." dir)
4177 (mkdir-p tgt-dir))
4178 (install-file file html)))
4179 (find-files "." ".*")))))
4180 #t)))))
4181 (home-page (package-home-page python-numpy))
4182 (synopsis "Documentation for the python-numpy package")
4183 (description (package-description python-numpy))
4184 (license (package-license python-numpy))))
4185
4186 (define-public python2-numpy-documentation
4187 (let ((numpy-documentation (package-with-python2 python-numpy-documentation)))
4188 (package
4189 (inherit numpy-documentation)
4190 (native-inputs `(("python2-functools32" ,python2-functools32)
4191 ,@(package-native-inputs numpy-documentation))))))
4192
4193 (define-public python-pygit2
4194 (package
4195 (name "python-pygit2")
4196 (version "0.26.0")
4197 (source
4198 (origin
4199 (method url-fetch)
4200 (uri (pypi-uri "pygit2" version))
4201 (sha256
4202 (base32
4203 "1cbc488ra3kg7r3qky17ms0szi3cda2d96qfkv1l9djsy9hnvw57"))
4204 (patches
4205 (search-patches "python-pygit2-disable-network-tests.patch"))))
4206 (build-system python-build-system)
4207 (propagated-inputs
4208 `(("python-six" ,python-six)
4209 ("python-cffi" ,python-cffi)
4210 ("libgit2" ,libgit2)
4211 ("python-tox" ,python-tox)))
4212 (home-page "https://github.com/libgit2/pygit2")
4213 (synopsis "Python bindings for libgit2")
4214 (description "Pygit2 is a set of Python bindings to the libgit2 shared
4215 library, libgit2 implements Git plumbing.")
4216 ;; GPL2.0 only, with linking exception.
4217 (license license:gpl2)))
4218
4219 (define-public python2-pygit2
4220 (package-with-python2 python-pygit2))
4221
4222 (define-public python-pyparsing
4223 (package
4224 (name "python-pyparsing")
4225 (version "2.2.0")
4226 (source
4227 (origin
4228 (method url-fetch)
4229 (uri (string-append "mirror://sourceforge/pyparsing/pyparsing"
4230 "/pyparsing-" version
4231 "/pyparsing-" version ".tar.gz"))
4232 (sha256
4233 (base32
4234 "016b9gh606aa44sq92jslm89bg874ia0yyiyb643fa6dgbsbqch8"))))
4235 (build-system python-build-system)
4236 (outputs '("out" "doc"))
4237 (arguments
4238 `(#:tests? #f ; no test target
4239 #:phases
4240 (modify-phases %standard-phases
4241 (add-after 'install 'install-doc
4242 (lambda* (#:key outputs #:allow-other-keys)
4243 (let* ((doc (string-append (assoc-ref outputs "doc")
4244 "/share/doc/" ,name "-" ,version))
4245 (html-doc (string-append doc "/html"))
4246 (examples (string-append doc "/examples")))
4247 (mkdir-p html-doc)
4248 (mkdir-p examples)
4249 (for-each
4250 (lambda (dir tgt)
4251 (map (lambda (file)
4252 (install-file file tgt))
4253 (find-files dir ".*")))
4254 (list "docs" "htmldoc" "examples")
4255 (list doc html-doc examples))
4256 #t))))))
4257 (home-page "http://pyparsing.wikispaces.com")
4258 (synopsis "Python parsing class library")
4259 (description
4260 "The pyparsing module is an alternative approach to creating and
4261 executing simple grammars, vs. the traditional lex/yacc approach, or the use
4262 of regular expressions. The pyparsing module provides a library of classes
4263 that client code uses to construct the grammar directly in Python code.")
4264 (license license:expat)))
4265
4266 (define-public python2-pyparsing
4267 (package-with-python2 python-pyparsing))
4268
4269 (define-public python-numpydoc
4270 (package
4271 (name "python-numpydoc")
4272 (version "0.5")
4273 (source
4274 (origin
4275 (method url-fetch)
4276 (uri (string-append
4277 "https://pypi.python.org/packages/source/n/numpydoc/numpydoc-"
4278 version ".tar.gz"))
4279 (sha256
4280 (base32
4281 "0d4dnifaxkll50jx6czj05y8cb4ny60njd2wz299sj2jxfy51w4k"))
4282 (modules '((guix build utils)))
4283 (snippet
4284 '(begin
4285 ;; Drop a test requiring matplotlib, which we cannot add as an
4286 ;; input since it would create a circular dependency: Extend the
4287 ;; test for Python 3, where it is already dropped, to Python 2.
4288 (substitute* "numpydoc/tests/test_plot_directive.py"
4289 (("3") "2"))))))
4290 (build-system python-build-system)
4291 (propagated-inputs
4292 `(("python-sphinx" ,python-sphinx)))
4293 (native-inputs
4294 `(("python-nose" ,python-nose)))
4295 (home-page "https://pypi.python.org/pypi/numpydoc")
4296 (synopsis
4297 "Numpy's Sphinx extensions")
4298 (description
4299 "Sphinx extension to support docstrings in Numpy format.")
4300 (license license:bsd-2)))
4301
4302 (define-public python2-numpydoc
4303 (package-with-python2 python-numpydoc))
4304
4305 (define-public python-numexpr
4306 (package
4307 (name "python-numexpr")
4308 (version "2.6.4")
4309 (source
4310 (origin
4311 (method url-fetch)
4312 (uri (pypi-uri "numexpr" version))
4313 (sha256
4314 (base32
4315 "1kpnbb5d5n927113zccfibn16z7gidjipyac6kbbhzs0lnizkgph"))))
4316 (build-system python-build-system)
4317 (arguments `(#:tests? #f)) ; no tests included
4318 (propagated-inputs
4319 `(("python-numpy" ,python-numpy)))
4320 (home-page "https://github.com/pydata/numexpr")
4321 (synopsis "Fast numerical expression evaluator for NumPy")
4322 (description
4323 "Numexpr is a fast numerical expression evaluator for NumPy. With it,
4324 expressions that operate on arrays are accelerated and use less memory than
4325 doing the same calculation in Python. In addition, its multi-threaded
4326 capabilities can make use of all your cores, which may accelerate
4327 computations, most specially if they are not memory-bounded (e.g. those using
4328 transcendental functions).")
4329 (license license:expat)))
4330
4331 (define-public python2-numexpr
4332 (package-with-python2 python-numexpr))
4333
4334 (define-public python-cycler
4335 (package
4336 (name "python-cycler")
4337 (version "0.10.0")
4338 (source (origin
4339 (method url-fetch)
4340 (uri (pypi-uri "cycler" version))
4341 (sha256
4342 (base32
4343 "1n69n23fak1gjxlrbhqisi2b9pv3ckrfj98llx3p53953082syyd"))))
4344 (build-system python-build-system)
4345 (arguments
4346 ;; XXX: The current version requires 'coveralls' which we don't have.
4347 ;; Enable this for the next release which uses 'python-pytest'.
4348 '(#:tests? #f))
4349 (propagated-inputs
4350 `(("python-six" ,python-six)))
4351 (home-page "http://matplotlib.org/cycler/")
4352 (synopsis "Composable keyword argument iterator")
4353 (description
4354 "When using @code{matplotlib} and plotting more than one line, it is
4355 common to want to be able to want to be able to cycle over one or more artist
4356 styles; but the plotting logic can quickly become involved.
4357 To address this and enable easy cycling over arbitrary @code{kwargs}, the
4358 @code{Cycler} class was developed.")
4359 (license license:bsd-3)))
4360
4361 (define-public python2-cycler
4362 (package-with-python2 python-cycler))
4363
4364 (define-public python-colorspacious
4365 (package
4366 (name "python-colorspacious")
4367 (version "1.1.0")
4368 (source
4369 (origin
4370 (method url-fetch)
4371 (uri (string-append "https://github.com/njsmith/colorspacious/archive/v"
4372 version ".tar.gz"))
4373 (file-name (string-append name "-" version))
4374 (sha256
4375 (base32 "1vflh5jm32qb0skza2i8pjacv09w6gq84fqpp2nj77s0rbmzgr4k"))))
4376 (build-system python-build-system)
4377 (propagated-inputs
4378 `(("python-numpy" ,python-numpy)))
4379 (native-inputs
4380 `(("python-nose" ,python-nose)))
4381 (arguments
4382 `(#:phases
4383 (modify-phases %standard-phases
4384 (replace 'check
4385 (lambda _
4386 (zero? (system* "nosetests" "--all-modules" "-v" "colorspacious")))))))
4387 (home-page "https://github.com/njsmith/colorspacious")
4388 (synopsis "Python library for colorspace conversions")
4389 (description "@code{colorspacious} is a Python library that lets you
4390 convert between colorspaces like sRGB, XYZ, CIEL*a*b*, CIECAM02, CAM02-UCS, etc.")
4391 (license license:expat)))
4392
4393 (define-public python2-colorspacious
4394 (package-with-python2 python-colorspacious))
4395
4396 (define-public python-matplotlib
4397 (package
4398 (name "python-matplotlib")
4399 (version "2.0.2")
4400 (source
4401 (origin
4402 (method url-fetch)
4403 (uri (pypi-uri "matplotlib" version))
4404 (sha256
4405 (base32
4406 "1w8z2a1l7s72p1byfz7g03wqhygqxi8w82619dqb3a1lm97w9yqg"))))
4407 (build-system python-build-system)
4408 (propagated-inputs ; the following packages are all needed at run time
4409 `(("python-cycler" ,python-cycler)
4410 ("python-pyparsing" ,python-pyparsing)
4411 ("python-pygobject" ,python-pygobject)
4412 ("gobject-introspection" ,gobject-introspection)
4413 ("python-tkinter" ,python "tk")
4414 ("python-dateutil" ,python-dateutil)
4415 ("python-numpy" ,python-numpy)
4416 ("python-pillow" ,python-pillow)
4417 ("python-pytz" ,python-pytz)
4418 ("python-six" ,python-six)
4419 ;; The 'gtk+' package (and 'gdk-pixbuf', 'atk' and 'pango' propagated
4420 ;; from 'gtk+') provides the required 'typelib' files used by
4421 ;; 'gobject-introspection'. The location of these files is set with the
4422 ;; help of the environment variable GI_TYPELIB_PATH. At build time this
4423 ;; is done automatically by a 'native-search-path' procedure. However,
4424 ;; at run-time the user must set this variable as follows:
4425 ;;
4426 ;; export GI_TYPELIB_PATH=~/.guix-profile/lib/girepository-1.0
4427 ("gtk+" ,gtk+)
4428 ;; From version 1.4.0 'matplotlib' makes use of 'cairocffi' instead of
4429 ;; 'pycairo'. However, 'pygobject' makes use of a 'pycairo' 'context'
4430 ;; object. For this reason we need to import both libraries.
4431 ;; https://pythonhosted.org/cairocffi/cffi_api.html#converting-pycairo
4432 ("python-pycairo" ,python-pycairo)
4433 ("python-cairocffi" ,python-cairocffi)))
4434 (inputs
4435 `(("libpng" ,libpng)
4436 ("imagemagick" ,imagemagick)
4437 ("freetype" ,freetype)
4438 ("cairo" ,cairo)
4439 ("glib" ,glib)
4440 ;; FIXME: Add backends when available.
4441 ;("python-wxpython" ,python-wxpython)
4442 ("python-pyqt" ,python-pyqt)
4443 ("tcl" ,tcl)
4444 ("tk" ,tk)))
4445 (native-inputs
4446 `(("pkg-config" ,pkg-config)
4447 ("python-nose" ,python-nose)
4448 ("python-mock" ,python-mock)))
4449 (arguments
4450 `(#:phases
4451 (modify-phases %standard-phases
4452 (add-before 'build 'configure-environment
4453 (lambda* (#:key outputs inputs #:allow-other-keys)
4454 (let ((cairo (assoc-ref inputs "cairo"))
4455 (gtk+ (assoc-ref inputs "gtk+")))
4456 ;; Setting these directories in the 'basedirlist' of 'setup.cfg'
4457 ;; has not effect.
4458 (setenv "LD_LIBRARY_PATH"
4459 (string-append cairo "/lib:" gtk+ "/lib"))
4460 (setenv "HOME" (getcwd))
4461 (call-with-output-file "setup.cfg"
4462 (lambda (port)
4463 (format port "[directories]~%
4464 basedirlist = ~a,~a~%
4465 [rc_options]~%
4466 backend = TkAgg~%"
4467 (assoc-ref inputs "tcl")
4468 (assoc-ref inputs "tk")))))
4469 #t)))))
4470 (home-page "http://matplotlib.org")
4471 (synopsis "2D plotting library for Python")
4472 (description
4473 "Matplotlib is a Python 2D plotting library which produces publication
4474 quality figures in a variety of hardcopy formats and interactive environments
4475 across platforms. Matplotlib can be used in Python scripts, the python and
4476 ipython shell, web application servers, and six graphical user interface
4477 toolkits.")
4478 (license license:psfl)
4479 (properties `((python2-variant . ,(delay python2-matplotlib))))))
4480
4481 (define-public python2-matplotlib
4482 (let ((matplotlib (package-with-python2
4483 (strip-python2-variant python-matplotlib))))
4484 (package (inherit matplotlib)
4485 ;; Make sure to use special packages for Python 2 instead
4486 ;; of those automatically rewritten by package-with-python2.
4487 (propagated-inputs
4488 `(("python2-pycairo" ,python2-pycairo)
4489 ("python2-functools32" ,python2-functools32)
4490 ("python2-pygobject-2" ,python2-pygobject-2)
4491 ("python2-subprocess32" ,python2-subprocess32)
4492 ("python2-tkinter" ,python-2 "tk")
4493 ,@(fold alist-delete (package-propagated-inputs matplotlib)
4494 '("python-pycairo" "python-pygobject" "python-tkinter")))))))
4495
4496 (define-public python-matplotlib-documentation
4497 (package
4498 (name "python-matplotlib-documentation")
4499 (version (package-version python-matplotlib))
4500 (source (package-source python-matplotlib))
4501 (build-system python-build-system)
4502 (native-inputs
4503 `(("python-matplotlib" ,python-matplotlib)
4504 ("python-colorspacious" ,python-colorspacious)
4505 ("python-sphinx" ,python-sphinx)
4506 ("python-numpydoc" ,python-numpydoc)
4507 ("python-ipython" ,python-ipython)
4508 ("python-mock" ,python-mock)
4509 ("graphviz" ,graphviz)
4510 ("texlive" ,texlive)
4511 ("texinfo" ,texinfo)
4512 ,@(package-native-inputs python-matplotlib)))
4513 (arguments
4514 `(#:tests? #f ; we're only generating documentation
4515 #:phases
4516 (modify-phases %standard-phases
4517 (replace 'build
4518 (lambda _
4519 (chdir "doc")
4520 ;; Produce pdf in 'A4' format.
4521 (substitute* "conf.py"
4522 (("latex_paper_size = 'letter'") "")
4523 ;; latex_paper_size is deprecated -> set paper size using
4524 ;; latex_elements
4525 (("latex_elements\\['pointsize'\\] = '11pt'" match)
4526 ;; insert at a point where latex_elements{} is defined:
4527 (string-append match "\nlatex_elements['papersize'] = 'a4paper'")))
4528 (zero? (system* "python" "make.py" "html" "latex" "texinfo"))))
4529 (replace 'install
4530 (lambda* (#:key inputs outputs #:allow-other-keys)
4531 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
4532 (doc (string-append data "/doc/python-matplotlib-" ,version))
4533 (info (string-append data "/info"))
4534 (html (string-append doc "/html")))
4535 (mkdir-p html)
4536 (mkdir-p info)
4537 (copy-recursively "build/html" html)
4538 (symlink (string-append html "/_images")
4539 (string-append info "/matplotlib-figures"))
4540 (with-directory-excursion "build/texinfo"
4541 (substitute* "matplotlib.texi"
4542 (("@image\\{([^,]*)" all file)
4543 (string-append "@image{matplotlib-figures/" file)))
4544 (symlink (string-append html "/_images")
4545 "./matplotlib-figures")
4546 (system* "makeinfo" "--no-split"
4547 "-o" "matplotlib.info" "matplotlib.texi"))
4548 (copy-file "build/texinfo/matplotlib.info"
4549 (string-append info "/matplotlib.info"))
4550 (copy-file "build/latex/Matplotlib.pdf"
4551 (string-append doc "/Matplotlib.pdf")))
4552 #t)))))
4553 (home-page (package-home-page python-matplotlib))
4554 (synopsis "Documentation for the python-matplotlib package")
4555 (description (package-description python-matplotlib))
4556 (license (package-license python-matplotlib))))
4557
4558 (define-public python2-matplotlib-documentation
4559 (package-with-python2 python-matplotlib-documentation))
4560
4561 (define-public python2-pysnptools
4562 (package
4563 (name "python2-pysnptools")
4564 (version "0.3.9")
4565 (source
4566 (origin
4567 (method url-fetch)
4568 (uri (pypi-uri "pysnptools" version ".zip"))
4569 (sha256
4570 (base32
4571 "1wybggjzz8zw7aav4pjsg2h22xp17a1lghrprza1pxwlm7wf96y2"))))
4572 (build-system python-build-system)
4573 (arguments
4574 `(#:python ,python-2)) ; only Python 2.7 is supported
4575 (propagated-inputs
4576 `(("python2-numpy" ,python2-numpy)
4577 ("python2-scipy" ,python2-scipy)
4578 ("python2-pandas" ,python2-pandas)))
4579 (native-inputs
4580 `(("python2-cython" ,python2-cython)))
4581 (native-inputs
4582 `(("unzip" ,unzip)))
4583 (home-page "http://research.microsoft.com/en-us/um/redmond/projects/mscompbio/")
4584 (synopsis "Library for reading and manipulating genetic data")
4585 (description
4586 "PySnpTools is a library for reading and manipulating genetic data. It
4587 can, for example, efficiently read whole PLINK *.bed/bim/fam files or parts of
4588 those files. It can also efficiently manipulate ranges of integers using set
4589 operators such as union, intersection, and difference.")
4590 (license license:asl2.0)))
4591
4592 (define-public python-rpy2
4593 (package
4594 (name "python-rpy2")
4595 (version "2.9.0")
4596 (source
4597 (origin
4598 (method url-fetch)
4599 (uri (pypi-uri "rpy2" version))
4600 (sha256
4601 (base32
4602 "0bqihjrdqwj5r1h86shvfb1p5hfr4a6klv1v54bzfr9r144w3rni"))))
4603 (build-system python-build-system)
4604 (arguments
4605 '(#:modules ((ice-9 ftw)
4606 (srfi srfi-1)
4607 (srfi srfi-26)
4608 (guix build utils)
4609 (guix build python-build-system))
4610 #:phases
4611 (modify-phases %standard-phases
4612 ;; Without this phase the test loader cannot find the directories, in
4613 ;; which it is supposed to look for test files.
4614 (add-after 'unpack 'fix-tests
4615 (lambda* (#:key outputs #:allow-other-keys)
4616 (substitute* "rpy/tests.py"
4617 (("loader.discover\\(")
4618 "loader.discover(rpy_root + '/' +"))
4619 #t))
4620 (replace 'check
4621 (lambda* (#:key outputs inputs #:allow-other-keys)
4622 (let ((cwd (getcwd)))
4623 (setenv "PYTHONPATH"
4624 (string-append cwd "/build/"
4625 (find (cut string-prefix? "lib" <>)
4626 (scandir (string-append cwd "/build")))
4627 ":"
4628 (getenv "PYTHONPATH"))))
4629 ;; FIXME: Even when all tests pass, the check phase will fail.
4630 (system* "python" "-m" "rpy2.tests" "-v"))))))
4631 (propagated-inputs
4632 `(("python-six" ,python-six)
4633 ("python-jinja2" ,python-jinja2)
4634 ("python-pytz" ,python-pytz)))
4635 (inputs
4636 `(("readline" ,readline)
4637 ("icu4c" ,icu4c)
4638 ("pcre" ,pcre)
4639 ("r-minimal" ,r-minimal)
4640 ("r-survival" ,r-survival)
4641 ("r-ggplot2" ,r-ggplot2)
4642 ("r-rsqlite" ,r-rsqlite)
4643 ("r-dplyr" ,r-dplyr)
4644 ("r-dbplyr" ,r-dbplyr)
4645 ("python-numpy" ,python-numpy)))
4646 (native-inputs
4647 `(("zlib" ,zlib)))
4648 (home-page "http://rpy.sourceforge.net/")
4649 (synopsis "Python interface to the R language")
4650 (description "rpy2 is a redesign and rewrite of rpy. It is providing a
4651 low-level interface to R from Python, a proposed high-level interface,
4652 including wrappers to graphical libraries, as well as R-like structures and
4653 functions.")
4654 ;; Any of these licenses can be picked for the R interface. The whole
4655 ;; project is released under GPLv2+ according to the license declaration
4656 ;; in "setup.py".
4657 (license (list license:mpl2.0 license:gpl2+ license:lgpl2.1+))))
4658
4659 (define-public python-scipy
4660 (package
4661 (name "python-scipy")
4662 (version "0.19.1")
4663 (source
4664 (origin
4665 (method url-fetch)
4666 (uri (pypi-uri "scipy" version))
4667 (sha256
4668 (base32
4669 "1rl411bvla6q7qfdb47fpdnyjhfgzl6smpha33n9ar1klykjr6m1"))))
4670 (build-system python-build-system)
4671 (propagated-inputs
4672 `(("python-numpy" ,python-numpy)
4673 ("python-matplotlib" ,python-matplotlib)
4674 ("python-pyparsing" ,python-pyparsing)))
4675 (inputs
4676 `(("lapack" ,lapack)
4677 ("openblas" ,openblas)))
4678 (native-inputs
4679 `(("python-cython" ,python-cython)
4680 ("python-nose" ,python-nose)
4681 ("python-sphinx" ,python-sphinx)
4682 ("python-numpydoc" ,python-numpydoc)
4683 ("gfortran" ,gfortran)
4684 ("perl" ,perl)))
4685 (outputs '("out" "doc"))
4686 (arguments
4687 `(#:phases
4688 (modify-phases %standard-phases
4689 (add-before 'build 'configure-openblas
4690 (lambda* (#:key inputs #:allow-other-keys)
4691 (call-with-output-file "site.cfg"
4692 (lambda (port)
4693 (format port
4694 "[blas]
4695 libraries = openblas
4696 library_dirs = ~a/lib
4697 include_dirs = ~a/include
4698
4699 # backslash-n to make emacs happy
4700 \n[atlas]
4701 library_dirs = ~a/lib
4702 atlas_libs = openblas
4703 "
4704 (assoc-ref inputs "openblas")
4705 (assoc-ref inputs "openblas")
4706 (assoc-ref inputs "openblas"))))
4707 #t))
4708 (add-after 'install 'install-doc
4709 (lambda* (#:key inputs outputs #:allow-other-keys)
4710 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
4711 (doc (string-append data "/doc/" ,name "-" ,version))
4712 (html (string-append doc "/html"))
4713 (pyver ,(string-append "PYVER=")))
4714 ;; Make installed package available for building the
4715 ;; documentation
4716 (add-installed-pythonpath inputs outputs)
4717 (with-directory-excursion "doc"
4718 ;; Fix generation of images for mathematical expressions.
4719 (substitute* (find-files "source" "conf\\.py")
4720 (("pngmath_use_preview = True")
4721 "pngmath_use_preview = False"))
4722 (mkdir-p html)
4723 (system* "make" "html" pyver)
4724 (with-directory-excursion "build/html"
4725 (for-each (lambda (file)
4726 (let* ((dir (dirname file))
4727 (tgt-dir (string-append html "/" dir)))
4728 (install-file file html)))
4729 (find-files "." ".*")))))
4730 #t))
4731 (add-after 'unpack 'fix-tests
4732 (lambda _
4733 (substitute* "scipy/integrate/tests/test_quadpack.py"
4734 (("libm.so") "libm.so.6"))
4735 #t))
4736 ;; Tests can only be run after the library has been installed and not
4737 ;; within the source directory.
4738 (delete 'check)
4739 (add-after 'install 'check
4740 (lambda* (#:key inputs outputs #:allow-other-keys)
4741 (add-installed-pythonpath inputs outputs)
4742 (with-directory-excursion "/tmp"
4743 (zero? (system* "python" "-c"
4744 "import scipy; scipy.test('full')")))
4745 #t)))))
4746 (home-page "http://www.scipy.org/")
4747 (synopsis "The Scipy library provides efficient numerical routines")
4748 (description "The SciPy library is one of the core packages that make up
4749 the SciPy stack. It provides many user-friendly and efficient numerical
4750 routines such as routines for numerical integration and optimization.")
4751 (properties `((python2-variant . ,(delay python2-scipy))))
4752 (license license:bsd-3)))
4753
4754 (define-public python2-scipy
4755 (package-with-python2
4756 (strip-python2-variant python-scipy)))
4757
4758 (define-public python-sockjs-tornado
4759 (package
4760 (name "python-sockjs-tornado")
4761 (version "1.0.3")
4762 (source
4763 (origin
4764 (method url-fetch)
4765 (uri (pypi-uri "sockjs-tornado" version))
4766 (sha256
4767 (base32
4768 "16cff40nniqsyvda1pb2j3b4zwmrw7y2g1vqq78lp20xpmhnwwkd"))))
4769 (build-system python-build-system)
4770 (arguments
4771 `(;; There are no tests, and running the test phase requires missing
4772 ;; dependencies
4773 #:tests? #f))
4774 (propagated-inputs
4775 `(("python-tornado" ,python-tornado)))
4776 (home-page "http://github.com/mrjoes/sockjs-tornado/")
4777 (synopsis
4778 "SockJS python server implementation on top of Tornado framework")
4779 (description
4780 "SockJS-tornado provides the server side counterpart to a SockJS client
4781 library, through the Tornado framework.
4782
4783 SockJS provides a low latency, full duplex, cross-domain communication channel
4784 between a web browser and web server.")
4785 (license license:expat)))
4786
4787 (define-public python2-sockjs-tornado
4788 (package-with-python2 python-sockjs-tornado))
4789
4790 (define-public python-socksipy-branch
4791 (package
4792 (name "python-socksipy-branch")
4793 (version "1.01")
4794 (source
4795 (origin
4796 (method url-fetch)
4797 (uri (pypi-uri "SocksiPy-branch" version))
4798 (sha256
4799 (base32
4800 "01l41v4g7fy9fzvinmjxy6zcbhgqaif8dhdqm4w90fwcw9h51a8p"))))
4801 (build-system python-build-system)
4802 (arguments
4803 `(#:tests? #f)) ; There are no tests
4804 (home-page "https://code.google.com/archive/p/socksipy-branch/")
4805 (synopsis "Python SOCKS module")
4806 (description
4807 "SocksiPy - A Python SOCKS client module. It provides a
4808 socket-like interface that supports connections to any TCP
4809 service through the use of a SOCKS4, SOCKS5 or HTTP proxy.
4810 The original version was developed by Dan Haim, this is a
4811 branch created by Mario Vilas to address some open issues,
4812 as the original project seems to have been abandoned circa 2007.")
4813 (license license:bsd-3)))
4814
4815 (define-public python2-socksipy-branch
4816 (package-with-python2 python-socksipy-branch))
4817
4818 (define-public python-sqlalchemy
4819 (package
4820 (name "python-sqlalchemy")
4821 (version "1.0.12")
4822 (source
4823 (origin
4824 (method url-fetch)
4825 (uri (string-append "https://pypi.python.org/packages/source/S/"
4826 "SQLAlchemy/SQLAlchemy-" version ".tar.gz"))
4827 (sha256
4828 (base32
4829 "1l8qclhd0s90w3pvwhi5mjxdwr5j7gw7cjka2fx6f2vqmq7f4yb6"))))
4830 (build-system python-build-system)
4831 (native-inputs
4832 `(("python-cython" ,python-cython) ;for c extensions
4833 ("python-pytest" ,python-pytest)
4834 ("python-mock" ,python-mock))) ;for tests
4835 (arguments
4836 `(#:phases
4837 (modify-phases %standard-phases
4838 (replace 'check
4839 (lambda _ (zero? (system* "py.test")))))))
4840 (home-page "http://www.sqlalchemy.org")
4841 (synopsis "Database abstraction library")
4842 (description
4843 "SQLAlchemy is the Python SQL toolkit and Object Relational Mapper that
4844 gives application developers the full power and flexibility of SQL. It
4845 provides a full suite of well known enterprise-level persistence patterns,
4846 designed for efficient and high-performing database access, adapted into a
4847 simple and Pythonic domain language.")
4848 (license license:x11)))
4849
4850 (define-public python2-sqlalchemy
4851 (package-with-python2 python-sqlalchemy))
4852
4853 (define-public python-pycodestyle
4854 (package
4855 (name "python-pycodestyle")
4856 (version "2.3.1")
4857 (source
4858 (origin
4859 (method url-fetch)
4860 (uri (pypi-uri "pycodestyle" version))
4861 (sha256
4862 (base32
4863 "0rk78b66p57ala26mdldl9lafr48blv5s659sah9q50qnfjmc8k8"))))
4864 (build-system python-build-system)
4865 (home-page "https://pycodestyle.readthedocs.io/")
4866 (synopsis "Python style guide checker")
4867 (description "@code{pycodestyle} (formerly pep8) is a tool to check
4868 Python code against some of the style conventions in
4869 @url{http://www.python.org/dev/peps/pep-0008/,PEP 8}.")
4870 (license license:expat)))
4871
4872 (define-public python2-pycodestyle
4873 (package-with-python2 python-pycodestyle))
4874
4875 (define-public python-orderedmultidict
4876 (package
4877 (name "python-orderedmultidict")
4878 (version "0.7.11")
4879 (source
4880 (origin
4881 (method url-fetch)
4882 (uri (pypi-uri "orderedmultidict" version))
4883 (sha256
4884 (base32
4885 "0dls862ibm7qbq4fnvwx0xn1v9hwyzywbff8xjjdr42dd75208yw"))))
4886 (build-system python-build-system)
4887 (arguments
4888 `(#:phases
4889 (modify-phases %standard-phases
4890 (add-after 'unpack 'fix-tests
4891 (lambda _
4892 ;; The package uses nosetest for running the tests.
4893 ;; Adding this initfile allows to run the test suite
4894 ;; without requiring nosetest.
4895 (zero? (system* "touch" "tests/__init__.py")))))))
4896 (propagated-inputs
4897 `(("python-six" ,python-six)))
4898 (native-inputs
4899 `(("python-pycodestyle" ,python-pycodestyle)))
4900 (home-page "https://github.com/gruns/orderedmultidict")
4901 (synopsis "Python Ordered Multivalue Dictionary - omdict")
4902 (description "This package contains a library for ordered multivalue
4903 dictionaries. A multivalue dictionary is a dictionary that can store
4904 multiple values for the same key. An ordered multivalue dictionary is a
4905 multivalue dictionary that retains the order of insertions and deletions.")
4906 (license license:unlicense)))
4907
4908 (define-public python2-orderedmultidict
4909 (package-with-python2 python-orderedmultidict))
4910
4911 (define-public python-furl
4912 (package
4913 (name "python-furl")
4914 (version "0.5.6")
4915 (source
4916 (origin
4917 (method url-fetch)
4918 (uri (pypi-uri "furl" version))
4919 (sha256
4920 (base32
4921 "0lzpfpm686hvz3sr1mcrnd1b3lgmnw8v59gb43wfi98r3b671pqc"))))
4922 (build-system python-build-system)
4923 (propagated-inputs
4924 `(("python-six" ,python-six)
4925 ("python-orderedmultidict" ,python-orderedmultidict)))
4926 (native-inputs
4927 `(("python-pycodestyle" ,python-pycodestyle)))
4928 (home-page "https://github.com/gruns/furl")
4929 (synopsis "URL manipulation in Python")
4930 (description "Furl provides an easy-to-use alternative to the
4931 @code{urllib} and @code{urlparse} modules for manipulating URLs.")
4932 (license license:unlicense)))
4933
4934 (define-public python2-furl
4935 (package-with-python2 python-furl))
4936
4937 (define-public python-flaky
4938 (package
4939 (name "python-flaky")
4940 (version "3.4.0")
4941 (source (origin
4942 (method url-fetch)
4943 (uri (pypi-uri "flaky" version))
4944 (sha256
4945 (base32
4946 "18pkmf79rfkfpy1d2rrx3v55nxj762ilyk9rvd6s6dccxw58imsa"))))
4947 (build-system python-build-system)
4948 (arguments
4949 ;; TODO: Tests require 'coveralls' and 'genty' which are not in Guix yet.
4950 '(#:tests? #f))
4951 (home-page "https://github.com/box/flaky")
4952 (synopsis "Automatically rerun flaky tests")
4953 (description
4954 "Flaky is a plugin for @code{nose} or @code{py.test} that automatically
4955 reruns flaky tests.
4956
4957 Ideally, tests reliably pass or fail, but sometimes test fixtures must rely
4958 on components that aren't 100% reliable. With flaky, instead of removing
4959 those tests or marking them to @code{@@skip}, they can be automatically
4960 retried.")
4961 (license license:asl2.0)))
4962
4963 (define-public python2-flaky
4964 (package-with-python2 python-flaky))
4965
4966 (define-public python-flask-babel
4967 (package
4968 (name "python-flask-babel")
4969 (version "0.11.1")
4970 (source
4971 (origin
4972 (method url-fetch)
4973 (uri (pypi-uri "Flask-Babel" version))
4974 (sha256
4975 (base32
4976 "16b80cipdba9xj3jlaiaq6wgrgpjb70w3j01jjy9hbp4k71kd6yj"))))
4977 (build-system python-build-system)
4978 (propagated-inputs
4979 `(("python-flask" ,python-flask)
4980 ("python-babel" ,python-babel)
4981 ("python-jinja2" ,python-jinja2)
4982 ("python-pytz" ,python-pytz)))
4983 (home-page "https://github.com/python-babel/flask-babel")
4984 (synopsis "Add i18n/l10n support to Flask applications")
4985 (description "This package implements internationalization and localization
4986 support for Flask. This is based on the Python babel module as well as pytz -
4987 both of which are installed automatically if you install this library.")
4988 (license license:bsd-3)))
4989
4990 (define-public python2-flask-babel
4991 (package-with-python2 python-flask-babel))
4992
4993 (define-public python-sqlalchemy-utils
4994 (package
4995 (name "python-sqlalchemy-utils")
4996 (version "0.32.13")
4997 (source
4998 (origin
4999 (method url-fetch)
5000 (uri (pypi-uri "SQLAlchemy-Utils" version))
5001 (sha256
5002 (base32
5003 "0vsib7gidjamzsz6w4s5pdhxzxsrkghjnm4sqwk94igjrl3i5ixj"))))
5004 (build-system python-build-system)
5005 (arguments
5006 '(#:tests? #f)) ; FIXME: Many tests require a running database server.
5007 ;; #:phases
5008 ;; (modify-phases %standard-phases
5009 ;; (replace 'check
5010 ;; (lambda _
5011 ;; (zero? (system* "py.test" "sqlalchemy_utils" "tests")))))
5012 (propagated-inputs
5013 `(("python-six" ,python-six)
5014 ("python-sqlalchemy" ,python-sqlalchemy)))
5015 (native-inputs
5016 `(("python-dateutil" ,python-dateutil)
5017 ("python-flexmock" ,python-flexmock)
5018 ("python-psycopg2" ,python-psycopg2)
5019 ("python-pytest" ,python-pytest)
5020 ("python-pytz" ,python-pytz)))
5021 (home-page "https://github.com/kvesteri/sqlalchemy-utils")
5022 (synopsis "Various utility functions for SQLAlchemy")
5023 (description
5024 "SQLAlchemy-utils provides various utility functions and custom data types
5025 for SQLAlchemy. SQLAlchemy is an SQL database abstraction library for Python.
5026
5027 You might also want to install the following optional dependencies:
5028 @enumerate
5029 @item @code{python-passlib}
5030 @item @code{python-babel}
5031 @item @code{python-cryptography}
5032 @item @code{python-pytz}
5033 @item @code{python-psycopg2}
5034 @item @code{python-furl}
5035 @item @code{python-flask-babel}
5036 @end enumerate
5037 ")
5038 (license license:bsd-3)))
5039
5040 (define-public python2-sqlalchemy-utils
5041 (package-with-python2 python-sqlalchemy-utils))
5042
5043 (define-public python-alembic
5044 (package
5045 (name "python-alembic")
5046 (version "0.9.5")
5047 (source
5048 (origin
5049 (method url-fetch)
5050 (uri (pypi-uri "alembic" version))
5051 (sha256
5052 (base32
5053 "01gx2syqbaxh4hr9pf7pxhlb6p36qaf99140dy19lsx1paxb9p4b"))))
5054 (build-system python-build-system)
5055 (native-inputs
5056 `(("python-mock" ,python-mock)
5057 ("python-pytest-cov" ,python-pytest-cov)))
5058 (propagated-inputs
5059 `(("python-dateutil" ,python-dateutil)
5060 ("python-sqlalchemy" ,python-sqlalchemy)
5061 ("python-mako" ,python-mako)
5062 ("python-editor" ,python-editor)))
5063 (home-page "http://bitbucket.org/zzzeek/alembic")
5064 (synopsis
5065 "Database migration tool for SQLAlchemy")
5066 (description
5067 "Alembic is a lightweight database migration tool for usage with the
5068 SQLAlchemy Database Toolkit for Python.")
5069 (license license:expat)))
5070
5071 (define-public python2-alembic
5072 (package-with-python2 python-alembic))
5073
5074 (define-public python-autopep8
5075 (package
5076 (name "python-autopep8")
5077 (version "1.3.2")
5078 (source
5079 (origin
5080 (method url-fetch)
5081 (uri (pypi-uri "autopep8" version))
5082 (sha256
5083 (base32
5084 "1p9pa1ffg4iy96l918808jggg9a69iaka5awmj8xid36yc5mk0ky"))))
5085 (build-system python-build-system)
5086 (propagated-inputs
5087 `(("python-pycodestyle" ,python-pycodestyle)))
5088 (home-page "https://github.com/hhatto/autopep8")
5089 (synopsis "Format Python code according to the PEP 8 style guide")
5090 (description
5091 "@code{autopep8} automatically formats Python code to conform to
5092 the PEP 8 style guide. It uses the pycodestyle utility to determine
5093 what parts of the code needs to be formatted. @code{autopep8} is
5094 capable of fixing most of the formatting issues that can be reported
5095 by pycodestyle.")
5096 (license (license:non-copyleft
5097 "https://github.com/hhatto/autopep8/blob/master/LICENSE"))))
5098
5099 (define-public python2-autopep8
5100 (package-with-python2 python-autopep8))
5101
5102 (define-public python-distutils-extra
5103 (package
5104 (name "python-distutils-extra")
5105 (version "2.38")
5106 (source
5107 (origin
5108 (method url-fetch)
5109 (uri (string-append "https://launchpad.net/python-distutils-extra/trunk/"
5110 version "/+download/python-distutils-extra-"
5111 version ".tar.gz"))
5112 (sha256
5113 (base32
5114 "0lx15kcbby9zisx33p2h5hgakgwh2bvh0ibag8z0px4j6ifhs41x"))))
5115 (build-system python-build-system)
5116 (home-page "https://launchpad.net/python-distutils-extra/")
5117 (synopsis "Enhancements to Python's distutils")
5118 (description
5119 "The python-distutils-extra module enables you to easily integrate
5120 gettext support, themed icons, and scrollkeeper-based documentation into
5121 Python's distutils.")
5122 (license license:gpl2)))
5123
5124 (define-public python2-distutils-extra
5125 (package-with-python2 python-distutils-extra))
5126
5127 (define-public python2-elib.intl
5128 (package
5129 (name "python2-elib.intl")
5130 (version "0.0.3")
5131 (source
5132 (origin
5133 ;; This project doesn't tag releases or publish tarballs, so we take
5134 ;; source from a (semi-arbitrary, i.e. latest as of now) git commit.
5135 (method git-fetch)
5136 (uri (git-reference
5137 (url "https://github.com/dieterv/elib.intl.git")
5138 (commit "d09997cfef")))
5139 (sha256
5140 (base32
5141 "0y7vzff9xgbnaay7m0va1arl6g68ncwrvbgwl7jqlclsahzzb09d"))))
5142 (build-system python-build-system)
5143 (arguments
5144 ;; incompatible with Python 3 (exception syntax)
5145 `(#:python ,python-2
5146 #:tests? #f))
5147 (home-page "https://github.com/dieterv/elib.intl")
5148 (synopsis "Enhanced internationalization for Python")
5149 (description
5150 "The elib.intl module provides enhanced internationalization (I18N)
5151 services for your Python modules and applications.")
5152 (license license:lgpl3+)))
5153
5154 (define-public python-pillow
5155 (package
5156 (name "python-pillow")
5157 (version "3.3.3")
5158 (source
5159 (origin
5160 (method url-fetch)
5161 (uri (pypi-uri "Pillow" version))
5162 (patches (search-patches "python-pillow-freetype-2.7-test-failure.patch"))
5163 (sha256
5164 (base32
5165 "0xkv0p1d73gz0a1qaasf0ai4262g8f334j07vd60bjrxs2wr3nmj"))))
5166 (build-system python-build-system)
5167 (native-inputs
5168 `(("python-nose" ,python-nose)))
5169 (inputs
5170 `(("freetype" ,freetype)
5171 ("lcms" ,lcms)
5172 ("zlib" ,zlib)
5173 ("libjpeg" ,libjpeg)
5174 ("openjpeg" ,openjpeg)
5175 ("libtiff" ,libtiff)
5176 ("libwebp" ,libwebp)))
5177 (arguments
5178 `(#:phases (modify-phases %standard-phases
5179 (add-after
5180 'install 'check-installed
5181 (lambda* (#:key outputs inputs #:allow-other-keys)
5182 (begin
5183 (setenv "HOME" (getcwd))
5184 ;; Make installed package available for running the
5185 ;; tests
5186 (add-installed-pythonpath inputs outputs)
5187 (and (zero? (system* "python" "selftest.py"
5188 "--installed"))
5189 (zero? (system* "python" "test-installed.py"))))))
5190 (delete 'check))))
5191 (home-page "https://pypi.python.org/pypi/Pillow")
5192 (synopsis "Fork of the Python Imaging Library")
5193 (description
5194 "The Python Imaging Library adds image processing capabilities to your
5195 Python interpreter. This library provides extensive file format support, an
5196 efficient internal representation, and fairly powerful image processing
5197 capabilities. The core image library is designed for fast access to data
5198 stored in a few basic pixel formats. It should provide a solid foundation for
5199 a general image processing tool.")
5200 (license (license:x11-style
5201 "http://www.pythonware.com/products/pil/license.htm"
5202 "The PIL Software License"))))
5203
5204 (define-public python2-pillow
5205 (package-with-python2 python-pillow))
5206
5207 (define-public python-pycparser
5208 (package
5209 (name "python-pycparser")
5210 (version "2.17")
5211 (source
5212 (origin
5213 (method url-fetch)
5214 (uri (pypi-uri "pycparser" version))
5215 (sha256
5216 (base32
5217 "1dkkjri0miidqb1zcqhqljfa34fcy9k5akasgwsv6k622zlk3b0a"))))
5218 (outputs '("out" "doc"))
5219 (build-system python-build-system)
5220 (native-inputs
5221 `(("pkg-config" ,pkg-config)))
5222 (arguments
5223 `(#:phases
5224 (modify-phases %standard-phases
5225 (replace 'check
5226 (lambda _
5227 (with-directory-excursion "tests"
5228 (zero? (system* "python" "all_tests.py")))))
5229 (add-after 'install 'install-doc
5230 (lambda* (#:key outputs #:allow-other-keys)
5231 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5232 (doc (string-append data "/doc/" ,name "-" ,version))
5233 (examples (string-append doc "/examples")))
5234 (mkdir-p examples)
5235 (for-each (lambda (file)
5236 (copy-file (string-append "." file)
5237 (string-append doc file)))
5238 '("/README.rst" "/CHANGES" "/LICENSE"))
5239 (copy-recursively "examples" examples)))))))
5240 (home-page "https://github.com/eliben/pycparser")
5241 (synopsis "C parser in Python")
5242 (description
5243 "Pycparser is a complete parser of the C language, written in pure Python
5244 using the PLY parsing library. It parses C code into an AST and can serve as
5245 a front-end for C compilers or analysis tools.")
5246 (license license:bsd-3)))
5247
5248 (define-public python2-pycparser
5249 (package-with-python2 python-pycparser))
5250
5251 (define-public python-xcffib
5252 (package
5253 (name "python-xcffib")
5254 (version "0.5.1")
5255 (source
5256 (origin
5257 (method url-fetch)
5258 (uri (pypi-uri "xcffib" version))
5259 (sha256
5260 (base32
5261 "09gbnmr5vn58mm8xi3fmd7fz6743cks6c46dphnxzwax6zsxmy60"))))
5262 (build-system python-build-system)
5263 (inputs
5264 `(("libxcb" ,libxcb)))
5265 (propagated-inputs
5266 `(("python-cffi" ,python-cffi) ; used at run time
5267 ("python-six" ,python-six)))
5268 (arguments
5269 `(;; FIXME: Tests need more work. See ".travis.yml" in the repository.
5270 #:tests? #f
5271 #:phases
5272 (modify-phases %standard-phases
5273 (add-after 'unpack 'fix-libxcb-path
5274 (lambda* (#:key inputs #:allow-other-keys)
5275 (let ((libxcb (assoc-ref inputs "libxcb")))
5276 (substitute* '("xcffib/__init__.py")
5277 (("^soname = \"") (string-append "soname = \"" libxcb "/lib/")))
5278 #t)))
5279 (add-after 'install 'install-doc
5280 (lambda* (#:key outputs #:allow-other-keys)
5281 (let ((doc (string-append (assoc-ref outputs "out") "/share"
5282 "/doc/" ,name "-" ,version)))
5283 (mkdir-p doc)
5284 (copy-file "README.md"
5285 (string-append doc "/README.md"))
5286 #t))))))
5287 (home-page "https://github.com/tych0/xcffib")
5288 (synopsis "XCB Python bindings")
5289 (description
5290 "Xcffib is a replacement for xpyb, an XCB Python bindings. It adds
5291 support for Python 3 and PyPy. It is based on cffi.")
5292 (license license:expat)))
5293
5294 (define-public python2-xcffib
5295 (package-with-python2 python-xcffib))
5296
5297 (define-public python-cairocffi
5298 (package
5299 (name "python-cairocffi")
5300 (version "0.8.0")
5301 (source
5302 (origin
5303 (method url-fetch)
5304 ;; The archive on pypi is missing the 'utils' directory!
5305 (uri (string-append "https://github.com/Kozea/cairocffi/archive/v"
5306 version ".tar.gz"))
5307 (file-name (string-append name "-" version ".tar.gz"))
5308 (sha256
5309 (base32
5310 "1rk2dvy3fxrga6bvvxc2fi5lbaynm5h4a0w0aaxyn3bc77rszjg9"))))
5311 (build-system python-build-system)
5312 (outputs '("out" "doc"))
5313 (inputs
5314 `(("gdk-pixbuf" ,gdk-pixbuf)
5315 ("cairo" ,cairo)))
5316 (native-inputs
5317 `(("pkg-config" ,pkg-config)
5318 ("python-sphinx" ,python-sphinx)
5319 ("python-docutils" ,python-docutils)))
5320 (propagated-inputs
5321 `(("python-xcffib" ,python-xcffib))) ; used at run time
5322 (arguments
5323 `(;; FIXME: Tests cannot find 'libcairo.so.2'.
5324 #:tests? #f
5325 #:phases
5326 (modify-phases %standard-phases
5327 (add-after 'install 'install-doc
5328 (lambda* (#:key inputs outputs #:allow-other-keys)
5329 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5330 (doc (string-append data "/doc/" ,name "-" ,version))
5331 (html (string-append doc "/html")))
5332 (setenv "LD_LIBRARY_PATH"
5333 (string-append (assoc-ref inputs "cairo") "/lib" ":"
5334 (assoc-ref inputs "gdk-pixbuf") "/lib"))
5335 (setenv "LANG" "en_US.UTF-8")
5336 (mkdir-p html)
5337 (for-each (lambda (file)
5338 (copy-file (string-append "." file)
5339 (string-append doc file)))
5340 '("/README.rst" "/CHANGES" "/LICENSE"))
5341 (system* "python" "setup.py" "build_sphinx")
5342 (copy-recursively "docs/_build/html" html)
5343 #t))))))
5344 (home-page "https://github.com/Kozea/cairocffi")
5345 (synopsis "Python bindings and object-oriented API for Cairo")
5346 (description
5347 "Cairocffi is a CFFI-based drop-in replacement for Pycairo, a set of
5348 Python bindings and object-oriented API for cairo. Cairo is a 2D vector
5349 graphics library with support for multiple backends including image buffers,
5350 PNG, PostScript, PDF, and SVG file output.")
5351 (license license:bsd-3)))
5352
5353 (define-public python2-cairocffi
5354 (package-with-python2 python-cairocffi))
5355
5356 (define-public python-decorator
5357 (package
5358 (name "python-decorator")
5359 (version "4.1.2")
5360 (source
5361 (origin
5362 (method url-fetch)
5363 (uri (pypi-uri "decorator" version))
5364 (sha256
5365 (base32 "1d8npb11kxyi36mrvjdpcjij76l5zfyrz2f820brf0l0rcw4vdkw"))))
5366 (build-system python-build-system)
5367 (arguments '(#:tests? #f)) ; no test target
5368 (home-page "https://pypi.python.org/pypi/decorator/")
5369 (synopsis "Python module to simplify usage of decorators")
5370 (description
5371 "The aim of the decorator module is to simplify the usage of decorators
5372 for the average programmer, and to popularize decorators usage giving examples
5373 of useful decorators, such as memoize, tracing, redirecting_stdout, locked,
5374 etc. The core of this module is a decorator factory.")
5375 (license license:expat)))
5376
5377 (define-public python2-decorator
5378 (package-with-python2 python-decorator))
5379
5380 (define-public python-drmaa
5381 (package
5382 (name "python-drmaa")
5383 (version "0.7.7")
5384 (source
5385 (origin
5386 (method url-fetch)
5387 (uri (pypi-uri "drmaa" version))
5388 (sha256
5389 (base32 "0xzqriqyvk5b8hszbavsyxd29wm3sxirm8zvvdm73rs2iq7w4hkx"))))
5390 (build-system python-build-system)
5391 ;; The test suite requires libdrmaa which is provided by the cluster
5392 ;; environment. At runtime the environment variable DRMAA_LIBRARY_PATH
5393 ;; should be set to the path of the libdrmaa library.
5394 (arguments '(#:tests? #f))
5395 (native-inputs
5396 `(("python-nose" ,python-nose)))
5397 (home-page "https://pypi.python.org/pypi/drmaa")
5398 (synopsis "Python bindings for the DRMAA library")
5399 (description
5400 "A Python package for Distributed Resource Management (DRM) job
5401 submission and control. This package is an implementation of the DRMAA 1.0
5402 Python language binding specification.")
5403 (license license:bsd-3)))
5404
5405 (define-public python2-drmaa
5406 (package-with-python2 python-drmaa))
5407
5408 (define-public python-grako
5409 (package
5410 (name "python-grako")
5411 (version "3.99.9")
5412 (source
5413 (origin
5414 (method url-fetch)
5415 (uri
5416 (pypi-uri "grako" version ".zip"))
5417 (sha256
5418 (base32
5419 "0r63i68wcnv63rfjkasq1ah81frz61a6mzbcnaxhrkdpx84p7hzw"))))
5420 (build-system python-build-system)
5421 (arguments '(#:tests? #f)) ; Test file 'grako.ebnf' is missing from archive.
5422 (native-inputs
5423 `(("unzip" ,unzip)
5424 ("python-pytest" ,python-pytest-3.0)
5425 ("python-pytest-runner" ,python-pytest-runner)))
5426 (home-page "https://bitbucket.org/neogeny/grako")
5427 (synopsis "EBNF parser generator")
5428 (description
5429 "Grako takes a grammar in a variation of EBNF as input, and outputs a
5430 memoizing PEG/Packrat parser in Python.")
5431 (license license:bsd-3)))
5432
5433 (define-public python2-grako
5434 (package-with-python2 python-grako))
5435
5436 (define-public python-gridmap
5437 (package
5438 (name "python-gridmap")
5439 (version "0.13.0")
5440 (source
5441 (origin
5442 (method url-fetch)
5443 (uri (string-append
5444 "https://github.com/pygridtools/gridmap/archive/v"
5445 version ".tar.gz"))
5446 (file-name (string-append name "-" version ".tar.gz"))
5447 (sha256
5448 (base32 "1gzjg2k6f14i1msm2b0ax8d9ds1hvk6qd5nlaivg8m4cxqp4cp1x"))))
5449 (build-system python-build-system)
5450 (arguments
5451 '(#:tests? #f)) ; FIXME: Requires python-cherrypy.
5452 (propagated-inputs
5453 `(("python-psutil" ,python-psutil)
5454 ("python-drmaa" ,python-drmaa)
5455 ("python-pyzmq" ,python-pyzmq)))
5456 (home-page "https://github.com/pygridtools/gridmap")
5457 (synopsis "Create jobs on a cluster directly from Python")
5458 (description
5459 "Gridmap is a Python package to allow you to easily create jobs on the
5460 cluster directly from Python. You can directly map Python functions onto the
5461 cluster without needing to write any wrapper code yourself.")
5462 (license license:gpl3+)))
5463
5464 (define-public python2-gridmap
5465 (package-with-python2 python-gridmap))
5466
5467 (define-public python-honcho
5468 (package
5469 (name "python-honcho")
5470 (version "1.0.1")
5471 (source
5472 (origin
5473 (method url-fetch)
5474 (uri (string-append
5475 "https://github.com/nickstenning/honcho/archive/v"
5476 version ".tar.gz"))
5477 (file-name (string-append name "-" version ".tar.gz"))
5478 (sha256
5479 (base32 "0zizn61n5z5hq421hkypk9pw8s6fpxw30f4hsg7k4ivwzy3gjw9j"))))
5480 (build-system python-build-system)
5481 (native-inputs
5482 `(("python-pytest" ,python-pytest-3.0)
5483 ("python-mock" ,python-mock)
5484 ("python-tox" ,python-tox)
5485 ("which" ,which))) ;for tests
5486 (propagated-inputs
5487 `(("python-jinja2" ,python-jinja2)))
5488 (arguments
5489 `(#:phases
5490 (modify-phases %standard-phases
5491 (delete 'check)
5492 (add-after 'install 'check
5493 (lambda* (#:key outputs inputs #:allow-other-keys)
5494 ;; fix honcho path in testsuite
5495 (substitute* "tests/conftest.py"
5496 (("'honcho'") (string-append "'" (assoc-ref outputs "out")
5497 "/bin/honcho" "'")))
5498 ;; It's easier to run tests after install.
5499 ;; Make installed package available for running the tests
5500 (add-installed-pythonpath inputs outputs)
5501 (zero? (system* "py.test" "-v")))))))
5502 (home-page "https://github.com/nickstenning/honcho")
5503 (synopsis "Manage Procfile-based applications")
5504 (description
5505 "A Procfile is a file which describes how to run an application
5506 consisting of serveral processes. honcho starts all listed processes.
5507 The output of all running processes is collected by honcho and
5508 displayed.")
5509 (license license:expat)))
5510
5511 (define-public python2-honcho
5512 (package-with-python2 python-honcho))
5513
5514 (define-public python-pexpect
5515 (package
5516 (name "python-pexpect")
5517 (version "4.2.1")
5518 (source
5519 (origin
5520 (method url-fetch)
5521 (uri (pypi-uri "pexpect" version))
5522 (sha256
5523 (base32 "14ls7k99pwvl21zqv65kzrhccv50j89m5ij1hf0slmsvlxjj84rx"))))
5524 (build-system python-build-system)
5525 (arguments
5526 `(#:phases
5527 (modify-phases %standard-phases
5528 (add-before 'check 'prepare-tests
5529 (lambda _
5530 (substitute* (find-files "tests")
5531 (("/bin/ls") (which "ls"))
5532 (("/bin/echo") (which "echo"))
5533 (("/bin/which") (which "which"))
5534 ;; Many tests try to use the /bin directory which
5535 ;; is not present in the build environment.
5536 ;; Use one that's non-empty and unlikely to change.
5537 (("/bin'") "/dev'"))
5538 ;; XXX: Socket connection test gets "Connection reset by peer".
5539 ;; Why does it not work? Delete for now.
5540 (delete-file "tests/test_socket.py")
5541 #t))
5542 (replace 'check (lambda _ (zero? (system* "nosetests" "-v")))))))
5543 (native-inputs
5544 `(("python-nose" ,python-nose)
5545 ("python-pytest" ,python-pytest-3.0)
5546 ("man-db" ,man-db)
5547 ("which" ,which)
5548 ("bash-full" ,bash))) ;full Bash for 'test_replwrap.py'
5549 (propagated-inputs
5550 `(("python-ptyprocess" ,python-ptyprocess)))
5551 (home-page "http://pexpect.readthedocs.org/")
5552 (synopsis "Controlling interactive console applications")
5553 (description
5554 "Pexpect is a pure Python module for spawning child applications;
5555 controlling them; and responding to expected patterns in their output.
5556 Pexpect works like Don Libes’ Expect. Pexpect allows your script to spawn a
5557 child application and control it as if a human were typing commands.")
5558 (license license:isc)))
5559
5560 (define-public python2-pexpect
5561 (package-with-python2 python-pexpect))
5562
5563 (define-public python-setuptools-scm
5564 (package
5565 (name "python-setuptools-scm")
5566 (version "1.15.0")
5567 (source (origin
5568 (method url-fetch)
5569 (uri (pypi-uri "setuptools_scm" version))
5570 (sha256
5571 (base32
5572 "0bwyc5markib0i7i2qlyhdzxhiywzxbkfiapldma8m91m82jvwfs"))))
5573 (build-system python-build-system)
5574 (home-page "https://github.com/pypa/setuptools_scm/")
5575 (synopsis "Manage Python package versions in SCM metadata")
5576 (description
5577 "Setuptools_scm handles managing your Python package versions in
5578 @dfn{software configuration management} (SCM) metadata instead of declaring
5579 them as the version argument or in a SCM managed file.")
5580 (license license:expat)))
5581
5582 (define-public python2-setuptools-scm
5583 (package-with-python2 python-setuptools-scm))
5584
5585 (define-public python-pathpy
5586 (package
5587 (name "python-pathpy")
5588 (version "8.1.1")
5589 (source
5590 (origin
5591 (method url-fetch)
5592 (uri (string-append "https://pypi.python.org/packages/source/p/"
5593 "path.py/path.py-" version ".tar.gz"))
5594 (sha256
5595 (base32 "1p8s1l2vfkqhqxdhqlj0g1jjw4f1as2frr35sjcpjjpd5a89y41f"))))
5596 (outputs '("out" "doc"))
5597 (build-system python-build-system)
5598 (propagated-inputs
5599 `(("python-appdirs" ,python-appdirs)))
5600 (native-inputs
5601 `(("python-setuptools-scm" ,python-setuptools-scm)
5602 ("python-sphinx" ,python-sphinx)
5603 ("python-rst.linker" ,python-rst.linker)
5604 ("python-pytest" ,python-pytest)
5605 ("python-pytest-runner" ,python-pytest-runner)))
5606 (arguments
5607 `(#:phases
5608 (modify-phases %standard-phases
5609 (add-after 'build 'build-doc
5610 (lambda _
5611 (setenv "LANG" "en_US.UTF-8")
5612 (zero? (system* "python" "setup.py" "build_sphinx"))))
5613 (add-after 'install 'install-doc
5614 (lambda* (#:key outputs #:allow-other-keys)
5615 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5616 (doc (string-append data "/doc/" ,name "-" ,version))
5617 (html (string-append doc "/html")))
5618 (mkdir-p html)
5619 (for-each (lambda (file)
5620 (copy-file file (string-append doc "/" file)))
5621 '("README.rst" "CHANGES.rst"))
5622 (copy-recursively "build/sphinx/html" html)))))))
5623 (home-page "https://github.com/jaraco/path.py")
5624 (synopsis "Python module wrapper for built-in os.path")
5625 (description
5626 "@code{path.py} implements path objects as first-class entities, allowing
5627 common operations on files to be invoked on those path objects directly.")
5628 (license license:expat)))
5629
5630 (define-public python2-pathpy
5631 (package-with-python2 python-pathpy))
5632
5633 (define-public python-pickleshare
5634 (package
5635 (name "python-pickleshare")
5636 (version "0.5")
5637 (source
5638 (origin
5639 (method url-fetch)
5640 (uri (string-append "https://pypi.python.org/packages/source/p/"
5641 "pickleshare/pickleshare-" version ".tar.gz"))
5642 (sha256
5643 (base32 "11ljr90j3p6qswdrbl7p4cjb2i93f6vn0vx9anzpshsx0d2mggn0"))))
5644 (build-system python-build-system)
5645 (propagated-inputs
5646 `(("python-pathpy" ,python-pathpy)))
5647 (home-page "https://github.com/vivainio/pickleshare")
5648 (synopsis "Tiny key value database with concurrency support")
5649 (description
5650 "PickleShare is a small ‘shelve’-like datastore with concurrency support.
5651 Like shelve, a PickleShareDB object acts like a normal dictionary. Unlike
5652 shelve, many processes can access the database simultaneously. Changing a
5653 value in database is immediately visible to other processes accessing the same
5654 database. Concurrency is possible because the values are stored in separate
5655 files. Hence the “database” is a directory where all files are governed by
5656 PickleShare.")
5657 (license license:expat)))
5658
5659 (define-public python2-pickleshare
5660 (package-with-python2 python-pickleshare))
5661
5662 (define-public python-simplegeneric
5663 (package
5664 (name "python-simplegeneric")
5665 (version "0.8.1")
5666 (source
5667 (origin
5668 (method url-fetch)
5669 (uri (string-append "https://pypi.python.org/packages/source/s/"
5670 "simplegeneric/simplegeneric-" version ".zip"))
5671 (sha256
5672 (base32 "0wwi1c6md4vkbcsfsf8dklf3vr4mcdj4mpxkanwgb6jb1432x5yw"))))
5673 (build-system python-build-system)
5674 (native-inputs
5675 `(("unzip" ,unzip)))
5676 (home-page "http://cheeseshop.python.org/pypi/simplegeneric")
5677 (synopsis "Python module for simple generic functions")
5678 (description
5679 "The simplegeneric module lets you define simple single-dispatch generic
5680 functions, akin to Python’s built-in generic functions like @code{len()},
5681 @code{iter()} and so on. However, instead of using specially-named methods,
5682 these generic functions use simple lookup tables, akin to those used by
5683 e.g. @code{pickle.dump()} and other generic functions found in the Python
5684 standard library.")
5685 (license license:zpl2.1)))
5686
5687 (define-public python2-simplegeneric
5688 (package-with-python2 python-simplegeneric))
5689
5690 (define-public python-ipython-genutils
5691 ;; TODO: This package is retired, check if can be removed, see description.
5692 (package
5693 (name "python-ipython-genutils")
5694 (version "0.1.0")
5695 (source
5696 (origin
5697 (method url-fetch)
5698 (uri (string-append "https://pypi.python.org/packages/source/i/"
5699 "ipython_genutils/ipython_genutils-"
5700 version ".tar.gz"))
5701 (sha256
5702 (base32 "19l2pp1c64ansr89l3cqh19jdi2ixhssdzx0vz4n6r52a6i281is"))))
5703 (build-system python-build-system)
5704 (arguments `(#:tests? #f)) ; no tests
5705 (home-page "http://ipython.org")
5706 (synopsis "Vestigial utilities from IPython")
5707 (description
5708 "This package provides retired utilities from IPython. No packages
5709 outside IPython/Jupyter should depend on it.
5710
5711 This package shouldn't exist. It contains some common utilities shared by
5712 Jupyter and IPython projects during The Big Split. As soon as possible, those
5713 packages will remove their dependency on this, and this package will go
5714 away.")
5715 (license license:bsd-3)))
5716
5717 (define-public python2-ipython-genutils
5718 (package-with-python2 python-ipython-genutils))
5719
5720 (define-public python-traitlets
5721 (package
5722 (name "python-traitlets")
5723 (version "4.2.0")
5724 (source
5725 (origin
5726 (method url-fetch)
5727 (uri (pypi-uri "traitlets" version))
5728 (sha256
5729 (base32
5730 "1afy08sa5n9gnkvh3da49c16zkyv598vchv0p1hp7zzjy8895hz4"))))
5731 (build-system python-build-system)
5732 (arguments
5733 `(#:phases
5734 (modify-phases %standard-phases
5735 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
5736 (propagated-inputs
5737 `(("python-ipython-genutils" ,python-ipython-genutils)
5738 ("python-decorator" ,python-decorator)))
5739 (native-inputs
5740 `(("python-mock" ,python-mock)
5741 ("python-nose" ,python-nose)))
5742 (home-page "http://ipython.org")
5743 (synopsis "Configuration system for Python applications")
5744 (description
5745 "Traitlets is a framework that lets Python classes have attributes with
5746 type checking, dynamically calculated default values, and ‘on change’
5747 callbacks. The package also includes a mechanism to use traitlets for
5748 configuration, loading values from files or from command line arguments. This
5749 is a distinct layer on top of traitlets, so you can use traitlets in your code
5750 without using the configuration machinery.")
5751 (license license:bsd-3)))
5752
5753 (define-public python2-traitlets
5754 (package-with-python2 python-traitlets))
5755
5756 (define-public python-jupyter-core
5757 (package
5758 (name "python-jupyter-core")
5759 (version "4.2.1")
5760 (source
5761 (origin
5762 (method url-fetch)
5763 (uri (string-append (pypi-uri "jupyter_core" version)))
5764 (sha256
5765 (base32
5766 "1cy7inv218dgh4m1fbzbsiqpz733ylgjrj62jxqpfzs3r2cm7ic9"))))
5767 (build-system python-build-system)
5768 ;; FIXME: not sure how to run the tests
5769 (arguments `(#:tests? #f))
5770 (propagated-inputs
5771 `(("python-traitlets" ,python-traitlets)))
5772 (home-page "http://jupyter.org/")
5773 (synopsis "Jupyter base package")
5774 (description
5775 "Jupyter core is the base package on which Jupyter projects rely.")
5776 (license license:bsd-3)))
5777
5778 (define-public python2-jupyter-core
5779 (package-with-python2 python-jupyter-core))
5780
5781 (define-public python-jupyter-client
5782 (package
5783 (name "python-jupyter-client")
5784 (version "4.4.0")
5785 (source
5786 (origin
5787 (method url-fetch)
5788 (uri (pypi-uri "jupyter_client" version))
5789 (sha256
5790 (base32
5791 "1vjjrpjw7k5sh982pbjnslv7byfbfazjw9g92jvs7dz5qbx556n9"))))
5792 (build-system python-build-system)
5793 ;; Tests fail because of missing native python kernel which I assume is
5794 ;; provided by the ipython package, which we cannot use because it would
5795 ;; cause a dependency cycle.
5796 (arguments `(#:tests? #f))
5797 (propagated-inputs
5798 `(("python-pyzmq" ,python-pyzmq)
5799 ("python-traitlets" ,python-traitlets)
5800 ("python-jupyter-core" ,python-jupyter-core)))
5801 (home-page "http://jupyter.org/")
5802 (synopsis "Jupyter protocol implementation and client libraries")
5803 (description
5804 "The @code{jupyter_client} package contains the reference implementation
5805 of the Jupyter protocol. It also provides client and kernel management APIs
5806 for working with kernels, and the @code{jupyter kernelspec} entrypoint for
5807 installing @code{kernelspec}s for use with Jupyter frontends.")
5808 (license license:bsd-3)))
5809
5810 (define-public python2-jupyter-client
5811 (package-with-python2 python-jupyter-client))
5812
5813 (define-public python-ipykernel
5814 (package
5815 (name "python-ipykernel")
5816 (version "4.5.2")
5817 (source
5818 (origin
5819 (method url-fetch)
5820 (uri (pypi-uri "ipykernel" version))
5821 (sha256
5822 (base32 "0qllv0k6zzv1r1cj1x2ygxmlrrqhbslzj8rc6r6fg3kc1rgz4m2s"))))
5823 (build-system python-build-system)
5824 ;; The tests load a submodule of IPython. However, IPython itself depends
5825 ;; on ipykernel.
5826 (arguments `(#:tests? #f))
5827 (propagated-inputs
5828 ;; imported at runtime during connect
5829 `(("python-jupyter-client" ,python-jupyter-client)))
5830 (home-page "http://ipython.org")
5831 (synopsis "IPython Kernel for Jupyter")
5832 (description
5833 "This package provides the IPython kernel for Jupyter.")
5834 (license license:bsd-3)))
5835
5836 (define-public python2-ipykernel
5837 (package-with-python2 python-ipykernel))
5838
5839 (define-public python-testpath
5840 (package
5841 (name "python-testpath")
5842 (version "0.2")
5843 (source
5844 (origin
5845 (method url-fetch)
5846 (uri (string-append "https://github.com/jupyter/testpath/archive/"
5847 version ".tar.gz"))
5848 (file-name (string-append name "-" version ".tar.gz"))
5849 (sha256
5850 (base32
5851 "04kh3fgvmqz6cfcw79q70qwjz7ib7lxm27cc548iy2rpr33qqf55"))))
5852 (build-system python-build-system)
5853 (arguments
5854 `(#:tests? #f ; this package does not even have a setup.py
5855 #:modules ((guix build python-build-system)
5856 (guix build utils)
5857 (srfi srfi-1))
5858 #:imported-modules (,@%python-build-system-modules
5859 (srfi srfi-1))
5860 #:phases
5861 (modify-phases %standard-phases
5862 (delete 'install)
5863 (replace 'build
5864 (lambda* (#:key inputs outputs #:allow-other-keys)
5865 (let* ((version (last
5866 (string-split (assoc-ref inputs "python") #\-)))
5867 (x.y (string-join (take (string-split version #\.) 2)
5868 "."))
5869 (dir (string-append
5870 (assoc-ref outputs "out")
5871 "/lib/python" x.y "/site-packages/testpath")))
5872 (mkdir-p dir)
5873 (copy-recursively "testpath" dir))
5874 #t)))))
5875 (home-page "https://github.com/takluyver/testpath")
5876 (synopsis "Test utilities for code working with files and commands")
5877 (description
5878 "Testpath is a collection of utilities for Python code working with files
5879 and commands. It contains functions to check things on the filesystem, and
5880 tools for mocking system commands and recording calls to those.")
5881 (license license:expat)))
5882
5883 (define-public python2-testpath
5884 (package-with-python2 python-testpath))
5885
5886 (define-public python-ipython
5887 (package
5888 (name "python-ipython")
5889 (version "5.3.0")
5890 (source
5891 (origin
5892 (method url-fetch)
5893 (uri (pypi-uri "ipython" version ".tar.gz"))
5894 (sha256
5895 (base32 "079wyjir4a9qx6kvx096b1asm63djbidk65z3ykcbnlngmg62pmz"))))
5896 (build-system python-build-system)
5897 (outputs '("out" "doc"))
5898 (propagated-inputs
5899 `(("python-pyzmq" ,python-pyzmq)
5900 ("python-prompt-toolkit" ,python-prompt-toolkit)
5901 ("python-terminado" ,python-terminado)
5902 ("python-matplotlib" ,python-matplotlib)
5903 ("python-numpy" ,python-numpy)
5904 ("python-numpydoc" ,python-numpydoc)
5905 ("python-jinja2" ,python-jinja2)
5906 ("python-jupyter-console"
5907 ;; The python-ipython and python-jupyter-console require each
5908 ;; other. To get the functionality in both packages working, strip
5909 ;; down the python-jupyter-console package when using it as an input
5910 ;; to python-ipython.
5911 ,python-jupyter-console-minimal)
5912 ("python-mistune" ,python-mistune)
5913 ("python-pexpect" ,python-pexpect)
5914 ("python-pickleshare" ,python-pickleshare)
5915 ("python-simplegeneric" ,python-simplegeneric)
5916 ("python-jsonschema" ,python-jsonschema)
5917 ("python-traitlets" ,python-traitlets)
5918 ("python-ipykernel" ,python-ipykernel)
5919 ("python-nbformat" ,python-nbformat)
5920 ("python-pygments" ,python-pygments)))
5921 (inputs
5922 `(("readline" ,readline)
5923 ("which" ,which)))
5924 (native-inputs
5925 `(("graphviz" ,graphviz)
5926 ("pkg-config" ,pkg-config)
5927 ("python-requests" ,python-requests) ;; for tests
5928 ("python-testpath" ,python-testpath)
5929 ("python-nose" ,python-nose)
5930 ("python-sphinx" ,python-sphinx)
5931 ("python-shpinx-rtd-theme" ,python-sphinx-rtd-theme)
5932 ;; FIXME: It's possible that a smaller union would work just as well.
5933 ("texlive" ,(texlive-union (list texlive-fonts-amsfonts
5934 texlive-fonts-ec
5935 texlive-generic-ifxetex
5936 texlive-generic-pdftex
5937 texlive-latex-amsfonts
5938 texlive-latex-capt-of
5939 texlive-latex-cmap
5940 texlive-latex-environ
5941 texlive-latex-eqparbox
5942 texlive-latex-etoolbox
5943 texlive-latex-expdlist
5944 texlive-latex-fancyhdr
5945 texlive-latex-fancyvrb
5946 texlive-latex-fncychap
5947 texlive-latex-float
5948 texlive-latex-framed
5949 texlive-latex-geometry
5950 texlive-latex-graphics
5951 texlive-latex-hyperref
5952 texlive-latex-mdwtools
5953 texlive-latex-multirow
5954 texlive-latex-oberdiek
5955 texlive-latex-parskip
5956 texlive-latex-preview
5957 texlive-latex-tabulary
5958 texlive-latex-threeparttable
5959 texlive-latex-titlesec
5960 texlive-latex-trimspaces
5961 texlive-latex-ucs
5962 texlive-latex-upquote
5963 texlive-latex-url
5964 texlive-latex-varwidth
5965 texlive-latex-wrapfig)))
5966 ("texinfo" ,texinfo)))
5967 (arguments
5968 `(#:phases
5969 (modify-phases %standard-phases
5970 (add-after
5971 'install 'install-doc
5972 (lambda* (#:key inputs outputs #:allow-other-keys)
5973 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5974 (doc (string-append data "/doc/" ,name "-" ,version))
5975 (html (string-append doc "/html"))
5976 (man1 (string-append data "/man/man1"))
5977 (info (string-append data "/info"))
5978 (examples (string-append doc "/examples"))
5979 (python-arg (string-append "PYTHON=" (which "python"))))
5980 (setenv "LANG" "en_US.utf8")
5981 ;; Make installed package available for running the tests
5982 (add-installed-pythonpath inputs outputs)
5983 (with-directory-excursion "docs"
5984 ;; FIXME: pdf fails to build
5985 ;;(system* "make" "pdf" "PAPER=a4")
5986 (system* "make" python-arg "html")
5987 (system* "make" python-arg "info"))
5988 (copy-recursively "docs/man" man1)
5989 (copy-recursively "examples" examples)
5990 (copy-recursively "docs/build/html" html)
5991 ;; (copy-file "docs/build/latex/ipython.pdf"
5992 ;; (string-append doc "/ipython.pdf"))
5993 (mkdir-p info)
5994 (copy-file "docs/build/texinfo/ipython.info"
5995 (string-append info "/ipython.info"))
5996 (copy-file "COPYING.rst" (string-append doc "/COPYING.rst")))))
5997 ;; Tests can only be run after the library has been installed and not
5998 ;; within the source directory.
5999 (delete 'check)
6000 (add-after
6001 'install 'check
6002 (lambda* (#:key inputs outputs tests? #:allow-other-keys)
6003 (if tests?
6004 (with-directory-excursion "/tmp"
6005 ;; Make installed package available for running the tests
6006 (add-installed-pythonpath inputs outputs)
6007 (setenv "HOME" "/tmp/") ;; required by a test
6008 (zero? (system* (string-append (assoc-ref outputs "out")
6009 "/bin/iptest"))))
6010 #t)))
6011 (add-before
6012 'install 'fix-tests
6013 (lambda* (#:key inputs #:allow-other-keys)
6014 (substitute* "./IPython/utils/_process_posix.py"
6015 (("/usr/bin/env', 'which") (which "which")))
6016 (substitute* "./IPython/core/tests/test_inputtransformer.py"
6017 (("#!/usr/bin/env python")
6018 (string-append "#!" (which "python"))))
6019 ;; Disable 1 failing test
6020 (substitute* "./IPython/core/tests/test_magic.py"
6021 (("def test_dirops\\(\\):" all)
6022 (string-append "@dec.skipif(True)\n" all))))))))
6023 (home-page "http://ipython.org")
6024 (synopsis "IPython is a tool for interactive computing in Python")
6025 (description
6026 "IPython provides a rich architecture for interactive computing with:
6027 Powerful interactive shells, a browser-based notebook, support for interactive
6028 data visualization, embeddable interpreters and tools for parallel
6029 computing.")
6030 (license license:bsd-3)
6031 (properties `((python2-variant . ,(delay python2-ipython))))))
6032
6033 (define-public python2-ipython
6034 (let ((ipython (package-with-python2 (strip-python2-variant python-ipython))))
6035 (package
6036 (inherit ipython)
6037 ;; FIXME: add pyreadline once available.
6038 (propagated-inputs
6039 `(("python2-backports-shutil-get-terminal-size"
6040 ,python2-backports-shutil-get-terminal-size)
6041 ("python2-pathlib2" ,python2-pathlib2)
6042 ,@(package-propagated-inputs ipython)))
6043 (native-inputs
6044 `(("python2-mock" ,python2-mock)
6045 ,@(package-native-inputs ipython))))))
6046
6047 (define-public python-isodate
6048 (package
6049 (name "python-isodate")
6050 (version "0.5.4")
6051 (source
6052 (origin
6053 (method url-fetch)
6054 (uri (pypi-uri "isodate" version))
6055 (sha256
6056 (base32
6057 "0cafaiwixgpxwh9dsd28qb0dbzsj6xpxjdkyk30ns91ps10mq422"))))
6058 (build-system python-build-system)
6059 (home-page
6060 "http://cheeseshop.python.org/pypi/isodate")
6061 (synopsis
6062 "Python date parser and formatter")
6063 (description
6064 "Python-isodate is a python module for parsing and formatting
6065 ISO 8601 dates, time and duration.")
6066 (license license:bsd-3)))
6067
6068 (define-public python2-isodate
6069 (package-with-python2 python-isodate))
6070
6071 (define-public python-html5lib
6072 (package
6073 (name "python-html5lib")
6074 (version "1.0b10")
6075 (source
6076 (origin
6077 (method url-fetch)
6078 (uri (pypi-uri "html5lib" version))
6079 (sha256
6080 (base32
6081 "1yd068a5c00wd0ajq0hqimv7fd82lhrw0w3s01vbhy9bbd6xapqd"))))
6082 (build-system python-build-system)
6083 (propagated-inputs
6084 `(("python-six" ,python-six)
6085 ("python-webencodings" ,python-webencodings)))
6086 (arguments
6087 `(#:test-target "check"))
6088 (home-page
6089 "https://github.com/html5lib/html5lib-python")
6090 (synopsis
6091 "Python HTML parser based on the WHATWG HTML specifcation")
6092 (description
6093 "Html5lib is an HTML parser based on the WHATWG HTML specifcation
6094 and written in Python.")
6095 (license license:expat)))
6096
6097 (define-public python2-html5lib
6098 (package-with-python2 python-html5lib))
6099
6100 ;; Needed for python-bleach, a dependency of python-notebook
6101 (define-public python-html5lib-0.9
6102 (package
6103 (inherit python-html5lib)
6104 (version "0.999")
6105 (source
6106 (origin
6107 (method url-fetch)
6108 (uri (pypi-uri "html5lib" version))
6109 (sha256
6110 (base32
6111 "17n4zfsj6ynmbwdwviywmj8r6nzr3xvfx2zs0xhndmvm51z7z263"))))))
6112
6113 (define-public python2-html5lib-0.9
6114 (package-with-python2 python-html5lib-0.9))
6115
6116 (define-public python-html5-parser
6117 (package
6118 (name "python-html5-parser")
6119 (version "0.4.4")
6120 (source (origin
6121 (method url-fetch)
6122 (uri (pypi-uri "html5-parser" version))
6123 (sha256
6124 (base32
6125 "1d8sxhl41ffh7qlk7wlsy17xw6slzx5v1yna9s72wx5qrpaa3wxr"))))
6126 (build-system python-build-system)
6127 (native-inputs
6128 `(("pkg-config" ,pkg-config)))
6129 (inputs
6130 `(("libxml2" ,libxml2)))
6131 (propagated-inputs
6132 `(("python-lxml" ,python-lxml)
6133 ("python-beautifulsoup4" ,python-beautifulsoup4)))
6134 (home-page "https://html5-parser.readthedocs.io")
6135 (synopsis "Fast C-based HTML5 parsing for Python")
6136 (description "This package provides a fast implementation of the HTML5
6137 parsing spec for Python. Parsing is done in C using a variant of the gumbo
6138 parser. The gumbo parse tree is then transformed into an lxml tree, also in
6139 C, yielding parse times that can be a thirtieth of the html5lib parse times.")
6140 ;; src/as-python-tree.[c|h] are licensed GPL3. The other files
6141 ;; indicate ASL2.0, including the LICENSE file for the whole project.
6142 (license (list license:asl2.0 license:gpl3))))
6143
6144 (define-public python2-html5-parser
6145 (package-with-python2 python-html5-parser))
6146
6147 (define-public python-webencodings
6148 (package
6149 (name "python-webencodings")
6150 (version "0.5")
6151 (source (origin
6152 (method url-fetch)
6153 (uri (pypi-uri "webencodings" version))
6154 (sha256
6155 (base32
6156 "015rw7662lkpb9aqiqah2hbizk6w531badqwjpz41rr47glmxid5"))))
6157 (build-system python-build-system)
6158 (arguments
6159 '(#:phases
6160 (modify-phases %standard-phases
6161 (replace 'check
6162 (lambda _
6163 (zero? (system* "py.test" "-v" "webencodings/tests.py")))))))
6164 (native-inputs
6165 `(("python-pytest" ,python-pytest)))
6166 (home-page "https://github.com/SimonSapin/python-webencodings")
6167 (synopsis "Character encoding aliases for legacy web content")
6168 (description
6169 "In order to be compatible with legacy web content when interpreting
6170 something like @code{Content-Type: text/html; charset=latin1}, tools need
6171 to use a particular set of aliases for encoding labels as well as some
6172 overriding rules. For example, @code{US-ASCII} and @code{iso-8859-1} on
6173 the web are actually aliases for @code{windows-1252}, and an @code{UTF-8}
6174 or @code{UTF-16} BOM takes precedence over any other encoding declaration.
6175 The WHATWG @url{https://encoding.spec.whatwg.org/,Encoding} standard
6176 defines all such details so that implementations do not have to
6177 reverse-engineer each other.
6178
6179 This module implements the Encoding standard and has encoding labels and
6180 BOM detection, but the actual implementation for encoders and decoders
6181 is Python’s.")
6182 (license license:bsd-3)))
6183
6184 (define-public python2-webencodings
6185 (package-with-python2 python-webencodings))
6186
6187 (define-public python-urwid
6188 (package
6189 (name "python-urwid")
6190 (version "1.3.1")
6191 (source
6192 (origin
6193 (method url-fetch)
6194 (uri (pypi-uri "urwid" version))
6195 (sha256
6196 (base32
6197 "18cnd1wdjcas08x5qwa5ayw6jsfcn33w4d9f7q3s29fy6qzc1kng"))))
6198 (build-system python-build-system)
6199 (arguments
6200 `(#:phases
6201 (modify-phases %standard-phases
6202 ;; Disable failing test. Bug filed upstream:
6203 ;; https://github.com/wardi/urwid/issues/164
6204 ;; TODO: check again for python-urwid > 1.3.1 or python > 3.4.3.
6205 (add-after 'unpack 'disable-failing-test
6206 (lambda _
6207 (substitute* "urwid/tests/test_event_loops.py"
6208 (("test_remove_watch_file")
6209 "disable_remove_watch_file")))))))
6210 (home-page "http://urwid.org")
6211 (synopsis "Console user interface library for Python")
6212 (description
6213 "Urwid is a curses-based UI/widget library for Python. It includes many
6214 features useful for text console applications.")
6215 (license license:lgpl2.1+)))
6216
6217 (define-public python2-urwid
6218 (let ((python2-urwid (package-with-python2 python-urwid)))
6219 (package
6220 (inherit python2-urwid)
6221 (arguments
6222 (append
6223 `(;; Explicitly using Python 2 is necessary due the argument list being
6224 ;; built from only the 'delete-test_vterm.py' phase and python-urwid's
6225 ;; package arguments, which by default assumes the use of Python 3.
6226 #:python ,python-2
6227 #:phases
6228 (modify-phases %standard-phases
6229 ;; Disable the vterm tests because of non-deterministic failures
6230 ;; with Python 2. See https://github.com/urwid/urwid/issues/230.
6231 (add-after 'unpack 'delete-test_vterm.py
6232 (delete-file "urwid/tests/test_vterm.py"))))
6233 (package-arguments python-urwid))))))
6234
6235 (define-public python-openid
6236 (package
6237 (name "python-openid")
6238 (version "3.0.10")
6239 (source
6240 (origin
6241 (method url-fetch)
6242 (uri (pypi-uri "python3-openid" version))
6243 (sha256
6244 (base32
6245 "1x3nh3fycqfn43jp5j5pb4q4y2jxp4mdka4absaa3bc0078qd758"))))
6246 (build-system python-build-system)
6247 (arguments
6248 `(#:phases
6249 (modify-phases %standard-phases
6250 (replace 'check
6251 (lambda _
6252 (zero? (system* "./admin/runtests")))))))
6253 (properties `((python2-variant . ,(delay python2-openid))))
6254 (propagated-inputs
6255 `(("python-defusedxml" ,python-defusedxml)))
6256 (native-inputs
6257 `(("python-psycopg2" ,python-psycopg2)
6258 ("python-django" ,python-django)))
6259 (home-page "https://github.com/necaris/python3-openid")
6260 (synopsis "OpenID support for servers and consumers")
6261 (description "This library provides OpenID authentication for Python, both
6262 for clients and servers.")
6263 (license license:asl2.0)))
6264
6265 (define-public python2-openid
6266 (package
6267 (name "python2-openid")
6268 (version "2.2.5")
6269 (source
6270 (origin
6271 (method url-fetch)
6272 (uri (pypi-uri "python-openid" version))
6273 (sha256
6274 (base32
6275 "1vvhxlghjan01snfdc4k7ykd80vkyjgizwgg9bncnin8rqz1ricj"))))
6276 (build-system python-build-system)
6277 (arguments
6278 ;; Python 3 support is in `python3-openid`, a separate package.
6279 `(#:python ,python-2))
6280 (home-page "https://github.com/openid/python-openid")
6281 (synopsis "OpenID support for servers and consumers")
6282 (description "This library provides OpenID authentication for Python, both
6283 for clients and servers.")
6284 (license license:asl2.0)))
6285
6286 (define-public python-urwidtrees
6287 (package
6288 (name "python-urwidtrees")
6289 (version "1.0.2")
6290 (source
6291 (origin
6292 (method url-fetch)
6293 ;; package author intends on distributing via github rather than pypi:
6294 ;; https://github.com/pazz/alot/issues/877#issuecomment-230173331
6295 (uri (string-append "https://github.com/pazz/urwidtrees/archive/"
6296 version ".tar.gz"))
6297 (file-name (string-append name "-" version ".tar.gz"))
6298 (sha256
6299 (base32
6300 "0d30lyd3s2a97rhqfax5w9ssqds2z6aydqx3c6j2c2lk3cb4ngvh"))))
6301 (build-system python-build-system)
6302 (arguments
6303 '(#:tests? #f)) ; no tests
6304 (propagated-inputs `(("python-urwid" ,python-urwid)))
6305 (home-page "https://github.com/pazz/urwidtrees")
6306 (synopsis "Tree widgets for urwid")
6307 (description "Urwidtrees is a Widget Container API for the @code{urwid}
6308 toolkit. Use it to build trees of widgets.")
6309 (license license:gpl3+)))
6310
6311 (define-public python2-urwidtrees
6312 (package-with-python2 python-urwidtrees))
6313
6314 (define-public python-dbus
6315 (package
6316 (name "python-dbus")
6317 (version "1.2.0")
6318 (source
6319 (origin
6320 (method url-fetch)
6321 (uri (string-append
6322 "https://dbus.freedesktop.org/releases/dbus-python/dbus-python-"
6323 version ".tar.gz"))
6324 (sha256
6325 (base32 "1py62qir966lvdkngg0v8k1khsqxwk5m4s8nflpk1agk5f5nqb71"))))
6326 (build-system gnu-build-system)
6327 (arguments
6328 '(#:phases
6329 (modify-phases %standard-phases
6330 (add-before
6331 'check 'pre-check
6332 (lambda _
6333 ;; XXX: For the missing '/etc/machine-id'.
6334 (substitute* "test/run-test.sh"
6335 (("DBUS_FATAL_WARNINGS=1")
6336 "DBUS_FATAL_WARNINGS=0"))
6337 #t)))))
6338 (native-inputs
6339 `(("pkg-config" ,pkg-config)))
6340 (inputs
6341 `(("python" ,python)
6342 ("dbus-glib" ,dbus-glib)))
6343 (synopsis "Python bindings for D-bus")
6344 (description "python-dbus provides bindings for libdbus, the reference
6345 implementation of D-Bus.")
6346 (home-page "http://www.freedesktop.org/wiki/Software/DBusBindings/")
6347 (license license:expat)))
6348
6349 (define-public python2-dbus
6350 (package (inherit python-dbus)
6351 (name "python2-dbus")
6352 (inputs `(("python" ,python-2)
6353 ,@(alist-delete "python"
6354 (package-inputs python-dbus)
6355 equal?)))
6356 ;; FIXME: on Python 2, the test_utf8 fails with:
6357 ;; "ValueError: unichr() arg not in range(0x10000) (narrow Python build)"
6358 (arguments `(#:tests? #f))))
6359
6360 (define-public python-apsw
6361 (package
6362 (name "python-apsw")
6363 (version "3.9.2-r1")
6364 (source
6365 (origin
6366 (method url-fetch)
6367 (uri (pypi-uri "apsw" version))
6368 (sha256
6369 (base32
6370 "0w4jb0wpx785qw42r3h4fh7gl5w2968q48i7gygybsfxck8nzffs"))))
6371 (build-system python-build-system)
6372 (inputs
6373 `(("sqlite" ,sqlite)))
6374 (arguments
6375 `(#:phases
6376 (modify-phases %standard-phases
6377 (replace 'build
6378 (lambda _
6379 (zero?
6380 (system* "python" "setup.py" "build" "--enable-all-extensions"))))
6381 (add-after 'build 'build-test-helper
6382 (lambda _
6383 (zero?
6384 (system
6385 (string-append "gcc -fPIC -shared -o ./testextension.sqlext "
6386 "-I. -Isqlite3 src/testextension.c") ))))
6387 (delete 'check)
6388 (add-after 'install 'check
6389 (lambda* (#:key inputs outputs #:allow-other-keys)
6390 (add-installed-pythonpath inputs outputs)
6391 (zero? (system* "python" "setup.py" "test")))))))
6392 (home-page "https://github.com/rogerbinns/apsw/")
6393 (synopsis "Another Python SQLite Wrapper")
6394 (description "APSW is a Python wrapper for the SQLite
6395 embedded relational database engine. In contrast to other wrappers such as
6396 pysqlite it focuses on being a minimal layer over SQLite attempting just to
6397 translate the complete SQLite API into Python.")
6398 (license license:zlib)))
6399
6400 (define-public python2-apsw
6401 (package-with-python2 python-apsw))
6402
6403 (define-public python-lxml
6404 (package
6405 (name "python-lxml")
6406 (version "3.8.0")
6407 (source
6408 (origin
6409 (method url-fetch)
6410 (uri (pypi-uri "lxml" version))
6411 (sha256
6412 (base32
6413 "15nvf6n285n282682qyw3wihsncb0x5amdhyi4b83bfa2nz74vvk"))))
6414 (build-system python-build-system)
6415 (inputs
6416 `(("libxml2" ,libxml2)
6417 ("libxslt" ,libxslt)))
6418 (home-page "http://lxml.de/")
6419 (synopsis
6420 "Python XML processing library")
6421 (description
6422 "The lxml XML toolkit is a Pythonic binding for the C libraries
6423 libxml2 and libxslt.")
6424 (license license:bsd-3))) ; and a few more, see LICENSES.txt
6425
6426 (define-public python2-lxml
6427 (package-with-python2 python-lxml))
6428
6429 ;; beautifulsoup4 has a totally different namespace than 3.x,
6430 ;; and pypi seems to put it under its own name, so I guess we should too
6431 (define-public python-beautifulsoup4
6432 (package
6433 (name "python-beautifulsoup4")
6434 (version "4.5.3")
6435 (source
6436 (origin
6437 (method url-fetch)
6438 (uri (pypi-uri "beautifulsoup4" version))
6439 (sha256
6440 (base32
6441 "0glaw1vyxnbp03fni7h5496n6iib0n5iim4gax1n0ngscs9s075j"))))
6442 (build-system python-build-system)
6443 (arguments
6444 `(#:phases
6445 (modify-phases %standard-phases
6446 ;; The Python 2 source is the definitive source of beautifulsoup4. We
6447 ;; must use this conversion script when building with Python 3. The
6448 ;; conversion script also runs the tests.
6449 ;; For more information, see the file 'convert-py3k' in the source
6450 ;; distribution.
6451 (replace 'check
6452 (lambda _ (zero? (system* "./convert-py3k")))))))
6453 (home-page
6454 "http://www.crummy.com/software/BeautifulSoup/bs4/")
6455 (synopsis
6456 "Python screen-scraping library")
6457 (description
6458 "Beautiful Soup is a Python library designed for rapidly setting up
6459 screen-scraping projects. It offers Pythonic idioms for navigating,
6460 searching, and modifying a parse tree, providing a toolkit for
6461 dissecting a document and extracting what you need. It automatically
6462 converts incoming documents to Unicode and outgoing documents to UTF-8.")
6463 (license license:expat)
6464 (properties `((python2-variant . ,(delay python2-beautifulsoup4))))))
6465
6466 (define-public python2-beautifulsoup4
6467 (package
6468 (inherit (package-with-python2
6469 (strip-python2-variant python-beautifulsoup4)))
6470 (arguments `(#:python ,python-2))))
6471
6472 (define-public python-cssutils
6473 (package
6474 (name "python-cssutils")
6475 (version "1.0.1")
6476 (source
6477 (origin
6478 (method url-fetch)
6479 (uri (pypi-uri "cssutils" version))
6480 (sha256
6481 (base32
6482 "0qwha9x1wml2qmipbcz03gndnlwhzrjdvw9i09si247a90l8p8fq"))))
6483 (build-system python-build-system)
6484 (native-inputs
6485 `(("unzip" ,unzip))) ; for unpacking the source
6486 (arguments
6487 `(#:tests? #f)) ;tests require python-pbr < 1.7.0
6488 (home-page "http://cthedot.de/cssutils/")
6489 (synopsis
6490 "CSS Cascading Style Sheets library for Python")
6491 (description
6492 "Cssutils is a Python package for parsing and building CSS
6493 Cascading Style Sheets. Currently it provides a DOM only and no rendering
6494 options.")
6495 (license license:lgpl3+)))
6496
6497 (define-public python2-cssutils
6498 (package-with-python2 python-cssutils))
6499
6500 (define-public python-cssselect
6501 (package
6502 (name "python-cssselect")
6503 (version "0.9.2")
6504 (source
6505 (origin
6506 (method url-fetch)
6507 (uri (pypi-uri "cssselect" version))
6508 (sha256
6509 (base32
6510 "1xg6gbva1yswghiycmgincv6ab4bn7hpm720ndbj40h8xycmnfvi"))))
6511 (build-system python-build-system)
6512 (arguments
6513 ;; tests fail with message
6514 ;; AttributeError: 'module' object has no attribute 'tests'
6515 `(#:tests? #f))
6516 (home-page
6517 "https://pythonhosted.org/cssselect/")
6518 (synopsis
6519 "CSS3 selector parser and translator to XPath 1.0")
6520 (description
6521 "Cssselect ia a Python module that parses CSS3 Selectors and translates
6522 them to XPath 1.0 expressions. Such expressions can be used in lxml or
6523 another XPath engine to find the matching elements in an XML or HTML document.")
6524 (license license:bsd-3)))
6525
6526 (define-public python2-cssselect
6527 (package-with-python2 python-cssselect))
6528
6529 (define-public python-openid-cla
6530 (package
6531 (name "python-openid-cla")
6532 (version "1.2")
6533 (source
6534 (origin
6535 (method url-fetch)
6536 (uri (pypi-uri "python-openid-cla" version))
6537 (sha256
6538 (base32
6539 "102hy2qisvjxp5s0v9lvwqi4f2dk0dhns40vjgn008yxc7k0h3cr"))))
6540 (build-system python-build-system)
6541 (arguments '(#:tests? #f)) ; No tests.
6542 (home-page "https://github.com/puiterwijk/python-openid-cla/")
6543 (synopsis "Implementation of the OpenID CLA extension for python-openid")
6544 (description "@code{openid-cla} is an implementation of the OpenID
6545 contributor license agreement extension for python-openid.")
6546 (license license:bsd-3)))
6547
6548 (define-public python2-openid-cla
6549 (package-with-python2 python-openid-cla))
6550
6551 (define-public python-openid-teams
6552 (package
6553 (name "python-openid-teams")
6554 (version "1.1")
6555 (source
6556 (origin
6557 (method url-fetch)
6558 (uri (pypi-uri "python-openid-teams" version))
6559 (sha256
6560 (base32
6561 "05zrh78alav24rxkbqlpbad6d3x2nljk6z6j7kflxf3vdqa7w969"))))
6562 (build-system python-build-system)
6563 (arguments '(#:tests? #f)) ; No tests.
6564 (home-page "https://github.com/puiterwijk/python-openid-teams/")
6565 (synopsis "Implementation of the OpenID teams extension for python-openid")
6566 (description
6567 "@code{openid-teams} is an implementation of the OpenID
6568 teams extension for python-openid.")
6569 (license license:bsd-3)))
6570
6571 (define-public python2-openid-teams
6572 (package-with-python2 python-openid-teams))
6573
6574 (define-public python-netifaces
6575 (package
6576 (name "python-netifaces")
6577 (version "0.10.4")
6578 (source
6579 (origin
6580 (method url-fetch)
6581 (uri (string-append
6582 "https://pypi.python.org/packages/source/n/netifaces/netifaces-"
6583 version
6584 ".tar.gz"))
6585 (sha256
6586 (base32
6587 "1plw237a4zib4z8s62g0mrs8gm3kjfrp5sxh6bbk9nl3rdls2mln"))))
6588 (build-system python-build-system)
6589 (home-page
6590 "https://bitbucket.org/al45tair/netifaces")
6591 (synopsis
6592 "Python module for portable network interface information")
6593 (description
6594 "Netifaces is a Python module providing information on network
6595 interfaces in an easy and portable manner.")
6596 (license license:expat)))
6597
6598 (define-public python2-netifaces
6599 (package-with-python2 python-netifaces))
6600
6601 (define-public python-networkx
6602 (package
6603 (name "python-networkx")
6604 (version "1.11")
6605 (source
6606 (origin
6607 (method url-fetch)
6608 (uri (pypi-uri "networkx" version))
6609 (sha256
6610 (base32 "1f74s56xb4ggixiq0vxyfxsfk8p20c7a099lpcf60izv1php03hd"))))
6611 (build-system python-build-system)
6612 ;; python-decorator is needed at runtime
6613 (propagated-inputs
6614 `(("python-decorator" ,python-decorator)))
6615 (native-inputs
6616 `(("python-nose" ,python-nose)))
6617 (home-page "http://networkx.github.io/")
6618 (synopsis "Python module for creating and manipulating graphs and networks")
6619 (description
6620 "NetworkX is a Python package for the creation, manipulation, and study
6621 of the structure, dynamics, and functions of complex networks.")
6622 (license license:bsd-3)))
6623
6624 (define-public python2-networkx
6625 (package-with-python2 python-networkx))
6626
6627 ;; Define new package, because the current version of python-colormath does
6628 ;; not build against 2.0.
6629 (define-public python-networkx2
6630 (package (inherit python-networkx)
6631 (name "python-networkx2")
6632 (version "2.0")
6633 (source
6634 (origin
6635 (method url-fetch)
6636 (uri (pypi-uri "networkx" version ".zip"))
6637 (sha256
6638 (base32
6639 "1ajl2jp8qry9nyjzzkqpy0vmsr14d23z1qk7y0vr5iwjbpvzhpyd"))
6640 (patches
6641 (search-patches "python-networkx2-reproducible-build.patch"))))))
6642
6643 (define-public python2-networkx2
6644 (package-with-python2 python-networkx2))
6645
6646 (define-public snakemake
6647 (package
6648 (name "snakemake")
6649 (version "4.2.0")
6650 (source
6651 (origin
6652 (method url-fetch)
6653 (uri (pypi-uri "snakemake" version))
6654 (sha256
6655 (base32 "0mgl44q152ws40zj2vicqark5szyd73vqy9pf26g6hk6dk0y0c79"))))
6656 (build-system python-build-system)
6657 (arguments
6658 ;; TODO: Package missing test dependencies.
6659 '(#:tests? #f
6660 #:phases
6661 (modify-phases %standard-phases
6662 ;; For cluster execution Snakemake will call Python. Since there is
6663 ;; no suitable PYTHONPATH set, cluster execution will fail. We fix
6664 ;; this by calling the snakemake wrapper instead.
6665 (add-after 'unpack 'call-wrapper-not-wrapped-snakemake
6666 (lambda* (#:key outputs #:allow-other-keys)
6667 (substitute* "snakemake/executors.py"
6668 (("\\{sys.executable\\} -m snakemake")
6669 (string-append (assoc-ref outputs "out")
6670 "/bin/snakemake")))
6671 #t)))))
6672 (propagated-inputs
6673 `(("python-wrapt" ,python-wrapt)
6674 ("python-requests" ,python-requests)
6675 ("python-appdirs" ,python-appdirs)
6676 ("python-configargparse" ,python-configargparse)
6677 ("python-pyyaml" ,python-pyyaml)
6678 ("python-ratelimiter" ,python-ratelimiter)))
6679 (home-page "https://bitbucket.org/snakemake/snakemake/wiki/Home")
6680 (synopsis "Python-based execution environment for make-like workflows")
6681 (description
6682 "Snakemake aims to reduce the complexity of creating workflows by
6683 providing a clean and modern domain specific specification language (DSL) in
6684 Python style, together with a fast and comfortable execution environment.")
6685 (license license:expat)))
6686
6687 (define-public python-pyqrcode
6688 (package
6689 (name "python-pyqrcode")
6690 (version "1.2.1")
6691 (source
6692 (origin
6693 (method url-fetch)
6694 (uri (pypi-uri "PyQRCode" version))
6695 (sha256
6696 (base32
6697 "1m9ln8k9v7dfbh1i81225hx5mdsh8mpf9g7r4wpbfmiyfcs7dgzx"))))
6698 (build-system python-build-system)
6699 (home-page
6700 "https://github.com/mnooner256/pyqrcode")
6701 (synopsis "QR code generator")
6702 (description
6703 "Pyqrcode is a QR code generator written purely in Python with
6704 SVG, EPS, PNG and terminal output.")
6705 (license license:bsd-3)))
6706
6707 (define-public python-seaborn
6708 (package
6709 (name "python-seaborn")
6710 (version "0.7.1")
6711 (source
6712 (origin
6713 (method url-fetch)
6714 (uri (pypi-uri "seaborn" version))
6715 (sha256
6716 (base32 "0pawrqc3mxpwd5g9pvi9gba02637bh5c8ldpp8izfwpfn52469zs"))))
6717 (build-system python-build-system)
6718 (arguments
6719 '(#:tests? #f)) ; Tests requires a running X11 server.
6720 (propagated-inputs
6721 `(("python-pandas" ,python-pandas)
6722 ("python-matplotlib" ,python-matplotlib)
6723 ("python-scipy" ,python-scipy)))
6724 (home-page "http://stanford.edu/~mwaskom/software/seaborn/")
6725 (synopsis "Statistical data visualization")
6726 (description
6727 "Seaborn is a library for making attractive and informative statistical
6728 graphics in Python. It is built on top of matplotlib and tightly integrated
6729 with the PyData stack, including support for numpy and pandas data structures
6730 and statistical routines from scipy and statsmodels.")
6731 (license license:bsd-3)
6732 (properties `((python2-variant . ,(delay python2-seaborn))))))
6733
6734 (define-public python2-seaborn
6735 (let ((base (package-with-python2 (strip-python2-variant python-seaborn))))
6736 (package
6737 (inherit base)
6738 (propagated-inputs `(("python2-pytz" ,python2-pytz)
6739 ,@(package-propagated-inputs base))))))
6740
6741 (define-public python-mpmath
6742 (package
6743 (name "python-mpmath")
6744 (version "0.19")
6745 (source (origin
6746 (method url-fetch)
6747 (uri (string-append "http://mpmath.org/files/mpmath-"
6748 version ".tar.gz"))
6749 (sha256
6750 (base32
6751 "08ijsr4ifrqv3cjc26mkw0dbvyygsa99in376hr4b96ddm1gdpb8"))))
6752 (build-system python-build-system)
6753 (arguments
6754 '(#:phases
6755 (modify-phases %standard-phases
6756 (replace 'check
6757 (lambda _
6758 (zero?
6759 (system* "python" "mpmath/tests/runtests.py" "-local")))))))
6760 (home-page "http://mpmath.org")
6761 (synopsis "Arbitrary-precision floating-point arithmetic in python")
6762 (description
6763 "@code{mpmath} can be used as an arbitrary-precision substitute for
6764 Python's float/complex types and math/cmath modules, but also does much
6765 more advanced mathematics.")
6766 (license license:bsd-3)))
6767
6768 (define-public python2-mpmath
6769 (package-with-python2 python-mpmath))
6770
6771 (define-public python-sympy
6772 (package
6773 (name "python-sympy")
6774 (version "1.0")
6775 (source
6776 (origin
6777 (method url-fetch)
6778 (uri (string-append
6779 "https://github.com/sympy/sympy/releases/download/sympy-"
6780 version "/sympy-" version ".tar.gz"))
6781 (sha256
6782 (base32 "1bpzjwr9hrr7w88v4vgnj9lr6vxcldc94si13n8xpr1rv08d5b1y"))))
6783 (build-system python-build-system)
6784 (propagated-inputs
6785 `(("python-mpmath" ,python-mpmath)))
6786 (home-page "http://www.sympy.org/")
6787 (synopsis "Python library for symbolic mathematics")
6788 (description
6789 "SymPy is a Python library for symbolic mathematics. It aims to become a
6790 full-featured computer algebra system (CAS) while keeping the code as simple
6791 as possible in order to be comprehensible and easily extensible.")
6792 (license license:bsd-3)))
6793
6794 (define-public python2-sympy
6795 (package-with-python2 python-sympy))
6796
6797 (define-public python-q
6798 (package
6799 (name "python-q")
6800 (version "2.6")
6801 (source
6802 (origin
6803 (method url-fetch)
6804 (uri (pypi-uri "q" version))
6805 (sha256
6806 (base32
6807 "1mgfazh8fkizh6walra2zv885f3lcgr3nb02v1frfm4p8ddcy3yy"))))
6808 (build-system python-build-system)
6809 (home-page "https://github.com/zestyping/q")
6810 (synopsis "Quick-and-dirty debugging output for tired programmers")
6811 (description
6812 "q is a Python module for \"print\" style of debugging Python code. It
6813 provides convenient short API for print out of values, tracebacks, and
6814 falling into the Python interpreter.")
6815 (license license:asl2.0)))
6816
6817 (define-public python2-q
6818 (package-with-python2 python-q))
6819
6820 (define-public python-testlib
6821 (package
6822 (name "python-testlib")
6823 (version "0.6.5")
6824 (source
6825 (origin
6826 (method url-fetch)
6827 (uri (string-append
6828 "https://pypi.python.org/packages/source/t/testlib/testlib-"
6829 version ".zip"))
6830 (sha256
6831 (base32 "1mz26cxn4x8bbgv0rn0mvj2z05y31rkc8009nvdlb3lam5b4mj3y"))))
6832 (build-system python-build-system)
6833 (native-inputs
6834 `(("unzip" ,unzip))) ; for unpacking the source
6835 (synopsis "Python micro test suite harness")
6836 (description "A micro unittest suite harness for Python.")
6837 (home-page "https://github.com/trentm/testlib")
6838 (license license:expat)))
6839
6840 (define-public python2-testlib
6841 (package-with-python2 python-testlib))
6842
6843 (define-public python2-xlib
6844 (package
6845 (name "python2-xlib")
6846 (version "0.14")
6847 (source (origin
6848 (method url-fetch)
6849 (uri (string-append "mirror://sourceforge/python-xlib/python-xlib"
6850 "/" version "/"
6851 "python-xlib-" version ".tar.gz"))
6852 (sha256
6853 (base32
6854 "1sv0447j0rx8cgs3jhjl695p5pv13ihglcjlrrz1kq05lsvb0wa7"))))
6855 (build-system python-build-system)
6856 (arguments
6857 `(#:python ,python-2 ;Python 2 only
6858 #:tests? #f)) ;no tests
6859 (home-page "http://python-xlib.sourceforge.net/")
6860 (synopsis "Python X11 client library")
6861 (description
6862 "The Python X Library is intended to be a fully functional X client
6863 library for Python programs. It is useful to implement low-level X clients.
6864 It is written entirely in Python.")
6865 (license license:gpl2+)))
6866
6867 (define-public python-singledispatch
6868 (package
6869 (name "python-singledispatch")
6870 (version "3.4.0.3")
6871 (source
6872 (origin
6873 (method url-fetch)
6874 (uri (pypi-uri "singledispatch" version))
6875 (sha256
6876 (base32
6877 "171b7ip0hsq5qm83np40h3phlr36ym18w0lay0a8v08kvy3sy1jv"))))
6878 (build-system python-build-system)
6879 (native-inputs
6880 `(("python-six" ,python-six))) ; required for conversion, not at run-time
6881 (home-page
6882 "http://docs.python.org/3/library/functools.html#functools.singledispatch")
6883 (synopsis "Backport of singledispatch feature from Python 3.4")
6884 (description
6885 "This library brings functools.singledispatch from Python 3.4 to Python
6886 2.6-3.3.")
6887 (license license:expat)))
6888
6889 (define-public python2-singledispatch
6890 (package-with-python2 python-singledispatch))
6891
6892 (define-public python-tornado
6893 (package
6894 (name "python-tornado")
6895 (version "4.5.1")
6896 (source
6897 (origin
6898 (method url-fetch)
6899 (uri (pypi-uri "tornado" version))
6900 (sha256
6901 (base32 "1zbkgcdfq81k298awrm8p0xwbwwn2p3nbizdglzfbkskhai082fv"))))
6902 (build-system python-build-system)
6903 (arguments
6904 '(;; FIXME: Two tests error out with:
6905 ;; AssertionError: b'Error in atexit._run_exitfuncs:\nFileNotF[44 chars]ry\n' != b''
6906 ;; #:phases
6907 ;; (modify-phases %standard-phases
6908 ;; (replace 'check
6909 ;; (lambda _
6910 ;; ;; 'setup.py test' hits an AssertionError on BSD-specific
6911 ;; ;; "tornado/platform/kqueue.py". This is the supported method:
6912 ;; (zero? (system* "python" "-m" "tornado.test")))))
6913 #:tests? #f))
6914 (native-inputs
6915 `(("python-certifi" ,python-certifi)))
6916 (propagated-inputs
6917 `(("python-backports-abc" ,python-backports-abc)))
6918 (home-page "http://www.tornadoweb.org/")
6919 (synopsis "Python web framework and asynchronous networking library")
6920 (description
6921 "Tornado is a Python web framework and asynchronous networking library,
6922 originally developed at FriendFeed. By using non-blocking network I/O,
6923 Tornado can scale to tens of thousands of open connections, making it ideal
6924 for long polling, WebSockets, and other applications that require a long-lived
6925 connection to each user.")
6926 (license license:asl2.0)
6927 (properties `((python2-variant . ,(delay python2-tornado))))))
6928
6929 (define-public python2-tornado
6930 (let ((tornado (package-with-python2 (strip-python2-variant python-tornado))))
6931 (package (inherit tornado)
6932 (propagated-inputs
6933 `(("python2-backport-ssl-match-hostname"
6934 ,python2-backport-ssl-match-hostname)
6935 ("python2-singledispatch" ,python2-singledispatch)
6936 ,@(package-propagated-inputs tornado))))))
6937
6938 (define-public python-tornado-http-auth
6939 (package
6940 (name "python-tornado-http-auth")
6941 (version "1.1.0")
6942 (source
6943 (origin
6944 (method url-fetch)
6945 (uri (pypi-uri "tornado-http-auth" version))
6946 (sha256
6947 (base32
6948 "0znrgqd7k2s4ia474xizi6h3061zj4sn5n6cq76bkwl3wwshifn5"))))
6949 (build-system python-build-system)
6950 (propagated-inputs
6951 `(("python-tornado" ,python-tornado)))
6952 (home-page
6953 "https://github.com/gvalkov/tornado-http-auth")
6954 (synopsis
6955 "Digest and basic authentication module for Tornado")
6956 (description
6957 "Provides support for adding authentication to services using the Tornado
6958 web framework, either via the basic or digest authentication schemes.")
6959 (license license:asl2.0)))
6960
6961 ;; the python- version can be removed with python-3.5
6962 (define-public python-backports-abc
6963 (package
6964 (name "python-backports-abc")
6965 (version "0.5")
6966 (source
6967 (origin
6968 (method url-fetch)
6969 (uri (pypi-uri "backports_abc" version))
6970 (sha256
6971 (base32
6972 "1pkv8d1zxj5f9i227dxbjczncbv7ks7ywnjwyxfjagm02i2yafq3"))))
6973 (build-system python-build-system)
6974 (home-page "https://github.com/cython/backports_abc")
6975 (synopsis "Backport of additions to the 'collections.abc' module")
6976 (description
6977 "Python-backports-abc provides a backport of additions to the
6978 'collections.abc' module in Python-3.5.")
6979 (license license:psfl)))
6980
6981 (define-public python2-backports-abc
6982 (package-with-python2 python-backports-abc))
6983
6984 (define-public python-backports-csv
6985 (package
6986 (name "python-backports-csv")
6987 (version "1.0.5")
6988 (source
6989 (origin
6990 (method url-fetch)
6991 (uri (pypi-uri "backports.csv" version))
6992 (sha256
6993 (base32
6994 "1imzbrradkfn8s2m1qcimyn74dn1mz2p3j381jljn166rf2i6hlc"))))
6995 (build-system python-build-system)
6996 (home-page "https://github.com/ryanhiebert/backports.csv")
6997 (synopsis "Backport of Python 3's csv module for Python 2")
6998 (description
6999 "Provides a backport of Python 3's @code{csv} module for parsing
7000 comma separated values. The API of the @code{csv} module in Python 2
7001 is drastically different from the @code{csv} module in Python 3.
7002 This is due, for the most part, to the difference between str in
7003 Python 2 and Python 3.")
7004 (license license:psfl)))
7005
7006 (define-public python2-backports-csv
7007 (package-with-python2 python-backports-csv))
7008
7009 (define-public python2-backports-shutil-get-terminal-size
7010 (package
7011 (name "python2-backports-shutil-get-terminal-size")
7012 (version "1.0.0")
7013 (source
7014 (origin
7015 (method url-fetch)
7016 (uri (pypi-uri "backports.shutil_get_terminal_size" version))
7017 (sha256
7018 (base32
7019 "107cmn7g3jnbkp826zlj8rrj19fam301qvaqf0f3905f5217lgki"))))
7020 (build-system python-build-system)
7021 (arguments
7022 `(#:python ,python-2
7023 #:phases
7024 (modify-phases %standard-phases
7025 (replace 'check
7026 (lambda _
7027 (zero? (system* "py.test" "-v")))))))
7028 (native-inputs
7029 `(("python2-pytest" ,python2-pytest)))
7030 (home-page "https://github.com/chrippa/backports.shutil_get_terminal_size")
7031 (synopsis "Backport of Python 3.3's @code{shutil.get_terminal_size}")
7032 (description
7033 "This package provides a backport of the @code{get_terminal_size
7034 function} from Python 3.3's @code{shutil}.
7035 Unlike the original version it is written in pure Python rather than C,
7036 so it might be a tiny bit slower.")
7037 (license license:expat)))
7038
7039 (define-public python-waf
7040 (package
7041 (name "python-waf")
7042 (version "1.9.8")
7043 (source (origin
7044 (method url-fetch)
7045 (uri (string-append "https://waf.io/"
7046 "waf-" version ".tar.bz2"))
7047 (sha256
7048 (base32
7049 "0wl4cnmp06lfxqjxaan58bqxn27smhydz0sg5prrfbl3bsw4gv6q"))))
7050 (build-system python-build-system)
7051 (arguments
7052 '(#:phases
7053 (modify-phases %standard-phases
7054 (replace 'build
7055 (lambda _
7056 (zero? (system* "python" "waf-light" "configure" "build"))))
7057 (replace 'check
7058 (lambda _
7059 (zero? (system* "python" "waf" "--version"))))
7060 (replace 'install
7061 (lambda _
7062 (copy-file "waf" %output))))))
7063 (home-page "https://waf.io/")
7064 (synopsis "Python-based build system")
7065 (description
7066 "Waf is a Python-based framework for configuring, compiling and installing
7067 applications.")
7068 (license license:bsd-3)))
7069
7070 (define-public python2-waf
7071 (package-with-python2 python-waf))
7072
7073 (define-public python-pyzmq
7074 (package
7075 (name "python-pyzmq")
7076 (version "15.1.0")
7077 (source
7078 (origin
7079 (method url-fetch)
7080 (uri (pypi-uri "pyzmq" version))
7081 (sha256
7082 (base32 "13fhwnlvsvxv72kfhqbpn6qi7msh8mc8377mpabv32skk2cjfnxx"))))
7083 (build-system python-build-system)
7084 (arguments
7085 `(#:configure-flags
7086 (list (string-append "--zmq=" (assoc-ref %build-inputs "zeromq")))
7087 ;; FIXME: You must build pyzmq with 'python setup.py build_ext
7088 ;; --inplace' for 'python setup.py test' to work.
7089 #:tests? #f))
7090 (inputs
7091 `(("zeromq" ,zeromq)))
7092 (native-inputs
7093 `(("pkg-config" ,pkg-config)
7094 ("python-nose" ,python-nose)))
7095 (home-page "https://github.com/zeromq/pyzmq")
7096 (synopsis "Python bindings for 0MQ")
7097 (description
7098 "PyZMQ is the official Python binding for the ZeroMQ messaging library.")
7099 (license license:bsd-4)))
7100
7101 (define-public python2-pyzmq
7102 (package-with-python2 python-pyzmq))
7103
7104 (define-public python-pep8
7105 (package
7106 (name "python-pep8")
7107 (version "1.7.0")
7108 (source
7109 (origin
7110 (method url-fetch)
7111 (uri (pypi-uri "pep8" version))
7112 (sha256
7113 (base32
7114 "002rkl4lsn6x2mxmf8ar00l0m8i3mzrc6pnzz77blyksmpsxa4x1"))))
7115 (build-system python-build-system)
7116 (home-page "http://pep8.readthedocs.org/")
7117 (synopsis "Python style guide checker")
7118 (description
7119 "This tools checks Python code against some of the style conventions in
7120 PEP 8.")
7121 (license license:expat)))
7122
7123 (define-public python2-pep8
7124 (package-with-python2 python-pep8))
7125
7126 (define-public python-pyflakes
7127 (package
7128 (name "python-pyflakes")
7129 (version "1.0.0")
7130 (source
7131 (origin
7132 (method url-fetch)
7133 (uri (pypi-uri "pyflakes" version))
7134 (sha256
7135 (base32
7136 "0qs2sgqszq7wcplis8509wk2ygqcrwzbs1ghfj3svvivq2j377pk"))))
7137 (build-system python-build-system)
7138 (home-page
7139 "https://github.com/pyflakes/pyflakes")
7140 (synopsis "Passive checker of Python programs")
7141 (description
7142 "Pyflakes statically checks Python source code for common errors.")
7143 (license license:expat)))
7144
7145 (define-public python2-pyflakes
7146 (package-with-python2 python-pyflakes))
7147
7148 (define-public python-mccabe
7149 (package
7150 (name "python-mccabe")
7151 (version "0.4.0")
7152 (source
7153 (origin
7154 (method url-fetch)
7155 (uri (pypi-uri "mccabe" version))
7156 (sha256
7157 (base32
7158 "0yr08a36h8lqlif10l4xcikbbig7q8f41gqywir7rrvnv3mi4aws"))))
7159 (build-system python-build-system)
7160 (native-inputs
7161 `(("python-pytest" ,python-pytest)
7162 ("python-pytest-runner" ,python-pytest-runner)))
7163 (home-page "https://github.com/flintwork/mccabe")
7164 (synopsis "McCabe checker, plugin for flake8")
7165 (description
7166 "This package provides a Flake8 plug-in to compute the McCabe cyclomatic
7167 complexity of Python source code.")
7168 (license license:expat)))
7169
7170 (define-public python2-mccabe
7171 (package-with-python2 python-mccabe))
7172
7173 (define-public python-mccabe-0.2.1
7174 (package (inherit python-mccabe)
7175 (version "0.2.1")
7176 (source
7177 (origin
7178 (method url-fetch)
7179 (uri (pypi-uri "mccabe" version))
7180 (sha256
7181 (base32
7182 "0fi4a81kr5bcv5p4xgibqr595hyj5dafkqgsmfk96mfy8w71fajs"))))))
7183
7184 (define-public python2-mccabe-0.2.1
7185 (package-with-python2 python-mccabe-0.2.1))
7186
7187 ;; Flake8 2.4.1 requires an older version of pep8.
7188 ;; This should be removed ASAP.
7189 (define-public python-pep8-1.5.7
7190 (package (inherit python-pep8)
7191 (version "1.5.7")
7192 (source
7193 (origin
7194 (method url-fetch)
7195 (uri (string-append
7196 "https://pypi.python.org/packages/source/p/pep8/pep8-"
7197 version
7198 ".tar.gz"))
7199 (sha256
7200 (base32
7201 "12b9bbdbwnspxgak14xg58c130x2n0blxzlms5jn2dszn8qj3d0m"))))
7202 (arguments
7203 ;; XXX Tests not compatible with Python 3.5.
7204 '(#:tests? #f))))
7205
7206 (define-public python2-pep8-1.5.7
7207 (package-with-python2 python-pep8-1.5.7))
7208
7209 ;; Flake8 2.4.1 requires an older version of pyflakes.
7210 ;; This should be removed ASAP.
7211 (define-public python-pyflakes-0.8.1
7212 (package (inherit python-pyflakes)
7213 (version "0.8.1")
7214 (source
7215 (origin
7216 (method url-fetch)
7217 (uri (string-append
7218 "https://pypi.python.org/packages/source/p/pyflakes/pyflakes-"
7219 version
7220 ".tar.gz"))
7221 (sha256
7222 (base32
7223 "0sbpq6pqm1i9wqi41mlfrsc5rk92jv4mskvlyxmnhlbdnc80ma1z"))))
7224 (arguments
7225 ;; XXX Tests not compatible with Python 3.5.
7226 '(#:tests? #f))))
7227
7228 (define-public python2-pyflakes-0.8.1
7229 (package-with-python2 python-pyflakes-0.8.1))
7230
7231 (define-public python-flake8
7232 (package
7233 (name "python-flake8")
7234 (version "2.5.4")
7235 (source
7236 (origin
7237 (method url-fetch)
7238 (uri (pypi-uri "flake8" version))
7239 (sha256
7240 (base32
7241 "0bs9cz4fr99r2rwig1b8jwaadl1nan7kgpdzqwj0bwbckwbmh7nc"))
7242 (modules '((guix build utils)))
7243 (snippet
7244 '(begin
7245 ;; Remove pre-compiled .pyc files from source.
7246 (for-each delete-file-recursively
7247 (find-files "." "__pycache__" #:directories? #t))
7248 (for-each delete-file (find-files "." "\\.pyc$"))
7249 #t))))
7250 (build-system python-build-system)
7251 (propagated-inputs
7252 `(("python-pep8" ,python-pep8)
7253 ("python-pyflakes" ,python-pyflakes)
7254 ("python-mccabe" ,python-mccabe)))
7255 (native-inputs
7256 `(("python-mock" ,python-mock) ; TODO: only required for < 3.3
7257 ("python-nose" ,python-nose)))
7258 (home-page "https://gitlab.com/pycqa/flake8")
7259 (synopsis
7260 "The modular source code checker: pep8, pyflakes and co")
7261 (description
7262 "Flake8 is a wrapper around PyFlakes, pep8 and python-mccabe.")
7263 (license license:expat)))
7264
7265 (define-public python2-flake8
7266 (package-with-python2 python-flake8))
7267
7268 (define-public python-flake8-polyfill
7269 (package
7270 (name "python-flake8-polyfill")
7271 (version "1.0.1")
7272 (source
7273 (origin
7274 (method url-fetch)
7275 (uri (pypi-uri "flake8-polyfill" version))
7276 (sha256
7277 (base32
7278 "02gn2wxvh9vnf7m7dld7ca4l60mg5c370hv3swwppkngwaqmcw67"))))
7279 (build-system python-build-system)
7280 (arguments
7281 '(#:phases
7282 (modify-phases %standard-phases
7283 (replace 'check
7284 (lambda _
7285 (setenv "PYTHONPATH"
7286 (string-append (getcwd) "/build/lib:"
7287 (getenv "PYTHONPATH")))
7288 (zero? (system* "py.test" "-v")))))))
7289 (native-inputs
7290 `(("python-flake8" ,python-flake8)
7291 ("python-mock" ,python-mock)
7292 ("python-pycodestyle" ,python-pycodestyle)
7293 ("python-pytest" ,python-pytest)))
7294 (home-page "https://gitlab.com/pycqa/flake8-polyfill")
7295 (synopsis "Polyfill package for Flake8 plugins")
7296 (description
7297 "This package that provides some compatibility helpers for Flake8
7298 plugins that intend to support Flake8 2.x and 3.x simultaneously.")
7299 (license license:expat)))
7300
7301 (define-public python2-flake8-polyfill
7302 (package-with-python2 python-flake8-polyfill))
7303
7304 (define-public python-mistune
7305 (package
7306 (name "python-mistune")
7307 (version "0.7.3")
7308 (source
7309 (origin
7310 (method url-fetch)
7311 (uri (pypi-uri "mistune" version))
7312 (sha256
7313 (base32
7314 "04xpk1zvslhq3xpnf01g3ag0dy9wfv4z28p093r8k49vvxlyil11"))))
7315 (build-system python-build-system)
7316 (native-inputs
7317 `(("python-nose" ,python-nose)
7318 ("python-cython" ,python-cython)))
7319 (home-page "https://github.com/lepture/mistune")
7320 (synopsis "Markdown parser in pure Python")
7321 (description "This package provides a fast markdown parser in pure
7322 Python.")
7323 (license license:bsd-3)))
7324
7325 (define-public python2-mistune
7326 (package-with-python2 python-mistune))
7327
7328 (define-public python-markdown
7329 (package
7330 (name "python-markdown")
7331 (version "2.6.8")
7332 (source
7333 (origin
7334 (method url-fetch)
7335 (uri (pypi-uri "Markdown" version))
7336 (sha256
7337 (base32
7338 "0cqfhr1km2s5d8jm6hbwgkrrj9hvkjf2gab3s2axlrw1clgaij0a"))))
7339 (build-system python-build-system)
7340 (arguments
7341 `(#:phases
7342 (modify-phases %standard-phases
7343 (replace 'check
7344 (lambda _
7345 (zero? (system* "python" "run-tests.py")))))))
7346 (native-inputs
7347 `(("python-nose" ,python-nose)
7348 ("python-pyyaml" ,python-pyyaml)))
7349 (home-page "https://pythonhosted.org/Markdown/")
7350 (synopsis "Python implementation of Markdown")
7351 (description
7352 "This package provides a Python implementation of John Gruber's
7353 Markdown. The library features international input, various Markdown
7354 extensions, and several HTML output formats. A command line wrapper
7355 markdown_py is also provided to convert Markdown files to HTML.")
7356 (license license:bsd-3)))
7357
7358 (define-public python2-markdown
7359 (package-with-python2 python-markdown))
7360
7361 (define-public python-ptyprocess
7362 (package
7363 (name "python-ptyprocess")
7364 (version "0.5.1")
7365 (source
7366 (origin
7367 (method url-fetch)
7368 (uri (string-append
7369 "https://pypi.python.org/packages/source/p/ptyprocess/ptyprocess-"
7370 version ".tar.gz"))
7371 (sha256
7372 (base32
7373 "19l1xrjn4l9gjz01s3vg92gn2dd9d8mw1v86ppkzlnr9m5iwwc05"))))
7374 (build-system python-build-system)
7375 (native-inputs
7376 `(("python-nose" ,python-nose)))
7377 (arguments
7378 `(#:phases
7379 (modify-phases %standard-phases
7380 (replace 'check
7381 (lambda _
7382 (zero? (system* "nosetests")))))))
7383 (home-page "https://github.com/pexpect/ptyprocess")
7384 (synopsis "Run a subprocess in a pseudo terminal")
7385 (description
7386 "This package provides a Python library used to launch a subprocess in a
7387 pseudo terminal (pty), and interact with both the process and its pty.")
7388 (license license:isc)))
7389
7390 (define-public python2-ptyprocess
7391 (package-with-python2 python-ptyprocess))
7392
7393 (define-public python-cram
7394 (package
7395 (name "python-cram")
7396 (version "0.7")
7397 (home-page "https://bitheap.org/cram/")
7398 (source (origin
7399 (method url-fetch)
7400 (uri (list (string-append home-page "cram-"
7401 version ".tar.gz")
7402 (pypi-uri "cram" version)))
7403 (sha256
7404 (base32
7405 "0bvz6fwdi55rkrz3f50zsy35gvvwhlppki2yml5bj5ffy9d499vx"))))
7406 (arguments
7407 '(#:phases
7408 (modify-phases %standard-phases
7409 (add-after 'unpack 'patch-source
7410 (lambda _
7411 (substitute* (find-files "cram" ".*\\.py$")
7412 ;; Replace default shell path.
7413 (("/bin/sh") (which "sh")))
7414 (substitute* (find-files "tests" ".*\\.t$")
7415 (("md5") "md5sum")
7416 (("/bin/bash") (which "bash"))
7417 (("/bin/sh") (which "sh")))
7418 (substitute* "cram/_test.py"
7419 ;; This hack works around a bug triggered by substituting
7420 ;; the /bin/sh paths. "tests/usage.t" compares the output of
7421 ;; "cram -h", which breaks the output at 80 characters. This
7422 ;; causes the line showing the default shell to break into two
7423 ;; lines, but the test expects a single line...
7424 (("env\\['COLUMNS'\\] = '80'")
7425 "env['COLUMNS'] = '160'"))
7426 #t))
7427 (delete 'check)
7428 (add-after 'install 'check
7429 ;; The test phase uses the built library and executable.
7430 ;; It's easier to run it after install since the build
7431 ;; directory contains version-specific PATH.
7432 (lambda* (#:key inputs outputs #:allow-other-keys)
7433 (add-installed-pythonpath inputs outputs)
7434 (setenv "PATH" (string-append (getenv "PATH") ":"
7435 (assoc-ref outputs "out") "/bin"))
7436 (zero? (system* "make" "test")))))))
7437 (build-system python-build-system)
7438 (native-inputs
7439 `(("python-coverage" ,python-coverage)
7440 ("which" ,which)))
7441 (synopsis "Simple testing framework for command line applications")
7442 (description
7443 "Cram is a functional testing framework for command line applications.
7444 Cram tests look like snippets of interactive shell sessions. Cram runs each
7445 command and compares the command output in the test with the command’s actual
7446 output.")
7447 (license license:gpl2+)))
7448
7449 (define-public python2-cram
7450 (package-with-python2 python-cram))
7451
7452 (define-public python-terminado
7453 (package
7454 (name "python-terminado")
7455 (version "0.6")
7456 (source
7457 (origin
7458 (method url-fetch)
7459 (uri (pypi-uri "terminado" version))
7460 (sha256
7461 (base32
7462 "09h1kwi86g5mrk14s4pgbhshd602zry29lnpxamcqz864kva22rc"))))
7463 (build-system python-build-system)
7464 (propagated-inputs
7465 `(("python-tornado" ,python-tornado)
7466 ("python-ptyprocess" ,python-ptyprocess)))
7467 (native-inputs
7468 `(("python-nose" ,python-nose)))
7469 (arguments
7470 `(#:phases
7471 (modify-phases %standard-phases
7472 (replace 'check
7473 (lambda _
7474 (zero? (system* "nosetests")))))))
7475 (home-page "https://github.com/takluyver/terminado")
7476 (synopsis "Terminals served to term.js using Tornado websockets")
7477 (description "This package provides a Tornado websocket backend for the
7478 term.js Javascript terminal emulator library.")
7479 (license license:bsd-2)
7480 (properties `((python2-variant . ,(delay python2-terminado))))))
7481
7482 (define-public python2-terminado
7483 (let ((terminado (package-with-python2 (strip-python2-variant python-terminado))))
7484 (package (inherit terminado)
7485 (propagated-inputs
7486 `(("python2-backport-ssl-match-hostname"
7487 ,python2-backport-ssl-match-hostname)
7488 ,@(package-propagated-inputs terminado))))))
7489
7490 (define-public python-straight-plugin
7491 (package
7492 (name "python-straight-plugin")
7493 (version "1.4.1")
7494 (source
7495 (origin
7496 (method url-fetch)
7497 (uri (pypi-uri "straight.plugin" version))
7498 (sha256
7499 (base32
7500 "069pjll4383p4kkgvcc40hgyvf79j2wdbpgwz77yigzxksh1gj62"))))
7501 (build-system python-build-system)
7502 (home-page "https://github.com/ironfroggy/straight.plugin")
7503 (synopsis "Simple namespaced plugin facility")
7504 (description "Straight Plugin provides a type of plugin you can create from
7505 almost any existing Python modules, and an easy way for outside developers to
7506 add functionality and customization to your projects with their own plugins.")
7507 (license license:expat)))
7508
7509 (define-public python2-straight-plugin
7510 (package-with-python2 python-straight-plugin))
7511
7512 (define-public python-fonttools
7513 (package
7514 (name "python-fonttools")
7515 (version "3.15.1")
7516 (source (origin
7517 (method url-fetch)
7518 (uri (pypi-uri "fonttools" version ".zip"))
7519 (sha256
7520 (base32
7521 "1hhj97izwliy0vybmza72d90l5d4mcn50y8akq7kyccfl82vdx4d"))))
7522 (build-system python-build-system)
7523 (arguments
7524 '(#:test-target "check"
7525 #:phases
7526 (modify-phases %standard-phases
7527 (add-after 'unpack 'patch-setuppy
7528 ;; Remove the undocumented "extra_path" argument, which adds an
7529 ;; intervening directories between site-packages and the package
7530 ;; directory.
7531 (lambda _
7532 (substitute* "setup.py"
7533 (("^[ \t]*extra_path *= *'FontTools',") ""))
7534 #t)))))
7535 (native-inputs
7536 `(("unzip" ,unzip)))
7537 (home-page "https://github.com/behdad/fonttools")
7538 (synopsis "Tools to manipulate font files")
7539 (description
7540 "FontTools/TTX is a library to manipulate font files from Python. It
7541 supports reading and writing of TrueType/OpenType fonts, reading and writing
7542 of AFM files, reading (and partially writing) of PS Type 1 fonts. The package
7543 also contains a tool called “TTX” which converts TrueType/OpenType fonts to and
7544 from an XML-based format.")
7545 (license (license:non-copyleft
7546 "file://LICENSE.txt"
7547 "See LICENSE.txt in the distribution."))))
7548
7549 (define-public python2-fonttools
7550 (package-with-python2 python-fonttools))
7551
7552 (define-public python-ly
7553 (package
7554 (name "python-ly")
7555 (version "0.9.4")
7556 (source
7557 (origin
7558 (method url-fetch)
7559 (uri (string-append "https://pypi.python.org/packages/57/4f/"
7560 "889579244947368f28eda66b782331b1e75f83fd72e63f9ece93cd7a18f9"
7561 "/python-ly-" version ".tar.gz"))
7562 (sha256
7563 (base32
7564 "0g6n288l83sfwavxh1aryi0aqvsr3sp7v6f903mckwqa4scpky62"))))
7565 (build-system python-build-system)
7566 (arguments
7567 ;; FIXME: Some tests need network access.
7568 '(#:tests? #f))
7569 (synopsis "Tool and library for manipulating LilyPond files")
7570 (description "This package provides a Python library to parse, manipulate
7571 or create documents in LilyPond format. A command line program ly is also
7572 provided that can be used to do various manipulations with LilyPond files.")
7573 (home-page "https://pypi.python.org/pypi/python-ly")
7574 (license license:gpl2+)))
7575
7576 (define-public python-appdirs
7577 (package
7578 (name "python-appdirs")
7579 (version "1.4.3")
7580 (source
7581 (origin
7582 (method url-fetch)
7583 (uri (pypi-uri "appdirs" version))
7584 (sha256
7585 (base32
7586 "14id6wxi12lgyw0mg3bcfnf888ad07jz9yj46gfzhn186z8rcn4y"))))
7587 (build-system python-build-system)
7588 (home-page "https://github.com/ActiveState/appdirs")
7589 (synopsis
7590 "Determine platform-specific dirs, e.g. a \"user data dir\"")
7591 (description
7592 "This module provides a portable way of finding out where user data
7593 should be stored on various operating systems.")
7594 (license license:expat)))
7595
7596 (define-public python2-appdirs
7597 (package-with-python2 python-appdirs))
7598
7599 (define-public python-llfuse
7600 (package
7601 (name "python-llfuse")
7602 (version "1.2")
7603 (source (origin
7604 (method url-fetch)
7605 (uri (string-append
7606 "https://bitbucket.org/nikratio/python-llfuse/downloads/"
7607 "llfuse-" version ".tar.bz2"))
7608 (sha256
7609 (base32
7610 "11hms1x68bf1bqbqy7w3wpffqsd3jkgricmzrc1hrnwkswfzzlr4"))))
7611 (build-system python-build-system)
7612 (inputs
7613 `(("fuse" ,fuse)
7614 ("attr" ,attr)))
7615 (native-inputs
7616 `(("pkg-config" ,pkg-config)))
7617 (synopsis "Python bindings for FUSE")
7618 (description
7619 "Python-LLFUSE is a set of Python bindings for the low level FUSE API.")
7620 (home-page "https://bitbucket.org/nikratio/python-llfuse/")
7621 (license license:lgpl2.0+)
7622 (properties `((python2-variant . ,(delay python2-llfuse))))))
7623
7624 (define-public python2-llfuse
7625 (package (inherit (package-with-python2
7626 (strip-python2-variant python-llfuse)))
7627 (propagated-inputs `(("python2-contextlib2" ,python2-contextlib2)))))
7628
7629 ;; For attic-0.16
7630 (define-public python-llfuse-0.41
7631 (package (inherit python-llfuse)
7632 (version "0.41.1")
7633 (source (origin
7634 (method url-fetch)
7635 (uri (string-append
7636 "https://bitbucket.org/nikratio/python-llfuse/downloads/"
7637 "llfuse-" version ".tar.bz2"))
7638 (sha256
7639 (base32
7640 "1imlqw9b73086y97izr036f58pgc5akv4ihc2rrf8j5h75jbrlaa"))))
7641 ;; Python-LLFUSE < 0.42 includes underscore.js, which is MIT (expat)
7642 ;; licensed. The rest of the package is licensed under LGPL2.0 or later.
7643 (license (list license:expat license:lgpl2.0+))))
7644
7645 (define-public python-msgpack
7646 (package
7647 (name "python-msgpack")
7648 (version "0.4.8")
7649 (source (origin
7650 (method url-fetch)
7651 (uri (pypi-uri "msgpack-python" version))
7652 (sha256
7653 (base32
7654 "11pqk5braa6wndpnr1dhg64js82vjgxnm0lzy73rwl831zgijaqs"))))
7655 (build-system python-build-system)
7656 (synopsis "MessagePack (de)serializer")
7657 (description "MessagePack is a fast, compact binary serialization format,
7658 suitable for similar data to JSON. This package provides CPython bindings for
7659 reading and writing MessagePack data.")
7660 (home-page "https://pypi.python.org/pypi/msgpack-python/")
7661 (license license:asl2.0)))
7662
7663 (define-public python2-msgpack
7664 (package-with-python2 python-msgpack))
7665
7666 (define-public python-netaddr
7667 (package
7668 (name "python-netaddr")
7669 (version "0.7.19")
7670 (source
7671 (origin
7672 (method url-fetch)
7673 (uri (pypi-uri "netaddr" version))
7674 (sha256
7675 (base32
7676 "1zdfadvpq4lmcqzr383gywxn4xyn355kj1n3lk9q2l03vmyfrbiq"))))
7677 (build-system python-build-system)
7678 (arguments `(#:tests? #f)) ;; No tests.
7679 (home-page "https://github.com/drkjam/netaddr/")
7680 (synopsis "Pythonic manipulation of network addresses")
7681 (description
7682 "A Python library for representing and manipulating IPv4, IPv6, CIDR, EUI
7683 and MAC network addresses.")
7684 (license license:bsd-3)))
7685
7686 (define-public python2-netaddr
7687 (package-with-python2 python-netaddr))
7688
7689 (define-public python2-neo4j-driver
7690 (package
7691 (name "python2-neo4j-driver")
7692 ;; NOTE: When upgrading to 1.5.0, please add a python3 variant.
7693 (version "1.4.0")
7694 (source (origin
7695 (method url-fetch)
7696 (uri (pypi-uri "neo4j-driver" version))
7697 (sha256
7698 (base32
7699 "011r1vh182p8mm83d8dz9rfnc3l7rf7fd00cyrbyfzi71jmc4g98"))))
7700 (build-system python-build-system)
7701 (arguments
7702 `(#:python ,python-2))
7703 (home-page "https://neo4j.com/developer/python/")
7704 (synopsis "Neo4j driver code written in Python")
7705 (description "This package provides the Neo4j Python driver that connects
7706 to the database using Neo4j's binary protocol. It aims to be minimal, while
7707 being idiomatic to Python.")
7708 (license license:asl2.0)))
7709
7710 (define-public python2-py2neo
7711 (package
7712 (name "python2-py2neo")
7713 (version "3.1.2")
7714 (source (origin
7715 (method url-fetch)
7716 (uri (pypi-uri "py2neo" version))
7717 (sha256
7718 (base32
7719 "1f1q95vqcvlc3nsc33p841swnjdcjazddlq2dzi3qfnjqjrajxw1"))))
7720 (build-system python-build-system)
7721 (arguments
7722 `(#:python ,python-2))
7723 (home-page "http://py2neo.org")
7724 (synopsis "Library and toolkit for working with Neo4j in Python")
7725 (description "This package provides a client library and toolkit for
7726 working with Neo4j from within Python applications and from the command
7727 line. The core library has no external dependencies and has been carefully
7728 designed to be easy and intuitive to use.")
7729 (license license:asl2.0)))
7730
7731 (define-public python-wrapt
7732 (package
7733 (name "python-wrapt")
7734 (version "1.10.8")
7735 (source
7736 (origin
7737 (method url-fetch)
7738 (uri (pypi-uri "wrapt" version))
7739 (sha256
7740 (base32
7741 "0wrcm1mydvfivbkzz0h81ygzdchnscshi6xvy5n3r21r9s0px8af"))))
7742 (build-system python-build-system)
7743 (arguments
7744 ;; Tests are not included in the tarball, they are only available in the
7745 ;; git repository.
7746 `(#:tests? #f))
7747 (home-page "https://github.com/GrahamDumpleton/wrapt")
7748 (synopsis "Module for decorators, wrappers and monkey patching")
7749 (description
7750 "The aim of the wrapt module is to provide a transparent object proxy for
7751 Python, which can be used as the basis for the construction of function
7752 wrappers and decorator functions.")
7753 (license license:bsd-2)))
7754
7755 (define-public python2-wrapt
7756 (package-with-python2 python-wrapt))
7757
7758 (define-public python-iso8601
7759 (package
7760 (name "python-iso8601")
7761 (version "0.1.11")
7762 (source
7763 (origin
7764 (method url-fetch)
7765 (uri (pypi-uri "iso8601" version))
7766 (sha256
7767 (base32
7768 "0c7gh3lsdjds262h0v1sqc66l7hqgfwbakn96qrhdbl0i3vm5yz8"))))
7769 (build-system python-build-system)
7770 (native-inputs
7771 `(("python-pytest" ,python-pytest)))
7772 (home-page "https://bitbucket.org/micktwomey/pyiso8601")
7773 (synopsis "Module to parse ISO 8601 dates")
7774 (description
7775 "This module parses the most common forms of ISO 8601 date strings (e.g.
7776 @code{2007-01-14T20:34:22+00:00}) into @code{datetime} objects.")
7777 (license license:expat)))
7778
7779 (define-public python2-iso8601
7780 (package-with-python2 python-iso8601))
7781
7782 (define-public python-monotonic
7783 (package
7784 (name "python-monotonic")
7785 (version "0.3")
7786 (source
7787 (origin
7788 (method url-fetch)
7789 (uri (string-append
7790 "https://pypi.python.org/packages/source/m/monotonic/monotonic-"
7791 version
7792 ".tar.gz"))
7793 (sha256
7794 (base32
7795 "0yz0bcbwx8r2c01czzfpbrxddynxyk9k95jj8h6sgcb7xmfvl998"))))
7796 (build-system python-build-system)
7797 (home-page "https://github.com/atdt/monotonic")
7798 (synopsis "Implementation of time.monotonic() for Python 2 & < 3.3")
7799 (description
7800 "This module provides a monotonic() function which returns the value (in
7801 fractional seconds) of a clock which never goes backwards.")
7802 (license license:asl2.0)))
7803
7804 (define-public python2-monotonic
7805 (package-with-python2 python-monotonic))
7806
7807 (define-public python-webob
7808 (package
7809 (name "python-webob")
7810 (version "1.5.1")
7811 (source
7812 (origin
7813 (method url-fetch)
7814 (uri (pypi-uri "WebOb" version))
7815 (sha256
7816 (base32
7817 "02bhhzijfhv8hmi1i54d4b0v43liwhnywhflvxsv4x3zax9s3afq"))))
7818 (build-system python-build-system)
7819 (native-inputs
7820 `(("python-nose" ,python-nose)))
7821 (home-page "http://webob.org/")
7822 (synopsis "WSGI request and response object")
7823 (description
7824 "WebOb provides wrappers around the WSGI request environment, and an
7825 object to help create WSGI responses.")
7826 (license license:expat)))
7827
7828 (define-public python2-webob
7829 (package-with-python2 python-webob))
7830
7831 (define-public python-xlrd
7832 (package
7833 (name "python-xlrd")
7834 (version "1.0.0")
7835 (source (origin
7836 (method url-fetch)
7837 (uri (pypi-uri "xlrd" version))
7838 (sha256
7839 (base32
7840 "0s8hjiz01vbhy85xalrz0qlsmd9ypf36zjqrf97hh984spapvy0g"))))
7841 (build-system python-build-system)
7842 (arguments
7843 `(#:phases
7844 (modify-phases %standard-phases
7845 ;; Current test in setup.py does not work as of 1.0.0, so use nose to
7846 ;; run tests instead for now.
7847 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
7848 (native-inputs `(("python-nose" ,python-nose)))
7849 (home-page "http://www.python-excel.org/")
7850 (synopsis "Library for extracting data from Excel files")
7851 (description "This packages provides a library to extract data from
7852 spreadsheets using Microsoft Excel proprietary file formats @samp{.xls} and
7853 @samp{.xlsx} (versions 2.0 onwards). It has support for Excel dates and is
7854 Unicode-aware. It is not intended as an end-user tool.")
7855 (license license:bsd-3)))
7856
7857 (define-public python2-xlrd
7858 (package-with-python2 python-xlrd))
7859
7860 (define-public python-prettytable
7861 (package
7862 (name "python-prettytable")
7863 (version "0.7.2")
7864 (source
7865 (origin
7866 (method url-fetch)
7867 (uri (string-append
7868 "https://pypi.python.org/packages/source/P/PrettyTable/"
7869 "prettytable-" version ".tar.bz2"))
7870 (sha256
7871 (base32
7872 "0diwsicwmiq2cpzpxri7cyl5fmsvicafw6nfqf6p6p322dji2g45"))))
7873 (build-system python-build-system)
7874 (home-page "http://code.google.com/p/prettytable/")
7875 (synopsis "Display tabular data in an ASCII table format")
7876 (description
7877 "A library designed to represent tabular data in visually appealing ASCII
7878 tables. PrettyTable allows for selection of which columns are to be printed,
7879 independent alignment of columns (left or right justified or centred) and
7880 printing of sub-tables by specifying a row range.")
7881 (license license:bsd-3)))
7882
7883 (define-public python2-prettytable
7884 (package-with-python2 python-prettytable))
7885
7886 (define-public python-tables
7887 (package
7888 (name "python-tables")
7889 (version "3.2.2")
7890 (source
7891 (origin
7892 (method url-fetch)
7893 (uri (pypi-uri "tables" version))
7894 (sha256
7895 (base32
7896 "117s6w7s3yxafpmf3zz3svana7xfrsviw01va1xp7h8ylx8v6r1m"))
7897 (modules '((guix build utils)))
7898 (snippet
7899 '(begin
7900 ;; Remove pre-compiled .pyc files from source.
7901 (for-each delete-file-recursively
7902 (find-files "." "__pycache__" #:directories? #t))
7903 (for-each delete-file (find-files "." "\\.pyc$"))
7904 #t))))
7905 (build-system python-build-system)
7906 (arguments
7907 `(;; FIXME: python-build-system does not pass configure-flags to "build"
7908 ;; or "check", so we must override the build and check phases.
7909 #:phases
7910 (modify-phases %standard-phases
7911 (add-after 'unpack 'use-gcc
7912 (lambda _
7913 (substitute* "setup.py"
7914 (("compiler = new_compiler\\(\\)" line)
7915 (string-append line
7916 "\ncompiler.set_executables(compiler='gcc',"
7917 "compiler_so='gcc',"
7918 "linker_exe='gcc',"
7919 "linker_so='gcc -shared')")))
7920 #t))
7921 (replace 'build
7922 (lambda* (#:key inputs #:allow-other-keys)
7923 (zero? (system* "python" "setup.py" "build"
7924 (string-append "--hdf5="
7925 (assoc-ref inputs "hdf5"))))))
7926 (replace 'check
7927 (lambda* (#:key inputs #:allow-other-keys)
7928 (zero? (system* "python" "setup.py" "check"
7929 (string-append "--hdf5="
7930 (assoc-ref inputs "hdf5")))))))))
7931 (propagated-inputs
7932 `(("python-numexpr" ,python-numexpr)
7933 ("python-numpy" ,python-numpy)))
7934 (native-inputs
7935 `(("python-cython" ,python-cython)
7936 ("pkg-config" ,pkg-config)))
7937 (inputs
7938 `(("hdf5" ,hdf5)
7939 ("bzip2" ,bzip2)
7940 ("zlib" ,zlib)))
7941 (home-page "http://www.pytables.org/")
7942 (synopsis "Hierarchical datasets for Python")
7943 (description "PyTables is a package for managing hierarchical datasets and
7944 designed to efficiently cope with extremely large amounts of data.")
7945 (license license:bsd-3)))
7946
7947 (define-public python2-tables
7948 (package-with-python2 python-tables))
7949
7950 (define-public python-pyasn1
7951 (package
7952 (name "python-pyasn1")
7953 (version "0.2.3")
7954 (source
7955 (origin
7956 (method url-fetch)
7957 (uri (pypi-uri "pyasn1" version))
7958 (sha256
7959 (base32
7960 "1b86yx23c1x74clai05a5ma8c8nfmhlx3j1mxq0ff657i2ylx33k"))))
7961 (build-system python-build-system)
7962 (home-page "http://pyasn1.sourceforge.net/")
7963 (synopsis "ASN.1 types and codecs")
7964 (description
7965 "This is an implementation of ASN.1 types and codecs in Python. It is
7966 suitable for a wide range of protocols based on the ASN.1 specification.")
7967 (license license:bsd-2)))
7968
7969 (define-public python2-pyasn1
7970 (package-with-python2 python-pyasn1))
7971
7972 (define-public python-pyasn1-modules
7973 (package
7974 (name "python-pyasn1-modules")
7975 (version "0.0.8")
7976 (source
7977 (origin
7978 (method url-fetch)
7979 (uri (pypi-uri "pyasn1-modules" version))
7980 (sha256
7981 (base32
7982 "0drqgw81xd3fxdlg89kgd79zzrabvfncvkbybi2wr6w2y4s1jmhh"))))
7983 (build-system python-build-system)
7984 (propagated-inputs
7985 `(("python-pyasn1" ,python-pyasn1)))
7986 (home-page "https://sourceforge.net/projects/pyasn1/")
7987 (synopsis "ASN.1 codec implementations")
7988 (description
7989 "Pyasn1-modules is a collection of Python modules providing ASN.1 types and
7990 implementations of ASN.1-based codecs and protocols.")
7991 (license license:bsd-3)))
7992
7993 (define-public python2-pyasn1-modules
7994 (package-with-python2 python-pyasn1-modules))
7995
7996 (define-public python-ipaddress
7997 (package
7998 (name "python-ipaddress")
7999 (version "1.0.18")
8000 (source (origin
8001 (method url-fetch)
8002 (uri (pypi-uri "ipaddress" version))
8003 (sha256
8004 (base32
8005 "1q8klj9d84cmxgz66073x1j35cplr3r77vx1znhxiwl5w74391ax"))))
8006 (build-system python-build-system)
8007 (home-page "https://github.com/phihag/ipaddress")
8008 (synopsis "IP address manipulation library")
8009 (description
8010 "This package provides a fast, lightweight IPv4/IPv6 manipulation library
8011 in Python. This library is used to create, poke at, and manipulate IPv4 and
8012 IPv6 addresses and networks. This is a port of the Python 3.3 ipaddress
8013 module to older versions of Python.")
8014 (license license:psfl)))
8015
8016 (define-public python2-ipaddress
8017 (package-with-python2 python-ipaddress))
8018
8019 (define-public python2-ipaddr
8020 (package
8021 (name "python2-ipaddr")
8022 (version "2.1.11")
8023 (source
8024 (origin
8025 (method url-fetch)
8026 (uri (pypi-uri "ipaddr" version))
8027 (sha256
8028 (base32 "1dwq3ngsapjc93fw61rp17fvzggmab5x1drjzvd4y4q0i255nm8v"))))
8029 (build-system python-build-system)
8030 (arguments
8031 `(#:python ,python-2 ;version 2 only
8032 #:phases
8033 (modify-phases %standard-phases
8034 (replace 'check
8035 (lambda* _
8036 (zero? (system* "python" "ipaddr_test.py")))))))
8037 (home-page "https://github.com/google/ipaddr-py")
8038 (synopsis "IP address manipulation library")
8039 (description
8040 "Ipaddr is a Python@tie{}2 library for creating and manupilating IPv4 and
8041 IPv6 addresses and networks.
8042
8043 For new implementations you may prefer to use the standard module
8044 @code{ipaddress}, which was introduced in Python 3.3 and backported to older
8045 versions of Python.")
8046 (license license:asl2.0)))
8047
8048 (define-public python-idna
8049 (package
8050 (name "python-idna")
8051 (version "2.5")
8052 (source
8053 (origin
8054 (method url-fetch)
8055 (uri (pypi-uri "idna" version))
8056 (sha256
8057 (base32
8058 "1ara12a7k2zc69msa0arrvw00gn61a6i6by01xb3lkkc0h4cxd9w"))))
8059 (build-system python-build-system)
8060 (home-page "https://github.com/kjd/idna")
8061 (synopsis "Internationalized domain names in applications")
8062 (description
8063 "This is a library to support the Internationalised Domain Names in
8064 Applications (IDNA) protocol as specified in RFC 5891. This version of the
8065 protocol is often referred to as “IDNA2008” and can produce different results
8066 from the earlier standard from 2003. The library is also intended to act as a
8067 suitable drop-in replacement for the “encodings.idna” module that comes with
8068 the Python standard library but currently only supports the older 2003
8069 specification.")
8070 (license license:bsd-4)))
8071
8072 (define-public python2-idna
8073 (package-with-python2 python-idna))
8074
8075 (define-public python-pretend
8076 (package
8077 (name "python-pretend")
8078 (version "1.0.8")
8079 (source
8080 (origin
8081 (method url-fetch)
8082 (uri (string-append "https://pypi.python.org/packages/source/p/"
8083 "pretend/pretend-" version ".tar.gz"))
8084 (sha256
8085 (base32
8086 "0r5r7ygz9m6d2bklflbl84cqhjkc2q12xgis8268ygjh30g2q3wk"))))
8087 (build-system python-build-system)
8088 (home-page "https://github.com/alex/pretend")
8089 (synopsis "Library for stubbing in Python")
8090 (description
8091 "Pretend is a library to make stubbing with Python easier. Stubbing is a
8092 technique for writing tests. You may hear the term mixed up with mocks,
8093 fakes, or doubles. Basically, a stub is an object that returns pre-canned
8094 responses, rather than doing any computation.")
8095 (license license:bsd-3)))
8096
8097 (define-public python2-pretend
8098 (package-with-python2 python-pretend))
8099
8100 (define-public python-cryptography-vectors
8101 (package
8102 (name "python-cryptography-vectors")
8103 (version "2.0.3")
8104 (source
8105 (origin
8106 (method url-fetch)
8107 (uri (pypi-uri "cryptography_vectors" version))
8108 (sha256
8109 (base32
8110 "1qa117fs1yd50zn2cfxh7d9l999ds0z4h83m9m7j4fk6ffm33f5y"))))
8111 (build-system python-build-system)
8112 (home-page "https://github.com/pyca/cryptography")
8113 (synopsis "Test vectors for the cryptography package")
8114 (description
8115 "This package contains test vectors for the cryptography package.")
8116 ;; Distributed under either BSD-3 or ASL2.0
8117 (license (list license:bsd-3 license:asl2.0))))
8118
8119 (define-public python2-cryptography-vectors
8120 (package-with-python2 python-cryptography-vectors))
8121
8122 (define-public python-cryptography
8123 (package
8124 (name "python-cryptography")
8125 (version "2.0.3")
8126 (source
8127 (origin
8128 (method url-fetch)
8129 (uri (pypi-uri "cryptography" version))
8130 (sha256
8131 (base32
8132 "0fnck37zyvbzmccbp7w3jy27jgmij1992j5wyy3gxhw6a11b4jyh"))))
8133 (build-system python-build-system)
8134 (inputs
8135 `(("openssl" ,openssl)))
8136 (propagated-inputs
8137 `(("python-asn1crypto" ,python-asn1crypto)
8138 ("python-cffi" ,python-cffi)
8139 ("python-six" ,python-six)
8140 ("python-idna" ,python-idna)
8141 ("python-iso8601" ,python-iso8601)))
8142 (native-inputs
8143 `(("python-cryptography-vectors" ,python-cryptography-vectors)
8144 ("python-hypothesis" ,python-hypothesis)
8145 ("python-pretend" ,python-pretend)
8146 ("python-pytz" ,python-pytz)
8147 ("python-pytest" ,python-pytest-3.0)))
8148 (home-page "https://github.com/pyca/cryptography")
8149 (synopsis "Cryptographic recipes and primitives for Python")
8150 (description
8151 "cryptography is a package which provides cryptographic recipes and
8152 primitives to Python developers. It aims to be the “cryptographic standard
8153 library” for Python. The package includes both high level recipes, and low
8154 level interfaces to common cryptographic algorithms such as symmetric ciphers,
8155 message digests and key derivation functions.")
8156 ;; Distributed under either BSD-3 or ASL2.0
8157 (license (list license:bsd-3 license:asl2.0))
8158 (properties `((python2-variant . ,(delay python2-cryptography))))))
8159
8160 (define-public python2-cryptography
8161 (let ((crypto (package-with-python2
8162 (strip-python2-variant python-cryptography))))
8163 (package (inherit crypto)
8164 (propagated-inputs
8165 `(("python2-ipaddress" ,python2-ipaddress)
8166 ("python2-backport-ssl-match-hostname"
8167 ,python2-backport-ssl-match-hostname)
8168 ("python2-enum34" ,python2-enum34)
8169 ,@(package-propagated-inputs crypto))))))
8170
8171 (define-public python-pyopenssl
8172 (package
8173 (name "python-pyopenssl")
8174 (version "17.3.0")
8175 (source
8176 (origin
8177 (method url-fetch)
8178 (uri (pypi-uri "pyOpenSSL" version))
8179 (sha256
8180 (base32
8181 "0xkc1wfnpg6abzllivg3ylhc63npjdy1v81f4kc08bm8cj80nqr9"))))
8182 (build-system python-build-system)
8183 (arguments
8184 '(#:phases
8185 (modify-phases %standard-phases
8186 (delete 'check)
8187 (add-after 'install 'check
8188 (lambda* (#:key inputs outputs #:allow-other-keys)
8189 (add-installed-pythonpath inputs outputs)
8190 (zero? (system* "py.test" "-v" "-k"
8191 (string-append
8192 ;; This test tries to look up certificates from
8193 ;; the compiled-in default path in OpenSSL, which
8194 ;; does not exist in the build environment.
8195 "not test_fallback_default_verify_paths "
8196 ;; This test attempts to make a connection to
8197 ;; an external web service.
8198 "and not test_set_default_verify_paths"))))))))
8199 (propagated-inputs
8200 `(("python-cryptography" ,python-cryptography)
8201 ("python-six" ,python-six)))
8202 (inputs
8203 `(("openssl" ,openssl)))
8204 (native-inputs
8205 `(("python-flaky" ,python-flaky)
8206 ("python-pretend" ,python-pretend)
8207 ("python-pytest" ,python-pytest-3.0)))
8208 (home-page "https://github.com/pyca/pyopenssl")
8209 (synopsis "Python wrapper module around the OpenSSL library")
8210 (description
8211 "PyOpenSSL is a high-level wrapper around a subset of the OpenSSL
8212 library.")
8213 (license license:asl2.0)))
8214
8215 (define-public python2-pyopenssl
8216 (package-with-python2 python-pyopenssl))
8217
8218 (define-public python-pip
8219 (package
8220 (name "python-pip")
8221 (version "9.0.1")
8222 (source
8223 (origin
8224 (method url-fetch)
8225 (uri (pypi-uri "pip" version))
8226 (sha256
8227 (base32
8228 "03clr9c1dih5n9c00c592zzvf6r1ffimywkaq9agcqdllzhl7wh9"))))
8229 (build-system python-build-system)
8230 (arguments
8231 '(#:tests? #f)) ; there are no tests in the pypi archive.
8232 (home-page "https://pip.pypa.io/")
8233 (synopsis "Package manager for Python software")
8234 (description
8235 "Pip is a package manager for Python software, that finds packages on the
8236 Python Package Index (PyPI).")
8237 (license license:expat)))
8238
8239 (define-public python2-pip
8240 (package-with-python2 python-pip))
8241
8242 (define-public python-tlsh
8243 (package
8244 (name "python-tlsh")
8245 (version "3.4.4")
8246 (home-page "https://github.com/trendmicro/tlsh")
8247 (source (origin
8248 (method url-fetch)
8249 (uri (string-append "https://github.com/trendmicro/tlsh/archive/v"
8250 version ".tar.gz"))
8251 (sha256
8252 (base32
8253 "00bhzjqrlh7v538kbkbn8lgx976j1138al3sdhklaizqjvpwyk4r"))
8254 (file-name (string-append name "-" version ".tar.gz"))))
8255 (build-system cmake-build-system)
8256 (arguments
8257 '(#:out-of-source? #f
8258 #:phases (modify-phases %standard-phases
8259 (replace
8260 'install
8261 (lambda* (#:key outputs #:allow-other-keys)
8262 ;; Build and install the Python bindings. The underlying
8263 ;; C++ library is apparently not meant to be installed.
8264 (let ((out (assoc-ref outputs "out")))
8265 (with-directory-excursion "py_ext"
8266 (and (system* "python" "setup.py" "build")
8267 (system* "python" "setup.py" "install"
8268 (string-append "--prefix=" out))))))))))
8269 (inputs `(("python" ,python-wrapper))) ;for the bindings
8270 (synopsis "Fuzzy matching library for Python")
8271 (description
8272 "Trend Micro Locality Sensitive Hash (TLSH) is a fuzzy matching library.
8273 Given a byte stream with a minimum length of 256 bytes, TLSH generates a hash
8274 value which can be used for similarity comparisons. Similar objects have
8275 similar hash values, which allows for the detection of similar objects by
8276 comparing their hash values. The byte stream should have a sufficient amount
8277 of complexity; for example, a byte stream of identical bytes will not generate
8278 a hash value.")
8279 (license license:asl2.0)))
8280
8281 (define-public python2-tlsh
8282 (package
8283 (inherit python-tlsh)
8284 (name "python2-tlsh")
8285 (inputs `(("python" ,python-2)))))
8286
8287 (define-public python-termcolor
8288 (package
8289 (name "python-termcolor")
8290 (version "1.1.0")
8291 (source
8292 (origin
8293 (method url-fetch)
8294 (uri (pypi-uri "termcolor" version))
8295 (sha256
8296 (base32
8297 "0fv1vq14rpqwgazxg4981904lfyp84mnammw7y046491cv76jv8x"))))
8298 (build-system python-build-system)
8299 (arguments
8300 ;; There are no tests.
8301 `(#:tests? #f))
8302 (home-page "http://pypi.python.org/pypi/termcolor")
8303 (synopsis "ANSII Color formatting for terminal output")
8304 (description
8305 "This package provides ANSII Color formatting for output in terminals.")
8306 (license license:expat)))
8307
8308 (define-public python2-termcolor
8309 (package-with-python2 python-termcolor))
8310
8311 (define-public python-libarchive-c
8312 (package
8313 (name "python-libarchive-c")
8314 (version "2.2")
8315 (source (origin
8316 (method url-fetch)
8317 (uri (pypi-uri "libarchive-c" version))
8318 (sha256
8319 (base32
8320 "0z4r7v3dhd6b3120mav05ff08srih176r2rg5k8kn7mjd9pslm2x"))))
8321 (build-system python-build-system)
8322 (arguments
8323 '(#:phases (modify-phases %standard-phases
8324 (add-before
8325 'build 'reference-libarchive
8326 (lambda* (#:key inputs #:allow-other-keys)
8327 ;; Retain the absolute file name of libarchive.so.
8328 (let ((libarchive (assoc-ref inputs "libarchive")))
8329 (substitute* "libarchive/ffi.py"
8330 (("find_library\\('archive'\\)")
8331 (string-append "'" libarchive
8332 "/lib/libarchive.so'")))))))))
8333 (inputs
8334 `(("libarchive" ,libarchive)))
8335 (home-page "https://github.com/Changaco/python-libarchive-c")
8336 (synopsis "Python interface to libarchive")
8337 (description
8338 "This package provides Python bindings to libarchive, a C library to
8339 access possibly compressed archives in many different formats. It uses
8340 Python's @code{ctypes} foreign function interface (FFI).")
8341 (license license:lgpl2.0+)))
8342
8343 (define-public python2-libarchive-c
8344 (package-with-python2 python-libarchive-c))
8345
8346 (define-public python-file
8347 (package
8348 (inherit file)
8349 (name "python-file")
8350 (build-system python-build-system)
8351 (arguments
8352 '(#:tests? #f ;no tests
8353 #:configure-flags '("--single-version-externally-managed" "--root=/")
8354 #:phases (modify-phases %standard-phases
8355 (add-before 'build 'change-directory
8356 (lambda _
8357 (chdir "python")
8358 #t))
8359 (add-before 'build 'set-library-file-name
8360 (lambda* (#:key inputs #:allow-other-keys)
8361 (let ((file (assoc-ref inputs "file")))
8362 (substitute* "magic.py"
8363 (("find_library\\('magic'\\)")
8364 (string-append "'" file "/lib/libmagic.so'")))
8365 #t))))))
8366 (inputs `(("file" ,file)))
8367 (self-native-input? #f)
8368 (synopsis "Python bindings to the libmagic file type guesser. Note that
8369 this module and the python-magic module both provide a \"magic.py\" file;
8370 these two modules, which are different and were developed separately, both
8371 serve the same purpose: provide Python bindings for libmagic.")))
8372
8373 (define-public python2-file
8374 (package-with-python2 python-file))
8375
8376 (define-public python-debian
8377 (package
8378 (name "python-debian")
8379 (version "0.1.28")
8380 (source
8381 (origin
8382 (method url-fetch)
8383 (uri (pypi-uri name version))
8384 (sha256
8385 (base32
8386 "0i15f0xzx679sd0ldq2sls9pnnps9fv6vhqvnv9dzf4qhma42i0y"))))
8387 (build-system python-build-system)
8388 (propagated-inputs
8389 `(("python-six" ,python-six)))
8390 (home-page "http://packages.debian.org/sid/python-debian")
8391 (synopsis "Debian package related modules")
8392 (description
8393 ;; XXX: Use @enumerate instead of @itemize to work around
8394 ;; <http://bugs.gnu.org/21772>.
8395 "This package provides Python modules that abstract many formats of
8396 Debian-related files, such as:
8397
8398 @enumerate
8399 @item Debtags information;
8400 @item @file{debian/changelog} files;
8401 @item packages files, pdiffs;
8402 @item control files of single or multiple RFC822-style paragraphs---e.g.
8403 @file{debian/control}, @file{.changes}, @file{.dsc};
8404 @item Raw @file{.deb} and @file{.ar} files, with (read-only) access to
8405 contained files and meta-information.
8406 @end enumerate\n")
8407
8408 ;; Modules are either GPLv2+ or GPLv3+.
8409 (license license:gpl3+)))
8410
8411 (define-public python2-debian
8412 (package-with-python2 python-debian))
8413
8414 (define-public python-nbformat
8415 (package
8416 (name "python-nbformat")
8417 (version "4.3.0")
8418 (source
8419 (origin
8420 (method url-fetch)
8421 (uri (pypi-uri "nbformat" version))
8422 (sha256
8423 (base32
8424 "12s7j4qja8b5bs1kyw5dzmrqbjxxj8wk52cyasbiqbv7fblcrssz"))))
8425 (build-system python-build-system)
8426 (arguments `(#:tests? #f)) ; no test target
8427 (propagated-inputs
8428 `(("python-ipython-genutils" ,python-ipython-genutils)
8429 ("python-jsonschema" ,python-jsonschema)
8430 ("python-jupyter-core" ,python-jupyter-core)
8431 ("python-traitlets" ,python-traitlets)))
8432 (home-page "http://jupyter.org")
8433 (synopsis "Jupyter Notebook format")
8434 (description "This package provides the reference implementation of the
8435 Jupyter Notebook format and Python APIs for working with notebooks.")
8436 (license license:bsd-3)))
8437
8438 (define-public python2-nbformat
8439 (package-with-python2 python-nbformat))
8440
8441 (define-public python-bleach
8442 (package
8443 (name "python-bleach")
8444 (version "1.4.3")
8445 (source
8446 (origin
8447 (method url-fetch)
8448 (uri (pypi-uri "bleach" version))
8449 (sha256
8450 (base32
8451 "0jvg3jxrvnx7xmm9gj262v60ib452xlnwlb0navyp7jsvcd0d4qj"))))
8452 (build-system python-build-system)
8453 (propagated-inputs
8454 `(("python-html5lib" ,python-html5lib-0.9)
8455 ("python-six" ,python-six)))
8456 (native-inputs
8457 `(("python-nose" ,python-nose)))
8458 (home-page "https://github.com/jsocol/bleach")
8459 (synopsis "Whitelist-based HTML-sanitizing tool")
8460 (description "Bleach is an easy whitelist-based HTML-sanitizing tool.")
8461 (license license:asl2.0)))
8462
8463 (define-public python2-bleach
8464 (package-with-python2 python-bleach))
8465
8466 (define-public python-entrypoints
8467 (package
8468 (name "python-entrypoints")
8469 (version "0.2.2")
8470 (source
8471 (origin
8472 (method url-fetch)
8473 (uri (string-append "https://github.com/takluyver/entrypoints/archive/"
8474 version ".tar.gz"))
8475 (file-name (string-append name "-" version ".tar.gz"))
8476 (sha256
8477 (base32
8478 "0azqlkh3j0za080lsf5crnhaxx3c93k9dpv5ihkhf5cppgw5sjz5"))))
8479 (build-system python-build-system)
8480 ;; The package does not come with a setup.py file, so we have to generate
8481 ;; one ourselves.
8482 (arguments
8483 `(#:tests? #f
8484 #:phases
8485 (modify-phases %standard-phases
8486 (add-after 'unpack 'create-setup.py
8487 (lambda _
8488 (call-with-output-file "setup.py"
8489 (lambda (port)
8490 (format port "\
8491 from setuptools import setup
8492 setup(name='entrypoints', version='~a', py_modules=['entrypoints'])
8493 " ,version))))))))
8494 (home-page "https://github.com/takluyver/entrypoints")
8495 (synopsis "Discover and load entry points from installed Python packages")
8496 (description "Entry points are a way for Python packages to advertise
8497 objects with some common interface. The most common examples are
8498 @code{console_scripts} entry points, which define shell commands by
8499 identifying a Python function to run. The @code{entrypoints} module contains
8500 functions to find and load entry points.")
8501 (license license:expat)))
8502
8503 (define-public python2-entrypoints
8504 (package-with-python2 python-entrypoints))
8505
8506 (define-public python-nbconvert
8507 (package
8508 (name "python-nbconvert")
8509 (version "5.0.0b1")
8510 (source
8511 (origin
8512 (method url-fetch)
8513 (uri (pypi-uri "nbconvert" version))
8514 (sha256
8515 (base32
8516 "0brclbb18l4nmd5qy3dl9wn05rjdh1fz4rmzdlfqacj12rcdvdgp"))))
8517 (build-system python-build-system)
8518 (arguments
8519 `(;; The "bdist_egg" target is disabled by default, causing the installation
8520 ;; to fail.
8521 #:configure-flags (list "bdist_egg")
8522 ;; FIXME: 5 failures, 40 errors.
8523 #:tests? #f))
8524 ;; #:phases
8525 ;; (modify-phases %standard-phases
8526 ;; (replace 'check
8527 ;; (lambda _
8528 ;; (zero? (system* "py.test" "-v")))))
8529 (native-inputs
8530 `(("python-pytest" ,python-pytest)))
8531 (propagated-inputs
8532 `(("python-bleach" ,python-bleach)
8533 ("python-entrypoints" ,python-entrypoints)
8534 ("python-jinja2" ,python-jinja2)
8535 ("python-jupyter-core" ,python-jupyter-core)
8536 ("python-mistune" ,python-mistune)
8537 ("python-nbformat" ,python-nbformat)
8538 ("python-pygments" ,python-pygments)
8539 ("python-traitlets" ,python-traitlets)))
8540 (home-page "http://jupyter.org")
8541 (synopsis "Converting Jupyter Notebooks")
8542 (description "The @code{nbconvert} tool, @{jupyter nbconvert}, converts
8543 notebooks to various other formats via Jinja templates. It allows you to
8544 convert an @code{.ipynb} notebook file into various static formats including:
8545
8546 @enumerate
8547 @item HTML
8548 @item LaTeX
8549 @item PDF
8550 @item Reveal JS
8551 @item Markdown (md)
8552 @item ReStructured Text (rst)
8553 @item executable script
8554 @end enumerate\n")
8555 (license license:bsd-3)))
8556
8557 (define-public python2-nbconvert
8558 (package-with-python2 python-nbconvert))
8559
8560 (define-public python-notebook
8561 (package
8562 (name "python-notebook")
8563 (version "4.2.3")
8564 (source (origin
8565 (method url-fetch)
8566 (uri (pypi-uri "notebook" version))
8567 (sha256
8568 (base32
8569 "0laq5c2f21frq6xcdckgq7raqhznbjb0qs0357g612z87wyn1a9r"))))
8570 (build-system python-build-system)
8571 (arguments
8572 `(#:phases
8573 (modify-phases %standard-phases
8574 (replace 'check
8575 (lambda _
8576 ;; HOME must be set for tests
8577 (setenv "HOME" "/tmp")
8578 (zero? (system* "nosetests")))))))
8579 (propagated-inputs
8580 `(("python-jupyter-core" ,python-jupyter-core)
8581 ("python-nbformat" ,python-nbformat)
8582 ("python-nbconvert" ,python-nbconvert)
8583 ("python-ipython" ,python-ipython)))
8584 (native-inputs
8585 `(("python-nose" ,python-nose)
8586 ("python-sphinx" ,python-sphinx)
8587 ("python-requests" ,python-requests)))
8588 (home-page "http://jupyter.org/")
8589 (synopsis "Web-based notebook environment for interactive computing")
8590 (description
8591 "The Jupyter HTML notebook is a web-based notebook environment for
8592 interactive computing.")
8593 (properties `((python2-variant . ,(delay python2-notebook))))
8594 (license license:bsd-3)))
8595
8596 (define-public python2-notebook
8597 (let ((base (package-with-python2
8598 (strip-python2-variant python-notebook))))
8599 (package (inherit base)
8600 (native-inputs
8601 `(("python2-mock" ,python2-mock)
8602 ,@(package-native-inputs base)))
8603 (arguments
8604 (substitute-keyword-arguments (package-arguments base)
8605 ((#:phases phases)
8606 `(modify-phases ,phases
8607 (add-before 'check 'disable-test-case
8608 ;; The test requires network access to localhost. Curiously it
8609 ;; fails with Python 2 only. Simply make the test-case return
8610 ;; immediately.
8611 (lambda _
8612 (substitute*
8613 "notebook/services/nbconvert/tests/test_nbconvert_api.py"
8614 (("formats = self.nbconvert_api") "return #")))))))))))
8615
8616 (define-public python-widgetsnbextension
8617 (package
8618 (name "python-widgetsnbextension")
8619 (version "1.2.6")
8620 (source
8621 (origin
8622 (method url-fetch)
8623 (uri (pypi-uri "widgetsnbextension" version))
8624 (sha256
8625 (base32
8626 "0lff2mrwrgsa1mxmwx3phl9xvy0jqfpg6khbmxy53jbq56rwy666"))))
8627 (build-system python-build-system)
8628 (propagated-inputs
8629 `(("python-notebook" ,python-notebook)))
8630 (native-inputs
8631 `(("python-certifi" ,python-certifi)
8632 ("python-nose" ,python-nose)))
8633 (home-page "http://ipython.org")
8634 (synopsis "IPython HTML widgets for Jupyter")
8635 (description "This package provides interactive HTML widgets for Jupyter
8636 notebooks.")
8637 (license license:bsd-3)))
8638
8639 (define-public python2-widgetsnbextension
8640 (package-with-python2 python-widgetsnbextension))
8641
8642 (define-public python-ipywidgets
8643 (package
8644 (name "python-ipywidgets")
8645 (version "5.2.2")
8646 (source
8647 (origin
8648 (method url-fetch)
8649 (uri (pypi-uri "ipywidgets" version))
8650 (sha256
8651 (base32
8652 "1lk0qrr5l9a0z7qkkn30hv5832whxwxymf1l576fmmad0n7hkxms"))))
8653 (build-system python-build-system)
8654 ;; FIXME: it's not clear how to run the tests.
8655 (arguments `(#:tests? #f))
8656 (propagated-inputs
8657 `(("python-ipykernel" ,python-ipykernel)
8658 ("python-ipython" ,python-ipython)
8659 ("python-traitlets" ,python-traitlets)
8660 ("python-widgetsnbextension" ,python-widgetsnbextension)))
8661 (home-page "http://ipython.org")
8662 (synopsis "IPython HTML widgets for Jupyter")
8663 (description "Ipywidgets are interactive HTML widgets for Jupyter
8664 notebooks and the IPython kernel. Notebooks come alive when interactive
8665 widgets are used. Users gain control of their data and can visualize changes
8666 in the data.")
8667 (license license:bsd-3)))
8668
8669 (define-public python2-ipywidgets
8670 (package-with-python2 python-ipywidgets))
8671
8672 (define-public python-jupyter-console
8673 (package
8674 (name "python-jupyter-console")
8675 (version "5.0.0")
8676 (source
8677 (origin
8678 (method url-fetch)
8679 (uri (pypi-uri "jupyter_console" version))
8680 (sha256
8681 (base32
8682 "04acmkwsi99rcg3vb54c6n492zv35s92h2ahabc0w6wj976cipvx"))))
8683 (build-system python-build-system)
8684 ;; FIXME: it's not clear how to run the tests.
8685 (arguments `(#:tests? #f))
8686 (propagated-inputs
8687 `(("python-ipykernel" ,python-ipykernel)
8688 ("python-ipython" ,python-ipython)
8689 ("python-jupyter-client" ,python-jupyter-client)
8690 ("python-prompt-toolkit" ,python-prompt-toolkit)
8691 ("python-pygments" ,python-pygments)))
8692 (home-page "https://jupyter.org")
8693 (synopsis "Jupyter terminal console")
8694 (description "This package provides a terminal-based console frontend for
8695 Jupyter kernels. It also allows for console-based interaction with non-Python
8696 Jupyter kernels such as IJulia and IRKernel.")
8697 (license license:bsd-3)))
8698
8699 (define-public python2-jupyter-console
8700 (package-with-python2 python-jupyter-console))
8701
8702 ;; The python-ipython and python-jupyter-console require each other. To get
8703 ;; the functionality in both packages working, strip down the
8704 ;; python-jupyter-console package when using it as an input to python-ipython.
8705 (define python-jupyter-console-minimal
8706 (package
8707 (inherit python-jupyter-console)
8708 (arguments
8709 (substitute-keyword-arguments
8710 (package-arguments python-jupyter-console)
8711 ((#:phases phases)
8712 `(modify-phases ,phases
8713 (add-after 'install 'delete-bin
8714 (lambda* (#:key outputs #:allow-other-keys)
8715 ;; Delete the bin files, to avoid conflicts in profiles
8716 ;; where python-ipython and python-jupyter-console are
8717 ;; both present.
8718 (delete-file-recursively
8719 (string-append
8720 (assoc-ref outputs "out") "/bin"))))))))
8721 ;; Remove the python-ipython propagated input, to avoid the cycle
8722 (propagated-inputs
8723 (alist-delete
8724 "python-ipython"
8725 (package-propagated-inputs python-jupyter-console)))))
8726
8727 (define-public jupyter
8728 (package
8729 (name "jupyter")
8730 (version "1.0.0")
8731 (source
8732 (origin
8733 (method url-fetch)
8734 (uri (pypi-uri "jupyter" version))
8735 (sha256
8736 (base32
8737 "0pwf3pminkzyzgx5kcplvvbvwrrzd3baa7lmh96f647k30rlpp6r"))))
8738 (build-system python-build-system)
8739 ;; FIXME: it's not clear how to run the tests.
8740 (arguments `(#:tests? #f))
8741 (propagated-inputs
8742 `(("python-ipykernel" ,python-ipykernel)
8743 ("python-ipywidgets" ,python-ipywidgets)
8744 ("python-jupyter-console" ,python-jupyter-console)
8745 ("python-nbconvert" ,python-nbconvert)
8746 ("python-notebook" ,python-notebook)))
8747 (home-page "http://jupyter.org")
8748 (synopsis "Web application for interactive documents")
8749 (description
8750 "The Jupyter Notebook is a web application that allows you to create and
8751 share documents that contain live code, equations, visualizations and
8752 explanatory text. Uses include: data cleaning and transformation, numerical
8753 simulation, statistical modeling, machine learning and much more.")
8754 (license license:bsd-3)))
8755
8756 (define-public python-chardet
8757 (package
8758 (name "python-chardet")
8759 (version "3.0.4")
8760 (source
8761 (origin
8762 (method url-fetch)
8763 (uri (pypi-uri "chardet" version))
8764 (sha256
8765 (base32
8766 "1bpalpia6r5x1kknbk11p1fzph56fmmnp405ds8icksd3knr5aw4"))))
8767 (native-inputs
8768 `(("python-hypothesis" ,python-hypothesis)
8769 ("python-pytest" ,python-pytest)
8770 ("python-pytest-runner" ,python-pytest-runner)))
8771 (build-system python-build-system)
8772 (home-page "https://github.com/chardet/chardet")
8773 (synopsis "Universal encoding detector for Python 2 and 3")
8774 (description
8775 "This package provides @code{chardet}, a Python module that can
8776 automatically detect a wide range of file encodings.")
8777 (license license:lgpl2.1+)))
8778
8779 (define-public python2-chardet
8780 (package-with-python2 python-chardet))
8781
8782 (define-public python-docopt
8783 (package
8784 (name "python-docopt")
8785 (version "0.6.2")
8786 (source
8787 (origin
8788 (method url-fetch)
8789 ;; The release on PyPI does not include tests.
8790 (uri (string-append
8791 "https://github.com/docopt/docopt/archive/"
8792 version ".tar.gz"))
8793 (file-name (string-append name "-" version ".tar.gz"))
8794 (sha256
8795 (base32
8796 "16bf890xbdz3m30rsv2qacklh2rdn1zrfspfnwzx9g7vwz8yw4r1"))))
8797 (build-system python-build-system)
8798 (native-inputs
8799 `(("python-pytest" ,python-pytest)))
8800 (arguments
8801 `(#:phases
8802 (modify-phases %standard-phases
8803 (replace 'check
8804 (lambda _ (zero? (system* "py.test")))))))
8805 (home-page "http://docopt.org")
8806 (synopsis "Command-line interface description language for Python")
8807 (description "This library allows the user to define a command-line
8808 interface from a program's help message rather than specifying it
8809 programatically with command-line parsers like @code{getopt} and
8810 @code{argparse}.")
8811 (license license:expat)))
8812
8813 (define-public python2-docopt
8814 (package-with-python2 python-docopt))
8815
8816 (define-public python-zope-event
8817 (package
8818 (name "python-zope-event")
8819 (version "4.1.0")
8820 (source
8821 (origin
8822 (method url-fetch)
8823 (uri (string-append "https://pypi.python.org/packages/source/z"
8824 "/zope.event/zope.event-" version ".tar.gz"))
8825 (sha256
8826 (base32
8827 "11p75zpfz3ffhz21nzx9wb23xs993ck5s6hkjcvhswwizni5jynw"))))
8828 (build-system python-build-system)
8829 (home-page "http://pypi.python.org/pypi/zope.event")
8830 (synopsis "Event publishing system for Python")
8831 (description "Zope.event provides an event publishing API, intended for
8832 use by applications which are unaware of any subscribers to their events. It
8833 is a simple event-dispatching system on which more sophisticated event
8834 dispatching systems can be built.")
8835 (license license:zpl2.1)))
8836
8837 (define-public python2-zope-event
8838 (package-with-python2 python-zope-event))
8839
8840 (define-public python-zope-interface
8841 (package
8842 (name "python-zope-interface")
8843 (version "4.1.3")
8844 (source
8845 (origin
8846 (method url-fetch)
8847 (uri (string-append "https://pypi.python.org/packages/source/z"
8848 "/zope.interface/zope.interface-" version ".tar.gz"))
8849 (sha256
8850 (base32
8851 "0ks8h73b2g4bkad821qbv0wzjppdrwys33i7ka45ik3wxjg1l8if"))))
8852 (build-system python-build-system)
8853 (native-inputs
8854 `(("python-zope-event" ,python-zope-event)))
8855 (home-page "https://github.com/zopefoundation/zope.interface")
8856 (synopsis "Python implementation of the \"design by contract\"
8857 methodology")
8858 (description "Zope.interface provides an implementation of \"object
8859 interfaces\" for Python. Interfaces are a mechanism for labeling objects as
8860 conforming to a given API or contract.")
8861 (license license:zpl2.1)))
8862
8863 (define-public python2-zope-interface
8864 (package-with-python2 python-zope-interface))
8865
8866 (define-public python-zope-exceptions
8867 (package
8868 (name "python-zope-exceptions")
8869 (version "4.0.8")
8870 (source
8871 (origin
8872 (method url-fetch)
8873 (uri (string-append "https://pypi.python.org/packages/source/z"
8874 "/zope.exceptions/zope.exceptions-"
8875 version ".tar.gz"))
8876 (sha256
8877 (base32
8878 "0zwxaaa66sqxg5k7zcrvs0fbg9ym1njnxnr28dfmchzhwjvwnfzl"))))
8879 (build-system python-build-system)
8880 (arguments
8881 '(#:tests? #f)) ; circular dependency with zope.testrunner
8882 (propagated-inputs
8883 `(("python-zope-interface" ,python-zope-interface)))
8884 (home-page "http://cheeseshop.python.org/pypi/zope.exceptions")
8885 (synopsis "Zope exceptions")
8886 (description "Zope.exceptions provides general-purpose exception types
8887 that have uses outside of the Zope framework.")
8888 (license license:zpl2.1)))
8889
8890 (define-public python2-zope-exceptions
8891 (package-with-python2 python-zope-exceptions))
8892
8893 (define-public python-zope-testing
8894 (package
8895 (name "python-zope-testing")
8896 (version "4.5.0")
8897 (source
8898 (origin
8899 (method url-fetch)
8900 (uri (string-append "https://pypi.python.org/packages/source/z"
8901 "/zope.testing/zope.testing-" version ".tar.gz"))
8902 (sha256
8903 (base32
8904 "1yvglxhzvhl45mndvn9gskx2ph30zz1bz7rrlyfs62fv2pvih90s"))
8905 (modules '((guix build utils)))
8906 (snippet
8907 '(begin
8908 ;; Remove pre-compiled .pyc files backup files from source.
8909 (for-each delete-file (find-files "." "(\\.pyc|~)$"))
8910 #t))))
8911 (build-system python-build-system)
8912 (native-inputs
8913 `(("python-zope-exceptions" ,python-zope-exceptions)))
8914 (propagated-inputs
8915 `(("python-zope-interface" ,python-zope-interface)))
8916 (home-page "http://pypi.python.org/pypi/zope.testing")
8917 (synopsis "Zope testing helpers")
8918 (description "Zope.testing provides a number of testing utilities for HTML
8919 forms, HTTP servers, regular expressions, and more.")
8920 (license license:zpl2.1)))
8921
8922 (define-public python2-zope-testing
8923 (package-with-python2 python-zope-testing))
8924
8925 (define-public python-zope-testrunner
8926 (package
8927 (name "python-zope-testrunner")
8928 (version "4.4.9")
8929 (source
8930 (origin
8931 (method url-fetch)
8932 (uri (string-append "https://pypi.python.org/packages/source/z"
8933 "/zope.testrunner/zope.testrunner-"
8934 version ".zip"))
8935 (sha256
8936 (base32
8937 "1r7iqknhh55y45f64mz5hghgvzx34h1i11k350s0avx6q8gznja1"))))
8938 (build-system python-build-system)
8939 (arguments
8940 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8941 (native-inputs
8942 `(("python-six" ,python-six)
8943 ;("python-zope-interface" ,python-zope-interface)
8944 ("python-zope-exceptions" ,python-zope-exceptions)
8945 ("python-zope-testing" ,python-zope-testing)
8946 ("unzip" ,unzip)))
8947 (propagated-inputs
8948 `(("python-zope-interface" ,python-zope-interface)))
8949 (home-page "http://pypi.python.org/pypi/zope.testrunner")
8950 (synopsis "Zope testrunner script")
8951 (description "Zope.testrunner provides a script for running Python
8952 tests.")
8953 (license license:zpl2.1)))
8954
8955 (define-public python2-zope-testrunner
8956 (let ((base (package-with-python2 python-zope-testrunner)))
8957 (package
8958 (inherit base)
8959 (native-inputs
8960 (append (package-native-inputs base)
8961 `(("python2-subunit" ,python2-subunit)
8962 ("python2-mimeparse" ,python2-mimeparse)))))))
8963
8964 (define-public python-zope-i18nmessageid
8965 (package
8966 (name "python-zope-i18nmessageid")
8967 (version "4.0.3")
8968 (source
8969 (origin
8970 (method url-fetch)
8971 (uri (string-append
8972 "https://pypi.python.org/packages/source/z"
8973 "/zope.i18nmessageid/zope.i18nmessageid-"
8974 version ".tar.gz"))
8975 (sha256
8976 (base32
8977 "1rslyph0klk58dmjjy4j0jxy21k03azksixc3x2xhqbkv97cmzml"))))
8978 (build-system python-build-system)
8979 (home-page "http://pypi.python.org/pypi/zope.i18nmessageid")
8980 (synopsis "Message identifiers for internationalization")
8981 (description "Zope.i18nmessageid provides facilities for declaring
8982 internationalized messages within program source text.")
8983 (license license:zpl2.1)))
8984
8985 (define-public python2-zope-i18nmessageid
8986 (package-with-python2 python-zope-i18nmessageid))
8987
8988 (define-public python-zope-schema
8989 (package
8990 (name "python-zope-schema")
8991 (version "4.4.2")
8992 (source
8993 (origin
8994 (method url-fetch)
8995 (uri (string-append "https://pypi.python.org/packages/source/z"
8996 "/zope.schema/zope.schema-" version ".tar.gz"))
8997 (sha256
8998 (base32
8999 "1p943jdxb587dh7php4vx04qvn7b2877hr4qs5zyckvp5afhhank"))))
9000 (build-system python-build-system)
9001 (arguments
9002 '(#:tests? #f)) ; FIXME: Tests can't find zope.event.
9003 (propagated-inputs
9004 `(("python-zope-event" ,python-zope-event)
9005 ("python-zope-exceptions", python-zope-exceptions)
9006 ("python-zope-interface" ,python-zope-interface)))
9007 (native-inputs
9008 `(("python-zope-testing" ,python-zope-testing)
9009 ("python-coverage" ,python-coverage)
9010 ("python-nose" ,python-nose)))
9011 (home-page "http://pypi.python.org/pypi/zope.schema")
9012 (synopsis "Zope data schemas")
9013 (description "Zope.scheme provides extensions to zope.interface for
9014 defining data schemas.")
9015 (license license:zpl2.1)))
9016
9017 (define-public python2-zope-schema
9018 (package-with-python2 python-zope-schema))
9019
9020 (define-public python-zope-configuration
9021 (package
9022 (name "python-zope-configuration")
9023 (version "4.0.3")
9024 (source (origin
9025 (method url-fetch)
9026 (uri (string-append "https://pypi.python.org/packages/source/z"
9027 "/zope.configuration/zope.configuration-"
9028 version ".tar.gz"))
9029 (sha256
9030 (base32
9031 "1x9dfqypgympnlm25p9m43xh4qv3p7d75vksv9pzqibrb4cggw5n"))))
9032 (build-system python-build-system)
9033 (arguments
9034 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
9035 (propagated-inputs
9036 `(("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
9037 ("python-zope-schema" ,python-zope-schema)))
9038 (home-page "http://pypi.python.org/pypi/zope.configuration")
9039 (synopsis "Zope Configuration Markup Language")
9040 (description "Zope.configuration implements ZCML, the Zope Configuration
9041 Markup Language.")
9042 (license license:zpl2.1)))
9043
9044 (define-public python2-zope-configuration
9045 (package-with-python2 python-zope-configuration))
9046
9047 (define-public python-zope-proxy
9048 (package
9049 (name "python-zope-proxy")
9050 (version "4.1.6")
9051 (source
9052 (origin
9053 (method url-fetch)
9054 (uri (string-append "https://pypi.python.org/packages/source/z"
9055 "/zope.proxy/zope.proxy-" version ".tar.gz"))
9056 (sha256
9057 (base32
9058 "0pqwwmvm1prhwv1ziv9lp8iirz7xkwb6n2kyj36p2h0ppyyhjnm4"))))
9059 (build-system python-build-system)
9060 (arguments
9061 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
9062 (propagated-inputs
9063 `(("python-zope-interface" ,python-zope-interface)))
9064 (home-page "http://pypi.python.org/pypi/zope.proxy")
9065 (synopsis "Generic, transparent proxies")
9066 (description "Zope.proxy provides generic, transparent proxies for Python.
9067 Proxies are special objects which serve as mostly-transparent wrappers around
9068 another object, intervening in the apparent behavior of the wrapped object
9069 only when necessary to apply the policy (e.g., access checking, location
9070 brokering, etc.) for which the proxy is responsible.")
9071 (license license:zpl2.1)))
9072
9073 (define-public python2-zope-proxy
9074 (package-with-python2 python-zope-proxy))
9075
9076 (define-public python-zope-location
9077 (package
9078 (name "python-zope-location")
9079 (version "4.0.3")
9080 (source
9081 (origin
9082 (method url-fetch)
9083 (uri (string-append "https://pypi.python.org/packages/source/z"
9084 "/zope.location/zope.location-" version ".tar.gz"))
9085 (sha256
9086 (base32
9087 "1nj9da4ksiyv3h8n2vpzwd0pb03mdsh7zy87hfpx72b6p2zcwg74"))))
9088 (build-system python-build-system)
9089 (arguments
9090 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
9091 (propagated-inputs
9092 `(("python-zope-proxy" ,python-zope-proxy)
9093 ("python-zope-schema" ,python-zope-schema)))
9094 (home-page "http://pypi.python.org/pypi/zope.location/")
9095 (synopsis "Zope location library")
9096 (description "Zope.location implements the concept of \"locations\" in
9097 Zope3, which are are special objects that have a structural location.")
9098 (license license:zpl2.1)))
9099
9100 (define-public python2-zope-location
9101 (package-with-python2 python-zope-location))
9102
9103 (define-public python-zope-security
9104 (package
9105 (name "python-zope-security")
9106 (version "4.0.3")
9107 (source
9108 (origin
9109 (method url-fetch)
9110 (uri (string-append "https://pypi.python.org/packages/source/z"
9111 "/zope.security/zope.security-" version ".tar.gz"))
9112 (sha256
9113 (base32
9114 "14zmf684amc0x32kq05yxnhfqd1cmyhafkw05gn81rn90zjv6ssy"))))
9115 (build-system python-build-system)
9116 (arguments
9117 '(#:tests? #f)) ; FIXME: Tests can't find zope.testrunner.
9118 (propagated-inputs
9119 `(("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
9120 ("python-zope-proxy" ,python-zope-proxy)
9121 ("python-zope-schema" ,python-zope-schema)))
9122 (native-inputs
9123 `(("python-six" ,python-six)
9124 ("python-zope-component" ,python-zope-component)
9125 ("python-zope-configuration" ,python-zope-configuration)
9126 ("python-zope-location" ,python-zope-location)
9127 ("python-zope-testrunner" ,python-zope-testrunner)
9128 ("python-zope-testing" ,python-zope-testing)))
9129 (home-page "http://pypi.python.org/pypi/zope.security")
9130 (synopsis "Zope security framework")
9131 (description "Zope.security provides a generic mechanism to implement
9132 security policies on Python objects.")
9133 (license license:zpl2.1)))
9134
9135 (define-public python2-zope-security
9136 (let ((zope-security (package-with-python2 python-zope-security)))
9137 (package (inherit zope-security)
9138 (propagated-inputs
9139 `(("python2-zope-testrunner" ,python2-zope-testrunner)
9140 ,@(alist-delete
9141 "python-zope-testrunner"
9142 (package-propagated-inputs zope-security)))))))
9143
9144 (define-public python-zope-component
9145 (package
9146 (name "python-zope-component")
9147 (version "4.3.0")
9148 (source
9149 (origin
9150 (method url-fetch)
9151 (uri (pypi-uri "zope.component" version))
9152 (sha256
9153 (base32
9154 "1hlvzwj1kcfz1qms1dzhwsshpsf38z9clmyksb1gh41n8k3kchdv"))))
9155 (build-system python-build-system)
9156 (arguments
9157 ;; Skip tests due to circular dependency with python-zope-security.
9158 '(#:tests? #f))
9159 (native-inputs
9160 `(("python-zope-testing" ,python-zope-testing)))
9161 (propagated-inputs
9162 `(("python-zope-event" ,python-zope-event)
9163 ("python-zope-interface" ,python-zope-interface)
9164 ("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
9165 ("python-zope-configuration" ,python-zope-configuration)))
9166 (home-page "https://github.com/zopefoundation/zope.component")
9167 (synopsis "Zope Component Architecture")
9168 (description "Zope.component represents the core of the Zope Component
9169 Architecture. Together with the zope.interface package, it provides
9170 facilities for defining, registering and looking up components.")
9171 (license license:zpl2.1)))
9172
9173 (define-public python2-zope-component
9174 (package-with-python2 python-zope-component))
9175
9176 (define-public python-pythondialog
9177 (package
9178 (name "python-pythondialog")
9179 (version "3.4.0")
9180 (source
9181 (origin
9182 (method url-fetch)
9183 (uri (pypi-uri "pythondialog" version))
9184 (sha256
9185 (base32
9186 "1728ghsran47jczn9bhlnkvk5bvqmmbihabgif5h705b84r1272c"))))
9187 (build-system python-build-system)
9188 (arguments
9189 `(#:phases
9190 (modify-phases %standard-phases
9191 (add-after 'unpack 'patch-path
9192 (lambda* (#:key inputs #:allow-other-keys)
9193 (let* ((dialog (assoc-ref inputs "dialog")))
9194 ;; Since this library really wants to grovel the search path, we
9195 ;; must hardcode dialog's store path into it.
9196 (substitute* "dialog.py"
9197 (("os.getenv\\(\"PATH\", \":/bin:/usr/bin\"\\)")
9198 (string-append "os.getenv(\"PATH\") + \":" dialog "/bin\"")))
9199 #t))))
9200 #:tests? #f)) ; no test suite
9201 (propagated-inputs
9202 `(("dialog" ,dialog)))
9203 (home-page "http://pythondialog.sourceforge.net/")
9204 (synopsis "Python interface to the UNIX dialog utility")
9205 (description "A Python wrapper for the dialog utility. Its purpose is to
9206 provide an easy to use, pythonic and comprehensive Python interface to dialog.
9207 This allows one to make simple text-mode user interfaces on Unix-like systems")
9208 (license license:lgpl2.1)
9209 (properties `((python2-variant . ,(delay python2-pythondialog))))))
9210
9211 (define-public python2-pythondialog
9212 (let ((base (package-with-python2 (strip-python2-variant python-pythondialog))))
9213 (package
9214 (inherit base)
9215 (version (package-version python-pythondialog))
9216 (source (origin
9217 (method url-fetch)
9218 (uri (pypi-uri "python2-pythondialog" version))
9219 (sha256
9220 (base32
9221 "0d8k7lxk50imdyx85lv8j98i4c93a71iwpapnl1506rpkbm9qvd9")))))))
9222
9223 (define-public python-pyrfc3339
9224 (package
9225 (name "python-pyrfc3339")
9226 (version "1.0")
9227 (source
9228 (origin
9229 (method url-fetch)
9230 (uri (pypi-uri "pyRFC3339" version))
9231 (sha256
9232 (base32
9233 "0dgm4l9y8jiax5cp6yxjd2i27cq8h33sh81n1wfbmnmqb32cdywd"))))
9234 (build-system python-build-system)
9235 (propagated-inputs
9236 `(("python-pytz" ,python-pytz)))
9237 (native-inputs
9238 `(("python-nose" ,python-nose)))
9239 (home-page "https://github.com/kurtraschke/pyRFC3339")
9240 (synopsis "Python timestamp library")
9241 (description "Python library for generating and parsing RFC 3339-compliant
9242 timestamps.")
9243 (license license:expat)))
9244
9245 (define-public python2-pyrfc3339
9246 (package-with-python2 python-pyrfc3339))
9247
9248 (define-public python-werkzeug
9249 (package
9250 (name "python-werkzeug")
9251 (version "0.11.15")
9252 (source
9253 (origin
9254 (method url-fetch)
9255 (uri (pypi-uri "Werkzeug" version))
9256 (sha256
9257 (base32
9258 "1h5wycw8yj7q0grqsjnsqflmrlsdagvl2j4dsgdncci6mjc7fpa5"))))
9259 (build-system python-build-system)
9260 (native-inputs
9261 `(("python-pytest" ,python-pytest)))
9262 (home-page "http://werkzeug.pocoo.org/")
9263 (synopsis "Utilities for WSGI applications")
9264 (description "One of the most advanced WSGI utility modules. It includes a
9265 powerful debugger, full-featured request and response objects, HTTP utilities to
9266 handle entity tags, cache control headers, HTTP dates, cookie handling, file
9267 uploads, a powerful URL routing system and a bunch of community-contributed
9268 addon modules.")
9269 (license license:x11)))
9270
9271 (define-public python2-werkzeug
9272 (package-with-python2 python-werkzeug))
9273
9274 (define-public python-configobj
9275 (package
9276 (name "python-configobj")
9277 (version "5.0.6")
9278 (source (origin
9279 (method url-fetch)
9280 (uri (string-append
9281 "https://pypi.python.org/packages/source/c/configobj/"
9282 "configobj-" version ".tar.gz"))
9283 (sha256
9284 (base32
9285 "00h9rcmws03xvdlfni11yb60bz3kxfvsj6dg6nrpzj71f03nbxd2"))
9286 ;; Patch setup.py so it looks for python-setuptools, which is
9287 ;; required to parse the keyword 'install_requires' in setup.py.
9288 (patches (search-patches "python-configobj-setuptools.patch"))))
9289 (build-system python-build-system)
9290 (propagated-inputs
9291 `(("python-six" ,python-six)))
9292 (synopsis "Config file reading, writing and validation")
9293 (description "ConfigObj is a simple but powerful config file reader and
9294 writer: an ini file round tripper. Its main feature is that it is very easy to
9295 use, with a straightforward programmer’s interface and a simple syntax for
9296 config files.")
9297 (home-page "https://github.com/DiffSK/configobj")
9298 (license license:bsd-3)))
9299
9300 (define-public python2-configobj
9301 (package-with-python2 python-configobj))
9302
9303 (define-public python-configargparse
9304 (package
9305 (name "python-configargparse")
9306 (version "0.12.0")
9307 (source (origin
9308 (method url-fetch)
9309 (uri (string-append
9310 "https://pypi.io/packages/source/C/ConfigArgParse/"
9311 "ConfigArgParse-" version ".tar.gz"))
9312 (sha256
9313 (base32
9314 "0fgkiqh6r3rbkdq3k8c48m85g52k96686rw3a6jg4lcncrkpvk98"))))
9315 (build-system python-build-system)
9316 (native-inputs
9317 `(("python-pyyaml" ,python-pyyaml)))
9318 (arguments
9319 `(#:phases
9320 (modify-phases %standard-phases
9321 (replace 'check
9322 (lambda _
9323 ;; Bypass setuptools-shim because one test relies on "setup.py"
9324 ;; being the first argument passed to the python call.
9325 ;;
9326 ;; NOTE: Many tests do not run because they rely on Python's
9327 ;; built-in test.test_argparse, but we remove the unit tests from
9328 ;; our Python installation.
9329 (zero? (system* "python" "setup.py" "test")))))))
9330 (synopsis "Replacement for argparse")
9331 (description "A drop-in replacement for argparse that allows options to also
9332 be set via config files and/or environment variables.")
9333 (home-page "https://github.com/bw2/ConfigArgParse")
9334 (license license:expat)))
9335
9336 (define-public python2-configargparse
9337 (package-with-python2 python-configargparse))
9338
9339 (define-public python-ndg-httpsclient
9340 (package
9341 (name "python-ndg-httpsclient")
9342 (version "0.4.2")
9343 (source (origin
9344 (method url-fetch)
9345 (uri (pypi-uri "ndg_httpsclient" version))
9346 (sha256
9347 (base32
9348 "1b5qirv46v4dpnmfqviwq42mdwfcby4dxmz0i41wad2337pqf2aq"))))
9349 (build-system python-build-system)
9350 (arguments
9351 '(;; The tests appear to require networking.
9352 #:tests? #f))
9353 (propagated-inputs
9354 `(("python-pyopenssl" ,python-pyopenssl)))
9355 (synopsis "HTTPS support for Python's httplib and urllib2")
9356 (description "This is a HTTPS client implementation for httplib and urllib2
9357 based on PyOpenSSL. PyOpenSSL provides a more fully featured SSL implementation
9358 over the default provided with Python and importantly enables full verification
9359 of the SSL peer.")
9360 (home-page "https://github.com/cedadev/ndg_httpsclient/")
9361 (license license:bsd-3)))
9362
9363 ;; python2-openssl requires special care, so package-with-python2 is
9364 ;; insufficient.
9365 (define-public python2-ndg-httpsclient
9366 (package (inherit python-ndg-httpsclient)
9367 (name "python2-ndg-httpsclient")
9368 (arguments `(#:python ,python-2))
9369 (propagated-inputs
9370 `(("python2-pyopenssl" ,python2-pyopenssl)))))
9371
9372 (define-public python-contextlib2
9373 (package
9374 (name "python-contextlib2")
9375 (version "0.4.0")
9376 (source
9377 (origin
9378 (method url-fetch)
9379 (uri (pypi-uri "contextlib2" version))
9380 (sha256
9381 (base32
9382 "0cmp131dlh0d0zvw0aza1zd13glvngzk8lb4avks0hm7yxwdr9am"))))
9383 (build-system python-build-system)
9384 (arguments
9385 `(#:phases
9386 (modify-phases %standard-phases
9387 (replace 'check
9388 (lambda _ (zero?
9389 (system*
9390 "python" "test_contextlib2.py" "-v")))))))
9391 (home-page "http://contextlib2.readthedocs.org/")
9392 (synopsis "Tools for decorators and context managers")
9393 (description "This module is primarily a backport of the Python
9394 3.2 contextlib to earlier Python versions. Like contextlib, it
9395 provides utilities for common tasks involving decorators and context
9396 managers. It also contains additional features that are not part of
9397 the standard library.")
9398 (license license:psfl)))
9399
9400 (define-public python2-contextlib2
9401 (package-with-python2 python-contextlib2))
9402
9403 (define-public python-texttable
9404 (package
9405 (name "python-texttable")
9406 (version "0.8.7")
9407 (source
9408 (origin
9409 (method url-fetch)
9410 (uri (pypi-uri "texttable" version))
9411 (sha256
9412 (base32
9413 "1liiiydgkg37i46a418aw19fyf6z3ds51wdwwpyjbs12x0phhf4a"))))
9414 (build-system python-build-system)
9415 (arguments '(#:tests? #f)) ; no tests
9416 (home-page "https://github.com/foutaise/texttable/")
9417 (synopsis "Python module for creating simple ASCII tables")
9418 (description "Texttable is a Python module for creating simple ASCII
9419 tables.")
9420 (license license:lgpl2.1+)))
9421
9422 (define-public python2-texttable
9423 (package-with-python2 python-texttable))
9424
9425 (define-public python-websocket-client
9426 (package
9427 (name "python-websocket-client")
9428 (version "0.37.0")
9429 (source
9430 (origin
9431 (method url-fetch)
9432 (uri (pypi-uri "websocket_client" version))
9433 (sha256
9434 (base32
9435 "0h9glp1jll3z76ly3kg08aqgxqk0a68p4zi9yn50353bh5nj92v7"))))
9436 (build-system python-build-system)
9437 (propagated-inputs
9438 `(("python-six" ,python-six)))
9439 (home-page "https://github.com/liris/websocket-client")
9440 (synopsis "WebSocket client for Python")
9441 (description "The Websocket-client module provides the low level APIs for
9442 WebSocket usage in Python programs.")
9443 (license license:lgpl2.1+)))
9444
9445 (define-public python2-websocket-client
9446 (package-with-python2 python-websocket-client))
9447
9448 (define-public python-atomicwrites
9449 (package
9450 (name "python-atomicwrites")
9451 (version "1.1.5")
9452 (source (origin
9453 (method url-fetch)
9454 (uri (pypi-uri "atomicwrites" version))
9455 (sha256
9456 (base32
9457 "11bm90fwm2avvf4f3ib8g925w7jr4m11vcsinn1bi6ns4bm32214"))))
9458 (build-system python-build-system)
9459 (synopsis "Atomic file writes in Python")
9460 (description "Library for atomic file writes using platform dependent tools
9461 for atomic file system operations.")
9462 (home-page "https://github.com/untitaker/python-atomicwrites")
9463 (license license:expat)))
9464
9465 (define-public python2-atomicwrites
9466 (package-with-python2 python-atomicwrites))
9467
9468 (define-public python-requests-toolbelt
9469 (package
9470 (name "python-requests-toolbelt")
9471 (version "0.8.0")
9472 (source (origin
9473 (method url-fetch)
9474 (uri (pypi-uri "requests-toolbelt" version))
9475 (sha256
9476 (base32
9477 "1dc7l42i4080r8i4m9fj51jx367lqkai170vrv7wd93gdj9k39gn"))))
9478 (build-system python-build-system)
9479 (native-inputs
9480 `(("python-betamax" ,python-betamax)
9481 ("python-mock" ,python-mock)
9482 ("python-pytest" ,python-pytest)))
9483 (propagated-inputs
9484 `(("python-requests" ,python-requests)))
9485 (synopsis "Extensions to python-requests")
9486 (description "This is a toolbelt of useful classes and functions to be used
9487 with python-requests.")
9488 (home-page "https://github.com/sigmavirus24/requests-toolbelt")
9489 (license license:asl2.0)))
9490
9491 (define-public python2-requests-toolbelt
9492 (package-with-python2 python-requests-toolbelt))
9493
9494 (define-public python-click-threading
9495 (package
9496 (name "python-click-threading")
9497 (version "0.4.3")
9498 (source (origin
9499 (method url-fetch)
9500 (uri (pypi-uri "click-threading" version))
9501 (sha256
9502 (base32
9503 "0xs4bg2ws0zgyiplk312l049hi23c2zqf1g771rjhh5vr2msk4cg"))))
9504 (build-system python-build-system)
9505 (propagated-inputs
9506 `(("python-click" ,python-click)))
9507 (synopsis "Utilities for multithreading in Click")
9508 (description "This package provides utilities for multithreading in Click
9509 applications.")
9510 (home-page "https://github.com/click-contrib/click-threading")
9511 (license license:expat)))
9512
9513 (define-public python-click-log
9514 (package
9515 (name "python-click-log")
9516 (version "0.2.0")
9517 (source (origin
9518 (method url-fetch)
9519 (uri (pypi-uri "click-log" version))
9520 (sha256
9521 (base32
9522 "1bjrfxji1yv4fj0g78ri2yfgn2wbivn8g69fxfinxvxpmighhshp"))))
9523 (build-system python-build-system)
9524 (propagated-inputs
9525 `(("python-click" ,python-click)))
9526 (synopsis "Logging for click applications")
9527 (description "This package provides a Python library for logging Click
9528 applications.")
9529 (home-page "https://github.com/click-contrib/click-log")
9530 (license license:expat)))
9531
9532 (define-public python-apipkg
9533 (package
9534 (name "python-apipkg")
9535 (version "1.4")
9536 (source (origin
9537 (method url-fetch)
9538 (uri (pypi-uri "apipkg" version))
9539 (sha256
9540 (base32
9541 "1iks5701qnp3dlr3q1d9qm68y2plp2m029irhpz92a44psfkjf1f"))))
9542 (build-system python-build-system)
9543 (native-inputs
9544 `(("python-pytest" ,python-pytest)))
9545 (synopsis "Namespace control and lazy-import mechanism")
9546 (description "With apipkg you can control the exported namespace of a Python
9547 package and greatly reduce the number of imports for your users. It is a small
9548 pure Python module that works on virtually all Python versions.")
9549 (home-page "https://bitbucket.org/hpk42/apipkg")
9550 (license license:expat)))
9551
9552 (define-public python2-apipkg
9553 (package-with-python2 python-apipkg))
9554
9555 (define-public python-execnet
9556 (package
9557 (name "python-execnet")
9558 (version "1.4.1")
9559 (source (origin
9560 (method url-fetch)
9561 (uri (pypi-uri "execnet" version))
9562 (sha256
9563 (base32
9564 "1rpk1vyclhg911p3hql0m0nrpq7q7mysxnaaw6vs29cpa6kx8vgn"))))
9565 (build-system python-build-system)
9566 (arguments
9567 `(;; 2 failed, 275 passed, 670 skipped, 4 xfailed
9568 ;; The two test failures are caused by the lack of an `ssh` executable.
9569 ;; The test suite can be run with pytest after the 'install' phase.
9570 #:tests? #f))
9571 (native-inputs
9572 `(("python-pytest" ,python-pytest)
9573 ("python-setuptools-scm" ,python-setuptools-scm)))
9574 (propagated-inputs
9575 `(("python-apipkg" ,python-apipkg)))
9576 (synopsis "Rapid multi-Python deployment")
9577 (description "Execnet provides a share-nothing model with
9578 channel-send/receive communication for distributing execution across many
9579 Python interpreters across version, platform and network barriers. It has a
9580 minimal and fast API targeting the following uses:
9581 @enumerate
9582 @item distribute tasks to (many) local or remote CPUs
9583 @item write and deploy hybrid multi-process applications
9584 @item write scripts to administer multiple environments
9585 @end enumerate")
9586 (home-page "http://codespeak.net/execnet/")
9587 (license license:expat)))
9588
9589 (define-public python2-execnet
9590 (package-with-python2 python-execnet))
9591
9592 (define-public python-trollius-redis
9593 (package
9594 (name "python-trollius-redis")
9595 (version "0.1.4")
9596 (source
9597 (origin
9598 (method url-fetch)
9599 (uri (pypi-uri "trollius_redis" version))
9600 (sha256
9601 (base32
9602 "0k3vypszmgmaipgw9xscvgm79h2zd6p6ci8gdp5sxl6g5kbqr9fy"))))
9603 (build-system python-build-system)
9604 ;; TODO: Tests require packaging 'hiredis'.
9605 (arguments '(#:tests? #f))
9606 (home-page "https://github.com/benjolitz/trollius-redis")
9607 (synopsis "Port of asyncio-redis to trollius")
9608 (description "@code{trollius-redis} is a Redis client for Python
9609 trollius. It is an asynchronious IO (PEP 3156) implementation of the
9610 Redis protocol.")
9611 (license license:bsd-2)))
9612
9613 (define-public python2-trollius-redis
9614 (package-with-python2 python-trollius-redis))
9615
9616 ;;; The software provided by this package was integrated into pytest 2.8.
9617 (define-public python-pytest-cache
9618 (package
9619 (name "python-pytest-cache")
9620 (version "1.0")
9621 (source (origin
9622 (method url-fetch)
9623 (uri (pypi-uri "pytest-cache" version))
9624 (sha256
9625 (base32
9626 "1a873fihw4rhshc722j4h6j7g3nj7xpgsna9hhg3zn6ksknnhx5y"))))
9627 (build-system python-build-system)
9628 (propagated-inputs
9629 `(("python-apipkg" ,python-apipkg)
9630 ("python-execnet" ,python-execnet)
9631 ("python-py" ,python-py)
9632 ("python-pytest" ,python-pytest)))
9633 (synopsis "Py.test plugin with mechanisms for caching across test runs")
9634 (description "The pytest-cache plugin provides tools to rerun failures from
9635 the last py.test invocation.")
9636 (home-page "https://bitbucket.org/hpk42/pytest-cache/")
9637 (license license:expat)))
9638
9639 (define-public python2-pytest-cache
9640 (package-with-python2 python-pytest-cache))
9641
9642 (define-public python-pytest-localserver
9643 (package
9644 (name "python-pytest-localserver")
9645 (version "0.3.5")
9646 (source (origin
9647 (method url-fetch)
9648 (uri (pypi-uri "pytest-localserver" version))
9649 (sha256
9650 (base32
9651 "0dvqspjr6va55zwmnnc2mmpqc7mm65kxig9ya44x1z8aadzxpa4p"))))
9652 (build-system python-build-system)
9653 (arguments
9654 `(#:phases (modify-phases %standard-phases
9655 (replace 'check
9656 (lambda _
9657 (zero? (system* "py.test" "--genscript=runtests.py"))
9658 (zero? (system* "py.test")))))))
9659 (native-inputs
9660 `(("python-pytest" ,python-pytest)
9661 ("python-requests" ,python-requests)
9662 ("python-six" ,python-six)))
9663 (propagated-inputs
9664 `(("python-werkzeug" ,python-werkzeug)))
9665 (synopsis "Py.test plugin to test server connections locally")
9666 (description "Pytest-localserver is a plugin for the pytest testing
9667 framework which enables you to test server connections locally.")
9668 (home-page "https://pypi.python.org/pypi/pytest-localserver")
9669 (license license:expat)))
9670
9671 (define-public python-wsgi-intercept
9672 (package
9673 (name "python-wsgi-intercept")
9674 (version "1.2.2")
9675 (source (origin
9676 (method url-fetch)
9677 (uri (string-append
9678 "https://pypi.python.org/packages/"
9679 "38/76/ebcbc24d0cb77db34520a3ca6ed1bd43ace17d182bbd8dd7d976f1c176fb/"
9680 "wsgi_intercept-" version ".tar.gz"))
9681 (sha256
9682 (base32
9683 "0kjj2v2dvmnpdd5h5gk9rzz0f54rhjb0yiz3zg65bmp65slfw65d"))))
9684 (build-system python-build-system)
9685 (propagated-inputs
9686 `(("python-six" ,python-six)))
9687 (native-inputs
9688 `(("python-pytest" ,python-pytest)
9689 ("python-httplib2" ,python-httplib2)
9690 ("python-requests" ,python-requests)
9691 ("python-urllib3" ,python-urllib3)))
9692 (synopsis "Puts a WSGI application in place of a real URI for testing")
9693 (description "Wsgi_intercept installs a WSGI application in place of a real
9694 URI for testing. Testing a WSGI application normally involves starting a
9695 server at a local host and port, then pointing your test code to that address.
9696 Instead, this library lets you intercept calls to any specific host/port
9697 combination and redirect them into a WSGI application importable by your test
9698 program. Thus, you can avoid spawning multiple processes or threads to test
9699 your Web app.")
9700 (home-page "https://github.com/cdent/wsgi-intercept")
9701 (license license:expat)))
9702
9703 (define-public python-pytest-xprocess
9704 (package
9705 (name "python-pytest-xprocess")
9706 (version "0.9.1")
9707 (source (origin
9708 (method url-fetch)
9709 (uri (pypi-uri "pytest-xprocess" version))
9710 (sha256
9711 (base32
9712 "17zlql1xqw3ywcgwwbqmw633aly99lab12hm02asr8awvg5603pp"))))
9713 (build-system python-build-system)
9714 (propagated-inputs
9715 `(("python-pytest" ,python-pytest)
9716 ("python-pytest-cache" ,python-pytest-cache)
9717 ("python-psutil" ,python-psutil)))
9718 (synopsis "Pytest plugin to manage external processes across test runs")
9719 (description "Pytest-xprocess is an experimental py.test plugin for managing
9720 processes across test runs.")
9721 (home-page "https://bitbucket.org/pytest-dev/pytest-xprocess")
9722 (license license:expat)))
9723
9724 (define-public python-icalendar
9725 (package
9726 (name "python-icalendar")
9727 (version "3.11.7")
9728 (source (origin
9729 (method url-fetch)
9730 (uri (pypi-uri "icalendar" version))
9731 (sha256
9732 (base32
9733 "0ahf1i98wjizhld2qd7v2vmvzsmdw08mmins82bf3fpbnp2sxbgc"))))
9734 (build-system python-build-system)
9735 (propagated-inputs
9736 `(("python-dateutil" ,python-dateutil)
9737 ("python-pytz" ,python-pytz)))
9738 (synopsis "Python library for parsing iCalendar files")
9739 (description "The icalendar package is a parser/generator of iCalendar
9740 files for use with Python.")
9741 (home-page "https://github.com/collective/icalendar")
9742 (license license:bsd-2)))
9743
9744 (define-public python-sphinxcontrib-newsfeed
9745 (package
9746 (name "python-sphinxcontrib-newsfeed")
9747 (version "0.1.4")
9748 (source (origin
9749 (method url-fetch)
9750 (uri (pypi-uri "sphinxcontrib-newsfeed" version))
9751 (sha256
9752 (base32
9753 "1d7gam3mn8v4in4p16yn3v10vps7nnaz6ilw99j4klij39dqd37p"))))
9754 (arguments '(#:tests? #f)) ; No tests.
9755 (build-system python-build-system)
9756 (propagated-inputs
9757 `(("python-sphinx" ,python-sphinx)))
9758 (synopsis "News Feed extension for Sphinx")
9759 (description "Sphinxcontrib-newsfeed is an extension for adding a simple
9760 Blog, News or Announcements section to a Sphinx website.")
9761 (home-page "https://bitbucket.org/prometheus/sphinxcontrib-newsfeed")
9762 (license license:bsd-2)))
9763
9764 (define-public python-args
9765 (package
9766 (name "python-args")
9767 (version "0.1.0")
9768 (source (origin
9769 (method url-fetch)
9770 (uri (pypi-uri "args" version))
9771 (sha256
9772 (base32
9773 "057qzi46h5dmxdqknsbrssn78lmqjlnm624iqdhrnpk26zcbi1d7"))))
9774 (build-system python-build-system)
9775 (home-page "https://github.com/kennethreitz/args")
9776 (synopsis "Command-line argument parser")
9777 (description
9778 "This library provides a Python module to parse command-line arguments.")
9779 (license license:bsd-3)))
9780
9781 (define-public python2-args
9782 (package-with-python2 python-args))
9783
9784 (define-public python-clint
9785 (package
9786 (name "python-clint")
9787 (version "0.5.1")
9788 (source (origin
9789 (method url-fetch)
9790 (uri (pypi-uri "clint" version))
9791 (sha256
9792 (base32
9793 "1an5lkkqk1zha47198p42ji3m94xmzx1a03dn7866m87n4r4q8h5"))))
9794 (build-system python-build-system)
9795 (arguments
9796 '(#:phases
9797 (modify-phases %standard-phases
9798 (replace 'check
9799 (lambda _
9800 (zero? (system* "py.test" "-v")))))))
9801 (native-inputs
9802 `(("python-pytest" ,python-pytest)))
9803 (propagated-inputs
9804 `(("python-args" ,python-args)))
9805 (home-page "https://github.com/kennethreitz/clint")
9806 (synopsis "Command-line interface tools")
9807 (description
9808 "Clint is a Python module filled with a set of tools for developing
9809 command-line applications, including tools for colored and indented
9810 output, progress bar display, and pipes.")
9811 (license license:isc)))
9812
9813 (define-public python2-clint
9814 (package-with-python2 python-clint))
9815
9816 (define-public python-astor
9817 (package
9818 (name "python-astor")
9819 (version "0.5")
9820 (source (origin
9821 (method url-fetch)
9822 (uri (pypi-uri "astor" version))
9823 (sha256
9824 (base32
9825 "1fdafq5hkis1fxqlmhw0sn44zp2ar46nxhbc22cvwg7hsd8z5gsa"))))
9826 (build-system python-build-system)
9827 (home-page "https://github.com/berkerpeksag/astor")
9828 (synopsis "Read and write Python ASTs")
9829 (description
9830 "Astor is designed to allow easy manipulation of Python source via the
9831 Abstract Syntax Tree.")
9832 (license license:bsd-3)))
9833
9834 (define-public python2-astor
9835 (package-with-python2 python-astor))
9836
9837 (define-public python-rply
9838 (package
9839 (name "python-rply")
9840 (version "0.7.4")
9841 (source (origin
9842 (method url-fetch)
9843 (uri (pypi-uri "rply" version))
9844 (sha256
9845 (base32
9846 "12rp1d9ba7nvd5rhaxi6xzx1rm67r1k1ylsrkzhpwnphqpb06cvj"))))
9847 (build-system python-build-system)
9848 (propagated-inputs
9849 `(("python-appdirs" ,python-appdirs)))
9850 (home-page "https://github.com/alex/rply")
9851 (synopsis "Parser generator for Python")
9852 (description
9853 "This package provides a pure Python based parser generator, that also
9854 works with RPython. It is a more-or-less direct port of David Bazzley's PLY,
9855 with a new public API, and RPython support.")
9856 (license license:bsd-3)))
9857
9858 (define-public python2-rply
9859 (package-with-python2 python-rply))
9860
9861 (define-public python-hy
9862 (package
9863 (name "python-hy")
9864 (version "0.13.0")
9865 (source (origin
9866 (method url-fetch)
9867 (uri (pypi-uri "hy" version))
9868 (sha256
9869 (base32
9870 "19sfymaksx9jhksfnb15ahid46mzrhdfzz6yy2craz2qnzvpmky8"))))
9871 (build-system python-build-system)
9872 (arguments
9873 '(#:phases
9874 (modify-phases %standard-phases
9875 (replace 'check
9876 (lambda _
9877 ;; Tests require write access to HOME.
9878 (setenv "HOME" "/tmp")
9879 (zero? (system* "nosetests")))))))
9880 (native-inputs
9881 `(("python-coverage" ,python-coverage)
9882 ("python-nose" ,python-nose)))
9883 (propagated-inputs
9884 `(("python-astor" ,python-astor)
9885 ("python-clint" ,python-clint)
9886 ("python-rply" ,python-rply)))
9887 (home-page "http://hylang.org/")
9888 (synopsis "Lisp frontend to Python")
9889 (description
9890 "Hy is a dialect of Lisp that's embedded in Python. Since Hy transforms
9891 its Lisp code into the Python Abstract Syntax Tree, you have the whole world of
9892 Python at your fingertips, in Lisp form.")
9893 (license license:expat)))
9894
9895 (define-public python2-hy
9896 (package-with-python2 python-hy))
9897
9898 (define-public python-rauth
9899 (package
9900 (name "python-rauth")
9901 (version "0.7.3")
9902 (source
9903 (origin
9904 (method url-fetch)
9905 (uri (pypi-uri "rauth" version))
9906 (sha256
9907 (base32
9908 "02kv8w8l98ky223avyq7vw7x1f2ya9chrm59r77ylq45qb0xnk2j"))))
9909 (build-system python-build-system)
9910 (arguments
9911 `(#:test-target "check"))
9912 (propagated-inputs
9913 `(("python-requests" ,python-requests)))
9914 (home-page "https://github.com/litl/rauth")
9915 (synopsis "Python library for OAuth 1.0/a, 2.0, and Ofly")
9916 (description
9917 "Rauth is a Python library for OAuth 1.0/a, 2.0, and Ofly. It also
9918 provides service wrappers for convenient connection initialization and
9919 authenticated session objects providing things like keep-alive.")
9920 (license license:expat)
9921 (properties `((python2-variant . ,(delay python2-rauth))))))
9922
9923 (define-public python2-rauth
9924 (let ((base (package-with-python2 (strip-python2-variant python-rauth))))
9925 (package
9926 (inherit base)
9927 (native-inputs `(("python2-unittest2" ,python2-unittest2)
9928 ,@(package-native-inputs base))))))
9929
9930 (define-public python2-functools32
9931 (package
9932 (name "python2-functools32")
9933 (version "3.2.3-2")
9934 (source
9935 (origin
9936 (method url-fetch)
9937 (uri (pypi-uri "functools32" version))
9938 (sha256
9939 (base32
9940 "0v8ya0b58x47wp216n1zamimv4iw57cxz3xxhzix52jkw3xks9gn"))))
9941 (build-system python-build-system)
9942 (arguments
9943 `(#:python ,python-2
9944 #:tests? #f)) ; no test target
9945 (home-page "https://github.com/MiCHiLU/python-functools32")
9946 (synopsis
9947 "Backport of the functools module from Python 3.2.3")
9948 (description
9949 "This package is a backport of the @code{functools} module from Python
9950 3.2.3 for use with older versions of Python and PyPy.")
9951 (license license:expat)))
9952
9953 (define-public python2-subprocess32
9954 (package
9955 (name "python2-subprocess32")
9956 (version "3.2.7")
9957 (source (origin
9958 (method url-fetch)
9959 (uri (pypi-uri "subprocess32" version))
9960 (sha256
9961 (base32
9962 "14350dhhlhyz5gqzi3lihn9m6lvskx5mcb20srx1kgsk9i50li8y"))
9963 (patches
9964 (search-patches "python2-subprocess32-disable-input-test.patch"))))
9965 (build-system python-build-system)
9966 (arguments
9967 `(#:python ,python-2
9968 #:phases
9969 (modify-phases %standard-phases
9970 (add-after 'unpack 'patch-/bin/sh
9971 (lambda _
9972 (substitute* '("subprocess32.py"
9973 "test_subprocess32.py")
9974 (("/bin/sh") (which "sh")))
9975 #t))
9976 (delete 'check)
9977 (add-after 'install 'check
9978 (lambda* (#:key inputs outputs #:allow-other-keys)
9979 ;; For some reason this package fails to import
9980 ;; _posixsubprocess.so when PYTHONPATH is set to the build
9981 ;; directory. Running tests after install is easier.
9982 (add-installed-pythonpath inputs outputs)
9983 (zero? (system* "python" "test_subprocess32.py")))))))
9984 (home-page "https://github.com/google/python-subprocess32")
9985 (synopsis "Backport of the subprocess module from Python 3.2")
9986 (description
9987 "This is a backport of the @code{subprocess} standard library module
9988 from Python 3.2 and 3.3 for use on Python 2. It includes bugfixes and some
9989 new features. On POSIX systems it is guaranteed to be reliable when used
9990 in threaded applications. It includes timeout support from Python 3.3 but
9991 otherwise matches 3.2’s API.")
9992 (license license:psfl)))
9993
9994 (define-public python2-futures
9995 (package
9996 (name "python2-futures")
9997 (version "3.0.5")
9998 (source
9999 (origin
10000 (method url-fetch)
10001 (uri (pypi-uri "futures" version))
10002 (sha256
10003 (base32
10004 "1pw1z4329xvlabdpwqa6b7v2fxf7hl64m4cgr22ckbym8m8m4hh5"))))
10005 (build-system python-build-system)
10006 (arguments `(#:python ,python-2))
10007 (home-page "https://github.com/agronholm/pythonfutures")
10008 (synopsis
10009 "Backport of the concurrent.futures package from Python 3.2")
10010 (description
10011 "The concurrent.futures module provides a high-level interface for
10012 asynchronously executing callables. This package backports the
10013 concurrent.futures package from Python 3.2")
10014 (license license:bsd-3)))
10015
10016 (define-public python-promise
10017 (package
10018 (name "python-promise")
10019 (version "0.4.2")
10020 (source
10021 (origin
10022 (method url-fetch)
10023 (uri (pypi-uri "promise" version))
10024 (sha256
10025 (base32
10026 "1k19ms8l3d5jzjh557rgkxb5sg4mqgfc315rn4hx1z3n8qq6lr3h"))))
10027 (build-system python-build-system)
10028 ;; Tests wants python-futures, which is a python2 only program, and
10029 ;; can't be found by python-promise at test time.
10030 (arguments `(#:tests? #f))
10031 (home-page "https://github.com/syrusakbary/promise")
10032 (synopsis "Promises/A+ implementation for Python")
10033 (description
10034 "Promises/A+ implementation for Python")
10035 (properties `((python2-variant . ,(delay python2-promise))))
10036 (license license:expat)))
10037
10038 (define-public python2-promise
10039 (let ((promise (package-with-python2
10040 (strip-python2-variant python-promise))))
10041 (package (inherit promise)
10042 (arguments (substitute-keyword-arguments (package-arguments promise)
10043 ((#:tests? _) #t)))
10044 (native-inputs
10045 `(("python2-futures" ,python2-futures)
10046 ("python2-pytest" ,python2-pytest)
10047 ,@(package-native-inputs promise))))))
10048
10049 (define-public python-urllib3
10050 (package
10051 (name "python-urllib3")
10052 (version "1.18.1")
10053 (source
10054 (origin
10055 (method url-fetch)
10056 (uri (pypi-uri "urllib3" version))
10057 (sha256
10058 (base32
10059 "1wb8aqnq53vzh2amrv8kc66f3h6fx217y0q62y6n30a64p2yqmam"))))
10060 (build-system python-build-system)
10061 (arguments `(#:tests? #f))
10062 (native-inputs
10063 `(;; some packages for tests
10064 ("python-nose" ,python-nose)
10065 ("python-mock" ,python-mock)
10066 ("python-tornado" ,python-tornado)))
10067 (propagated-inputs
10068 `(;; These 5 inputs are used to build urrlib3[secure]
10069 ("python-certifi" ,python-certifi)
10070 ("python-cryptography" ,python-cryptography) ;
10071 ("python-idna" ,python-idna)
10072 ("python-ipaddress" ,python-ipaddress)
10073 ("python-pyopenssl" ,python-pyopenssl)))
10074 (home-page "https://urllib3.readthedocs.org/")
10075 (synopsis "HTTP library with thread-safe connection pooling")
10076 (description
10077 "Urllib3 supports features left out of urllib and urllib2 libraries. It
10078 can reuse the same socket connection for multiple requests, it can POST files,
10079 supports url redirection and retries, and also gzip and deflate decoding.")
10080 (license license:expat)))
10081
10082 (define-public python2-urllib3
10083 (package-with-python2 python-urllib3))
10084
10085 (define-public python-colorama
10086 (package
10087 (name "python-colorama")
10088 (version "0.3.7")
10089 (source
10090 (origin
10091 (method url-fetch)
10092 (uri (pypi-uri "colorama" version))
10093 (sha256
10094 (base32
10095 "0avqkn6362v7k2kg3afb35g4sfdvixjgy890clip4q174p9whhz0"))))
10096 (build-system python-build-system)
10097 (synopsis "Colored terminal text rendering for Python")
10098 (description "Colorama is a Python library for rendering colored terminal
10099 text.")
10100 (home-page "https://pypi.python.org/pypi/colorama")
10101 (license license:bsd-3)))
10102
10103 (define-public python2-colorama
10104 (package-with-python2 python-colorama))
10105
10106 (define-public python-rsa
10107 (package
10108 (name "python-rsa")
10109 (version "3.4.2")
10110 (source
10111 (origin
10112 (method url-fetch)
10113 (uri (pypi-uri "rsa" version))
10114 (sha256
10115 (base32
10116 "1dcxvszbikgzh99ybdc7jq0zb9wspy2ds8z9mjsqiyv3q884xpr5"))))
10117 (build-system python-build-system)
10118 (propagated-inputs
10119 `(("python-pyasn1" ,python-pyasn1)))
10120 (synopsis "Pure-Python RSA implementation")
10121 (description "Python-RSA is a pure-Python RSA implementation. It supports
10122 encryption and decryption, signing and verifying signatures, and key
10123 generation according to PKCS#1 version 1.5. It can be used as a Python
10124 library as well as on the command line.")
10125 (home-page "http://stuvel.eu/rsa")
10126 (license license:asl2.0)))
10127
10128 (define-public python2-rsa
10129 (package-with-python2 python-rsa))
10130
10131 (define-public python-pluggy
10132 (package
10133 (name "python-pluggy")
10134 (version "0.3.1")
10135 (source
10136 (origin
10137 (method url-fetch)
10138 (uri (pypi-uri "pluggy" version))
10139 (sha256
10140 (base32
10141 "18qfzfm40bgx672lkg8q9x5hdh76n7vax99aank7vh2nw21wg70m"))))
10142 (build-system python-build-system)
10143 (synopsis "Plugin and hook calling mechanism for Python")
10144 (description "Pluggy is an extraction of the plugin manager as used by
10145 Pytest but stripped of Pytest specific details.")
10146 (home-page "https://pypi.python.org/pypi/pluggy")
10147 (license license:expat)))
10148
10149 (define-public python2-pluggy
10150 (package-with-python2 python-pluggy))
10151
10152 (define-public python-tox
10153 (package
10154 (name "python-tox")
10155 (version "2.8.1")
10156 (source
10157 (origin
10158 (method url-fetch)
10159 (uri (pypi-uri "tox" version))
10160 (sha256
10161 (base32
10162 "1drp6mwm8wdypjym15ia8lwjxbhcksb9vzxg4ay5dh4ji57by2ny"))))
10163 (build-system python-build-system)
10164 (arguments
10165 ;; FIXME: Tests require pytest-timeout, which itself requires
10166 ;; pytest>=2.8.0 for installation.
10167 '(#:tests? #f))
10168 (propagated-inputs
10169 `(("python-pluggy" ,python-pluggy) ; >=0.3.0,<0.4.0
10170 ("python-py" ,python-py)
10171 ("python-virtualenv" ,python-virtualenv)))
10172 (native-inputs
10173 `(; FIXME: Missing: ("python-pytest-timeout" ,python-pytest-timeout)
10174 ("python-pytest" ,python-pytest) ; >= 2.3.5
10175 ("python-setuptools-scm" ,python-setuptools-scm)))
10176 (home-page "http://tox.testrun.org/")
10177 (synopsis "Virtualenv-based automation of test activities")
10178 (description "Tox is a generic virtualenv management and test command line
10179 tool. It can be used to check that a package installs correctly with
10180 different Python versions and interpreters, or run tests in each type of
10181 supported environment, or act as a frontend to continuous integration
10182 servers.")
10183 (license license:expat)))
10184
10185 (define-public python2-tox
10186 (package-with-python2 python-tox))
10187
10188 (define-public python-jmespath
10189 (package
10190 (name "python-jmespath")
10191 (version "0.9.0")
10192 (source
10193 (origin
10194 (method url-fetch)
10195 (uri (pypi-uri "jmespath" version))
10196 (sha256
10197 (base32
10198 "0g9xvl69y7nr3w7ag4fsp6sm4fqf6vrqjw7504x2hzrrsh3ampq8"))))
10199 (build-system python-build-system)
10200 (native-inputs
10201 `(("python-nose" ,python-nose)))
10202 (synopsis "JSON Matching Expressions")
10203 (description "JMESPath (pronounced “james path”) is a Python library that
10204 allows one to declaratively specify how to extract elements from a JSON
10205 document.")
10206 (home-page "https://github.com/jmespath/jmespath.py")
10207 (license license:expat)))
10208
10209 (define-public python2-jmespath
10210 (package-with-python2 python-jmespath))
10211
10212 (define-public python-botocore
10213 (package
10214 (name "python-botocore")
10215 (version "1.7.9")
10216 (source
10217 (origin
10218 (method url-fetch)
10219 (uri (pypi-uri "botocore" version))
10220 (sha256
10221 (base32
10222 "02b1bw25r1wdjs5yppb1h9igf11wj092biriv2yg8hzp5r0wrkmg"))))
10223 (build-system python-build-system)
10224 (arguments
10225 ;; FIXME: Many tests are failing.
10226 '(#:tests? #f))
10227 (propagated-inputs
10228 `(("python-dateutil" ,python-dateutil)
10229 ("python-docutils" ,python-docutils)
10230 ("python-jmespath" ,python-jmespath)))
10231 (native-inputs
10232 `(("python-mock" ,python-mock)
10233 ("python-nose" ,python-nose)
10234 ("behave" ,behave)
10235 ("python-tox" ,python-tox)
10236 ("python-wheel" ,python-wheel)))
10237 (home-page "https://github.com/boto/botocore")
10238 (synopsis "Low-level interface to AWS")
10239 (description "Botocore is a Python library that provides a low-level
10240 interface to the Amazon Web Services (AWS) API.")
10241 (license license:asl2.0)))
10242
10243 (define-public python2-botocore
10244 (package-with-python2 python-botocore))
10245
10246 (define-public awscli
10247 (package
10248 (name "awscli")
10249 (version "1.11.164")
10250 (source
10251 (origin
10252 (method url-fetch)
10253 (uri (pypi-uri name version))
10254 (sha256
10255 (base32
10256 "05r8cw7i7ff6barpmyxxk3i52gzb1xyxwj8isynmiyqlmk3c9r8w"))))
10257 (build-system python-build-system)
10258 (propagated-inputs
10259 `(("python-colorama" ,python-colorama)
10260 ("python-botocore" ,python-botocore)
10261 ("python-s3transfer" ,python-s3transfer)
10262 ("python-docutils" ,python-docutils)
10263 ("python-pyyaml" ,python-pyyaml)
10264 ("python-rsa" ,python-rsa)))
10265 (arguments
10266 ;; FIXME: The 'pypi' release does not contain tests.
10267 '(#:tests? #f))
10268 (home-page "https://aws.amazon.com/cli/")
10269 (synopsis "Command line client for AWS")
10270 (description "AWS CLI provides a unified command line interface to the
10271 Amazon Web Services (AWS) API.")
10272 (license license:asl2.0)))
10273
10274 (define-public python-hypothesis
10275 (package
10276 (name "python-hypothesis")
10277 (version "3.1.0")
10278 (source (origin
10279 (method url-fetch)
10280 (uri (pypi-uri "hypothesis" version))
10281 (sha256
10282 (base32
10283 "0qyqq9akm4vshhn8cngjc1qykcvsn7cz6dlm6njfsgpbraqrmbbw"))))
10284 (build-system python-build-system)
10285 (native-inputs
10286 `(("python-flake8" ,python-flake8)
10287 ("python-pytest" ,python-pytest)))
10288 (synopsis "Library for property based testing")
10289 (description "Hypothesis is a library for testing your Python code against a
10290 much larger range of examples than you would ever want to write by hand. It’s
10291 based on the Haskell library, Quickcheck, and is designed to integrate
10292 seamlessly into your existing Python unit testing work flow.")
10293 (home-page "https://github.com/DRMacIver/hypothesis")
10294 (license license:mpl2.0)
10295 (properties `((python2-variant . ,(delay python2-hypothesis))))))
10296
10297 (define-public python2-hypothesis
10298 (let ((hypothesis (package-with-python2
10299 (strip-python2-variant python-hypothesis))))
10300 (package (inherit hypothesis)
10301 (propagated-inputs
10302 `(("python2-enum34" ,python2-enum34)
10303 ,@(package-propagated-inputs hypothesis))))))
10304
10305 (define-public python-pytest-subtesthack
10306 (package
10307 (name "python-pytest-subtesthack")
10308 (version "0.1.1")
10309 (source (origin
10310 (method url-fetch)
10311 (uri (pypi-uri "pytest-subtesthack" version))
10312 (sha256
10313 (base32
10314 "15kzcr5pchf3id4ikdvlv752rc0j4d912n589l4rifp8qsj19l1x"))))
10315 (build-system python-build-system)
10316 (propagated-inputs
10317 `(("python-pytest" ,python-pytest)))
10318 (synopsis "Set-up and tear-down fixtures for unit tests")
10319 (description "This plugin allows you to set up and tear down fixtures within
10320 unit test functions that use @code{py.test}. This is useful for using
10321 @command{hypothesis} inside py.test, as @command{hypothesis} will call the test
10322 function multiple times, without setting up or tearing down fixture state as is
10323 normally the case.")
10324 (home-page "https://github.com/untitaker/pytest-subtesthack/")
10325 (license license:unlicense)))
10326
10327 (define-public python2-pytest-subtesthack
10328 (package-with-python2 python-pytest-subtesthack))
10329
10330 (define-public python-xdo
10331 (package
10332 (name "python-xdo")
10333 (version "0.3")
10334 (source (origin
10335 (method url-fetch)
10336 (uri (string-append
10337 "http://http.debian.net/debian/pool/main/p/python-xdo/"
10338 "python-xdo_" version ".orig.tar.gz"))
10339 (sha256
10340 (base32
10341 "1vqh1n5yy5dhnq312kwrl90fnck4v26is3lq3lxdvcn60vv19da0"))))
10342 (build-system python-build-system)
10343 (arguments
10344 '(#:phases
10345 (modify-phases %standard-phases
10346 (add-before 'install 'patch-libxdo-path
10347 ;; Hardcode the path of dynamically loaded libxdo library.
10348 (lambda* (#:key inputs #:allow-other-keys)
10349 (let ((libxdo (string-append
10350 (assoc-ref inputs "xdotool")
10351 "/lib/libxdo.so")))
10352 (substitute* "xdo/_xdo.py"
10353 (("find_library\\(\"xdo\"\\)")
10354 (simple-format #f "\"~a\"" libxdo)))
10355 #t))))
10356 #:tests? #f)) ; no tests provided
10357 (propagated-inputs
10358 `(("python-six" ,python-six)))
10359 (inputs
10360 `(("xdotool" ,xdotool)
10361 ("libX11" ,libx11)))
10362 (home-page "https://tracker.debian.org/pkg/python-xdo")
10363 (synopsis "Python library for simulating X11 keyboard/mouse input")
10364 (description "Provides bindings to libxdo for manipulating X11 via simulated
10365 input. (Note that this is mostly a legacy library; you may wish to look at
10366 python-xdo for newer bindings.)")
10367 (license license:bsd-3)))
10368
10369 (define-public python2-xdo
10370 (package-with-python2 python-xdo))
10371
10372 (define-public python-wtforms
10373 (package
10374 (name "python-wtforms")
10375 (version "2.1")
10376 (source
10377 (origin
10378 (method url-fetch)
10379 (uri (pypi-uri "WTForms" version ".zip"))
10380 (sha256
10381 (base32
10382 "0vyl26y9cg409cfyj8rhqxazsdnd0jipgjw06civhrd53yyi1pzz"))))
10383 (build-system python-build-system)
10384 (arguments
10385 '(#:phases
10386 (modify-phases %standard-phases
10387 (add-after 'unpack 'remove-django-test
10388 ;; Don't fail the tests when the inputs for the optional tests cannot be found.
10389 (lambda _
10390 (substitute*
10391 "tests/runtests.py"
10392 (("'ext_django.tests', 'ext_sqlalchemy', 'ext_dateutil', 'locale_babel'") "")
10393 (("sys.stderr.write(\"### Disabled test '%s', dependency not found\n\" % name)") ""))
10394 #t)))))
10395 (native-inputs
10396 `(("unzip" ,unzip)))
10397 (home-page "http://wtforms.simplecodes.com/")
10398 (synopsis
10399 "Form validation and rendering library for Python web development")
10400 (description
10401 "WTForms is a flexible forms validation and rendering library
10402 for Python web development. It is very similar to the web form API
10403 available in Django, but is a standalone package.")
10404 (license license:bsd-3)))
10405
10406 (define-public python2-wtforms
10407 (package-with-python2 python-wtforms))
10408
10409 (define-public python-mako
10410 (package
10411 (name "python-mako")
10412 (version "1.0.6")
10413 (source
10414 (origin
10415 (method url-fetch)
10416 (uri (pypi-uri "Mako" version))
10417 (sha256
10418 (base32
10419 "03dyxgjknp4ffsv7vwfd28l5bbpzi0ylp20543wpg3iahyyrwma8"))))
10420 (build-system python-build-system)
10421 (propagated-inputs
10422 `(("python-markupsafe" ,python-markupsafe)))
10423 (native-inputs
10424 `(("python-mock" ,python-mock)
10425 ("python-nose" ,python-nose)
10426 ("python-pytest" ,python-pytest)))
10427 (home-page "http://www.makotemplates.org/")
10428 (synopsis "Templating language for Python")
10429 (description "Mako is a templating language for Python that compiles
10430 templates into Python modules.")
10431 (license license:expat)))
10432
10433 (define-public python2-mako
10434 (package-with-python2 python-mako))
10435
10436 (define-public python-waitress
10437 (package
10438 (name "python-waitress")
10439 (version "0.8.10")
10440 (source
10441 (origin
10442 (method url-fetch)
10443 (uri (pypi-uri "waitress" version))
10444 (sha256
10445 (base32
10446 "017n9ra6vvmq9d5sfhdzyzr1mg15x2hj2dhm4pdlw98c1ypw2h3w"))))
10447 (build-system python-build-system)
10448 (home-page "https://github.com/Pylons/waitress")
10449 (synopsis "Waitress WSGI server")
10450 (description "Waitress is meant to be a production-quality pure-Python WSGI
10451 server with very acceptable performance.")
10452 (license license:zpl2.1)))
10453
10454 (define-public python2-waitress
10455 (package-with-python2 python-waitress))
10456
10457 (define-public python-wsgiproxy2
10458 (package
10459 (name "python-wsgiproxy2")
10460 (version "0.4.2")
10461 (source
10462 (origin
10463 (method url-fetch)
10464 (uri (pypi-uri "WSGIProxy2" version ".zip"))
10465 (sha256
10466 (base32
10467 "13kf9bdxrc95y9vriaz0viry3ah11nz4rlrykcfvb8nlqpx3dcm4"))))
10468 (build-system python-build-system)
10469 (arguments
10470 '(;; Wsgiproxy2's test suite requires Restkit, which does not yet fully
10471 ;; support Python 3:
10472 ;; https://github.com/benoitc/restkit/issues/140
10473 #:tests? #f))
10474 (native-inputs
10475 `(("unzip" ,unzip)
10476 ("python-nose" ,python-nose)
10477 ("python-coverage" ,python-coverage)))
10478 (propagated-inputs
10479 `(("python-six" ,python-six)
10480 ("python-webob" ,python-webob)))
10481 (home-page
10482 "https://github.com/gawel/WSGIProxy2/")
10483 (synopsis "WSGI Proxy with various http client backends")
10484 (description "WSGI turns HTTP requests into WSGI function calls.
10485 WSGIProxy turns WSGI function calls into HTTP requests.
10486 It also includes code to sign requests and pass private data,
10487 and to spawn subprocesses to handle requests.")
10488 (license license:expat)))
10489
10490 (define-public python2-wsgiproxy2
10491 (package-with-python2 python-wsgiproxy2))
10492
10493 (define-public python-pastedeploy
10494 (package
10495 (name "python-pastedeploy")
10496 (version "1.5.2")
10497 (source
10498 (origin
10499 (method url-fetch)
10500 (uri (pypi-uri "PasteDeploy" version))
10501 (sha256
10502 (base32
10503 "1jz3m4hq8v6hyhfjz9425nd3nvn52cvbfipdcd72krjmla4qz1fm"))))
10504 (build-system python-build-system)
10505 (native-inputs
10506 `(("python-nose" ,python-nose)))
10507 (home-page "http://pythonpaste.org/deploy/")
10508 (synopsis
10509 "Load, configure, and compose WSGI applications and servers")
10510 (description
10511 "This tool provides code to load WSGI applications and servers from URIs;
10512 these URIs can refer to Python Eggs for INI-style configuration files. Paste
10513 Script provides commands to serve applications based on this configuration
10514 file.")
10515 (license license:expat)))
10516
10517 (define-public python2-pastedeploy
10518 (package-with-python2 python-pastedeploy))
10519
10520 (define-public python-paste
10521 (package
10522 (name "python-paste")
10523 (version "2.0.3")
10524 (source
10525 (origin
10526 (method url-fetch)
10527 (uri (pypi-uri "Paste" version))
10528 (sha256
10529 (base32
10530 "062jk0nlxf6lb2wwj6zc20rlvrwsnikpkh90y0dn8cjch93s6ii3"))
10531 (patches (search-patches "python-paste-remove-website-test.patch"
10532 "python-paste-remove-timing-test.patch"))))
10533 (build-system python-build-system)
10534 (native-inputs
10535 `(("python-nose" ,python-nose)))
10536 (propagated-inputs
10537 `(("python-six" ,python-six)))
10538 (home-page "http://pythonpaste.org")
10539 (synopsis
10540 "Python web development tools, focusing on WSGI")
10541 (description
10542 "Paste provides a variety of web development tools and middleware which
10543 can be nested together to build web applications. Paste's design closely
10544 follows ideas flowing from WSGI (Web Standard Gateway Interface).")
10545 (license license:expat)))
10546
10547 (define-public python2-paste
10548 (package-with-python2 python-paste))
10549
10550 (define-public python-pastescript
10551 (package
10552 (name "python-pastescript")
10553 (version "2.0.2")
10554 (source
10555 (origin
10556 (method url-fetch)
10557 (uri (pypi-uri "PasteScript" version))
10558 (sha256
10559 (base32
10560 "1h3nnhn45kf4pbcv669ik4faw04j58k8vbj1hwrc532k0nc28gy0"))))
10561 (build-system python-build-system)
10562 (native-inputs
10563 `(("python-nose" ,python-nose)))
10564 (propagated-inputs
10565 `(("python-paste" ,python-paste)
10566 ("python-pastedeploy" ,python-pastedeploy)))
10567 (home-page "http://pythonpaste.org/script/")
10568 (arguments
10569 '(;; Unfortunately, this requires the latest unittest2,
10570 ;; but that requires traceback2 which requires linecache2 which requires
10571 ;; unittest2. So we're skipping tests for now.
10572 ;; (Note: Apparently linetest2 only needs unittest2 for its tests,
10573 ;; so in theory we could get around this situation somehow.)
10574 #:tests? #f))
10575 (synopsis
10576 "Pluggable command line tool for serving web applications and more")
10577 (description
10578 "PasteScript is a plugin-friendly command line tool which provides a
10579 variety of features, from launching web applications to bootstrapping project
10580 layouts.")
10581 (license license:expat)))
10582
10583 (define-public python2-pastescript
10584 (package-with-python2 python-pastescript))
10585
10586 (define-public python-pyquery
10587 (package
10588 (name "python-pyquery")
10589 (version "1.2.17")
10590 (source
10591 (origin
10592 (method url-fetch)
10593 (uri (pypi-uri "pyquery" version))
10594 (sha256
10595 (base32
10596 "1xia20wm0vx5dk85kcwgh13bylz8qh47ffjxssd2586r60xi783a"))))
10597 (build-system python-build-system)
10598 (native-inputs
10599 `(("python-webob" ,python-webob)
10600 ("python-webtest" ,python-webtest)))
10601 (propagated-inputs
10602 `(("python-lxml" ,python-lxml)
10603 ("python-cssselect" ,python-cssselect)))
10604 (home-page "https://github.com/gawel/pyquery")
10605 (synopsis "Make jQuery-like queries on xml documents")
10606 (description "pyquery allows you to make jQuery queries on xml documents.
10607 The API is as much as possible the similar to jQuery. pyquery uses lxml for
10608 fast xml and html manipulation.")
10609 (license license:bsd-3)))
10610
10611 (define-public python2-pyquery
10612 (package-with-python2 python-pyquery))
10613
10614 (define-public python-webtest
10615 (package
10616 (name "python-webtest")
10617 (version "2.0.20")
10618 (source
10619 (origin
10620 (method url-fetch)
10621 (uri (pypi-uri "WebTest" version))
10622 (sha256
10623 (base32
10624 "0bv0qhdjakdsdgj4sk21gnpp8xp8bga4x03p6gjb83ihrsb7n4xv"))))
10625 (build-system python-build-system)
10626 (arguments
10627 `(;; Unfortunately we have to disable tests!
10628 ;; This release of WebTest is pinned to python-nose < 1.3,
10629 ;; but older versions of python-nose are plagued with the following
10630 ;; bug(s), which rears its ugly head during test execution:
10631 ;; https://github.com/nose-devs/nose/issues/759
10632 ;; https://github.com/nose-devs/nose/pull/811
10633 #:tests? #f))
10634 ;; Commented out code is no good, but in this case, once tests
10635 ;; are ready to be enabled again, we should put the following
10636 ;; in place:
10637 ;; (native-inputs
10638 ;; `(("python-nose" ,python-nose) ; technially < 1.3,
10639 ;; ; but see above comment
10640 ;; ("python-coverage" ,python-coverage)
10641 ;; ("python-mock" ,python-mock)
10642 ;; ("python-pastedeploy" ,python-pastedeploy)
10643 ;; ("python-wsgiproxy2" ,python-wsgiproxy2)
10644 ;; ("python-pyquery" ,python-pyquery)))
10645 (propagated-inputs
10646 `(("python-waitress" ,python-waitress)
10647 ("python-webob" ,python-webob)
10648 ("python-six" ,python-six)
10649 ("python-beautifulsoup4" ,python-beautifulsoup4)))
10650 (home-page "http://webtest.pythonpaste.org/")
10651 (synopsis "Helper to test WSGI applications")
10652 (description "Webtest allows you to test your Python web applications
10653 without starting an HTTP server. It supports anything that supports the
10654 minimum of WSGI.")
10655 (license license:expat)))
10656
10657 (define-public python2-webtest
10658 (package-with-python2 python-webtest))
10659
10660 (define-public python-anyjson
10661 (package
10662 (name "python-anyjson")
10663 (version "0.3.3")
10664 (source
10665 (origin
10666 (method url-fetch)
10667 (uri (pypi-uri "anyjson" version))
10668 (sha256
10669 (base32
10670 "1fjph4alvcscsl5d4b6qpv1yh31jy05jxi1l0xff7lws7j32v09p"))))
10671 (build-system python-build-system)
10672 (arguments
10673 `(;; We could possibly get tests working, but on Python 3 it's not so easy.
10674 ;; Very strangely, 2to3 is run *during setup.py install* (or bdist, or
10675 ;; whatever) so this transformation needs to be done before the tests
10676 ;; can be run. Maybe we could add a build step to transform beforehand
10677 ;; but it could be annoying/difficult.
10678 ;; We can enable tests for the Python 2 version, though, and do below.
10679 #:tests? #f))
10680 (home-page "http://bitbucket.org/runeh/anyjson/")
10681 (synopsis
10682 "Wraps best available JSON implementation in a common interface")
10683 (description
10684 "Anyjson loads whichever is the fastest JSON module installed
10685 and provides a uniform API regardless of which JSON implementation is used.")
10686 (license license:bsd-3)
10687 (properties `((python2-variant . ,(delay python2-anyjson))))))
10688
10689 (define-public python2-anyjson
10690 (let ((anyjson (package-with-python2
10691 (strip-python2-variant python-anyjson))))
10692 (package
10693 (inherit anyjson)
10694 (arguments `(;; Unlike the python 3 variant, we do run tests. See above!
10695 #:tests? #t
10696 ,@(package-arguments anyjson)))
10697 (native-inputs `(("python2-nose" ,python2-nose))))))
10698
10699 (define-public python-amqp
10700 (package
10701 (name "python-amqp")
10702 (version "1.4.9")
10703 (source
10704 (origin
10705 (method url-fetch)
10706 (uri (pypi-uri "amqp" version))
10707 (sha256
10708 (base32
10709 "06n6q0kxhjnbfz3vn8x9yz09lwmn1xi9d6wxp31h5jbks0b4vsid"))))
10710 (build-system python-build-system)
10711 (native-inputs
10712 `(("python-nose" ,python-nose)
10713 ("python-mock" ,python-mock)))
10714 (home-page "https://github.com/celery/py-amqp")
10715 (synopsis
10716 "Low-level AMQP client for Python (fork of amqplib)")
10717 (description
10718 "This is a fork of amqplib which was originally written by Barry Pederson.
10719 It is maintained by the Celery project, and used by kombu as a pure python
10720 alternative when librabbitmq is not available.")
10721 (license license:lgpl2.1+)
10722 (properties `((python2-variant . ,(delay python2-amqp))))))
10723
10724 (define-public python2-amqp
10725 (let ((amqp (package-with-python2
10726 (strip-python2-variant python-amqp))))
10727 (package
10728 (inherit amqp)
10729 (arguments `(;; Tries to run coverage tests with nose-cover3, which seems
10730 ;; unmaintained. Weirdly, does not do this on the python 3
10731 ;; version?
10732 #:tests? #f
10733 ,@(package-arguments amqp))))))
10734
10735 (define-public python-kombu
10736 (package
10737 (name "python-kombu")
10738 (version "3.0.37")
10739 (source
10740 (origin
10741 (method url-fetch)
10742 (uri (pypi-uri "kombu" version))
10743 (sha256
10744 (base32
10745 "0l16chb314gpq2v7fh94a22c30lcv6w3ylmhsa60bldlcq6a0r70"))))
10746 (build-system python-build-system)
10747 (native-inputs
10748 `(("python-mock" ,python-mock)
10749 ("python-nose" ,python-nose)))
10750 (propagated-inputs
10751 `(("python-anyjson" ,python-anyjson)
10752 ("python-amqp" ,python-amqp)
10753 ("python-redis" ,python-redis)))
10754 (home-page "http://kombu.readthedocs.org")
10755 (synopsis "Message passing library for Python")
10756 (description "The aim of Kombu is to make messaging in Python as easy as
10757 possible by providing an idiomatic high-level interface for the AMQ protocol,
10758 and also provide proven and tested solutions to common messaging problems.
10759 AMQP is the Advanced Message Queuing Protocol, an open standard protocol for
10760 message orientation, queuing, routing, reliability and security, for which the
10761 RabbitMQ messaging server is the most popular implementation.")
10762 (license license:bsd-3)
10763 (properties `((python2-variant . ,(delay python2-kombu))))))
10764
10765 (define-public python2-kombu
10766 (let ((kombu (package-with-python2
10767 (strip-python2-variant python-kombu))))
10768 (package
10769 (inherit kombu)
10770 (arguments `(;; FIXME: 'TestTransport.test_del_sync' fails on python2.
10771 ;; It works fine on the python3 variant.
10772 #:tests? #f
10773 ,@(package-arguments kombu)))
10774 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10775 ,@(package-native-inputs kombu))))))
10776
10777 (define-public python-billiard
10778 (package
10779 (name "python-billiard")
10780 (version "3.3.0.23")
10781 (source
10782 (origin
10783 (method url-fetch)
10784 (uri (pypi-uri "billiard" version))
10785 (sha256
10786 (base32
10787 "02wxsc6bhqvzh8j6w758kvgqbnj14l796mvmrcms8fgfamd2lak9"))))
10788 (build-system python-build-system)
10789 (native-inputs
10790 `(("python-nose" ,python-nose)))
10791 (home-page "https://github.com/celery/billiard")
10792 (synopsis
10793 "Python multiprocessing fork with improvements and bugfixes")
10794 (description
10795 "Billiard is a fork of the Python 2.7 multiprocessing package. The
10796 multiprocessing package itself is a renamed and updated version of R Oudkerk's
10797 pyprocessing package. This standalone variant is intended to be compatible with
10798 Python 2.4 and 2.5, and will draw its fixes/improvements from python-trunk.")
10799 (license license:bsd-3)
10800 (properties `((python2-variant . ,(delay python2-billiard))))))
10801
10802 (define-public python2-billiard
10803 (let ((billiard (package-with-python2
10804 (strip-python2-variant python-billiard))))
10805 (package
10806 (inherit billiard)
10807 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10808 ("python2-mock" ,python2-mock)
10809 ,@(package-native-inputs billiard))))))
10810
10811 (define-public python-celery
10812 (package
10813 (name "python-celery")
10814 (version "3.1.24")
10815 (source
10816 (origin
10817 (method url-fetch)
10818 (uri (pypi-uri "celery" version))
10819 (sha256
10820 (base32
10821 "0yh2prhdnx2dgkb67a5drj12hh2zvzx5f611p7mqqg01ydghif4r"))))
10822 (build-system python-build-system)
10823 (arguments
10824 `(#:phases
10825 (modify-phases %standard-phases
10826 ;; These tests break with Python 3.5:
10827 ;; https://github.com/celery/celery/issues/2897#issuecomment-253066295
10828 (replace 'check
10829 (lambda _
10830 (zero?
10831 (system* "nosetests" "--exclude=^test_safe_to_remove.*")))))))
10832 (native-inputs
10833 `(("python-nose" ,python-nose)))
10834 (propagated-inputs
10835 `(("python-pytz" ,python-pytz)
10836 ("python-billiard" ,python-billiard)
10837 ("python-kombu" ,python-kombu)))
10838 (home-page "http://celeryproject.org")
10839 (synopsis "Distributed Task Queue")
10840 (description "Celery is an asynchronous task queue/job queue based on
10841 distributed message passing. It is focused on real-time operation, but
10842 supports scheduling as well. The execution units, called tasks, are executed
10843 concurrently on a single or more worker servers using multiprocessing,
10844 Eventlet, or gevent. Tasks can execute asynchronously (in the background) or
10845 synchronously (wait until ready).")
10846 (license license:bsd-3)
10847 (properties `((python2-variant . ,(delay python2-celery))))))
10848
10849 (define-public python2-celery
10850 (let ((celery (package-with-python2
10851 (strip-python2-variant python-celery))))
10852 (package
10853 (inherit celery)
10854 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10855 ("python2-mock" ,python2-mock)
10856 ,@(package-native-inputs celery))))))
10857
10858 (define-public python-translitcodec
10859 (package
10860 (name "python-translitcodec")
10861 (version "0.4.0")
10862 (source
10863 (origin
10864 (method url-fetch)
10865 (uri (pypi-uri "translitcodec" version))
10866 (sha256
10867 (base32
10868 "10x6pvblkzky1zhjs8nmx64nb9jdzxad4bxhq4iwv0j4z2aqjnki"))))
10869 (build-system python-build-system)
10870 (arguments
10871 `(#:tests? #f)) ; no tests provided
10872 (home-page
10873 "https://github.com/claudep/translitcodec")
10874 (synopsis
10875 "Unicode to 8-bit charset transliteration codec")
10876 (description
10877 "This package contains codecs for transliterating ISO 10646 texts into
10878 best-effort representations using smaller coded character sets (ASCII,
10879 ISO 8859, etc.).")
10880 (license license:expat)))
10881
10882 (define-public python2-translitcodec
10883 (package-with-python2 python-translitcodec))
10884
10885 (define-public python-editor
10886 (package
10887 (name "python-editor")
10888 (version "0.5")
10889 (source
10890 (origin
10891 (method url-fetch)
10892 (uri (pypi-uri "python-editor" version))
10893 (sha256
10894 (base32
10895 "1ypnpgvzpkbwsg4rdvy4sy51j28b5xq9v8pnkwxncn07vqz06p7n"))))
10896 (build-system python-build-system)
10897 (home-page
10898 "https://github.com/fmoo/python-editor")
10899 (synopsis
10900 "Programmatically open an editor, capture the result")
10901 (description
10902 "python-editor is a library that provides the editor module for
10903 programmatically interfacing with your system's $EDITOR.")
10904 (license license:asl2.0)))
10905
10906 (define-public python2-editor
10907 (package-with-python2 python-editor))
10908
10909 (define-public python-sphinxcontrib-programoutput
10910 (package
10911 (name "python-sphinxcontrib-programoutput")
10912 (version "0.10")
10913 (source (origin
10914 (method url-fetch)
10915 (uri (pypi-uri "sphinxcontrib-programoutput" version))
10916 (sha256
10917 (base32
10918 "153hhnlbx4688zj9wd64819ps5znc2jlyp5crkgzvn5hxgy99vpx"))))
10919 (build-system python-build-system)
10920 (arguments
10921 ;; FIXME: Many tests are failing and the upstream is gone.
10922 '(#:tests? #f))
10923 (propagated-inputs
10924 `(("python-sphinx" ,python-sphinx)))
10925 (synopsis "Sphinx extension to include program output")
10926 (description "A Sphinx extension to literally insert the output of arbitrary
10927 commands into documents, helping you to keep your command examples up to date.")
10928 (home-page "https://github.com/lunaryorn/sphinxcontrib-programoutput")
10929 (license license:bsd-2)))
10930
10931 (define-public python2-sphinxcontrib-programoutput
10932 (package-with-python2 python-sphinxcontrib-programoutput))
10933
10934 (define-public python-sphinx-repoze-autointerface
10935 (package
10936 (name "python-sphinx-repoze-autointerface")
10937 (version "0.8")
10938 (source (origin
10939 (method url-fetch)
10940 (uri (pypi-uri "repoze.sphinx.autointerface" version))
10941 (sha256
10942 (base32
10943 "08ycivzf7bh4a1zcyp31hbyqs1b2c9r26raa3vxjwwmbfqr3iw4f"))))
10944 (build-system python-build-system)
10945 (arguments '(#:tests? #f)) ; No tests.
10946 (propagated-inputs
10947 `(("python-sphinx" ,python-sphinx)
10948 ("python-zope-interface" ,python-zope-interface)))
10949 (synopsis "Auto-generate Sphinx API docs from Zope interfaces")
10950 (description "This package defines an extension for the Sphinx documentation
10951 system. The extension allows generation of API documentation by
10952 introspection of @code{zope.interface} instances in code.")
10953 (home-page "https://github.com/repoze/repoze.sphinx.autointerface")
10954 (license license:repoze)))
10955
10956 (define-public python2-sphinx-repoze-autointerface
10957 (package-with-python2 python-sphinx-repoze-autointerface))
10958
10959 (define-public python-psycopg2
10960 (package
10961 (name "python-psycopg2")
10962 (version "2.7.3.1")
10963 (source
10964 (origin
10965 (method url-fetch)
10966 (uri (pypi-uri "psycopg2" version))
10967 (sha256
10968 (base32
10969 "0rda1j02ds6s28752fhmpwg761sh6jsxi1gpczqkrd28cki1cywv"))))
10970 (build-system python-build-system)
10971 (arguments
10972 ;; Tests would require a postgresql database "psycopg2_test"
10973 ;; and a running postgresql database management service.
10974 `(#:tests? #f)) ; TODO re-enable after providing a test-db.
10975 (inputs
10976 `(("postgresql" ,postgresql))) ; libpq
10977 (home-page "http://initd.org/psycopg/")
10978 (synopsis "Python PostgreSQL adapter")
10979 (description
10980 "psycopg2 is a thread-safe PostgreSQL adapter that implements DB-API 2.0. ")
10981 (license license:lgpl3+)))
10982
10983 (define-public python2-psycopg2
10984 (package-with-python2 python-psycopg2))
10985
10986 (define-public python-vobject
10987 (package
10988 (name "python-vobject")
10989 (version "0.9.5")
10990 (source (origin
10991 (method url-fetch)
10992 (uri (pypi-uri "vobject" version))
10993 (sha256
10994 (base32
10995 "0hqjgf3ay1m5w1c0k00g5yfpdz1zni5qnr5rh9b8fg9hjvhwlmhg"))))
10996 (build-system python-build-system)
10997 (arguments
10998 '(;; The test suite relies on some non-portable Windows interfaces.
10999 #:tests? #f))
11000 (propagated-inputs
11001 `(("python-dateutil" ,python-dateutil)
11002 ("python-pyicu" ,python-pyicu)))
11003 (synopsis "Parse and generate vCard and vCalendar files")
11004 (description "Vobject is intended to be a full featured Python package for
11005 parsing and generating vCard and vCalendar files. Currently, iCalendar files
11006 are supported and well tested. vCard 3.0 files are supported, and all data
11007 should be imported, but only a few components are understood in a sophisticated
11008 way.")
11009 (home-page "http://eventable.github.io/vobject/")
11010 (license license:asl2.0)))
11011
11012 (define-public python2-vobject
11013 (package-with-python2 python-vobject))
11014
11015 (define-public python-munkres
11016 (package
11017 (name "python-munkres")
11018 (version "1.0.8")
11019 (source (origin
11020 (method url-fetch)
11021 (uri (pypi-uri "munkres" version))
11022 (sha256
11023 (base32
11024 "0mbspx4zv8id4x6pim6ybsa1xh96qwpbqj7skbqz4c9c9nf1lpqq"))))
11025 (build-system python-build-system)
11026 (arguments
11027 '(#:tests? #f)) ; no test suite
11028 (home-page "http://software.clapper.org/munkres/")
11029 (synopsis "Implementation of the Munkres algorithm")
11030 (description "The Munkres module provides an implementation of the Munkres
11031 algorithm (also called the Hungarian algorithm or the Kuhn-Munkres algorithm),
11032 useful for solving the Assignment Problem.")
11033 (license license:bsd-3)))
11034
11035 (define-public python2-munkres
11036 (package-with-python2 python-munkres))
11037
11038 (define-public python-flask
11039 (package
11040 (name "python-flask")
11041 (version "0.11.1")
11042 (source (origin
11043 (method url-fetch)
11044 (uri (pypi-uri "Flask" version))
11045 (sha256
11046 (base32
11047 "03kbfll4sj3v5z7r31c7bhfpi11r1np076d4p1k2kg4yzcmkywdl"))))
11048 (build-system python-build-system)
11049 (propagated-inputs
11050 `(("python-itsdangerous" ,python-itsdangerous)
11051 ("python-jinja2" ,python-jinja2)
11052 ("python-click" ,python-click)
11053 ("python-werkzeug" ,python-werkzeug)))
11054 (home-page "https://github.com/mitsuhiko/flask/")
11055 (synopsis "Microframework based on Werkzeug, Jinja2 and good intentions")
11056 (description "Flask is a micro web framework based on the Werkzeug toolkit
11057 and Jinja2 template engine. It is called a micro framework because it does not
11058 presume or force a developer to use a particular tool or library.")
11059 (license license:bsd-3)))
11060
11061 (define-public python2-flask
11062 (package-with-python2 python-flask))
11063
11064 (define-public python-flask-wtf
11065 (package
11066 (name "python-flask-wtf")
11067 (version "0.13.1")
11068 (source
11069 (origin
11070 (method url-fetch)
11071 (uri (pypi-uri "Flask-WTF" version))
11072 (sha256
11073 (base32
11074 "04l5743j2dici46038sqlzvf0xzpg8rf7s9ld2x24xv7f4idg990"))))
11075 (build-system python-build-system)
11076 (arguments
11077 '(#:phases
11078 (modify-phases %standard-phases
11079 (add-before 'check 'drop-failing-test
11080 (lambda _
11081 ;; FIXME: This file tries resolving an external server, which
11082 ;; fails. Try to patch out the offending section instead of
11083 ;; deleting the whole thing.
11084 (delete-file "tests/test_recaptcha.py")
11085 #t)))))
11086 (propagated-inputs
11087 `(("python-flask-babel" ,python-flask-babel)
11088 ("python-babel" ,python-babel)
11089 ("python-wtforms" ,python-wtforms)))
11090 (native-inputs
11091 `(("python-nose" ,python-nose)))
11092 (home-page "https://github.com/lepture/flask-wtf")
11093 (synopsis "Simple integration of Flask and WTForms")
11094 (description "Flask-WTF integrates Flask and WTForms, including CSRF, file
11095 upload, and reCAPTCHA.")
11096 (license license:bsd-3)))
11097
11098 (define-public python2-flask-wtf
11099 (package-with-python2 python-flask-wtf))
11100
11101 (define-public python-flask-multistatic
11102 (package
11103 (name "python-flask-multistatic")
11104 (version "1.0")
11105 (source
11106 (origin
11107 (method url-fetch)
11108 (uri (pypi-uri "flask-multistatic" version))
11109 (sha256
11110 (base32
11111 "0p4v50rwv64wcd0zlq7rzl4waprwr4hj19s3cgf1isywa7jcisgm"))))
11112 (build-system python-build-system)
11113 (propagated-inputs
11114 `(("python-flask" ,python-flask)))
11115 (home-page "https://pagure.io/flask-multistatic")
11116 (synopsis "Flask plugin to allow overriding static files")
11117 (description "@code{flask-multistatic} is a flask plugin that adds support
11118 for overriding static files.")
11119 (license license:gpl3+)))
11120
11121 (define-public python2-flask-multistatic
11122 (package-with-python2 python-flask-multistatic))
11123
11124 (define-public python-cookies
11125 (package
11126 (name "python-cookies")
11127 (version "2.2.1")
11128 (source (origin
11129 (method url-fetch)
11130 (uri (pypi-uri "cookies" version))
11131 (sha256
11132 (base32
11133 "13pfndz8vbk4p2a44cfbjsypjarkrall71pgc97glk5fiiw9idnn"))))
11134 (build-system python-build-system)
11135 (arguments
11136 `(;; test are broken: https://gitlab.com/sashahart/cookies/issues/3
11137 #:tests? #f))
11138 (native-inputs
11139 `(("python-pytest" ,python2-pytest)))
11140 (synopsis "HTTP cookie parser and renderer")
11141 (description "A RFC 6265-compliant HTTP cookie parser and renderer in
11142 Python.")
11143 (home-page "https://gitlab.com/sashahart/cookies")
11144 (license license:expat)))
11145
11146 (define-public python2-cookies
11147 (package-with-python2 python-cookies))
11148
11149 (define-public python-responses
11150 (package
11151 (name "python-responses")
11152 (version "0.5.1")
11153 (source (origin
11154 (method url-fetch)
11155 (uri (pypi-uri "responses" version))
11156 (sha256
11157 (base32
11158 "1spcfxixyk9k7pk82jm6zqkwk031s95lh8q0mz7539jrb7269bcc"))))
11159 (build-system python-build-system)
11160 (arguments
11161 `(;; Test suite is not distributed:
11162 ;; https://github.com/getsentry/responses/issues/38
11163 #:tests? #f))
11164 (native-inputs
11165 `(("python-mock" ,python-mock)))
11166 (propagated-inputs
11167 `(("python-requests" ,python-requests)
11168 ("python-cookies" ,python-cookies)
11169 ("python-six" ,python-six)))
11170 (home-page "https://github.com/getsentry/responses")
11171 (synopsis "Utility for mocking out the `requests` Python library")
11172 (description "A utility library for mocking out the `requests` Python
11173 library.")
11174 (license license:asl2.0)))
11175
11176 (define-public python2-responses
11177 (package-with-python2 python-responses))
11178
11179 (define-public python-whoosh
11180 (package
11181 (name "python-whoosh")
11182 (version "2.7.4")
11183 (source
11184 (origin
11185 (method url-fetch)
11186 (uri (pypi-uri "Whoosh" version))
11187 (sha256
11188 (base32
11189 "10qsqdjpbc85fykc1vgcs8xwbgn4l2l52c8d83xf1q59pwyn79bw"))))
11190 (build-system python-build-system)
11191 (native-inputs
11192 `(("python-pytest" ,python-pytest)))
11193 (home-page "http://bitbucket.org/mchaput/whoosh")
11194 (synopsis "Full text indexing, search, and spell checking library")
11195 (description
11196 "Whoosh is a fast, pure-Python full text indexing, search, and spell
11197 checking library.")
11198 (license license:bsd-2)))
11199
11200 (define-public python2-whoosh
11201 (let ((whoosh (package-with-python2 (strip-python2-variant python-whoosh))))
11202 (package (inherit whoosh)
11203 (propagated-inputs
11204 `(("python2-backport-ssl-match-hostname"
11205 ,python2-backport-ssl-match-hostname)
11206 ,@(package-propagated-inputs whoosh))))))
11207
11208 (define-public python-pathlib
11209 (package
11210 (name "python-pathlib")
11211 (version "1.0.1")
11212 (source (origin
11213 (method url-fetch)
11214 (uri (pypi-uri "pathlib" version))
11215 (sha256
11216 (base32
11217 "17zajiw4mjbkkv6ahp3xf025qglkj0805m9s41c45zryzj6p2h39"))))
11218 (build-system python-build-system)
11219 ;; The tests depend on the internal "test" module, which does not provide
11220 ;; a stable interface.
11221 (arguments `(#:tests? #f))
11222 (home-page "https://pathlib.readthedocs.org/")
11223 (synopsis "Object-oriented file system paths")
11224 (description "Pathlib offers a set of classes to handle file system paths.
11225 It offers the following advantages over using string objects:
11226
11227 @enumerate
11228 @item No more cumbersome use of os and os.path functions. Everything can
11229 be done easily through operators, attribute accesses, and method calls.
11230 @item Embodies the semantics of different path types. For example,
11231 comparing Windows paths ignores casing.
11232 @item Well-defined semantics, eliminating any inconsistencies or
11233 ambiguities (forward vs. backward slashes, etc.).
11234 @end enumerate
11235
11236 Note: In Python 3.4, pathlib is now part of the standard library. For other
11237 Python versions please consider python-pathlib2 instead, which tracks the
11238 standard library module. This module (python-pathlib) isn't maintained
11239 anymore.")
11240 (license license:expat)))
11241
11242 (define-public python2-pathlib
11243 (package-with-python2 python-pathlib))
11244
11245 (define-public python2-pathlib2
11246 (package
11247 (name "python2-pathlib2")
11248 (version "2.1.0")
11249 (source (origin
11250 (method url-fetch)
11251 (uri (pypi-uri "pathlib2" version))
11252 (sha256
11253 (base32
11254 "0p050msg5c8d0kadv702jnfshaxrb0il765cpkgnhn6mq5hakcyy"))))
11255 (build-system python-build-system)
11256 ;; We only need the the Python 2 variant, since for Python 3 our minimum
11257 ;; version is 3.4 which already includes this package as part of the
11258 ;; standard library.
11259 (arguments
11260 `(#:python ,python-2))
11261 (native-inputs
11262 `(("python2-six" ,python2-six)))
11263 (home-page "http://pypi.python.org/pypi/pathlib2/")
11264 (synopsis "Object-oriented file system paths - backport of standard
11265 pathlib module")
11266 (description "The goal of pathlib2 is to provide a backport of standard
11267 pathlib module which tracks the standard library module, so all the newest
11268 features of the standard pathlib can be used also on older Python versions.
11269
11270 Pathlib offers a set of classes to handle file system paths. It offers the
11271 following advantages over using string objects:
11272
11273 @enumerate
11274 @item No more cumbersome use of os and os.path functions. Everything can
11275 be done easily through operators, attribute accesses, and method calls.
11276 @item Embodies the semantics of different path types. For example,
11277 comparing Windows paths ignores casing.
11278 @item Well-defined semantics, eliminating any inconsistencies or
11279 ambiguities (forward vs. backward slashes, etc.).
11280 @end enumerate")
11281 (license license:expat)))
11282
11283 (define-public python-jellyfish
11284 (package
11285 (name "python-jellyfish")
11286 (version "0.5.6")
11287 (source (origin
11288 (method url-fetch)
11289 (uri (pypi-uri "jellyfish" version))
11290 (sha256
11291 (base32
11292 "1j9rplb16ba2prjj6mip46z0w9pnhnqpwgiwi0x93vnas14rlyl8"))))
11293 (build-system python-build-system)
11294 (native-inputs
11295 `(("python-pytest" ,python-pytest)))
11296 (home-page "https://github.com/jamesturk/jellyfish")
11297 (synopsis "Approximate and phonetic matching of strings")
11298 (description "Jellyfish uses a variety of string comparison and phonetic
11299 encoding algorithms to do fuzzy string matching.")
11300 (license license:bsd-2)
11301 (properties `((python2-variant . ,(delay python2-jellyfish))))))
11302
11303 (define-public python2-jellyfish
11304 (let ((jellyfish (package-with-python2
11305 (strip-python2-variant python-jellyfish))))
11306 (package (inherit jellyfish)
11307 (native-inputs `(("python2-unicodecsv" ,python2-unicodecsv)
11308 ,@(package-native-inputs jellyfish))))))
11309
11310 (define-public python2-unicodecsv
11311 (package
11312 (name "python2-unicodecsv")
11313 (version "0.14.1")
11314 (source (origin
11315 (method url-fetch)
11316 ;; The test suite is not included in the PyPi release.
11317 ;; https://github.com/jdunck/python-unicodecsv/issues/19
11318 (uri (string-append "https://github.com/jdunck/python-unicodecsv/"
11319 "archive/" version ".tar.gz"))
11320 (file-name (string-append name "-" version ".tar.gz"))
11321 (sha256
11322 (base32
11323 "087nqanfcyp6mlfbbr5lva5f3w6iz1bybls9xlrb8icmc474wh4w"))))
11324 (build-system python-build-system)
11325 (arguments
11326 `(;; It supports Python 3, but Python 3 can already do Unicode CSV.
11327 #:python ,python-2))
11328 (native-inputs
11329 `(("python2-unittest2" ,python2-unittest2)))
11330 (home-page "https://github.com/jdunck/python-unicodecsv")
11331 (synopsis "Unicode CSV module for Python 2")
11332 (description "Unicodecsv is a drop-in replacement for Python 2.7's CSV
11333 module, adding support for Unicode strings.")
11334 (license license:bsd-2)))
11335
11336 (define-public python-rarfile
11337 (package
11338 (name "python-rarfile")
11339 (version "2.8")
11340 (source (origin
11341 (method url-fetch)
11342 (uri (pypi-uri "rarfile" version))
11343 (sha256
11344 (base32
11345 "0qfad483kcbga0bn4qmcz953xjk16r52fahiy46zzn56v80y89ra"))))
11346 (build-system python-build-system)
11347 (arguments
11348 '(#:phases
11349 (modify-phases %standard-phases
11350 (replace 'check
11351 ;; Many tests fail, but the installation proceeds.
11352 (lambda _ (zero? (system* "make" "-C" "test" "test")))))))
11353 (native-inputs
11354 `(("which" ,which))) ; required for tests
11355 (propagated-inputs
11356 `(("libarchive" ,libarchive)))
11357 (home-page "https://github.com/markokr/rarfile")
11358 (synopsis "RAR archive reader for Python")
11359 (description "This is Python module for RAR archive reading. The interface
11360 is made as zipfile like as possible.")
11361 (license license:isc)))
11362
11363 (define-public python2-rarfile
11364 (package-with-python2 python-rarfile))
11365
11366 (define-public python-magic
11367 (package
11368 (name "python-magic")
11369 (version "0.4.3")
11370 (source
11371 (origin
11372 (method url-fetch)
11373 (uri (string-append "https://github.com/ahupp/python-magic/archive/"
11374 version ".tar.gz"))
11375 (sha256
11376 (base32
11377 "17bgy92i7sb021f2s4mw1dcvpm6p1mi9jihridwy1pyn8mzvpjgk"))
11378 (file-name (string-append name "-" version "-checkout"))))
11379 (build-system python-build-system)
11380 (arguments
11381 ;; The tests are unreliable, so don't run them. The tests fail
11382 ;; under Python3 because they were written for Python2 and
11383 ;; contain import statements that do not work in Python3. One of
11384 ;; the tests fails under Python2 because its assertions are
11385 ;; overly stringent; it relies on comparing output strings which
11386 ;; are brittle and can change depending on the version of
11387 ;; libmagic being used and the system on which the test is
11388 ;; running. In my case, under GuixSD 0.10.0, only one test
11389 ;; failed, and it seems to have failed only because the version
11390 ;; of libmagic that is packaged in Guix outputs a slightly
11391 ;; different (but not wrong) string than the one that the test
11392 ;; expected.
11393 '(#:tests? #f
11394 #:phases (modify-phases %standard-phases
11395 ;; Replace a specific method call with a hard-coded
11396 ;; path to the necessary libmagic.so file in the
11397 ;; store. If we don't do this, then the method call
11398 ;; will fail to find the libmagic.so file, which in
11399 ;; turn will cause any application using
11400 ;; python-magic to fail.
11401 (add-before 'build 'hard-code-path-to-libmagic
11402 (lambda* (#:key inputs #:allow-other-keys)
11403 (let ((file (assoc-ref inputs "file")))
11404 (substitute* "magic.py"
11405 (("ctypes.util.find_library\\('magic'\\)")
11406 (string-append "'" file "/lib/libmagic.so'")))
11407 #t)))
11408 (add-before 'install 'disable-egg-compression
11409 (lambda _
11410 (let ((port (open-file "setup.cfg" "a")))
11411 (display "\n[easy_install]\nzip_ok = 0\n"
11412 port)
11413 (close-port port)
11414 #t))))))
11415 (inputs
11416 ;; python-magic needs to be able to find libmagic.so.
11417 `(("file" ,file)))
11418 (home-page "https://github.com/ahupp/python-magic")
11419 (synopsis "File type identification using libmagic")
11420 (description
11421 "This module uses ctypes to access the libmagic file type
11422 identification library. It makes use of the local magic database and
11423 supports both textual and MIME-type output. Note that this module and
11424 the python-file module both provide a \"magic.py\" file; these two
11425 modules, which are different and were developed separately, both serve
11426 the same purpose: to provide Python bindings for libmagic.")
11427 (license license:expat)))
11428
11429 (define-public python2-magic
11430 (package-with-python2 python-magic))
11431
11432 (define-public python2-s3cmd
11433 (package
11434 (name "python2-s3cmd")
11435 (version "1.6.1")
11436 (source
11437 (origin
11438 (method url-fetch)
11439 (uri (string-append "mirror://sourceforge/s3tools/s3cmd/" version "/"
11440 "s3cmd-" version ".tar.gz"))
11441 (sha256
11442 (base32
11443 "0ki1rzhm5icvi9ry5jswi4b22yqwyj0d2wsqsgilwx6qhi7pjxa6"))))
11444 (build-system python-build-system)
11445 (arguments
11446 ;; s3cmd is written for python2 only and contains no tests.
11447 `(#:python ,python-2
11448 #:tests? #f))
11449 (propagated-inputs
11450 `(("python2-dateutil" ,python2-dateutil)
11451 ;; The python-file package also provides a magic.py module.
11452 ;; This is an unfortunate state of affairs; however, s3cmd
11453 ;; fails to install if it cannot find specifically the
11454 ;; python-magic package. Thus we include it, instead of using
11455 ;; python-file. Ironically, s3cmd sometimes works better
11456 ;; without libmagic bindings at all:
11457 ;; https://github.com/s3tools/s3cmd/issues/198
11458 ("python2-magic" ,python2-magic)))
11459 (home-page "http://s3tools.org/s3cmd")
11460 (synopsis "Command line tool for S3-compatible storage services")
11461 (description
11462 "S3cmd is a command line tool for uploading, retrieving and managing data
11463 in storage services that are compatible with the Amazon Simple Storage
11464 Service (S3) protocol, including S3 itself. It supports rsync-like backup,
11465 GnuPG encryption, and more. It also supports management of Amazon's
11466 CloudFront content delivery network.")
11467 (license license:gpl2+)))
11468
11469 (define-public python-pkgconfig
11470 (package
11471 (name "python-pkgconfig")
11472 (version "1.1.0")
11473 (source
11474 (origin
11475 (method url-fetch)
11476 (uri (pypi-uri "pkgconfig" version))
11477 (sha256
11478 (base32
11479 "1pw0kmvc57sjmaxi6c54fqsnihqj6hvhc9y1vaz36axafzqam7bh"))))
11480 (build-system python-build-system)
11481 (native-inputs
11482 `(("python-nose" ,python-nose)))
11483 (inputs
11484 `(("pkg-config" ,pkg-config)))
11485 (arguments
11486 `(;; Tests fail with "ValueError: _type_ 'v' not supported" on Python 3,
11487 ;; and on Python 2 they need the dl module deprecated since Python 2.6.
11488 #:tests? #f
11489 ;; Hard-code the path to pkg-config.
11490 #:phases
11491 (modify-phases %standard-phases
11492 (add-before
11493 'build 'patch
11494 (lambda _
11495 (substitute* "pkgconfig/pkgconfig.py"
11496 (("cmd = 'pkg-config")
11497 (string-append "cmd = '" (which "pkg-config"))))
11498 #t)))))
11499 (home-page "https://github.com/matze/pkgconfig")
11500 (synopsis "Python interface for pkg-config")
11501 (description "This module provides a Python interface to pkg-config. It
11502 can be used to find all pkg-config packages, check if a package exists,
11503 check if a package meets certain version requirements, query CFLAGS and
11504 LDFLAGS and parse the output to build extensions with setup.py.")
11505 (license license:expat)))
11506
11507 (define-public python2-pkgconfig
11508 (package-with-python2 python-pkgconfig))
11509
11510 (define-public python-bz2file
11511 (package
11512 (name "python-bz2file")
11513 (version "0.98")
11514 (source
11515 (origin
11516 (method url-fetch)
11517 (uri (pypi-uri "bz2file" version))
11518 (sha256
11519 (base32
11520 "126s53fkpx04f33a829yqqk8fj4png3qwg4m66cvlmhmwc8zihb4"))))
11521 (build-system python-build-system)
11522 (arguments
11523 `(#:tests? #f)) ; Tests use deprecated python modules.
11524 (home-page "https://github.com/nvawda/bz2file")
11525 (synopsis "Read and write bzip2-compressed files")
11526 (description
11527 "Bz2file is a Python library for reading and writing bzip2-compressed
11528 files. It contains a drop-in replacement for the I/O interface in the
11529 standard library's @code{bz2} module, including features from the latest
11530 development version of CPython that are not available in older releases.")
11531 (license license:asl2.0)
11532 (properties `((python2-variant . ,(delay python2-bz2file))))))
11533
11534 (define-public python2-bz2file
11535 (let ((base (package-with-python2
11536 (strip-python2-variant python-bz2file))))
11537 (package
11538 (inherit base)
11539 (arguments
11540 `(#:python ,python-2
11541 #:phases
11542 (modify-phases %standard-phases
11543 ;; 'python setup.py test' does not work as of 0.98.
11544 ;; There is only the one test file, so we run it directly.
11545 (replace 'check
11546 (lambda _ (zero? (system* "python"
11547 "test_bz2file.py"))))))))))
11548
11549 (define-public python-future
11550 (package
11551 (name "python-future")
11552 (version "0.16.0")
11553 (source
11554 (origin
11555 (method url-fetch)
11556 (uri (pypi-uri "future" version))
11557 (sha256
11558 (base32
11559 "1nzy1k4m9966sikp0qka7lirh8sqrsyainyf8rk97db7nwdfv773"))))
11560 (build-system python-build-system)
11561 ;; Many tests connect to the network or are otherwise flawed.
11562 ;; https://github.com/PythonCharmers/python-future/issues/210
11563 (arguments
11564 `(#:tests? #f))
11565 (home-page "http://python-future.org")
11566 (synopsis "Single-source support for Python 3 and 2")
11567 (description
11568 "@code{python-future} is the missing compatibility layer between Python 2 and
11569 Python 3. It allows you to use a single, clean Python 3.x-compatible codebase
11570 to support both Python 2 and Python 3 with minimal overhead.")
11571 (license license:expat)))
11572
11573 (define-public python2-future
11574 (package-with-python2 python-future))
11575
11576 (define-public python-cysignals
11577 (package
11578 (name "python-cysignals")
11579 (version "1.1.0")
11580 (source
11581 (origin
11582 (method url-fetch)
11583 (uri (pypi-uri "cysignals" version ".tar.bz2"))
11584 (sha256
11585 (base32
11586 "14cbyd9znlz6cxy1s3g6v6dv5jj45hn27pywkidd9b1zanaysqc6"))))
11587 (build-system python-build-system)
11588 (native-inputs
11589 `(("python-cython" ,python-cython)
11590 ("python-sphinx" ,python-sphinx)))
11591 (inputs
11592 `(("pari-gp" ,pari-gp)))
11593 (arguments
11594 `(#:modules ((guix build python-build-system)
11595 ((guix build gnu-build-system) #:prefix gnu:)
11596 (guix build utils))
11597 ;; FIXME: Tests are executed after installation and currently fail
11598 ;; when not installing into standard locations; the author is working
11599 ;; on a fix.
11600 #:tests? #f
11601 #:phases
11602 (modify-phases %standard-phases
11603 (add-before
11604 'build 'configure
11605 (assoc-ref gnu:%standard-phases 'configure)))))
11606 (home-page
11607 "https://github.com/sagemath/cysignals")
11608 (synopsis
11609 "Handling of interrupts and signals for Cython")
11610 (description
11611 "The cysignals package provides mechanisms to handle interrupts (and
11612 other signals and errors) in Cython code, using two related approaches,
11613 for mixed Cython/Python code or external C libraries and pure Cython code,
11614 respectively.")
11615 (license license:lgpl3+)))
11616
11617 (define-public python2-cysignals
11618 (package-with-python2 python-cysignals))
11619
11620 (define-public python2-shedskin
11621 (package
11622 (name "python2-shedskin")
11623 (version "0.9.4")
11624 (source
11625 (origin
11626 (method url-fetch)
11627 (uri (string-append "https://github.com/shedskin/shedskin/"
11628 "releases/download/v" version
11629 "/shedskin-" version ".tgz"))
11630 (sha256
11631 (base32
11632 "0nzwrzgw1ga8rw6f0ryq7zr9kkiavd1cqz5hzxkcbicl1dk7kz41"))))
11633 (build-system python-build-system)
11634 (arguments
11635 `(#:python ,python-2
11636 #:phases (modify-phases %standard-phases
11637 (add-after 'unpack 'fix-resulting-include-libs
11638 (lambda* (#:key inputs #:allow-other-keys)
11639 (let ((libgc (assoc-ref inputs "libgc"))
11640 (pcre (assoc-ref inputs "pcre")))
11641 (substitute* "shedskin/makefile.py"
11642 (("variable == 'CCFLAGS':[ ]*")
11643 (string-append "variable == 'CCFLAGS':\n"
11644 " line += ' -I " pcre "/include"
11645 " -I " libgc "/include'"))
11646 (("variable == 'LFLAGS':[ ]*")
11647 (string-append "variable == 'LFLAGS':\n"
11648 " line += ' -L" pcre "/lib"
11649 " -L " libgc "/lib'")))
11650 #t))))))
11651 (inputs `(("pcre" ,pcre)
11652 ("libgc" ,libgc)))
11653 (home-page "https://shedskin.github.io/")
11654 (synopsis "Experimental Python-2 to C++ Compiler")
11655 (description (string-append "This is an experimental compiler for a subset of
11656 Python. It generates C++ code and a Makefile."))
11657 (license (list license:gpl3 license:bsd-3 license:expat))))
11658
11659 (define-public python2-rope
11660 (package
11661 (name "python2-rope")
11662 (version "0.10.3")
11663 (source
11664 (origin
11665 (method url-fetch)
11666 (uri (pypi-uri "rope" version))
11667 (sha256
11668 (base32
11669 "18k5znhpwvrfck3yp0jmhd5j8r0f0s8bk1zh5yhs2cfgmfhbwigb"))))
11670 (arguments
11671 ;; Rope is currently python-2 only.
11672 ;; https://github.com/python-rope/rope/issues/57
11673 `(#:python ,python-2))
11674 (build-system python-build-system)
11675 (native-inputs
11676 `(("python2-unittest2" ,python2-unittest2)))
11677 (home-page "https://github.com/python-rope/rope")
11678 (synopsis "Refactoring library for Python")
11679 (description "Rope is a refactoring library for Python. It facilitates
11680 the renaming, moving and extracting of attributes, functions, modules, fields
11681 and parameters in Python 2 source code. These refactorings can also be applied
11682 to occurrences in strings and comments.")
11683 (license license:gpl2)))
11684
11685 (define-public python-py3status
11686 (package
11687 (name "python-py3status")
11688 (version "3.1")
11689 (source
11690 (origin
11691 (method url-fetch)
11692 (uri (pypi-uri "py3status" version))
11693 (sha256
11694 (base32
11695 "0i283z1pivmir61z8kbiycigc94l61v33ygzkhczf1ifq7cppyds"))))
11696 (build-system python-build-system)
11697 (inputs
11698 `(("file" ,file)))
11699 (arguments
11700 '(#:phases
11701 (modify-phases %standard-phases
11702 ;; 'file' is used for detection of configuration file encoding
11703 ;; let's make link the dependency to particular input
11704 (add-before 'build 'patch-file-path
11705 (lambda* (#:key inputs #:allow-other-keys)
11706 (let ((file-path (assoc-ref inputs "file")))
11707 (substitute* "py3status/parse_config.py"
11708 (("check_output\\(\\['file'")
11709 (string-append "check_output(['" file-path "/bin/file'")))
11710 #t))))
11711 #:tests? #f)) ; TODO: Requires many libraries not in Guix.
11712 (home-page "https://github.com/ultrabug/py3status")
11713 (synopsis "Extensible i3status wrapper written in Python")
11714 (description "py3status is an i3status wrapper which extends i3status
11715 functionality in a modular way, allowing you to extend your panel with your
11716 own code, responding to click events and updating clock every second.")
11717 (license license:bsd-3)))
11718
11719 (define-public python-tblib
11720 (package
11721 (name "python-tblib")
11722 (version "1.3.0")
11723 (source (origin
11724 (method url-fetch)
11725 (uri (pypi-uri "tblib" version))
11726 (sha256 (base32
11727 "02iahfkfa927hb4jq2bak36ldihwapzacfiq5lyxg8llwn98a1yi"))))
11728 (build-system python-build-system)
11729 (arguments
11730 `(#:phases
11731 (modify-phases %standard-phases
11732 (replace 'check
11733 (lambda _
11734 ;; Upstream runs tests after installation and the package itself
11735 ;; resides in a subdirectory. Extend PYTHONPATH so it will be
11736 ;; found.
11737 (setenv "PYTHONPATH"
11738 (string-append (getcwd) "/build/lib:"
11739 (getenv "PYTHONPATH")))
11740 (zero? (system* "py.test" "-vv" "tests" "README.rst")))))))
11741 (native-inputs
11742 `(("python-pytest" ,python-pytest)
11743 ("python-six" ,python-six)))
11744 (home-page "https://github.com/ionelmc/python-tblib")
11745 (synopsis "Traceback serialization library")
11746 (description
11747 "Traceback serialization allows you to:
11748
11749 @enumerate
11750 @item Pickle tracebacks and raise exceptions with pickled tracebacks in
11751 different processes. This allows better error handling when running code over
11752 multiple processes (imagine multiprocessing, billiard, futures, celery etc).
11753
11754 @item Parse traceback strings and raise with the parsed tracebacks.
11755 @end enumerate\n")
11756 (license license:bsd-3)))
11757
11758 (define-public python2-tblib
11759 (package-with-python2 python-tblib))
11760
11761 (define-public python-sqlparse
11762 (package
11763 (name "python-sqlparse")
11764 (version "0.1.19")
11765 (source (origin
11766 (method url-fetch)
11767 (uri (pypi-uri "sqlparse" version))
11768 (sha256
11769 (base32
11770 "1s2fvaxgh9kqzrd6iwy5h7i61ckn05plx9np13zby93z3hdbx5nq"))))
11771 (build-system python-build-system)
11772 (arguments
11773 `(#:phases
11774 (modify-phases %standard-phases
11775 (replace 'check
11776 (lambda* _
11777 ;; setup.py-integrated 2to3 only affects the build files, but
11778 ;; py.test is using the source files. So we need to convert them
11779 ;; manually.
11780 (when (zero? (system* "python3"))
11781 (system* "2to3" "--no-diff" "-wn" "sqlparse" "tests"))
11782 (zero? (system* "py.test")))))))
11783 (native-inputs
11784 `(("python-pytest" ,python-pytest)))
11785 (home-page "https://github.com/andialbrecht/sqlparse")
11786 (synopsis "Non-validating SQL parser")
11787 (description "Sqlparse is a non-validating SQL parser for Python. It
11788 provides support for parsing, splitting and formatting SQL statements.")
11789 (license license:bsd-3)))
11790
11791 (define-public python2-sqlparse
11792 (package-with-python2 python-sqlparse))
11793
11794 (define-public python-greenlet
11795 (package
11796 (name "python-greenlet")
11797 (version "0.4.11")
11798 (source (origin
11799 (method url-fetch)
11800 (uri (pypi-uri "greenlet" version))
11801 (sha256
11802 (base32
11803 "1xhik26j4f3kc4qw9xmj0c567rb5h1zryb4ijwqnqwwjvfhbv59h"))))
11804 (build-system python-build-system)
11805 (home-page "https://greenlet.readthedocs.io/")
11806 (synopsis "Lightweight in-process concurrent programming")
11807 (description
11808 "Greenlet package is a spin-off of Stackless, a version of CPython
11809 that supports micro-threads called \"tasklets\". Tasklets run
11810 pseudo-concurrently (typically in a single or a few OS-level threads) and
11811 are synchronized with data exchanges on \"channels\".")
11812 (license (list license:psfl license:expat))))
11813
11814 (define-public python2-greenlet
11815 (package-with-python2 python-greenlet))
11816
11817 (define-public python-gevent
11818 (package
11819 (name "python-gevent")
11820 (version "1.1.1")
11821 (source (origin
11822 (method url-fetch)
11823 (uri (pypi-uri "gevent" version))
11824 (sha256
11825 (base32
11826 "1smf3kvidpdiyi2c81alal74p2zm0clrm6xbyy6y1k9a3f2vkrbf"))
11827 (modules '((guix build utils)))
11828 (snippet
11829 '(begin
11830 ;; unbunding libev and c-ares
11831 (for-each delete-file-recursively '("libev" "c-ares"))
11832 ;; fixing testsuite
11833 (call-with-output-file "greentest/__init__.py" noop)
11834 (substitute* "greentest/testrunner.py"
11835 (("import util") "from . import util")
11836 (("from util import log") "from .util import log"))))))
11837 (build-system python-build-system)
11838 (propagated-inputs
11839 `(("python-greenlet" ,python-greenlet)))
11840 (native-inputs
11841 `(("python-six" ,python-six)))
11842 (inputs
11843 `(("c-ares" ,c-ares)
11844 ("libev" ,libev)))
11845 (home-page "http://www.gevent.org/")
11846 (synopsis "Coroutine-based network library")
11847 (description
11848 "gevent is a coroutine-based Python networking library that uses greenlet
11849 to provide a high-level synchronous API on top of the libev event loop.")
11850 (license license:expat)))
11851
11852 (define-public python2-gevent
11853 (package-with-python2 python-gevent))
11854
11855 (define-public python-geventhttpclient
11856 (package
11857 (name "python-geventhttpclient")
11858 (version "1.3.1")
11859 (source (origin
11860 (method url-fetch)
11861 (uri (pypi-uri "geventhttpclient" version))
11862 (sha256
11863 (base32
11864 "07d0q3wzmml75227r6y6mrl5a0zpf4v9gj0ni5rhbyzmaj4az1xx"))
11865 (modules '((guix build utils)))
11866 (snippet
11867 '(begin
11868 ;; Delete pre-compiled files.
11869 (for-each delete-file (find-files "src/geventhttpclient"
11870 ".*\\.pyc"))
11871 #t))))
11872 (build-system python-build-system)
11873 (arguments
11874 '(#:phases
11875 (modify-phases %standard-phases
11876 (add-after 'unpack 'delete-network-tests
11877 (lambda _
11878 (delete-file "src/geventhttpclient/tests/test_client.py")
11879 #t))
11880 (delete 'check)
11881 (add-after 'install 'check
11882 (lambda* (#:key inputs outputs #:allow-other-keys)
11883 (add-installed-pythonpath inputs outputs)
11884 (zero? (system* "py.test" "src/geventhttpclient/tests" "-v")))))))
11885 (native-inputs
11886 `(("python-pytest" ,python-pytest)))
11887 (propagated-inputs
11888 `(("python-certifi" ,python-certifi)
11889 ("python-gevent" ,python-gevent)
11890 ("python-six" ,python-six)))
11891 (home-page "https://github.com/gwik/geventhttpclient")
11892 (synopsis "HTTP client library for gevent")
11893 (description "@code{python-geventhttpclient} is a high performance,
11894 concurrent HTTP client library for python using @code{gevent}.")
11895 (license license:expat)))
11896
11897 (define-public python2-geventhttpclient
11898 (package-with-python2 python-geventhttpclient))
11899
11900 (define-public python-fastimport
11901 (package
11902 (name "python-fastimport")
11903 (version "0.9.6")
11904 (source
11905 (origin
11906 (method url-fetch)
11907 (uri (pypi-uri "fastimport" version))
11908 (sha256
11909 (base32 "1aqjsin4rmqm7ln4j0p73fzxifws6c6ikgyhav7r137m2ixsxl43"))))
11910 (build-system python-build-system)
11911 (home-page "https://github.com/jelmer/python-fastimport")
11912 (synopsis "VCS fastimport parser and generator in Python")
11913 (description "This package provides a parser for and generator of the Git
11914 @url{https://www.kernel.org/pub/software/scm/git/docs/git-fast-import.html,fastimport}
11915 format.")
11916 (license license:gpl2+)))
11917
11918 (define-public python2-fastimport
11919 (package-with-python2 python-fastimport))
11920
11921 (define-public python-twisted
11922 (package
11923 (name "python-twisted")
11924 (version "17.1.0")
11925 (source (origin
11926 (method url-fetch)
11927 (uri (pypi-uri "Twisted" version ".tar.bz2"))
11928 (sha256
11929 (base32
11930 "1p245mg15hkxp7hy5cyq2fgvlgjkb4cg0gwkwd148nzy1bbi3wnv"))))
11931 (build-system python-build-system)
11932 (arguments
11933 '(#:tests? #f)) ; FIXME: Some tests are failing.
11934 ;; #:phases
11935 ;; (modify-phases %standard-phases
11936 ;; (replace 'check
11937 ;; (lambda _
11938 ;; (zero? (system* "./bin/trial" "twisted")))))
11939 (propagated-inputs
11940 `(("python-zope-interface" ,python-zope-interface)
11941 ("python-incremental" ,python-incremental)
11942 ("python-constantly" ,python-constantly)
11943 ("python-automat" ,python-automat)))
11944 (home-page "https://twistedmatrix.com/")
11945 (synopsis "Asynchronous networking framework written in Python")
11946 (description
11947 "Twisted is an extensible framework for Python programming, with special
11948 focus on event-based network programming and multiprotocol integration.")
11949 (license license:expat)))
11950
11951 (define-public python2-twisted
11952 (package-with-python2 python-twisted))
11953
11954 (define-public python-pika
11955 (package
11956 (name "python-pika")
11957 (version "0.10.0")
11958 (source
11959 (origin
11960 (method url-fetch)
11961 (uri (pypi-uri "pika" version))
11962 (sha256
11963 (base32
11964 "0nb4h08di432lv7dy2v9kpwgk0w92f24sqc2hw2s9vwr5b8v8xvj"))))
11965 (build-system python-build-system)
11966 (native-inputs
11967 `(("python-pyev" ,python-pyev)
11968 ("python-tornado" ,python-tornado)
11969 ("python-twisted" ,python-twisted)))
11970 (home-page "https://pika.readthedocs.org")
11971 (synopsis "Pure Python AMQP Client Library")
11972 (description
11973 "Pika is a pure-Python implementation of the AMQP (Advanced Message Queuing
11974 Protocol) 0-9-1 protocol that tries to stay fairly independent of the underlying
11975 network support library.")
11976 (license license:bsd-3)))
11977
11978 (define-public python2-pika
11979 (package-with-python2 python-pika))
11980
11981 (define-public python-ply
11982 (package
11983 (name "python-ply")
11984 (version "3.9")
11985 (source
11986 (origin
11987 (method url-fetch)
11988 (uri (pypi-uri "ply" version))
11989 (sha256
11990 (base32
11991 "0gpl0yli3w03ipyqfrp3w5nf0iawhsq65anf5wwm2wf5p502jzhd"))))
11992 (build-system python-build-system)
11993 (home-page "http://www.dabeaz.com/ply/")
11994 (synopsis "Python Lex & Yacc")
11995 (description "PLY is a @code{lex}/@code{yacc} implemented purely in Python.
11996 It uses LR parsing and does extensive error checking.")
11997 (license license:bsd-3)))
11998
11999 (define-public python2-ply
12000 (package-with-python2 python-ply))
12001
12002 (define-public python-tabulate
12003 (package
12004 (name "python-tabulate")
12005 (version "0.7.7")
12006 (source (origin
12007 (method url-fetch)
12008 (uri (pypi-uri "tabulate" version))
12009 (sha256
12010 (base32
12011 "1inqhspd4frxnp08c32yndr0lc4px1xfkqah184i5w09gkhvi843"))))
12012 (build-system python-build-system)
12013 (arguments
12014 ;; FIXME: The pypi release tarball is missing a 'test/common.py'
12015 ;; and the latest release is not tagged in the upstream repository.
12016 '(#:tests? #f))
12017 (home-page "https://bitbucket.org/astanin/python-tabulate")
12018 (synopsis "Pretty-print tabular data")
12019 (description
12020 "Tabulate is a library and command-line utility to pretty-print tabular
12021 data in Python.")
12022 (license license:expat)))
12023
12024 (define-public python2-tabulate
12025 (package-with-python2 python-tabulate))
12026
12027 (define-public python-kazoo
12028 (package
12029 (name "python-kazoo")
12030 (version "2.2.1")
12031 (source
12032 (origin
12033 (method url-fetch)
12034 (uri (pypi-uri "kazoo" version))
12035 (sha256
12036 (base32
12037 "10pb864if9qi2pq9lfb9m8f7z7ss6rml80gf1d9h64lap5crjnjj"))))
12038 (build-system python-build-system)
12039 (arguments '(#:tests? #f)) ; XXX: needs zookeeper
12040 (propagated-inputs
12041 `(("python-six" ,python-six)))
12042 (home-page "https://kazoo.readthedocs.org")
12043 (synopsis "High-level Zookeeper client library")
12044 (description
12045 "Kazoo is a Python client library for the Apache Zookeeper distributed
12046 application service. It is designed to be easy to use and to avoid common
12047 programming errors.")
12048 (license license:asl2.0)))
12049
12050 (define-public python2-kazoo
12051 (package-with-python2 python-kazoo))
12052
12053 (define-public python-pykafka
12054 (package
12055 (name "python-pykafka")
12056 (version "2.4.0")
12057 (source (origin
12058 (method url-fetch)
12059 (uri (string-append
12060 "https://pypi.python.org/packages/8b/3e/"
12061 "384eeff406b06315738b62483fd2126c6e4f544167116b17cc04ea7d2a59/"
12062 "pykafka-" version ".tar.gz"))
12063 (sha256
12064 (base32
12065 "1id6sr159p6aa13bxcqyr9gln8sqg1l0ddzns5iws8kk5q1p5cfv"))))
12066 (build-system python-build-system)
12067 (arguments '(#:tests? #f)) ; XXX: needs zookeeper, kafka, etc.
12068 (propagated-inputs
12069 `(("python-gevent" ,python-gevent)
12070 ("python-kazoo" ,python-kazoo)
12071 ("python-tabulate" ,python-tabulate)))
12072 (inputs
12073 `(("librdkafka" ,librdkafka)))
12074 (home-page "https://pykafka.readthedocs.io/")
12075 (synopsis "Apache Kafka client for Python")
12076 (description
12077 "PyKafka is a client for the Apache Kafka distributed messaging system.
12078 It includes Python implementations of Kafka producers and consumers, which
12079 are optionally backed by a C extension built on librdkafka.")
12080 (license license:asl2.0)))
12081
12082 (define-public python2-pykafka
12083 (package-with-python2 python-pykafka))
12084
12085 (define-public python-wcwidth
12086 (package
12087 (name "python-wcwidth")
12088 (version "0.1.7")
12089 (source
12090 (origin
12091 (method url-fetch)
12092 (uri (pypi-uri "wcwidth" version))
12093 (sha256
12094 (base32
12095 "0pn6dflzm609m4r3i8ik5ni9ijjbb5fa3vg1n7hn6vkd49r77wrx"))))
12096 (build-system python-build-system)
12097 (home-page "https://github.com/jquast/wcwidth")
12098 (synopsis "Measure number of terminal column cells of wide-character codes")
12099 (description "Wcwidth measures the number of terminal column cells of
12100 wide-character codes. It is useful for those implementing a terminal emulator,
12101 or programs that carefully produce output to be interpreted by one. It is a
12102 Python implementation of the @code{wcwidth} and @code{wcswidth} C functions
12103 specified in POSIX.1-2001 and POSIX.1-2008.")
12104 (license license:expat)))
12105
12106 (define-public python2-wcwidth
12107 (package-with-python2 python-wcwidth))
12108
12109 (define-public python2-jsonrpclib
12110 (package
12111 (name "python2-jsonrpclib")
12112 (version "0.1.7")
12113 (source (origin
12114 (method url-fetch)
12115 (uri (string-append
12116 "https://pypi.python.org/packages/source/j/jsonrpclib/"
12117 "jsonrpclib-" version ".tar.gz"))
12118 (sha256
12119 (base32
12120 "02vgirw2bcgvpcxhv5hf3yvvb4h5wzd1lpjx8na5psdmaffj6l3z"))))
12121 (build-system python-build-system)
12122 (arguments
12123 `(#:tests? #f
12124 #:python ,python-2))
12125 (home-page "https://github.com/joshmarshall/jsonrpclib/")
12126 (synopsis "Implementation of JSON-RPC specification for Python")
12127 (description
12128 "This library is an implementation of the JSON-RPC specification.
12129 It supports both the original 1.0 specification, as well as the
12130 new (proposed) 2.0 spec, which includes batch submission, keyword arguments,
12131 etc.")
12132 (license license:asl2.0)))
12133
12134 (define-public python-chai
12135 (package
12136 (name "python-chai")
12137 (version "1.1.1")
12138 (source (origin
12139 (method url-fetch)
12140 (uri (pypi-uri "chai" version))
12141 (sha256
12142 (base32
12143 "016kf3irrclpkpvcm7q0gmkfibq7jgy30a9v73pp42bq9h9a32bl"))))
12144 (build-system python-build-system)
12145 (home-page "https://github.com/agoragames/chai")
12146 (synopsis "Mocking framework for Python")
12147 (description
12148 "Chai provides an api for mocking, stubbing and spying your python
12149 objects, patterned after the Mocha library for Ruby.")
12150 (license license:bsd-3)))
12151
12152 (define-public python2-chai
12153 (package-with-python2 python-chai))
12154
12155 (define-public python-arrow
12156 (package
12157 (name "python-arrow")
12158 (version "0.10.0")
12159 (source (origin
12160 (method url-fetch)
12161 (uri (pypi-uri "arrow" version))
12162 (sha256
12163 (base32
12164 "08n7q2l69hlainds1byd4lxhwrq7zsw7s640zkqc3bs5jkq0cnc0"))))
12165 (build-system python-build-system)
12166 (native-inputs
12167 `(;; For testing
12168 ("python-chai" ,python-chai)
12169 ("python-simplejson" ,python-simplejson)))
12170 (propagated-inputs
12171 `(("python-dateutil" ,python-dateutil)))
12172 (home-page "https://github.com/crsmithdev/arrow/")
12173 (synopsis "Dates and times for Python")
12174 (description
12175 "Arrow is a Python library to creating, manipulating, formatting and
12176 converting dates, times, and timestamps. It implements and updates the
12177 datetime type.")
12178 (license license:asl2.0)))
12179
12180 (define-public python2-arrow
12181 (package-with-python2 python-arrow))
12182
12183 (define-public python-inflection
12184 (package
12185 (name "python-inflection")
12186 (version "0.3.1")
12187 (source
12188 (origin (method url-fetch)
12189 (uri (pypi-uri "inflection" version))
12190 (sha256
12191 (base32
12192 "1jhnxgnw8y3mbzjssixh6qkc7a3afc4fygajhqrqalnilyvpzshq"))))
12193 (build-system python-build-system)
12194 (native-inputs
12195 `(("python-pytest" ,python-pytest)))
12196 (home-page "https://github.com/jpvanhal/inflection")
12197 (synopsis "Python string transformation library")
12198 (description
12199 "Inflection is a string transformation library. It singularizes
12200 and pluralizes English words, and transforms strings from CamelCase to
12201 underscored string.")
12202 (license license:expat)))
12203
12204 (define-public python2-inflection
12205 (package-with-python2 python-inflection))
12206
12207 (define-public python-pylev
12208 (package
12209 (name "python-pylev")
12210 (version "1.3.0")
12211 (source (origin
12212 (method url-fetch)
12213 (uri (pypi-uri "pylev" version))
12214 (sha256
12215 (base32
12216 "1hz1x9blsbxya1y9nnhnwwdnqmakxi9mc0jkwj0rn6b1h44i0f86"))))
12217 (build-system python-build-system)
12218 (home-page "https://github.com/toastdriven/pylev")
12219 (synopsis "Levenshtein distance implementation in Python")
12220 (description "Pure Python Levenshtein implementation, based off the
12221 Wikipedia code samples at
12222 @url{http://en.wikipedia.org/wiki/Levenshtein_distance}.")
12223 (license license:bsd-3)))
12224
12225 (define-public python2-pylev
12226 (package-with-python2 python-pylev))
12227
12228 (define-public python-cleo
12229 (package
12230 (name "python-cleo")
12231 (version "0.6.1")
12232 (source (origin
12233 (method url-fetch)
12234 (uri (pypi-uri "cleo" version))
12235 (sha256
12236 (base32
12237 "0q1cf0szr0d54am4pypzwdnm74zpladdsinad94c2fz5i06fdpf7"))))
12238 (build-system python-build-system)
12239 (native-inputs
12240 `(;; For testing
12241 ("python-mock" ,python-mock)
12242 ("python-pytest-mock" ,python-pytest-mock)
12243 ("python-pytest" ,python-pytest)))
12244 (propagated-inputs
12245 `(("python-backpack" ,python-backpack)
12246 ("python-pastel" ,python-pastel)
12247 ("python-pylev" ,python-pylev)))
12248 (home-page "https://github.com/sdispater/cleo")
12249 (synopsis "Command-line arguments library for Python")
12250 (description
12251 "Cleo allows you to create command-line commands with signature in
12252 docstring and colored output.")
12253 (license license:expat)))
12254
12255 (define-public python2-cleo
12256 (package-with-python2 python-cleo))
12257
12258 (define-public python-lazy-object-proxy
12259 (package
12260 (name "python-lazy-object-proxy")
12261 (version "1.2.2")
12262 (source (origin
12263 (method url-fetch)
12264 (uri (pypi-uri "lazy-object-proxy" version))
12265 (sha256
12266 (base32
12267 "0s22aqqkdscyh8sjspyyax7qa1aiz8p4midrnyf39717fhfczm6x"))))
12268 (build-system python-build-system)
12269 (home-page "https://github.com/ionelmc/python-lazy-object-proxy")
12270 (synopsis "Lazy object proxy for python")
12271 (description
12272 "Lazy object proxy is an object that wraps a callable but defers the call
12273 until the object is actually required, and caches the result of said call.")
12274 (license license:bsd-2)))
12275
12276 (define-public python2-lazy-object-proxy
12277 (package-with-python2 python-lazy-object-proxy))
12278
12279 (define-public python-dnspython
12280 (package
12281 (name "python-dnspython")
12282 (version "1.15.0")
12283 (source (origin
12284 (method url-fetch)
12285 (uri (string-append "http://www.dnspython.org/kits/"
12286 version "/dnspython-" version ".tar.gz"))
12287 (sha256
12288 (base32
12289 "0jr4v2pd90i6l1xxbss2m05psbjaxvyvvvpq44wycijpfgjqln8i"))))
12290 (build-system python-build-system)
12291 (arguments '(#:tests? #f)) ; XXX: requires internet access
12292 (home-page "http://www.dnspython.org")
12293 (synopsis "DNS toolkit for Python")
12294 (description
12295 "dnspython is a DNS toolkit for Python. It supports almost all record
12296 types. It can be used for queries, zone transfers, and dynamic updates.
12297 It supports TSIG authenticated messages and EDNS0.")
12298 (license license:expat)))
12299
12300 (define-public python2-dnspython
12301 (package-with-python2 python-dnspython))
12302
12303 (define-public python-email-validator
12304 (package
12305 (name "python-email-validator")
12306 (version "1.0.2")
12307 (source
12308 (origin (method url-fetch)
12309 (uri (pypi-uri "email_validator" version))
12310 (sha256
12311 (base32
12312 "1ja9149l9ck5n45a72h3is7v476hjny5ybxbcamx1nw6iplsm7k6"))))
12313 (build-system python-build-system)
12314 (arguments
12315 '(#:phases
12316 (modify-phases %standard-phases
12317 (add-before 'build 'use-dnspython
12318 (lambda _
12319 (substitute* "setup.py"
12320 (("dnspython3") "dnspython"))
12321 #t)))))
12322 (propagated-inputs
12323 `(("python-dnspython" ,python-dnspython)
12324 ("python-idna" ,python-idna)))
12325 (home-page "https://github.com/JoshData/python-email-validator")
12326 (synopsis "Email address validation library for Python")
12327 (description
12328 "This library validates email address syntax and deliverability.")
12329 (license license:cc0)))
12330
12331 (define-public python2-email-validator
12332 (package-with-python2 python-email-validator))
12333
12334 (define-public python-ukpostcodeparser
12335 (package
12336 (name "python-ukpostcodeparser")
12337 (version "1.0.3")
12338 (source (origin
12339 (method url-fetch)
12340 (uri (pypi-uri "UkPostcodeParser" version))
12341 (sha256
12342 (base32
12343 "1jwg9z4rz51mcka1821rwgycsd0mcicyp1kiwjfa2kvg8bm9p2qd"))))
12344 (build-system python-build-system)
12345 (home-page "https://github.com/hamstah/ukpostcodeparser")
12346 (synopsis "UK Postcode parser for Python")
12347 (description
12348 "This library provides the @code{parse_uk_postcode} function for
12349 parsing UK postcodes.")
12350 (license license:expat)))
12351
12352 (define-public python2-ukpostcodeparser
12353 (package-with-python2 python-ukpostcodeparser))
12354
12355 (define-public python-faker
12356 (package
12357 (name "python-faker")
12358 (version "0.7.9")
12359 (source (origin
12360 (method url-fetch)
12361 (uri (pypi-uri "Faker" version))
12362 (sha256
12363 (base32
12364 "1fh2p2yz0fsdr4fqwxgddwbvfb6qn6vp8yx0qwqzra27yq5d1wsm"))
12365 (patches
12366 (search-patches "python-faker-fix-build-32bit.patch"))
12367 (modules '((guix build utils)))
12368 (snippet
12369 '(begin
12370 (for-each delete-file (find-files "." "\\.pyc$"))
12371 #t))))
12372 (build-system python-build-system)
12373 (arguments
12374 '(#:phases
12375 (modify-phases %standard-phases
12376 (replace 'check
12377 (lambda _
12378 (zero? (system* "python" "-m" "unittest" "-v" "tests")))))))
12379 (native-inputs
12380 `(;; For testing
12381 ("python-email-validator" ,python-email-validator)
12382 ("python-mock" ,python-mock)
12383 ("python-ukpostcodeparser" ,python-ukpostcodeparser)))
12384 (propagated-inputs
12385 `(("python-dateutil" ,python-dateutil)
12386 ("python-six" ,python-six)))
12387 (home-page "https://github.com/joke2k/faker")
12388 (synopsis "Python package that generates fake data")
12389 (description
12390 "Faker is a Python package that generates fake data such as names,
12391 addresses, and phone numbers.")
12392 (license license:expat)
12393 (properties `((python2-variant . ,(delay python2-faker))))))
12394
12395 (define-public python2-faker
12396 (let ((base (package-with-python2 (strip-python2-variant
12397 python-faker))))
12398 (package
12399 (inherit base)
12400 (propagated-inputs
12401 `(("python2-ipaddress" ,python2-ipaddress)
12402 ,@(package-propagated-inputs base))))))
12403
12404 (define-public python-pyaml
12405 (package
12406 (name "python-pyaml")
12407 (version "17.7.2")
12408 (source (origin
12409 (method url-fetch)
12410 (uri (pypi-uri "pyaml" version))
12411 (sha256
12412 (base32
12413 "132grrw0ajq4nrappi3ldbkb952k7yn9b6c7csi2rmvzm1g6ppp2"))))
12414 (build-system python-build-system)
12415 (native-inputs
12416 `(("python-unidecode" ,python-unidecode)))
12417 (propagated-inputs
12418 `(("python-pyyaml" ,python-pyyaml)))
12419 (home-page "https://github.com/mk-fg/pretty-yaml")
12420 (synopsis "YAML pretty-print library for Python")
12421 (description
12422 "pyaml is a PyYAML based python module to produce pretty and readable
12423 YAML-serialized data.")
12424 (license (license:non-copyleft "http://www.wtfpl.net/txt/copying/"))))
12425
12426 (define-public python2-pyaml
12427 (package-with-python2 python-pyaml))
12428
12429 (define-public python-backpack
12430 (package
12431 (name "python-backpack")
12432 (version "0.1")
12433 (source
12434 (origin
12435 (method url-fetch)
12436 (uri (pypi-uri "backpack" version))
12437 (sha256
12438 (base32
12439 "14rq1mvm0jda90lcx9gyyby9dvq4x3js2cmxvd6vl4686ixwyqh1"))))
12440 (build-system python-build-system)
12441 (native-inputs
12442 `(("python-pytest" ,python-pytest)
12443 ("python-nose" ,python-nose)))
12444 (propagated-inputs
12445 `(("python-simplejson" ,python-simplejson)))
12446 (home-page "https://github.com/sdispater/backpack")
12447 (synopsis "Utilities for working with Python collections")
12448 (description "Backpack provides some useful utilities for working with
12449 collections of data.")
12450 (license license:expat)))
12451
12452 (define-public python2-backpack
12453 (package-with-python2 python-backpack))
12454
12455 (define-public python-flexmock
12456 (package
12457 (name "python-flexmock")
12458 (version "0.10.2")
12459 (source (origin
12460 (method url-fetch)
12461 (uri (pypi-uri "flexmock" version))
12462 (sha256
12463 (base32
12464 "0arc6njvs6i9v9hgvzk5m50296g7zy5m9d7pyb43vdsdgxrci5gy"))))
12465 (build-system python-build-system)
12466 (home-page "https://flexmock.readthedocs.org")
12467 (synopsis "Testing library for Python")
12468 (description
12469 "flexmock is a testing library for Python that makes it easy to create
12470 mocks, stubs and fakes.")
12471 (license license:bsd-3)))
12472
12473 (define-public python2-flexmock
12474 (package-with-python2 python-flexmock))
12475
12476 (define-public python-prompt-toolkit
12477 (package
12478 (name "python-prompt-toolkit")
12479 (version "1.0.9")
12480 (source
12481 (origin
12482 (method url-fetch)
12483 (uri (pypi-uri "prompt_toolkit" version ".tar.gz"))
12484 (sha256
12485 (base32
12486 "172r15k9kwdw2lnajvpz1632dd16nqz1kcal1p0lq5ywdarj6rfd"))))
12487 (build-system python-build-system)
12488 (arguments
12489 '(#:tests? #f)) ; The test suite uses some Windows-specific data types.
12490 (propagated-inputs
12491 `(("python-wcwidth" ,python-wcwidth)
12492 ("python-six" ,python-six)
12493 ("python-pygments" ,python-pygments)))
12494 (home-page "https://github.com/jonathanslenders/python-prompt-toolkit")
12495 (synopsis "Library for building command line interfaces in Python")
12496 (description
12497 "Prompt-Toolkit is a library for building interactive command line
12498 interfaces in Python. It's like GNU Readline but it also features syntax
12499 highlighting while typing, out-of-the-box multi-line input editing, advanced
12500 code completion, incremental search, support for Chinese double-width
12501 characters, mouse support, and auto suggestions.")
12502 (license license:bsd-3)))
12503
12504 (define-public python2-prompt-toolkit
12505 (package-with-python2 python-prompt-toolkit))
12506
12507 (define-public python-jedi
12508 (package
12509 (name "python-jedi")
12510 (version "0.9.0")
12511 (source
12512 (origin
12513 (method url-fetch)
12514 (uri (pypi-uri "jedi" version))
12515 (sha256
12516 (base32
12517 "0c8x962ynpx001fdvp07m2q5jk4igkxbj3rmnydavphvlgxijk1v"))))
12518 (build-system python-build-system)
12519 (arguments
12520 ;; FIXME: One test fails (use "py.test" instead of 'setup.py test').
12521 '(#:tests? #f))
12522 (native-inputs
12523 `(("python-pytest" ,python-pytest)))
12524 (home-page "https://github.com/davidhalter/jedi")
12525 (synopsis
12526 "Autocompletion for Python that can be used for text editors")
12527 (description
12528 "Jedi is an autocompletion tool for Python that can be used for text editors.")
12529 (license license:expat)))
12530
12531 (define-public python2-jedi
12532 (package-with-python2 python-jedi))
12533
12534 (define-public ptpython
12535 (package
12536 (name "ptpython")
12537 (version "0.34")
12538 (source (origin
12539 (method url-fetch)
12540 (uri (pypi-uri "ptpython" version))
12541 (sha256
12542 (base32
12543 "1mmbiyzf0n8hm7z2a562x7w5cbl6jc0zsk6vp40q1z4cyblv1k13"))))
12544 (build-system python-build-system)
12545 (arguments
12546 '(#:tests? #f)) ; FIXME: No tests in pypi tarball.
12547 (propagated-inputs
12548 `(("python-docopt" ,python-docopt)
12549 ("python-jedi" ,python-jedi)
12550 ("python-prompt-toolkit" ,python-prompt-toolkit)
12551 ("python-pygments" ,python-pygments)))
12552 (home-page "https://github.com/jonathanslenders/ptpython")
12553 (synopsis "Python Read-Eval-Print-Loop with nice IDE-like features")
12554 (description
12555 "ptpython is a Python read-eval-print loop with IDE-like features.
12556 It supports syntax highlighting, multiline editing, autocompletion, mouse,
12557 color schemes, bracketed paste, Vi and Emacs keybindings, Chinese characters
12558 etc.")
12559 (license license:bsd-3)
12560 (properties `((python2-variant . ,(delay ptpython-2))))))
12561
12562 (define-public ptpython-2
12563 (let ((base (package-with-python2 (strip-python2-variant ptpython))))
12564 (package
12565 (inherit base)
12566 (name "ptpython2"))))
12567
12568 (define-public python-requests-oauthlib
12569 (package
12570 (name "python-requests-oauthlib")
12571 (version "0.6.2")
12572 (source
12573 (origin
12574 (method url-fetch)
12575 (uri (pypi-uri "requests-oauthlib" version))
12576 (sha256
12577 (base32
12578 "0ykff67sjcl227c23g0rxzfx34rr5bf21kwv0z3zmgk0lfmch7hn"))))
12579 (build-system python-build-system)
12580 (arguments
12581 `(#:phases
12582 (modify-phases %standard-phases
12583 ;; removes tests that require network access
12584 (add-before 'check 'pre-check
12585 (lambda _
12586 (delete-file "tests/test_core.py")
12587 #t)))))
12588 (native-inputs
12589 `(("python-requests-mock" ,python-requests-mock)
12590 ("python-mock" ,python-mock)))
12591 (propagated-inputs
12592 `(("python-oauthlib" ,python-oauthlib)
12593 ("python-requests" ,python-requests)))
12594 (home-page
12595 "https://github.com/requests/requests-oauthlib")
12596 (synopsis
12597 "OAuthlib authentication support for Requests")
12598 (description
12599 "Requests-OAuthlib uses the Python Requests and OAuthlib libraries to
12600 provide an easy-to-use Python interface for building OAuth1 and OAuth2 clients.")
12601 (license license:isc)))
12602
12603 (define-public python2-requests-oauthlib
12604 (package-with-python2 python-requests-oauthlib))
12605
12606 (define-public python-stem
12607 (package
12608 (name "python-stem")
12609 (version "1.5.4")
12610 (source
12611 (origin
12612 (method url-fetch)
12613 (uri (pypi-uri "stem" version))
12614 (sha256
12615 (base32
12616 "1j7pnblrn0yr6jmxvsq6y0ihmxmj5x50jl2n2606w67f6wq16j9n"))))
12617 (build-system python-build-system)
12618 (arguments
12619 `(#:phases
12620 (modify-phases %standard-phases
12621 (replace 'check
12622 (lambda _
12623 (zero? (system* "./run_tests.py" "--unit")))))))
12624 (native-inputs
12625 `(("python-mock" ,python-mock)
12626 ("python-pep8" ,python-pep8)
12627 ("python-pyflakes" ,python-pyflakes)))
12628 (home-page "https://stem.torproject.org/")
12629 (synopsis
12630 "Python controller library that allows applications to interact with Tor")
12631 (description
12632 "Stem is a Python controller library for Tor. With it you can use Tor's
12633 control protocol to script against the Tor process and read descriptor data
12634 relays publish about themselves.")
12635 (license license:lgpl3)))
12636
12637 (define-public python2-stem
12638 (package-with-python2 python-stem))
12639
12640 (define-public python-pyserial
12641 (package
12642 (name "python-pyserial")
12643 (version "3.1.1")
12644 (source
12645 (origin
12646 (method url-fetch)
12647 (uri (pypi-uri "pyserial" version))
12648 (sha256
12649 (base32
12650 "0k1nfdrxxkdlv4zgaqsdv8li0pj3gbh2pyxw8q2bsg6f9490amyn"))))
12651 (build-system python-build-system)
12652 (arguments
12653 '(#:tests? #f)) ; FIXME: 3/49 tests are failing.
12654 ;; #:phases
12655 ;; (modify-phases %standard-phases
12656 ;; (replace 'check
12657 ;; (lambda _
12658 ;; (zero? (system* "python" "test/run_all_tests.py" "loop://")))))))
12659 (home-page
12660 "https://github.com/pyserial/pyserial")
12661 (synopsis "Python Serial Port Bindings")
12662 (description "@code{pyserial} provide serial port bindings for Python. It
12663 supports different byte sizes, stop bits, parity and flow control with RTS/CTS
12664 and/or Xon/Xoff. The port is accessed in RAW mode.")
12665 (license license:bsd-3)))
12666
12667 (define-public python2-pyserial
12668 (package-with-python2 python-pyserial))
12669
12670 (define-public python-kivy
12671 (package
12672 (name "python-kivy")
12673 (version "1.9.1")
12674 (source
12675 (origin
12676 (method url-fetch)
12677 (uri (pypi-uri "kivy" version))
12678 (file-name (string-append name "-" version ".tar.gz"))
12679 (sha256
12680 (base32
12681 "0zk3g1j1z0lzcm9d0k1lprrs95zr8n8k5pdg3p5qlsn26jz4bg19"))))
12682 (build-system python-build-system)
12683 (arguments
12684 `(#:tests? #f ; Tests require many optional packages
12685 #:phases
12686 (modify-phases %standard-phases
12687 (replace 'build (lambda _ (zero? (system* "make" "force"))))
12688 (add-after 'patch-generated-file-shebangs 'set-sdl-paths
12689 (lambda* (#:key inputs #:allow-other-keys)
12690 (setenv "KIVY_SDL2_PATH"
12691 (string-append (assoc-ref inputs "sdl-union")
12692 "/include/SDL2"))
12693 #t)))))
12694 (native-inputs
12695 `(("pkg-config" ,pkg-config)
12696 ("python-cython" ,python-cython)))
12697 (inputs
12698 `(("gstreamer" ,gstreamer)
12699 ("mesa" ,mesa)
12700 ("sdl-union"
12701 ,(sdl-union (list sdl2 sdl2-image sdl2-mixer sdl2-ttf)))))
12702 (home-page "http://kivy.org")
12703 (synopsis
12704 "Multitouch application framework")
12705 (description
12706 "A software library for rapid development of
12707 hardware-accelerated multitouch applications.")
12708 (license license:expat)))
12709
12710 (define-public python2-kivy
12711 (package-with-python2 python-kivy))
12712
12713 (define-public python-kivy-next
12714 (let ((commit "a988c5e7a47da56263ff39514264a3de516ef2fe")
12715 (revision "1"))
12716 (package (inherit python-kivy)
12717 (name "python-kivy-next")
12718 (version (string-append "1.9.1-" revision "."
12719 (string-take commit 7)))
12720 (source
12721 (origin
12722 (method git-fetch)
12723 (uri (git-reference
12724 (url "https://github.com/kivy/kivy")
12725 (commit commit)))
12726 (file-name (string-append name "-" version "-checkout"))
12727 (sha256
12728 (base32
12729 "0jk92b4a8l7blkvkgkjihk171s0dfnq582cckff5srwc8kal5m0p")))))))
12730
12731 (define-public python2-kivy-next
12732 (package-with-python2 python-kivy-next))
12733
12734 (define-public python-binaryornot
12735 (package
12736 (name "python-binaryornot")
12737 (version "0.4.0")
12738 (source (origin
12739 (method url-fetch)
12740 (uri (pypi-uri "binaryornot" version))
12741 (sha256
12742 (base32
12743 "1j4f51dxic39mdwf6alj7gd769wy6mhk916v031wjali51xkh3xb"))))
12744 (build-system python-build-system)
12745 (propagated-inputs
12746 `(("python-chardet" ,python-chardet)
12747 ("python-hypothesis" ,python-hypothesis)))
12748 (home-page "https://github.com/audreyr/binaryornot")
12749 (synopsis "Package to check if a file is binary or text")
12750 (description "Ultra-lightweight pure Python package to check if a file is
12751 binary or text.")
12752 (license license:bsd-3)
12753 (properties `((python2-variant . ,(delay python2-binaryornot))))))
12754
12755 (define-public python2-binaryornot
12756 (let ((base (package-with-python2 (strip-python2-variant python-binaryornot))))
12757 (package (inherit base)
12758 (propagated-inputs
12759 `(("python2-enum34" ,python2-enum34)
12760 ,@(package-propagated-inputs base))))))
12761
12762 (define-public python-nltk
12763 (package
12764 (name "python-nltk")
12765 (version "3.2.1")
12766 (source (origin
12767 (method url-fetch)
12768 (uri (pypi-uri "nltk" version))
12769 (sha256
12770 (base32
12771 "0skxbhnymwlspjkzga0f7x1hg3y50fwpfghs8g8k7fh6f4nknlym"))))
12772 (build-system python-build-system)
12773 (arguments
12774 '(;; The tests require some extra resources to be downloaded.
12775 ;; TODO Try packaging these resources.
12776 #:tests? #f))
12777 (home-page "http://nltk.org/")
12778 (synopsis "Natural Language Toolkit")
12779 (description "It provides interfaces to over 50 corpora and lexical
12780 resources such as WordNet, along with a suite of text processing libraries
12781 for classification, tokenization, stemming, tagging, parsing, and semantic
12782 reasoning, wrappers for natural language processing libraries.")
12783 (license license:asl2.0)))
12784
12785 (define-public python2-nltk
12786 (package-with-python2 python-nltk))
12787
12788 (define-public python-pymongo
12789 (package
12790 (name "python-pymongo")
12791 (version "3.3.0")
12792 (source (origin
12793 (method url-fetch)
12794 (uri (pypi-uri "pymongo" version))
12795 (sha256
12796 (base32
12797 "07mra6w86wjqy4lx5fvimidjhhfzd562gfjn8grsnbv2q8pk0i9x"))))
12798 (build-system python-build-system)
12799 (propagated-inputs
12800 `(("python-certifi" ,python-certifi)))
12801 (home-page "https://github.com/mongodb/mongo-python-driver")
12802 (synopsis "Python driver for MongoDB")
12803 (description "Python driver for MongoDB.")
12804 (license license:asl2.0)))
12805
12806 (define-public python2-pymongo
12807 (package-with-python2 python-pymongo))
12808
12809 (define-public python-sh
12810 (package
12811 (name "python-sh")
12812 (version "1.11")
12813 (source (origin
12814 (method url-fetch)
12815 (uri (pypi-uri "sh" version))
12816 (sha256
12817 (base32
12818 "192r0mpv6dmkysjzhc43ddffiwb5g7c76bgr1mb1z2xz9awbj3sr"))))
12819 (build-system python-build-system)
12820 (arguments
12821 `(#:tests? #f)) ; no tests
12822 (home-page "https://github.com/amoffat/sh")
12823 (synopsis "Python subprocess interface")
12824 (description "Abstracts process invocation by providing a function
12825 interface for programs.")
12826 (license license:expat)))
12827
12828 (define-public python2-sh
12829 (package-with-python2 python-sh))
12830
12831 (define-public python-consul
12832 (package
12833 (name "python-consul")
12834 (version "0.6.1")
12835 (source
12836 (origin
12837 (method url-fetch)
12838 (uri (pypi-uri "python-consul" version))
12839 (sha256
12840 (base32
12841 "0rfyxcy4cr3x848vhx876ifalxd5ghq6l5x813m49h4vq2d4jiq8"))))
12842 (build-system python-build-system)
12843 (native-inputs
12844 `(("python-pytest" ,python-pytest)))
12845 (propagated-inputs
12846 `(("python-requests" ,python-requests)
12847 ("python-six" ,python-six)))
12848 (home-page "https://github.com/cablehead/python-consul")
12849 (synopsis "Python client for Consul")
12850 (description
12851 "Python client for @url{http://www.consul.io/,Consul}, a tool for service
12852 discovery, monitoring and configuration.")
12853 (license license:expat)))
12854
12855 (define-public python2-consul
12856 (package-with-python2 python-consul))
12857
12858 (define-public python-schematics
12859 (package
12860 (name "python-schematics")
12861 (version "1.1.1")
12862 (source
12863 (origin
12864 (method url-fetch)
12865 (uri (string-append
12866 "https://github.com/schematics/schematics/archive/v" version ".tar.gz"))
12867 (file-name (string-append name "-" version ".tar.gz"))
12868 (sha256
12869 (base32
12870 "19v1i69bf3bzarfxmbv0v6ivpcn758x3shvbiy9l2hy0lvqwnp6l"))))
12871 (build-system python-build-system)
12872 (propagated-inputs
12873 `(("python-six" ,python-six)))
12874 (arguments
12875 `(#:tests? #f)) ; requires a bunch of not very nice packages with fixed
12876 ; version requirements (eg python-coveralls)
12877 (home-page "https://github.com/schematics/schematics")
12878 (synopsis "Python Data Structures for Humans")
12879 (description "Python Data Structures for Humans.")
12880 (license license:bsd-3)))
12881
12882 (define-public python2-schematics
12883 (package-with-python2 python-schematics))
12884
12885 (define-public python-publicsuffix
12886 (package
12887 (name "python-publicsuffix")
12888 (version "1.1.0")
12889 (source (origin
12890 (method url-fetch)
12891 (uri (pypi-uri "publicsuffix" version))
12892 (sha256
12893 (base32
12894 "1adx520249z2cy7ykwjr1k190mn2888wqn9jf8qm27ly4qymjxxf"))))
12895 (build-system python-build-system)
12896 (arguments
12897 `(#:tests? #f)) ; tests use the internet
12898 (home-page "https://www.tablix.org/~avian/git/publicsuffix.git")
12899 (synopsis "Get suffix for a domain name")
12900 (description "Get a public suffix for a domain name using the Public Suffix
12901 List.")
12902 (license license:expat)))
12903
12904 (define-public python2-publicsuffix
12905 (package-with-python2 python-publicsuffix))
12906
12907 (define-public python-publicsuffix2
12908 (package
12909 (name "python-publicsuffix2")
12910 (version "2.20160818")
12911 (source
12912 (origin
12913 (method url-fetch)
12914 (uri (pypi-uri "publicsuffix2" version ".tar.bz2"))
12915 (sha256
12916 (base32
12917 "1bb55yka9vkn7i6y1kjzxa516kh6v4gsrxa90w5wdz5p5n968r68"))))
12918 (build-system python-build-system)
12919 (arguments
12920 '(#:tests? #f)) ; The test suite requires network access.
12921 (home-page "https://github.com/pombredanne/python-publicsuffix2")
12922 (synopsis "Get a public suffix for a domain name using the Public Suffix List")
12923 (description "Get a public suffix for a domain name using the Public Suffix
12924 List. Forked from and using the same API as the publicsuffix package.")
12925 (license (list license:expat license:mpl2.0))))
12926
12927 (define-public python2-publicsuffix2
12928 (package-with-python2 python-publicsuffix2))
12929
12930 (define-public python-url
12931 (package
12932 (name "python-url")
12933 (version "0.2.0")
12934 (source (origin
12935 (method url-fetch)
12936 (uri (pypi-uri "url" version))
12937 (sha256
12938 (base32
12939 "0v879yadcz9qxfl41ak6wkga1kimp9cflla9ddz03hjjvgkqy5ki"))))
12940 (build-system python-build-system)
12941 (propagated-inputs
12942 `(("python-publicsuffix" ,python-publicsuffix)))
12943 (native-inputs
12944 `(("python-coverage" ,python-coverage)
12945 ("python-nose" ,python-nose)))
12946 (arguments
12947 `(#:tests? #f)) ; FIXME: tests fail with "ImportError: No module named 'tests'"
12948 (home-page "https://github.com/seomoz/url-py")
12949 (synopsis "URL Parsing")
12950 (description "Library for parsing urls.")
12951 (license license:expat)
12952 (properties `((python2-variant . ,(delay python2-url))))))
12953
12954 (define-public python2-url
12955 (let ((base (package-with-python2 (strip-python2-variant python-url))))
12956 (package (inherit base)
12957 (propagated-inputs
12958 `(("python2-publicsuffix" ,python2-publicsuffix))))))
12959
12960 (define-public python-freezegun
12961 (package
12962 (name "python-freezegun")
12963 (version "0.3.8")
12964 (source
12965 (origin
12966 (method url-fetch)
12967 (uri (pypi-uri "freezegun" version))
12968 (sha256
12969 (base32
12970 "1sf38d3ibv1jhhvr52x7dhrsiyqk1hm165dfv8w8wh0fhmgxg151"))))
12971 (build-system python-build-system)
12972 (native-inputs
12973 `(("python-mock" ,python-mock)
12974 ("python-nose" ,python-nose)
12975 ("python-coverage" ,python-coverage)))
12976 (propagated-inputs
12977 `(("python-six" ,python-six)
12978 ("python-dateutil" ,python-dateutil)))
12979 (arguments
12980 `(#:phases (modify-phases %standard-phases
12981 ;; The tests are normally executed via `make test`, but the PyPi
12982 ;; package does not include the Makefile.
12983 (replace 'check
12984 (lambda _
12985 (zero? (system* "nosetests" "./tests/")))))))
12986 (home-page "https://github.com/spulec/freezegun")
12987 (synopsis "Test utility for mocking the datetime module")
12988 (description
12989 "FreezeGun is a library that allows your python tests to travel through
12990 time by mocking the datetime module.")
12991 (license license:asl2.0)))
12992
12993 (define-public python2-freezegun
12994 (package-with-python2 python-freezegun))
12995
12996
12997 (define-public python-odfpy
12998 (package
12999 (name "python-odfpy")
13000 (version "1.3.3")
13001 (source (origin
13002 (method url-fetch)
13003 (uri (pypi-uri "odfpy" version))
13004 (sha256
13005 (base32
13006 "1a6ms0w9zfhhkqhvrnynwwbxrivw6hgjc0s5k7j06npc7rq0blxw"))))
13007 (arguments
13008 `(#:modules ((srfi srfi-1)
13009 (guix build python-build-system)
13010 (guix build utils))
13011 #:phases
13012 (modify-phases %standard-phases
13013 (replace 'check
13014 ;; The test runner invokes python2 and python3 for test*.py.
13015 ;; To avoid having both in inputs, we replicate it here.
13016 (lambda _
13017 (every (lambda (test-file)
13018 (zero? (system* "python" test-file)))
13019 (find-files "tests" "^test.*\\.py$")))))))
13020 (build-system python-build-system)
13021 (home-page "https://github.com/eea/odfpy")
13022 (synopsis "Python API and tools to manipulate OpenDocument files")
13023 (description "Collection of libraries and utility programs written in
13024 Python to manipulate OpenDocument 1.2 files.")
13025 (license
13026 ;; The software is mainly dual GPL2+ and ASL2.0, but includes a
13027 ;; number of files with other licenses.
13028 (list license:gpl2+ license:asl2.0 license:lgpl2.1+ license:cc-by-sa3.0))))
13029
13030 (define-public python2-odfpy
13031 (package-with-python2 python-odfpy))
13032
13033 (define-public python-cachecontrol
13034 (package
13035 (name "python-cachecontrol")
13036 (version "0.11.6")
13037 (source
13038 (origin
13039 (method url-fetch)
13040 ;; Pypi does not have tests.
13041 (uri (string-append
13042 "https://github.com/ionrock/cachecontrol/archive/v"
13043 version ".tar.gz"))
13044 (file-name (string-append name "-" version ".tar.gz"))
13045 (sha256
13046 (base32
13047 "0yj60d0f69a2l8p7y86k4zhzzm6rnxpq74sfl240pry9l0lfw2vw"))))
13048 (build-system python-build-system)
13049 (arguments
13050 `(#:phases
13051 (modify-phases %standard-phases
13052 (replace 'check
13053 (lambda _
13054 ;; Drop test that requires internet access.
13055 (delete-file "tests/test_regressions.py")
13056 (setenv "PYTHONPATH"
13057 (string-append (getcwd) "/build/lib:"
13058 (getenv "PYTHONPATH")))
13059 (zero? (system* "py.test" "-vv")))))))
13060 (native-inputs
13061 `(("python-pytest" ,python-pytest)
13062 ("python-redis" ,python-redis)
13063 ("python-webtest" ,python-webtest)
13064 ("python-mock" ,python-mock)))
13065 (propagated-inputs
13066 `(("python-requests" ,python-requests)
13067 ("python-lockfile" ,python-lockfile)))
13068 (home-page "https://github.com/ionrock/cachecontrol")
13069 (synopsis "The httplib2 caching algorithms for use with requests")
13070 (description "CacheControl is a port of the caching algorithms in
13071 @code{httplib2} for use with @code{requests} session objects.")
13072 (license license:asl2.0)))
13073
13074 (define-public python2-cachecontrol
13075 (package-with-python2 python-cachecontrol))
13076
13077 (define-public python-lit
13078 (package
13079 (name "python-lit")
13080 (version "0.5.0")
13081 (source
13082 (origin
13083 (method url-fetch)
13084 (uri (pypi-uri "lit" version))
13085 (sha256
13086 (base32
13087 "135m2b9cwih85g66rjggavck328z7lj37srgpq3jxszbg0g2b91y"))))
13088 (build-system python-build-system)
13089 (home-page "http://llvm.org/")
13090 (synopsis "LLVM Software Testing Tool")
13091 (description "@code{lit} is a portable tool for executing LLVM and Clang
13092 style test suites, summarizing their results, and providing indication of
13093 failures.")
13094 (license license:ncsa)))
13095
13096 (define-public python2-lit
13097 (package-with-python2 python-lit))
13098
13099 (define-public python-pytest-pep8
13100 (package
13101 (name "python-pytest-pep8")
13102 (version "1.0.6")
13103 (source (origin
13104 (method url-fetch)
13105 (uri (pypi-uri "pytest-pep8" version))
13106 (sha256
13107 (base32
13108 "06032agzhw1i9d9qlhfblnl3dw5hcyxhagn7b120zhrszbjzfbh3"))))
13109 (build-system python-build-system)
13110 (arguments
13111 `(#:tests? #f)) ; Fails with recent pytest and pep8. See upstream issues #8 and #12.
13112 (native-inputs
13113 `(("python-pytest" ,python-pytest)))
13114 (propagated-inputs
13115 `(("python-pep8" ,python-pep8)))
13116 (home-page "https://bitbucket.org/pytest-dev/pytest-pep8")
13117 (synopsis "Py.test plugin to check PEP8 requirements")
13118 (description "Pytest plugin for checking PEP8 compliance.")
13119 (license license:expat)))
13120
13121 (define-public python2-pytest-pep8
13122 (package-with-python2 python-pytest-pep8))
13123
13124 (define-public python-pytest-flakes
13125 (package
13126 (name "python-pytest-flakes")
13127 (version "1.0.1")
13128 (source (origin
13129 (method url-fetch)
13130 (uri (pypi-uri "pytest-flakes" version))
13131 (sha256
13132 (base32
13133 "0flag3n33kbhyjrhzmq990rvg4yb8hhhl0i48q9hw0ll89jp28lw"))))
13134 (build-system python-build-system)
13135 (arguments
13136 `(#:phases
13137 (modify-phases %standard-phases
13138 (delete 'check)
13139 (add-after 'install 'check
13140 (lambda* (#:key outputs inputs #:allow-other-keys)
13141 ;; It's easier to run tests after install.
13142 ;; Make installed package available for running the tests
13143 (add-installed-pythonpath inputs outputs)
13144 (zero? (system* "py.test" "-vv")))))))
13145 (native-inputs
13146 `(("python-coverage" ,python-coverage)
13147 ("python-pytest" ,python-pytest)
13148 ("python-pytest-cache" ,python-pytest-cache)
13149 ("python-pytest-pep8" ,python-pytest-pep8)))
13150 (propagated-inputs
13151 `(("python-pyflakes" ,python-pyflakes)))
13152 (home-page "https://github.com/fschulze/pytest-flakes")
13153 (synopsis "Py.test plugin to check source code with pyflakes")
13154 (description "Pytest plugin for checking Python source code with pyflakes.")
13155 (license license:expat)))
13156
13157 (define-public python2-pytest-flakes
13158 (package-with-python2 python-pytest-flakes))
13159
13160 (define-public python-natsort
13161 (package
13162 (name "python-natsort")
13163 (version "5.0.2")
13164 (source (origin
13165 (method url-fetch)
13166 (uri (pypi-uri "natsort" version))
13167 (sha256
13168 (base32
13169 "0bh6j0l8iapjnsgg3bs6q075cnzjl6zw1vlgqyv3qrygm2cxypkn"))))
13170 (build-system python-build-system)
13171 (arguments
13172 `(#:phases
13173 (modify-phases %standard-phases
13174 (add-before 'check 'set-cachedir
13175 ;; Tests require write access to $HOME by default
13176 (lambda _ (setenv "PYTHON_EGG_CACHE" "/tmp") #t)))))
13177 (native-inputs
13178 `(("python-hypothesis" ,python-hypothesis)
13179 ("python-pytest-cache" ,python-pytest-cache)
13180 ("python-pytest-cov" ,python-pytest-cov)
13181 ("python-pytest-flakes" ,python-pytest-flakes)
13182 ("python-pytest-pep8" ,python-pytest-pep8)))
13183 (propagated-inputs ; TODO: Add python-fastnumbers.
13184 `(("python-pyicu" ,python-pyicu)))
13185 (home-page "https://github.com/SethMMorton/natsort")
13186 (synopsis "Natural sorting for python and shell")
13187 (description
13188 "Natsort lets you apply natural sorting on lists instead of
13189 lexicographical. If you use the built-in @code{sorted} method in python
13190 on a list such as @code{['a20', 'a9', 'a1', 'a4', 'a10']}, it would be
13191 returned as @code{['a1', 'a10', 'a20', 'a4', 'a9']}. Natsort provides a
13192 function @code{natsorted} that identifies numbers and sorts them separately
13193 from strings. It can also sort version numbers, real numbers, mixed types
13194 and more, and comes with a shell command @command{natsort} that exposes this
13195 functionality in the command line.")
13196 (license license:expat)
13197 (properties `((python2-variant . ,(delay python2-natsort))))))
13198
13199 (define-public python2-natsort
13200 (let ((base (package-with-python2 (strip-python2-variant python-natsort))))
13201 (package (inherit base)
13202 (native-inputs
13203 `(("python2-pathlib" ,python2-pathlib)
13204 ("python2-mock" ,python2-mock)
13205 ("python2-enum34" ,python2-enum34)
13206 ,@(package-native-inputs base))))))
13207
13208 (define-public python-glances
13209 (package
13210 (name "python-glances")
13211 (version "2.7.1")
13212 (source
13213 (origin
13214 (method url-fetch)
13215 (uri (pypi-uri "Glances" version))
13216 (sha256
13217 (base32
13218 "11jbq40g8alsbirnd4kiagznqg270247i0m8qhi48ldf2i5xppxg"))))
13219 (build-system python-build-system)
13220 (propagated-inputs
13221 `(("python-psutil" ,python-psutil)))
13222 (home-page
13223 "https://github.com/nicolargo/glances")
13224 (synopsis
13225 "A cross-platform curses-based monitoring tool")
13226 (description
13227 "Glances is a curses-based monitoring tool for a wide variety of platforms.
13228 Glances uses the PsUtil library to get information from your system. It monitors
13229 CPU, load, memory, network bandwidth, disk I/O, disk use, and more.")
13230 (license license:lgpl3+)))
13231
13232 (define-public python2-glances
13233 (package-with-python2 python-glances))
13234
13235 (define-public python-graphql-core
13236 (package
13237 (name "python-graphql-core")
13238 (version "0.5.3")
13239 (source
13240 (origin
13241 (method url-fetch)
13242 (uri (pypi-uri "graphql-core" version))
13243 (sha256
13244 (base32
13245 "0rsaarx2sj4xnw9966rhh4haiqaapm4lm2mfqm48ywd51j5vh1a0"))))
13246 (build-system python-build-system)
13247 (arguments
13248 `(#:tests? #f ; Tests require the unpackaged pytest-benchmark.
13249 #:phases
13250 (modify-phases %standard-phases
13251 (add-after 'unpack 'patch-hardcoded-version
13252 (lambda _ (substitute*
13253 "setup.py"
13254 (("'gevent==1.1rc1'") "'gevent'"))
13255 #t)))))
13256 (native-inputs
13257 `(("python-gevent" ,python-gevent)
13258 ("python-mock" ,python-mock)
13259 ("python-pytest-mock" ,python-pytest-mock)))
13260 (propagated-inputs
13261 `(("python-promise" ,python-promise)
13262 ("python-six" ,python-six)))
13263 (home-page "https://github.com/graphql-python/graphql-core")
13264 (synopsis "GraphQL implementation for Python")
13265 (description
13266 "GraphQL implementation for Python. GraphQL is a data query language and
13267 runtime designed and used to request and deliver data to mobile and web apps.
13268 This library is a port of @url{https://github.com/graphql/graphql-js,graphql-js}
13269 to Python.")
13270 (license license:expat)))
13271
13272 (define-public python2-graphql-core
13273 (package-with-python2 python-graphql-core))
13274
13275 (define-public python-graphql-relay
13276 (package
13277 (name "python-graphql-relay")
13278 (version "0.4.5")
13279 (source
13280 (origin
13281 (method url-fetch)
13282 (uri (pypi-uri "graphql-relay" version))
13283 (sha256
13284 (base32
13285 "1nv5dxcj59zv31qvl8bd142njmxcmymny2dz3br1l2cpbljbf5i7"))))
13286 (build-system python-build-system)
13287 (native-inputs
13288 `(("python-pytest" ,python-pytest)))
13289 (propagated-inputs
13290 `(("python-graphql-core" ,python-graphql-core)
13291 ("python-promise" ,python-promise)
13292 ("python-six" ,python-six)))
13293 (home-page "https://github.com/graphql-python/graphql-relay-py")
13294 (synopsis "Relay implementation for Python")
13295 (description
13296 "This is a library to allow the easy creation of Relay-compliant servers
13297 using the GraphQL Python reference implementation of a GraphQL server. It
13298 should be noted that the code is a exact port of the original
13299 @url{https://github.com/graphql/graphql-relay-js,graphql-relay js implementation}
13300 from Facebook.")
13301 (license license:expat)))
13302
13303 (define-public python2-graphql-relay
13304 (package-with-python2 python-graphql-relay))
13305
13306 (define-public python-graphene
13307 (package
13308 (name "python-graphene")
13309 (version "0.10.2")
13310 (source
13311 (origin
13312 (method url-fetch)
13313 (uri (pypi-uri "graphene" version))
13314 (sha256
13315 (base32
13316 "09zhac7igh9ixdz0ay6csy35b40l1jwbf2wrbxmgxwfhy51iy06q"))))
13317 (build-system python-build-system)
13318 (propagated-inputs
13319 `(("python-graphql-core" ,python-graphql-core)
13320 ("python-graphql-relay" ,python-graphql-relay)
13321 ("python-iso8601" ,python-iso8601)
13322 ("python-promise" ,python-promise)
13323 ("python-six" ,python-six)))
13324 (arguments
13325 `(#:tests? #f)) ; no tests/ in the PyPI tarball
13326 (home-page "http://graphene-python.org/")
13327 (synopsis "GraphQL Framework for Python")
13328 (description
13329 "Graphene is a Python library for building GraphQL schemas/types.
13330 A GraphQL schema describes your data model, and provides a GraphQL server
13331 with an associated set of resolve methods that know how to fetch data.")
13332 (properties `((python2-variant . ,(delay python2-graphene))))
13333 (license license:expat)))
13334
13335 (define-public python2-graphene
13336 (let ((base (package-with-python2
13337 (strip-python2-variant python-graphene))))
13338 (package (inherit base)
13339 (native-inputs
13340 `(("python2-sqlalchemy" ,python2-sqlalchemy)
13341 ,@(package-native-inputs base))))))
13342
13343 (define-public python-nautilus
13344 (package
13345 (name "python-nautilus")
13346 (version "0.4.9")
13347 (source
13348 (origin
13349 (method url-fetch)
13350 (uri (pypi-uri "nautilus" version))
13351 (sha256
13352 (base32
13353 "01hwzjc1zshk4vvxrcghm398fpy4jls66dyz06g07mrwqif8878p"))))
13354 (build-system python-build-system)
13355 (arguments `(#:tests? #f)) ; fails to import test modules
13356 (propagated-inputs
13357 `(("python-bcrypt" ,python-bcrypt)
13358 ("python-click" ,python-click)
13359 ("python-consul" ,python-consul)
13360 ("python-graphene" ,python-graphene)
13361 ("python-jinja2" ,python-jinja2)
13362 ("python-peewee" ,python-peewee)
13363 ("python-pika" ,python-pika)
13364 ("python-tornado" ,python-tornado)
13365 ("python-wtforms" ,python-wtforms)))
13366 (native-inputs
13367 `(("python-nose2" ,python-nose2)))
13368 (home-page "https://github.com/AlecAivazis/nautilus")
13369 (synopsis "Library for creating microservice applications")
13370 (description
13371 "Nautilus is a framework for flux based microservices that looks to
13372 provide extendible implementations of common aspects of a cloud so that you can
13373 focus on building massively scalable web applications.")
13374 (license license:expat)))
13375
13376 (define-public python-snowballstemmer
13377 (package
13378 (name "python-snowballstemmer")
13379 (version "1.2.1")
13380 (source (origin
13381 (method url-fetch)
13382 (uri (pypi-uri "snowballstemmer" version))
13383 (sha256
13384 (base32
13385 "0a0idq4y5frv7qsg2x62jd7rd272749xk4x99misf5rcifk2d7wi"))))
13386 (build-system python-build-system)
13387 (arguments
13388 `(;; No tests exist
13389 #:tests? #f))
13390 (home-page "https://github.com/shibukawa/snowball_py")
13391 (synopsis "Snowball stemming library collection for Python")
13392 (description "This package provides 16 word stemmer algorithms generated
13393 from Snowball algorithms. It includes the 15 original ones plus the Poerter
13394 English stemmer.")
13395 (license license:bsd-3)))
13396
13397 (define-public python2-snowballstemmer
13398 (package-with-python2 python-snowballstemmer))
13399
13400 (define-public python-sphinx-cloud-sptheme
13401 (package
13402 (name "python-sphinx-cloud-sptheme")
13403 (version "1.8.0")
13404 (source (origin
13405 (method url-fetch)
13406 (uri (pypi-uri "cloud_sptheme" version))
13407 (sha256
13408 (base32
13409 "1dniqb6a39yh786f86c4jn666rwnyi1jvzn4616zhcchb7sfdshd"))))
13410 (build-system python-build-system)
13411 ;; FIXME: The 'pypi' release archive does not contain tests.
13412 (arguments '(#:tests? #f))
13413 (native-inputs
13414 `(("python-sphinx" ,python-sphinx)))
13415 (home-page "https://bitbucket.org/ecollins/cloud_sptheme")
13416 (synopsis "'Cloud' theme for Sphinx documenter")
13417 (description "This package contains the \"Cloud\" theme for Sphinx and some
13418 related extensions.")
13419 (license license:bsd-3)))
13420
13421 (define-public python2-sphinx-cloud-sptheme
13422 (package-with-python2 python-sphinx-cloud-sptheme))
13423
13424 (define-public python-sphinx-alabaster-theme
13425 (package
13426 (name "python-sphinx-alabaster-theme")
13427 (version "0.7.9")
13428 (source (origin
13429 (method url-fetch)
13430 (uri (pypi-uri "alabaster" version))
13431 (sha256
13432 (base32
13433 "027anxzcb951gjlcc43y3rbn9qrw36d16vj9wd2smv5410xx9bs7"))))
13434 (build-system python-build-system)
13435 (propagated-inputs
13436 `(("python-pygments" ,python-pygments)))
13437 (home-page "https://alabaster.readthedocs.io/")
13438 (synopsis "Configurable sidebar-enabled Sphinx theme")
13439 (description "Alabaster is a visually (c)lean, responsive, configurable
13440 theme for the Sphinx documentation system. It's the default theme of Sphinx.")
13441 (license license:bsd-3)))
13442
13443 (define-public python2-sphinx-alabaster-theme
13444 (package-with-python2 python-sphinx-alabaster-theme))
13445
13446 (define-public python-betamax
13447 (package
13448 (name "python-betamax")
13449 (version "0.8.0")
13450 (source
13451 (origin
13452 (method url-fetch)
13453 (uri (pypi-uri "betamax" version))
13454 (sha256
13455 (base32
13456 "18f8v5gng3j773jlbbzx4rg1i4y2zw3m2l1zpmbvp8bh5a2q1i42"))))
13457 (build-system python-build-system)
13458 (arguments
13459 '(;; Many tests fail because they require networking.
13460 #:tests? #f))
13461 (propagated-inputs
13462 `(("python-requests" ,python-requests)))
13463 (home-page "https://github.com/sigmavirus24/betamax")
13464 (synopsis "Record HTTP interactions with python-requests")
13465 (description "Betamax will record your test suite's HTTP interactions and
13466 replay them during future tests. It is designed to work with python-requests.")
13467 (license license:expat)))
13468
13469 (define-public python2-betamax
13470 (package-with-python2 python-betamax))
13471
13472 (define-public python-betamax-matchers
13473 (package
13474 (name "python-betamax-matchers")
13475 (version "0.4.0")
13476 (source
13477 (origin
13478 (method url-fetch)
13479 (uri (pypi-uri "betamax-matchers" version))
13480 (sha256
13481 (base32
13482 "07qpwjyq2i2aqhz5iwghnj4pqr2ys5n45v1vmpcfx9r5mhwrsq43"))))
13483 (build-system python-build-system)
13484 (propagated-inputs
13485 `(("python-betamax" ,python-betamax)
13486 ("python-requests-toolbelt" ,python-requests-toolbelt)))
13487 (home-page "https://github.com/sigmavirus24/betamax_matchers")
13488 (synopsis "VCR imitation for python-requests")
13489 (description "@code{betamax-matchers} provides a set of Matchers for
13490 Betamax.")
13491 (license license:asl2.0)))
13492
13493 (define-public python2-betamax-matchers
13494 (package-with-python2 python-betamax-matchers))
13495
13496 (define-public python-s3transfer
13497 (package
13498 (name "python-s3transfer")
13499 (version "0.1.11")
13500 (source (origin
13501 (method url-fetch)
13502 (uri (pypi-uri "s3transfer" version))
13503 (sha256
13504 (base32
13505 "0yfrfnf404cxzn3iswibqjxklsl0b1lwgqiml6pwiqj79a7zbwbn"))))
13506 (build-system python-build-system)
13507 (arguments
13508 `(#:phases
13509 (modify-phases %standard-phases
13510 (replace 'check
13511 (lambda _
13512 ;; 7 of the 'integration' tests require network access or login
13513 ;; credentials.
13514 (zero? (system* "nosetests" "--exclude=integration")))))))
13515 (native-inputs
13516 `(("python-docutils" ,python-docutils)
13517 ("python-mock" ,python-mock)
13518 ("python-nose" ,python-nose)))
13519 (propagated-inputs
13520 `(("python-botocore" ,python-botocore)))
13521 (synopsis "Amazon S3 Transfer Manager")
13522 (description "S3transfer is a Python library for managing Amazon S3
13523 transfers.")
13524 (home-page "https://github.com/boto/s3transfer")
13525 (license license:asl2.0)
13526 (properties `((python2-variant . ,(delay python2-s3transfer))))))
13527
13528 (define-public python2-s3transfer
13529 (let ((base (package-with-python2 (strip-python2-variant python-s3transfer))))
13530 (package
13531 (inherit base)
13532 (native-inputs
13533 `(("python2-futures" ,python2-futures)
13534 ,@(package-native-inputs base))))))
13535
13536 (define-public python-setproctitle
13537 (package
13538 (name "python-setproctitle")
13539 (version "1.1.10")
13540 (source
13541 (origin
13542 (method url-fetch)
13543 (uri (pypi-uri "setproctitle" version))
13544 (sha256
13545 (base32
13546 "163kplw9dcrw0lffq1bvli5yws3rngpnvrxrzdw89pbphjjvg0v2"))))
13547 (build-system python-build-system)
13548 (arguments
13549 '(#:phases
13550 (modify-phases %standard-phases
13551 (add-before 'check 'patch-Makefile
13552 ;; Stricly this is only required for the python2 variant.
13553 ;; But adding a phase in an inherited package seems to be
13554 ;; cumbersum. So we patch even for python3.
13555 (lambda _
13556 (let ((nose (assoc-ref %build-inputs "python2-nose")))
13557 (when nose
13558 (substitute* "Makefile"
13559 (("\\$\\(PYTHON\\) [^ ]which nosetests[^ ] ")
13560 (string-append nose "/bin/nosetests "))))
13561 #t)))
13562 (replace 'check
13563 (lambda _
13564 (setenv "PYTHON" (or (which "python3") (which "python")))
13565 (setenv "PYCONFIG" (or (which "python3-config")
13566 (which "python-config")))
13567 (setenv "CC" "gcc")
13568 ;; No need to extend PYTHONPATH to find the built package, since
13569 ;; the Makefile will build anyway
13570 (zero? (system* "make" "check")))))))
13571 (native-inputs
13572 `(("procps" ,procps))) ; required for tests
13573 (home-page
13574 "https://github.com/dvarrazzo/py-setproctitle")
13575 (synopsis
13576 "Setproctitle implementation for Python to customize the process title")
13577 (description "The library allows a process to change its title (as displayed
13578 by system tools such as ps and top).
13579
13580 Changing the title is mostly useful in multi-process systems, for
13581 example when a master process is forked: changing the children's title
13582 allows to identify the task each process is busy with. The technique
13583 is used by PostgreSQL and the OpenSSH Server for example.")
13584 (license license:bsd-3)
13585 (properties `((python2-variant . ,(delay python2-setproctitle))))))
13586
13587 (define-public python2-setproctitle
13588 (let ((base (package-with-python2
13589 (strip-python2-variant python-setproctitle))))
13590 (package
13591 (inherit base)
13592 (native-inputs `(("python2-nose" ,python2-nose)
13593 ,@(package-native-inputs base))))))
13594
13595 (define-public python-validictory
13596 (package
13597 (name "python-validictory")
13598 (version "1.0.1")
13599 (source
13600 (origin
13601 (method url-fetch)
13602 (uri (pypi-uri "validictory" version))
13603 (sha256
13604 (base32
13605 "1zf1g9sw47xzp5f80bd94pb42j9yqv82lcrgcvdwr6nkaphfi37q"))))
13606 (build-system python-build-system)
13607 (arguments
13608 '(#:phases
13609 (modify-phases %standard-phases
13610 (add-after 'unpack 'bootstrap
13611 ;; Move the tests out of the package directory to avoid
13612 ;; packaging them.
13613 (lambda* _
13614 (rename-file "validictory/tests" "tests")
13615 (delete-file "tests/__init__.py")))
13616 (replace 'check
13617 (lambda _
13618 ;; Extend PYTHONPATH so the built package will be found.
13619 (setenv "PYTHONPATH"
13620 (string-append (getcwd) "/build/lib:"
13621 (getenv "PYTHONPATH")))
13622 (zero? (system* "py.test" "-vv" )))))))
13623 (native-inputs
13624 `(("python-pytest" ,python-pytest)))
13625 (home-page
13626 "https://github.com/jamesturk/validictory")
13627 (synopsis "General purpose Python data validator")
13628 (description "It allows validation of arbitrary Python data structures.
13629
13630 The schema format is based on the JSON Schema
13631 proposal (http://json-schema.org), so combined with json the library is also
13632 useful as a validator for JSON data.")
13633 (license license:expat)))
13634
13635 (define-public python2-validictory
13636 (package-with-python2 python-validictory))
13637
13638 (define-public python-aniso8601
13639 (package
13640 (name "python-aniso8601")
13641 (version "1.3.0")
13642 (source
13643 (origin
13644 (method url-fetch)
13645 (uri (pypi-uri "aniso8601" version))
13646 (sha256
13647 (base32
13648 "1waj54iv3n3lw1fapbz8a93yjgrybgpc86wif5baxdh1arpj9df3"))))
13649 (build-system python-build-system)
13650 (propagated-inputs
13651 `(("python-dateutil" ,python-dateutil)))
13652 (home-page
13653 "https://bitbucket.org/nielsenb/aniso8601")
13654 (synopsis
13655 "Python library for parsing ISO 8601 strings")
13656 (description
13657 "This package contains a library for parsing ISO 8601 datetime strings.")
13658 (license license:bsd-3)))
13659
13660 (define-public python2-aniso8601
13661 (package-with-python2 python-aniso8601))
13662
13663 (define-public python-flask-restful
13664 (package
13665 (name "python-flask-restful")
13666 (version "0.3.5")
13667 (source
13668 (origin
13669 (method url-fetch)
13670 (uri (pypi-uri "Flask-RESTful" version))
13671 (sha256
13672 (base32
13673 "0hjcmdb56b7z4bkw848lxfkyrpnkwzmqn2dgnlv12mwvjpzsxr6c"))))
13674 (build-system python-build-system)
13675 (propagated-inputs
13676 `(("python-aniso8601" ,python-aniso8601)
13677 ("python-flask" ,python-flask)
13678 ("python-pycrypto" ,python-pycrypto)
13679 ("python-pytz" ,python-pytz)))
13680 (native-inputs
13681 `(;; Optional dependency of Flask. Tests need it.
13682 ("python-blinker" ,python-blinker)
13683 ("python-mock" ,python-mock) ; For tests
13684 ("python-nose" ,python-nose) ; For tests
13685 ("python-sphinx" ,python-sphinx)))
13686 (home-page
13687 "https://www.github.com/flask-restful/flask-restful/")
13688 (synopsis
13689 "Flask module for creating REST APIs")
13690 (description
13691 "This package contains a Flask module for creating REST APIs.")
13692 (license license:bsd-3)))
13693
13694 (define-public python-flask-basicauth
13695 (package
13696 (name "python-flask-basicauth")
13697 (version "0.2.0")
13698 (source
13699 (origin
13700 (method url-fetch)
13701 (uri (pypi-uri "Flask-BasicAuth" version))
13702 (sha256
13703 (base32
13704 "1zq1spkjr4sjdnalpp8wl242kdqyk6fhbnhr8hi4r4f0km4bspnz"))))
13705 (build-system python-build-system)
13706 (propagated-inputs
13707 `(("python-flask" ,python-flask)))
13708 (home-page
13709 "https://github.com/jpvanhal/flask-basicauth")
13710 (synopsis
13711 "HTTP basic access authentication for Flask")
13712 (description
13713 "This package provides HTTP basic access authentication for Flask.")
13714 (license license:bsd-3)))
13715
13716 (define-public python-flask-sqlalchemy
13717 (package
13718 (name "python-flask-sqlalchemy")
13719 (version "2.1")
13720 (source
13721 (origin
13722 (method url-fetch)
13723 (uri (pypi-uri "Flask-SQLAlchemy" version))
13724 (sha256
13725 (base32
13726 "1i9ps5d5snih9xlqhrvmi3qfiygkmqzxh92n25kj4pf89kj4s965"))))
13727 (build-system python-build-system)
13728 (propagated-inputs
13729 `(("python-flask" ,python-flask)
13730 ("python-sqlalchemy" ,python-sqlalchemy)))
13731 (home-page
13732 "https://github.com/mitsuhiko/flask-sqlalchemy")
13733 (synopsis
13734 "Module adding SQLAlchemy support to your Flask application")
13735 (description
13736 "This package adds SQLAlchemy support to your Flask application.")
13737 (license license:bsd-3)))
13738
13739 (define-public python-pyev
13740 (package
13741 (name "python-pyev")
13742 (version "0.9.0")
13743 (source
13744 (origin
13745 (method url-fetch)
13746 (uri (pypi-uri "pyev" version))
13747 (sha256
13748 (base32
13749 "0rf603lc0s6zpa1nb25vhd8g4y337wg2wyz56i0agsdh7jchl0sx"))))
13750 (build-system python-build-system)
13751 (arguments
13752 `(#:tests? #f ; no test suite
13753 #:phases
13754 (modify-phases %standard-phases
13755 (add-after 'unpack 'patch
13756 (lambda* (#:key inputs #:allow-other-keys)
13757 (let ((libev (string-append (assoc-ref inputs "libev")
13758 "/lib/libev.so.4")))
13759 (substitute* "setup.py"
13760 (("libev_dll_name = find_library\\(\\\"ev\\\"\\)")
13761 (string-append "libev_dll_name = \"" libev "\"")))))))))
13762 (inputs
13763 `(("libev" ,libev)))
13764 (home-page "http://pythonhosted.org/pyev/")
13765 (synopsis "Python libev interface")
13766 (description "Pyev provides a Python interface to libev.")
13767 (license license:gpl3)))
13768
13769 (define-public python2-pyev
13770 (package-with-python2 python-pyev))
13771
13772 (define-public python-imagesize
13773 (package
13774 (name "python-imagesize")
13775 (version "0.7.1")
13776 (source
13777 (origin
13778 (method url-fetch)
13779 (uri (pypi-uri "imagesize" version))
13780 (sha256
13781 (base32
13782 "0qk07k0z4241lkzzjji7z4da04pcvg7bfc4xz1934zlqhwmwdcha"))))
13783 (build-system python-build-system)
13784 (arguments
13785 '(;; Test files are not distributed on PyPi:
13786 ;; https://github.com/shibukawa/imagesize_py/issues/7
13787 #:tests? #f))
13788 (home-page "https://github.com/shibukawa/imagesize_py")
13789 (synopsis "Gets image size of files in variaous formats in Python")
13790 (description
13791 "This package allows determination of image size from
13792 PNG, JPEG, JPEG2000 and GIF files in pure Python.")
13793 (license license:expat)))
13794
13795 (define-public python2-imagesize
13796 (package-with-python2 python-imagesize))
13797
13798 (define-public python-axolotl-curve25519
13799 (package
13800 (name "python-axolotl-curve25519")
13801 (version "0.1")
13802 (source
13803 (origin
13804 (method git-fetch)
13805 (uri (git-reference
13806 (url "https://github.com/tgalal/python-axolotl-curve25519")
13807 (commit "e4a9c4de0eae27223200579c58d1f8f6d20637e2")))
13808 (file-name (string-append name "-" version "-checkout"))
13809 (sha256
13810 (base32
13811 "0agap5q0hmvf6cwzjqc05kw53pjgf6942pcivpazksmg1vk400ra"))))
13812 (build-system python-build-system)
13813 (arguments
13814 `(;; Prevent creation of the egg. This works around
13815 ;; https://debbugs.gnu.org/cgi/bugreport.cgi?bug=20765
13816 #:configure-flags '("--root=/")))
13817 (home-page "https://github.com/tgalal/python-axolotl-curve25519")
13818 (synopsis "Python wrapper for curve25519 library")
13819 (description "This is a python wrapper for the curve25519 library
13820 with ed25519 signatures. The C code was pulled from
13821 libaxolotl-android. At the moment this wrapper is meant for use by
13822 python-axolotl.")
13823 (license (list license:gpl3 ; Most files
13824 license:bsd-3)))) ; curve/curve25519-donna.c
13825
13826 (define-public python2-axolotl-curve25519
13827 (package-with-python2 python-axolotl-curve25519))
13828
13829 (define-public python-axolotl
13830 (package
13831 (name "python-axolotl")
13832 (version "0.1.35")
13833 (source
13834 (origin
13835 (method url-fetch)
13836 (uri (string-append
13837 "https://github.com/tgalal/python-axolotl/archive/"
13838 version ".tar.gz"))
13839 (file-name (string-append name "-" version ".tar.gz"))
13840 (sha256
13841 (base32 "1z8d89p7v40p4bwywjm9h4z28fdvra79ddw06azlkrfjbl7dxmz8"))))
13842 (build-system python-build-system)
13843 (arguments
13844 `(#:phases
13845 (modify-phases %standard-phases
13846 ;; Don't install tests
13847 (add-before 'install 'remove-tests
13848 (lambda _
13849 (for-each delete-file-recursively
13850 '("axolotl/tests" "build/lib/axolotl/tests"))
13851 #t)))))
13852 (propagated-inputs
13853 `(("python-axolotl-curve25519" ,python-axolotl-curve25519)
13854 ("python-dateutil" ,python-dateutil)
13855 ("python-protobuf" ,python-protobuf)
13856 ("python-pycrypto" ,python-pycrypto)))
13857 (home-page "https://github.com/tgalal/python-axolotl")
13858 (synopsis "Python port of libaxolotl-android")
13859 (description "This is a python port of libaxolotl-android. This
13860 is a ratcheting forward secrecy protocol that works in synchronous and
13861 asynchronous messaging environments.")
13862 (license license:gpl3)))
13863
13864 (define-public python2-axolotl
13865 (package-with-python2 python-axolotl))
13866
13867 (define-public python-termstyle
13868 (package
13869 (name "python-termstyle")
13870 (version "0.1.11")
13871 (source
13872 (origin
13873 (method url-fetch)
13874 (uri (pypi-uri "termstyle" version))
13875 (sha256
13876 (base32
13877 "17wzkkcqy5zc0g68xlad3kcv66iw14d2pwqc0h9420gak0vbhx7g"))))
13878 (build-system python-build-system)
13879 (arguments
13880 '(#:phases
13881 (modify-phases %standard-phases
13882 (replace 'check
13883 (lambda _
13884 (zero? (system* "python" "test3.py")))))))
13885 (home-page "https://github.com/gfxmonk/termstyle")
13886 (synopsis "Console text coloring for Python")
13887 (description "This package provides console text coloring for Python.")
13888 (license license:bsd-3)))
13889
13890 (define-public python-rednose
13891 (package
13892 (name "python-rednose")
13893 (version "1.2.1")
13894 (source
13895 (origin
13896 (method url-fetch)
13897 (uri (pypi-uri "rednose" version))
13898 (sha256
13899 (base32
13900 "0b0bsna217lr1nykyhl5fgjly15zhdvqd4prg4wy1zrgfv7al6m0"))))
13901 (build-system python-build-system)
13902 (arguments
13903 `(#:phases
13904 (modify-phases %standard-phases
13905 (add-after 'unpack 'fix-deps
13906 (lambda _
13907 ;; See <https://github.com/JBKahn/rednose/issues/12>
13908 (substitute* "setup.py"
13909 (("python-termstyle") "termstyle"))
13910 #t)))))
13911 (propagated-inputs
13912 `(("python-colorama" ,python-colorama)
13913 ("python-termstyle" ,python-termstyle)))
13914 (native-inputs
13915 `(("python-six" ,python-six)
13916 ("python-nose" ,python-nose)))
13917 (home-page "https://github.com/JBKahn/rednose")
13918 (synopsis "Colored output for Python nosetests")
13919 (description "This package provides colored output for the
13920 @command{nosetests} command of the Python Nose unit test framework.")
13921 (license license:bsd-3)))
13922
13923 (define-public python2-rednose
13924 (package-with-python2 python-rednose))
13925
13926 (define-public python-flask-restplus
13927 (package
13928 (name "python-flask-restplus")
13929 (version "0.9.2")
13930 (source
13931 (origin
13932 (method url-fetch)
13933 (uri (pypi-uri "flask-restplus" version))
13934 (sha256
13935 (base32
13936 "11his6ii5brpkhld0d5bwzjjw4q3vmplpd6fmgzjrvvklsbk0cf4"))))
13937 (build-system python-build-system)
13938 (arguments
13939 '(#:tests? #f)) ; FIXME: 35/882 tests failing.
13940 ;; #:phases
13941 ;; (modify-phases %standard-phases
13942 ;; (replace 'check
13943 ;; (lambda _
13944 ;; (zero? (system* "nosetests")))))))
13945 (propagated-inputs
13946 `(("python-aniso8601" ,python-aniso8601)
13947 ("python-flask" ,python-flask)
13948 ("python-jsonschema" ,python-jsonschema)
13949 ("python-pytz" ,python-pytz)
13950 ("python-six" ,python-six)))
13951 (native-inputs
13952 `(("python-tzlocal" ,python-tzlocal)
13953 ("python-blinker" ,python-blinker)
13954 ("python-nose" ,python-nose)
13955 ("python-rednose" ,python-rednose)))
13956 (home-page "https://github.com/noirbizarre/flask-restplus")
13957 (synopsis "Framework for documented API development with Flask")
13958 (description "This package provides a framework for API development with
13959 the Flask web framework in Python. It is similar to package
13960 @code{python-flask-restful} but supports the @code{python-swagger}
13961 documentation builder.")
13962 (license license:expat)))
13963
13964 (define-public python-sadisplay
13965 (package
13966 (name "python-sadisplay")
13967 (version "0.4.6")
13968 (source
13969 (origin
13970 (method url-fetch)
13971 (uri (pypi-uri "sadisplay" version))
13972 (sha256
13973 (base32
13974 "0zqad2fl7q26p090qmqgmxbm6iwgf9zij1w8da1g3wdgjj72ql05"))))
13975 (build-system python-build-system)
13976 (propagated-inputs
13977 `(("python-sqlalchemy" ,python-sqlalchemy)))
13978 (native-inputs
13979 `(("python-nose" ,python-nose)))
13980 (home-page "https://bitbucket.org/estin/sadisplay")
13981 (synopsis "SQLAlchemy schema displayer")
13982 (description "This package provides a program to build Entity
13983 Relationship diagrams from a SQLAlchemy model (or directly from the
13984 database).")
13985 (license license:bsd-3)))
13986
13987 (define-public python2-sadisplay
13988 (package-with-python2 python-sadisplay))
13989
13990 (define-public python-flask-restful-swagger
13991 (package
13992 (name "python-flask-restful-swagger")
13993 (version "0.19")
13994 (source
13995 (origin
13996 (method url-fetch)
13997 (uri (pypi-uri "flask-restful-swagger" version))
13998 (sha256
13999 (base32
14000 "16msl8hd5xjmj833bpy264v98cpl5hkw5bgl5gf5vgndxbv3rm6v"))))
14001 (build-system python-build-system)
14002 (propagated-inputs
14003 `(("python-flask-restful" ,python-flask-restful)))
14004 (home-page "https://github.com/rantav/flask-restful-swagger")
14005 (synopsis "Extract Swagger specs from Flask-Restful projects")
14006 (description "This package lets you extract Swagger API documentation
14007 specs from your Flask-Restful projects.")
14008 (license license:expat)))
14009
14010 (define-public python2-flask-restful-swagger
14011 (package-with-python2 python-flask-restful-swagger))
14012
14013 (define-public python-argcomplete
14014 (package
14015 (name "python-argcomplete")
14016 (version "1.7.0")
14017 (source
14018 (origin
14019 (method url-fetch)
14020 (uri (pypi-uri "argcomplete" version))
14021 (sha256
14022 (base32
14023 "11bwiw6j0nilgz81xnw6f1npyga3prp8asjqrm87cdr3ria5l03x"))))
14024 (build-system python-build-system)
14025 (native-inputs
14026 `(("python-pexpect" ,python-pexpect)
14027 ("tcsh" ,tcsh)
14028 ("bash-full" ,bash))) ;full Bash for 'test_file_completion'
14029 (home-page "https://github.com/kislyuk/argcomplete")
14030 (synopsis "Shell tab completion for Python argparse")
14031 (description "argcomplete provides extensible command line tab completion
14032 of arguments and options for Python scripts using @code{argparse}. It's
14033 particularly useful for programs with many options or sub-parsers that can
14034 dynamically suggest completions; for example, when browsing resources over the
14035 network.")
14036 (license license:asl2.0)))
14037
14038 (define-public python2-argcomplete
14039 (package-with-python2 python-argcomplete))
14040
14041 (define-public python-xopen
14042 (package
14043 (name "python-xopen")
14044 (version "0.1.1")
14045 (source
14046 (origin
14047 (method url-fetch)
14048 (uri (pypi-uri "xopen" version))
14049 (sha256
14050 (base32
14051 "1wx6mylzcsyhjl19ycb83qq6iqpmr927lz62njfsar6ldsj0qcni"))
14052 (file-name (string-append name "-" version ".tar.gz"))))
14053 (build-system python-build-system)
14054 (home-page "https://github.com/marcelm/xopen/")
14055 (synopsis "Open compressed files transparently")
14056 (description "This module provides an @code{xopen} function that works like
14057 Python's built-in @code{open} function, but can also deal with compressed files.
14058 Supported compression formats are gzip, bzip2 and, xz, and are automatically
14059 recognized by their file extensions. The focus is on being as efficient as
14060 possible on all supported Python versions.")
14061 (license license:expat)))
14062
14063 (define-public python2-xopen
14064 (package-with-python2 python-xopen))
14065
14066 (define-public python2-cheetah
14067 (package
14068 (name "python2-cheetah")
14069 (version "2.4.4")
14070 (source
14071 (origin
14072 (method url-fetch)
14073 (uri (pypi-uri "Cheetah" version))
14074 (sha256
14075 (base32
14076 "0l5mm4lnysjkzpjr95q5ydm9xc8bv43fxmr79ypybrf1y0lq4c5y"))))
14077 (build-system python-build-system)
14078 (arguments
14079 `(#:python ,python-2))
14080 (propagated-inputs
14081 `(("python2-markdown" ,python2-markdown)))
14082 (home-page "https://pythonhosted.org/Cheetah/")
14083 (synopsis "Template engine")
14084 (description "Cheetah is a text-based template engine and Python code
14085 generator.
14086
14087 Cheetah can be used as a standalone templating utility or referenced as
14088 a library from other Python applications. It has many potential uses,
14089 but web developers looking for a viable alternative to ASP, JSP, PHP and
14090 PSP are expected to be its principle user group.
14091
14092 Features:
14093 @enumerate
14094 @item Generates HTML, SGML, XML, SQL, Postscript, form email, LaTeX, or any other
14095 text-based format.
14096 @item Cleanly separates content, graphic design, and program code.
14097 @item Blends the power and flexibility of Python with a simple template language
14098 that non-programmers can understand.
14099 @item Gives template writers full access to any Python data structure, module,
14100 function, object, or method in their templates.
14101 @item Makes code reuse easy by providing an object-orientated interface to
14102 templates that is accessible from Python code or other Cheetah templates.
14103 One template can subclass another and selectively reimplement sections of it.
14104 @item Provides a simple, yet powerful, caching mechanism that can dramatically
14105 improve the performance of a dynamic website.
14106 @item Compiles templates into optimized, yet readable, Python code.
14107 @end enumerate")
14108 (license (license:x11-style "file://LICENSE"))))
14109
14110 (define-public python-dulwich
14111 (package
14112 (name "python-dulwich")
14113 (version "0.16.3")
14114 (source
14115 (origin
14116 (method url-fetch)
14117 (uri (list (string-append "https://www.dulwich.io/releases/"
14118 "dulwich-" version ".tar.gz")
14119 (pypi-uri "dulwich" version)))
14120 (sha256
14121 (base32 "0fl47vzfgc3w3rmhn8naii905cjqcp0vc68iyvymxp7567hh6als"))))
14122 (build-system python-build-system)
14123 (arguments
14124 `(#:phases
14125 (modify-phases %standard-phases
14126 (add-before 'check 'fix-tests
14127 (lambda* (#:key inputs #:allow-other-keys)
14128 ;; The tests use Popen with a custom environment which doesn't
14129 ;; include PATH.
14130 (substitute* "dulwich/tests/compat/utils.py"
14131 (("'git'") (string-append "'"
14132 (which "git")
14133 "'")))
14134 (substitute* '("dulwich/tests/test_repository.py"
14135 "dulwich/tests/test_hooks.py")
14136 (("#!/bin/sh") (string-append "#!" (which "sh"))))
14137 (setenv "TEST_RUNNER" "unittest")
14138 (setenv "PYTHONHASHSEED" "random")
14139 #t)))))
14140 (propagated-inputs
14141 `(("python-fastimport" ,python-fastimport)))
14142 (native-inputs
14143 `(("python-mock" ,python-mock)
14144 ("python-geventhttpclient" ,python-geventhttpclient)
14145 ("git" ,git)))
14146 (home-page "https://www.dulwich.io/")
14147 (synopsis "Git implementation in Python")
14148 (description "Dulwich is an implementation of the Git file formats and
14149 protocols written in pure Python.")
14150 ;; Can be used with either license.
14151 (license (list license:asl2.0 license:gpl2+))))
14152
14153 (define-public python2-dulwich
14154 (package-with-python2 python-dulwich))
14155
14156 (define-public python-pbkdf2
14157 (package
14158 (name "python-pbkdf2")
14159 (version "1.3")
14160 (source
14161 (origin
14162 (method url-fetch)
14163 (uri (pypi-uri "pbkdf2" version))
14164 (sha256
14165 (base32
14166 "0yb99rl2mbsaamj571s1mf6vgniqh23v98k4632150hjkwv9fqxc"))))
14167 (build-system python-build-system)
14168 (arguments
14169 '(#:phases
14170 (modify-phases %standard-phases
14171 (replace 'check
14172 (lambda _
14173 (setenv "PYTHONPATH"
14174 (string-append (getcwd) "/build/lib:"
14175 (getenv "PYTHONPATH")))
14176 (zero? (system* "python" "test/test_pbkdf2.py")))))))
14177 (propagated-inputs
14178 `(("python-pycrypto" ,python-pycrypto))) ; optional
14179 (home-page "http://www.dlitz.net/software/python-pbkdf2/")
14180 (synopsis "Password-based key derivation")
14181 (description "This module implements the password-based key derivation
14182 function, PBKDF2, specified in RSA PKCS#5 v2.0.
14183
14184 PKCS#5 v2.0 Password-Based Key Derivation is a key derivation function which
14185 is part of the RSA Public Key Cryptography Standards series. The provided
14186 implementation takes a password or a passphrase and a salt value (and
14187 optionally a iteration count, a digest module, and a MAC module) and provides
14188 a file-like object from which an arbitrarly-sized key can be read.")
14189 (license license:expat)))
14190
14191 (define-public python2-pbkdf2
14192 (package-with-python2 python-pbkdf2))
14193
14194 (define-public python-qrcode
14195 (package
14196 (name "python-qrcode")
14197 (version "5.3")
14198 (source
14199 (origin
14200 (method url-fetch)
14201 (uri (pypi-uri "qrcode" version))
14202 (sha256
14203 (base32
14204 "0kljfrfq0c2rmxf8am57333ia41kd0snbm2rnqbdy816hgpcq5a1"))))
14205 (build-system python-build-system)
14206 (arguments
14207 ;; FIXME: Tests require packaging 'pymaging'.
14208 '(#:tests? #f))
14209 (propagated-inputs
14210 `(("python-lxml" ,python-lxml) ; for SVG output
14211 ("python-pillow" ,python-pillow) ; for PNG output
14212 ("python-six" ,python-six)))
14213 (home-page "https://github.com/lincolnloop/python-qrcode")
14214 (synopsis "QR Code image generator")
14215 (description "This package provides a pure Python QR Code generator
14216 module. It uses the Python Imaging Library (PIL) to allow for the generation
14217 of QR Codes.
14218
14219 In addition this package provides a command line tool to generate QR codes and
14220 either write these QR codes to a file or do the output as ascii art at the
14221 console.")
14222 (license license:bsd-3)))
14223
14224 (define-public python2-qrcode
14225 (package-with-python2 python-qrcode))
14226
14227 ;; SlowAES isn't compatible with Python 3.
14228 (define-public python2-slowaes
14229 (package
14230 (name "python2-slowaes")
14231 (version "0.1a1")
14232 (source
14233 (origin
14234 (method url-fetch)
14235 (uri (pypi-uri "slowaes" version))
14236 (sha256
14237 (base32
14238 "02dzajm83a7lqgxf6r3hgj64wfmcxz8gs4nvgxpvj5n19kjqlrc3"))))
14239 (build-system python-build-system)
14240 (arguments `(#:python ,python-2))
14241 (home-page "http://code.google.com/p/slowaes/")
14242 (synopsis "Implementation of AES in Python")
14243 (description "This package contains an implementation of AES in Python.
14244 This implementation is slow (hence the project name) but still useful when
14245 faster ones are not available.")
14246 (license license:asl2.0)))
14247
14248 (define-public python-rst2ansi
14249 (package
14250 (name "python-rst2ansi")
14251 (version "0.1.5")
14252 (source
14253 (origin
14254 (method url-fetch)
14255 (uri (pypi-uri "rst2ansi" version))
14256 (sha256
14257 (base32
14258 "0vzy6gd60l79ff750scl0sz48r1laalkl6md6dwzah4dcadgn5qv"))))
14259 (build-system python-build-system)
14260 (propagated-inputs
14261 `(("python-docutils" ,python-docutils)))
14262 (home-page "https://github.com/Snaipe/python-rst-to-ansi")
14263 (synopsis "Convert RST to ANSI-decorated console output")
14264 (description
14265 "Python module dedicated to rendering RST (reStructuredText) documents
14266 to ansi-escaped strings suitable for display in a terminal.")
14267 (license license:expat)))
14268
14269 (define-public python-ansi2html
14270 (package
14271 (name "python-ansi2html")
14272 (version "1.2.0")
14273 (source
14274 (origin
14275 (method url-fetch)
14276 (uri (pypi-uri "ansi2html" version))
14277 (sha256
14278 (base32
14279 "1wa00zffprb78w1mqq90dk47czz1knanys2a40zbw2vyapd5lp9y"))))
14280 (build-system python-build-system)
14281 (native-inputs
14282 `(("python-mock" ,python-mock)
14283 ("python-nose" ,python-nose)))
14284 (propagated-inputs
14285 `(("python-six" ,python-six)))
14286 (home-page "http://github.com/ralphbean/ansi2html")
14287 (synopsis "Convert ANSI-decorated console output to HTML")
14288 (description
14289 "@command{ansi2html} is a Python library and command line utility for
14290 convering text with ANSI color codes to HTML or LaTeX.")
14291 (license license:gpl3+)))
14292
14293 (define-public python2-ansi2html
14294 (package-with-python2 python-ansi2html))
14295
14296 (define-public python-ddt
14297 (package
14298 (name "python-ddt")
14299 (version "1.1.1")
14300 (source
14301 (origin
14302 (method url-fetch)
14303 (uri (pypi-uri "ddt" version))
14304 (sha256
14305 (base32
14306 "1c00ikkxr7lha97c81k938bzhgd4pbwamkjn0h4nkhr3xk00zp6n"))))
14307 (build-system python-build-system)
14308 (native-inputs
14309 `(("python-mock" ,python-mock)
14310 ("python-nose" ,python-nose)))
14311 (propagated-inputs
14312 `(("python-six" ,python-six)
14313 ("python-pyyaml" ,python-pyyaml)))
14314 (home-page "https://github.com/txels/ddt")
14315 (synopsis "Data-Driven Tests")
14316 (description
14317 "DDT (Data-Driven Tests) allows you to multiply one test case by running
14318 it with different test data, and make it appear as multiple test cases.")
14319 (license license:expat)))
14320
14321 (define-public python2-ddt
14322 (package-with-python2 python-ddt))
14323
14324 (define-public python-pycosat
14325 (package
14326 (name "python-pycosat")
14327 (version "0.6.1")
14328 (source
14329 (origin
14330 (method url-fetch)
14331 (uri (pypi-uri "pycosat" version))
14332 (sha256
14333 (base32
14334 "1kl3wh1f47rc712n4bmwplbx3fqz3x9i1b587jrbpmvdva4c8f6l"))))
14335 ;; TODO: Unundle picosat. http://fmv.jku.at/picosat/
14336 (build-system python-build-system)
14337 (home-page "https://github.com/ContinuumIO/pycosat")
14338 (synopsis "Bindings to picosat (a SAT solver)")
14339 (description
14340 "This package provides efficient Python bindings to @code{picosat} on
14341 the C level. When importing pycosat, the @code{picosat} solver becomes part
14342 of the Python process itself. @code{picosat} is a @dfn{Boolean Satisfiability
14343 Problem} (SAT) solver.")
14344 (license license:expat)))
14345
14346 (define-public python2-pycosat
14347 (package-with-python2 python-pycosat))
14348
14349 (define-public python2-ruamel.ordereddict
14350 (package
14351 (name "python2-ruamel.ordereddict")
14352 (version "0.4.9")
14353 (source
14354 (origin
14355 (method url-fetch)
14356 (uri (pypi-uri "ruamel.ordereddict" version))
14357 (sha256
14358 (base32
14359 "1xmkl8v9l9inm2pyxgc1fm5005yxm7fkd5gv74q7lj1iy5qc8n3h"))))
14360 (build-system python-build-system)
14361 (arguments
14362 `(#:python ,python-2
14363 #:phases
14364 (modify-phases %standard-phases
14365 (delete 'check)
14366 (add-after 'install 'check
14367 (lambda* (#:key inputs outputs #:allow-other-keys)
14368 (add-installed-pythonpath inputs outputs)
14369 (zero? (system* "python" "test/testordereddict.py")))))))
14370 (home-page "https://bitbucket.org/ruamel/ordereddict")
14371 (synopsis "Version of dict that keeps keys in insertion order")
14372 (description
14373 "This is an implementation of an ordered dictionary with @dfn{Key
14374 Insertion Order} (KIO: updates of values do not affect the position of the
14375 key), @dfn{Key Value Insertion Order} (KVIO, an existing key's position is
14376 removed and put at the back). The standard library module @code{OrderedDict},
14377 implemented later, implements a subset of @code{ordereddict} functionality.
14378 Sorted dictionaries are also provided. Currently only with @dfn{Key Sorted
14379 Order} (KSO, no sorting function can be specified, but a transform can be
14380 specified to apply on the key before comparison (e.g. @code{string.lower})).")
14381 (license license:expat)))
14382
14383 (define-public python-pypeg2
14384 (package
14385 (name "python-pypeg2")
14386 (version "2.15.2")
14387 (source
14388 (origin
14389 (method url-fetch)
14390 (uri (pypi-uri "pyPEG2" version))
14391 (sha256
14392 (base32
14393 "0v8ziaam2r637v94ra4dbjw6jzxz99gs5x4i585kgag1v204yb9b"))))
14394 (build-system python-build-system)
14395 (propagated-inputs `(("python-lxml" ,python-lxml)))
14396 (arguments
14397 ;;https://bitbucket.org/fdik/pypeg/issues/36/test-failures-on-py35
14398 '(#:tests? #f))
14399 (home-page "https://fdik.org/pyPEG/")
14400 (synopsis "Parsering Expression Grammars in Python")
14401 (description "PyPEG is an intrinsic parser interpreter framework for
14402 Python. It is based on Parsing Expression Grammars, PEG. With pyPEG you can
14403 parse many formal languages.")
14404 (license license:gpl2)))
14405
14406 (define-public python-incremental
14407 (package
14408 (name "python-incremental")
14409 (version "17.5.0")
14410 (source
14411 (origin
14412 (method url-fetch)
14413 (uri (pypi-uri "incremental" version))
14414 (sha256
14415 (base32
14416 "1cylxdz1cnkm5g3pklna3h2n0i0rks95ir1pnpxfnvpkmab1cxbv"))))
14417 (build-system python-build-system)
14418 (home-page "https://github.com/hawkowl/incremental")
14419 (synopsis "Library for versioning Python projects")
14420 (description "Incremental is a small library that versions your Python
14421 projects.")
14422 (license license:expat)))
14423
14424 (define-public python2-incremental
14425 (package-with-python2 python-incremental))
14426
14427 (define-public python-automat
14428 (package
14429 (name "python-automat")
14430 (version "0.6.0")
14431 (source (origin
14432 (method url-fetch)
14433 (uri (pypi-uri "Automat" version))
14434 (sha256
14435 (base32
14436 "1a7nsrljysfmdqmpn2apfa1gg6rfah4y9sizvns8gb08rx7d07rw"))))
14437 (build-system python-build-system)
14438 ;; We disable the tests because they require python-twisted, while
14439 ;; python-twisted depends on python-automat. Twisted is optional, but the
14440 ;; tests fail if it is not available. Also see
14441 ;; <https://github.com/glyph/automat/issues/71>.
14442 (arguments '(#:tests? #f))
14443 (native-inputs
14444 `(("python-m2r" ,python-m2r)
14445 ("python-setuptools-scm" ,python-setuptools-scm)
14446 ("python-graphviz" ,python-graphviz)))
14447 (propagated-inputs
14448 `(("python-six" ,python-six)
14449 ("python-attrs" ,python-attrs)))
14450 (home-page "https://github.com/glyph/Automat")
14451 (synopsis "Self-service finite-state machines")
14452 (description "Automat is a library for concise, idiomatic Python
14453 expression of finite-state automata (particularly deterministic finite-state
14454 transducers).")
14455 (license license:expat)))
14456
14457 (define-public python2-automat
14458 (package-with-python2 python-automat))
14459
14460 (define-public python-m2r
14461 (package
14462 (name "python-m2r")
14463 (version "0.1.12")
14464 (source (origin
14465 (method url-fetch)
14466 (uri (pypi-uri "m2r" version))
14467 (sha256
14468 (base32
14469 "1axrwnf425sz4qz3c0qc7yhhki4myzb8rki7pczcsgzznzmqdyxd"))))
14470 (build-system python-build-system)
14471 (propagated-inputs
14472 `(("python-docutils" ,python-docutils)
14473 ("python-mistune" ,python-mistune)))
14474 (native-inputs
14475 `(("python-pygments" ,python-pygments)
14476 ("python-mock" ,python-mock)))
14477 (home-page "https://github.com/miyakogi/m2r")
14478 (synopsis "Markdown to reStructuredText converter")
14479 (description "M2R converts a markdown file including reST markups to valid
14480 reST format.")
14481 (license license:expat)))
14482
14483 (define-public python2-m2r
14484 (package-with-python2 python-m2r))
14485
14486 (define-public python-constantly
14487 (package
14488 (name "python-constantly")
14489 (version "15.1.0")
14490 (source (origin
14491 (method url-fetch)
14492 (uri (pypi-uri "constantly" version))
14493 (sha256
14494 (base32
14495 "0dgwdla5kfpqz83hfril716inm41hgn9skxskvi77605jbmp4qsq"))))
14496 (build-system python-build-system)
14497 (home-page "https://github.com/twisted/constantly")
14498 (synopsis "Symbolic constants in Python")
14499 (description "Constantly is a Python library that provides symbolic
14500 constant support. It includes collections and constants with text, numeric,
14501 and bit flag values.")
14502 (license license:expat)))
14503
14504 (define-public python2-constantly
14505 (package-with-python2 python-constantly))
14506
14507 (define-public python-attrs
14508 (package
14509 (name "python-attrs")
14510 (version "17.2.0")
14511 (source (origin
14512 (method url-fetch)
14513 (uri (pypi-uri "attrs" version))
14514 (sha256
14515 (base32
14516 "04gx08ikpk26wnq22f7l42gapcvk8iz1512r927k6sadz6cinkax"))))
14517 (build-system python-build-system)
14518 (native-inputs
14519 `(("python-pytest" ,python-pytest)
14520 ("python-hypothesis" ,python-hypothesis)
14521 ("python-zope-interface" ,python-zope-interface)
14522 ("python-six" ,python-six)))
14523 (home-page "https://github.com/python-attrs/attrs/")
14524 (synopsis "Attributes without boilerplate")
14525 (description "@code{attrs} is a Python package with class decorators that
14526 ease the chores of implementing the most common attribute-related object
14527 protocols.")
14528 (license license:expat)))
14529
14530 (define-public python2-attrs
14531 (package-with-python2 python-attrs))
14532
14533 (define-public python2-cliapp
14534 (package
14535 (name "python2-cliapp")
14536 (version "1.20170823")
14537 (source
14538 (origin
14539 (method url-fetch)
14540 (uri (string-append
14541 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/cliapp/snapshot/cliapp-"
14542 version ".tar.gz"))
14543 (sha256
14544 (base32
14545 "1i9gik0xrj6jmi95s5w988jl1y265baz5xm5pbqdyvsh8h9ln6yq"))))
14546 (build-system python-build-system)
14547 (arguments
14548 `(#:python ,python-2
14549 #:phases
14550 (modify-phases %standard-phases
14551 ;; check phase needs to be run before the build phase. If not,
14552 ;; coverage-test-runner looks for tests for the built source files,
14553 ;; and fails.
14554 (delete 'check)
14555 (add-before 'build 'check
14556 (lambda _
14557 ;; Disable python3 tests
14558 (substitute* "check"
14559 (("python3") "# python3"))
14560 (zero? (system* "./check")))))))
14561 (native-inputs
14562 `(("python2-coverage-test-runner" ,python2-coverage-test-runner)
14563 ("python2-pep8" ,python2-pep8)))
14564 (propagated-inputs
14565 `(("python2-pyaml" ,python2-pyaml)))
14566 (home-page "https://liw.fi/cliapp/")
14567 (synopsis "Python framework for command line programs")
14568 (description "@code{python2-cliapp} is a python framework for
14569 command line programs. It contains the typical stuff such programs
14570 need to do, such as parsing the command line for options, and
14571 iterating over input files.")
14572 (license license:gpl2+)))
14573
14574 (define-public python2-ttystatus
14575 (package
14576 (name "python2-ttystatus")
14577 (version "0.35")
14578 (source
14579 (origin
14580 (method url-fetch)
14581 (uri (string-append
14582 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/ttystatus/snapshot/ttystatus-"
14583 version ".tar.gz"))
14584 (sha256
14585 (base32
14586 "0vivqbw7ddhsq1zj3g9cvvv4f0phl0pis2smsnwcr2szz2fk3hl6"))))
14587 (build-system python-build-system)
14588 (native-inputs
14589 `(("python2-coverage-test-runner" ,python2-coverage-test-runner)
14590 ("python2-pep8" ,python2-pep8)))
14591 (arguments
14592 `(#:python ,python-2
14593 #:phases
14594 (modify-phases %standard-phases
14595 ;; check phase needs to be run before the build phase. If not,
14596 ;; coverage-test-runner looks for tests for the built source files,
14597 ;; and fails.
14598 (delete 'check)
14599 (add-before 'build 'check
14600 (lambda _
14601 (zero? (system* "make" "check")))))))
14602 (home-page "https://liw.fi/ttystatus/")
14603 (synopsis "Python library for showing progress reporting and
14604 status updates on terminals")
14605 (description "@code{python2-ttystatus} is a python library for
14606 showing progress reporting and status updates on terminals, for
14607 command line programs. Output is automatically adapted to the width
14608 of the terminal: truncated if it does not fit, and resized if the
14609 terminal size changes.")
14610 (license license:gpl3+)))
14611
14612 (define-public python2-tracing
14613 (package
14614 (name "python2-tracing")
14615 (version "0.10")
14616 (source
14617 (origin
14618 (method url-fetch)
14619 (uri (string-append
14620 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/python-tracing/snapshot/tracing-"
14621 version ".tar.gz"))
14622 (sha256
14623 (base32
14624 "06cw4zg42fsvqy372vi2whj26w56vzg5axhzwdjc2bgwf03garbw"))))
14625 (build-system python-build-system)
14626 (arguments
14627 `(#:python ,python-2))
14628 (home-page "https://liw.fi/tracing/")
14629 (synopsis "Python debug logging helper")
14630 (description "@code{python2-tracing} is a python library for
14631 logging debug messages. It provides a way to turn debugging messages
14632 on and off, based on the filename they occur in. It is much faster
14633 than using @code{logging.Filter} to accomplish the same thing, which
14634 matters when code is run in production mode. The actual logging still
14635 happens using the @code{logging} library.")
14636 (license license:gpl3+)))
14637
14638 (define-public python2-larch
14639 (package
14640 (name "python2-larch")
14641 (version "1.20151025")
14642 (source
14643 (origin
14644 (method url-fetch)
14645 (uri (string-append
14646 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/larch/snapshot/larch-"
14647 version ".tar.gz"))
14648 (patches (search-patches
14649 "python2-larch-coverage-4.0a6-compatibility.patch"))
14650 (sha256
14651 (base32
14652 "1p4knkkavlqymgciz2wbcnfrdgdbafhg14maplnk4vbw0q8xs663"))))
14653 (build-system python-build-system)
14654 (arguments
14655 `(#:python ,python-2
14656 #:phases
14657 (modify-phases %standard-phases
14658 ;; check phase needs to be run before the build phase. If not,
14659 ;; coverage-test-runner looks for tests for the built source files,
14660 ;; and fails.
14661 (delete 'check)
14662 (add-before 'build 'check
14663 (lambda _
14664 (zero? (system* "make" "check")))))))
14665 (native-inputs
14666 `(("cmdtest" ,cmdtest)
14667 ("python2-coverage-test-runner" ,python2-coverage-test-runner)))
14668 (propagated-inputs
14669 `(("python2-tracing" ,python2-tracing)))
14670 (home-page "https://liw.fi/larch/")
14671 (synopsis "Python copy-on-write B-tree library")
14672 (description "@code{python2-larch} is an implementation of
14673 particular kind of B-tree, based on research by Ohad Rodeh. See
14674 @url{http://liw.fi/larch/ohad-btrees-shadowing-clones.pdf} for details
14675 on the data structure.
14676
14677 The distinctive feature of this B-tree is that a node is never
14678 (conceptually) modified. Instead, all updates are done by
14679 copy-on-write. This makes it easy to clone a tree, and modify only the
14680 clone, while other processes access the original tree.")
14681 (license license:gpl3+)))
14682
14683 (define-public python-htmlmin
14684 (package
14685 (name "python-htmlmin")
14686 (version "0.1.10")
14687 (source
14688 (origin
14689 (method url-fetch)
14690 (uri (pypi-uri "htmlmin" version))
14691 (sha256
14692 (base32
14693 "0qxa93j3p1ak32qh8d9kshqv8v3z0hkc13dwbhp5cn7sn3xmsp6a"))))
14694 (arguments
14695 `(#:tests? #f)) ;htmlmin has no tests
14696 (build-system python-build-system)
14697 (home-page "https://htmlmin.readthedocs.org/en/latest/")
14698 (synopsis "HTML minifier")
14699 (description "@code{htmlmin} is an HTML minifier that just works.
14700 It comes with safe defaults and easily configurable options.")
14701 (license license:bsd-3)))
14702
14703 (define-public python2-htmlmin
14704 (package-with-python2 python-htmlmin))
14705
14706 (define-public python-flask-htmlmin
14707 (package
14708 (name "python-flask-htmlmin")
14709 (version "1.2")
14710 (source
14711 (origin
14712 (method url-fetch)
14713 (uri (pypi-uri "Flask-HTMLmin" version))
14714 (sha256
14715 (base32
14716 "1n6zlq72kakkw0z2jpq6nh74lfsmxybm4g053pwhc14fbr809348"))))
14717 (propagated-inputs
14718 `(("python-flask" ,python-flask)
14719 ("python-htmlmin" ,python-htmlmin)))
14720 (build-system python-build-system)
14721 (home-page "https://github.com/hamidfzm/Flask-HTMLmin")
14722 (synopsis "HTML response minifier for Flask")
14723 (description
14724 "Minify @code{text/html} MIME type responses when using @code{Flask}.")
14725 (license license:bsd-3)))
14726
14727 (define-public python2-flask-htmlmin
14728 (package-with-python2 python-flask-htmlmin))
14729
14730 (define-public python-flask-login
14731 (package
14732 (name "python-flask-login")
14733 (version "0.4.0")
14734 (source
14735 (origin
14736 (method url-fetch)
14737 (uri (string-append "https://github.com/maxcountryman/flask-login/archive/"
14738 version ".tar.gz"))
14739 (file-name (string-append name "-" version ".tar.gz"))
14740 (sha256
14741 (base32
14742 "1pdqp7a2gyb7k06xda004x0fi2w66s6kn2i0ndkqndmg12d83f9w"))))
14743 (arguments
14744 ;; Tests fail PEP8 compliance. See:
14745 ;; https://github.com/maxcountryman/flask-login/issues/340
14746 `(#:tests? #f))
14747 (build-system python-build-system)
14748 (home-page "https://github.com/maxcountryman/flask-login")
14749 (synopsis "User session management for Flask")
14750 (description
14751 "@code{Flask-Login} provides user session management for Flask. It
14752 handles the common tasks of logging in, logging out, and remembering your
14753 users' sessions over extended periods of time.")
14754 (license license:expat)))
14755
14756 (define-public python2-flask-login
14757 (package-with-python2 python-flask-login))
14758
14759 (define-public python-astroid
14760 (package
14761 (name "python-astroid")
14762 (version "1.5.3")
14763 (source
14764 (origin
14765 (method url-fetch)
14766 (uri (string-append
14767 "https://github.com/PyCQA/astroid/archive/astroid-"
14768 version ".tar.gz"))
14769 (sha256
14770 (base32
14771 "0isn5p7f9n48hmksgbrj7dkm9dyglnayzn5jngk37qywg8a74ngn"))))
14772 (build-system python-build-system)
14773 (propagated-inputs
14774 `(("python-lazy-object-proxy" ,python-lazy-object-proxy)
14775 ("python-six" ,python-six)
14776 ("python-wrapt" ,python-wrapt)))
14777 (arguments
14778 `(#:phases
14779 (modify-phases %standard-phases
14780 (replace 'check
14781 (lambda _
14782 (zero? (system* "python" "-m" "unittest" "discover"
14783 "-p" "unittest*.py")))))))
14784 (home-page "https://github.com/PyCQA/astroid")
14785 (synopsis "Common base representation of python source code for pylint and
14786 other projects")
14787 (description "@code{python-astroid} provides a common base representation
14788 of python source code for projects such as pychecker, pyreverse, pylint, etc.
14789
14790 It provides a compatible representation which comes from the _ast module. It
14791 rebuilds the tree generated by the builtin _ast module by recursively walking
14792 down the AST and building an extended ast. The new node classes have
14793 additional methods and attributes for different usages. They include some
14794 support for static inference and local name scopes. Furthermore, astroid
14795 builds partial trees by inspecting living objects.")
14796 (license license:lgpl2.1+)
14797 (properties `((python2-variant . ,(delay python2-astroid))))))
14798
14799 (define-public python2-astroid
14800 (let ((base (package-with-python2
14801 (strip-python2-variant python-astroid))))
14802 (package (inherit base)
14803 (propagated-inputs
14804 `(("python2-backports-functools-lru-cache"
14805 ,python2-backports-functools-lru-cache)
14806 ("python2-enum34" ,python2-enum34)
14807 ("python2-singledispatch" ,python2-singledispatch)
14808 ,@(package-propagated-inputs base))))))
14809
14810 (define-public python-isort
14811 (package
14812 (name "python-isort")
14813 (version "4.2.5")
14814 (source
14815 (origin
14816 (method url-fetch)
14817 (uri (string-append
14818 "https://github.com/timothycrosley/isort/archive/"
14819 version ".tar.gz"))
14820 (file-name (string-append name "-" version ".tar.gz"))
14821 (sha256
14822 (base32
14823 "0zsrgkb0krn5476yncy5dd56k7dk34zqb4bnlvwy44ixgilyjmfh"))))
14824 (build-system python-build-system)
14825 (native-inputs
14826 `(("python-mock" ,python-mock)
14827 ("python-pytest" ,python-pytest)))
14828 (home-page "https://github.com/timothycrosley/isort")
14829 (synopsis "Python utility/library to sort python imports")
14830 (description "@code{python-isort} is a python utility/library to sort
14831 imports alphabetically, and automatically separated into sections. It
14832 provides a command line utility, a python library and plugins for various
14833 editors.")
14834 (license license:expat)))
14835
14836 (define-public python2-isort
14837 (package-with-python2 python-isort))
14838
14839 (define-public python2-backports-functools-lru-cache
14840 (package
14841 (name "python2-backports-functools-lru-cache")
14842 (version "1.3")
14843 (source
14844 (origin
14845 (method url-fetch)
14846 ;; only the pypi tarballs contain the necessary metadata
14847 (uri (pypi-uri "backports.functools_lru_cache" version))
14848 (sha256
14849 (base32
14850 "158ysf2hb0q4p4695abfiym9x1ywg0dgh8a3apd7gqaaxjy22jj4"))))
14851 (build-system python-build-system)
14852 (native-inputs
14853 `(("python2-setuptools-scm" ,python2-setuptools-scm)))
14854 (arguments
14855 `(#:python ,python-2))
14856 (home-page "https://github.com/jaraco/backports.functools_lru_cache")
14857 (synopsis "Backport of functools.lru_cache from Python 3.3")
14858 (description "@code{python2-backports-functools-lru-cache} is a backport
14859 of @code{functools.lru_cache} from python 3.3.")
14860 (license license:expat)))
14861
14862 (define-public python-configparser
14863 (package
14864 (name "python-configparser")
14865 (version "3.5.0")
14866 (source
14867 (origin
14868 (method url-fetch)
14869 (uri (string-append
14870 "https://bitbucket.org/ambv/configparser/get/"
14871 version ".tar.bz2"))
14872 (file-name (string-append name "-" version ".tar.gz"))
14873 (sha256
14874 (base32
14875 "0waq40as14abwzbb321hfz4vr1fi363nscy32ga14qvfygrg96wa"))))
14876 (build-system python-build-system)
14877 (home-page "http://docs.python.org/py3k/library/configparser.html")
14878 (synopsis "Backport of configparser from python 3.5")
14879 (description "@code{python-configparser} is a backport of
14880 @code{configparser} from Python 3.5 so that it can be used directly
14881 in other versions.")
14882 (license license:expat)))
14883
14884 (define-public python2-configparser
14885 (package-with-python2 python-configparser))
14886
14887 (define-public python2-coverage-test-runner
14888 (package
14889 (name "python2-coverage-test-runner")
14890 (version "1.11")
14891 (source
14892 (origin
14893 (method url-fetch)
14894 (uri (string-append
14895 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/"
14896 "coverage-test-runner/snapshot/coverage-test-runner-"
14897 version ".tar.gz"))
14898 (sha256
14899 (base32
14900 "0y1m7z3dl63kmhcmydl1mwg0hacnf6ghrx9dah17j9iasssfa3g7"))))
14901 (build-system python-build-system)
14902 (arguments
14903 `(#:python ,python-2
14904 #:phases
14905 (modify-phases %standard-phases
14906 (replace 'check
14907 (lambda _
14908 (zero? (system* "./testrun")))))))
14909 (propagated-inputs
14910 `(("python2-coverage" ,python2-coverage)))
14911 (home-page "https://liw.fi/coverage-test-runner/")
14912 (synopsis "Python module for running unit tests")
14913 (description "@code{CoverageTestRunner} is a python module for running
14914 unit tests and failing them if the unit test module does not exercise all
14915 statements in the module it tests.")
14916 (license license:gpl3+)))
14917
14918 (define-public python-pylint
14919 (package
14920 (name "python-pylint")
14921 (version "1.7.2")
14922 (source
14923 (origin
14924 (method url-fetch)
14925 (uri (string-append
14926 "https://github.com/PyCQA/pylint/archive/pylint-"
14927 version ".tar.gz"))
14928 (sha256
14929 (base32
14930 "0mzn1czhf1mgr2wiqfihb274sja02h899b85kywdpivppa9nwrmp"))))
14931 (build-system python-build-system)
14932 (native-inputs
14933 `(("python-pytest" ,python-pytest)
14934 ("python-pytest-runner" ,python-pytest-runner)
14935 ("python-tox" ,python-tox)))
14936 (propagated-inputs
14937 `(("python-astroid" ,python-astroid)
14938 ("python-isort" ,python-isort)
14939 ("python-mccabe" ,python-mccabe)
14940 ("python-six" ,python-six)))
14941 (arguments
14942 `(#:phases
14943 (modify-phases %standard-phases
14944 (replace 'check
14945 (lambda _
14946 ;; Somehow, tests for python2-pylint
14947 ;; fail if run from the build directory
14948 (let ((work "/tmp/work"))
14949 (mkdir-p work)
14950 (setenv "PYTHONPATH"
14951 (string-append (getenv "PYTHONPATH") ":" work))
14952 (copy-recursively "." work)
14953 (with-directory-excursion "/tmp"
14954 (zero? (system* "python" "-m" "unittest" "discover"
14955 "-s" (string-append work "/pylint/test")
14956 "-p" "*test_*.py")))))))))
14957 (home-page "https://github.com/PyCQA/pylint")
14958 (synopsis "Python source code analyzer which looks for coding standard
14959 errors")
14960 (description "Pylint is a Python source code analyzer which looks
14961 for programming errors, helps enforcing a coding standard and sniffs
14962 for some code smells (as defined in Martin Fowler's Refactoring book).
14963
14964 Pylint has many rules enabled by default, way too much to silence them
14965 all on a minimally sized program. It's highly configurable and handle
14966 pragmas to control it from within your code. Additionally, it is
14967 possible to write plugins to add your own checks.")
14968 (properties `((python2-variant . ,(delay python2-pylint))))
14969 (license license:gpl2+)))
14970
14971 (define-public python2-pylint
14972 (let ((pylint (package-with-python2
14973 (strip-python2-variant python-pylint))))
14974 (package (inherit pylint)
14975 (propagated-inputs
14976 `(("python2-backports-functools-lru-cache"
14977 ,python2-backports-functools-lru-cache)
14978 ("python2-configparser" ,python2-configparser)
14979 ,@(package-propagated-inputs pylint))))))
14980
14981 (define-public python-paramunittest
14982 (package
14983 (name "python-paramunittest")
14984 (version "0.2")
14985 (source
14986 (origin
14987 (method url-fetch)
14988 (uri (pypi-uri "ParamUnittest" version))
14989 (sha256
14990 (base32
14991 "0kp793hws5xv1wvycxq7jw2pwy36f35k39jg8hx5qikij5a0jid1"))))
14992 (build-system python-build-system)
14993 (home-page
14994 "https://github.com/rik0/ParamUnittest")
14995 (synopsis
14996 "Simple extension to have parametrized unit tests")
14997 (description
14998 "This package allows to create parametrized unit-tests that work with the standard
14999 unittest package. A parametrized test case is automatically converted to multiple test
15000 cases. Since they are TestCase subclasses, they work with other test suites that
15001 recognize TestCases.")
15002 (license license:bsd-2)))
15003
15004 (define-public python2-python-paramunittest
15005 (package-with-python2 python-paramunittest))
15006
15007 (define-public python-mando
15008 (package
15009 (name "python-mando")
15010 (version "0.5")
15011 (source
15012 (origin
15013 (method url-fetch)
15014 (uri (pypi-uri "mando" version))
15015 (sha256
15016 (base32
15017 "0q05h66439gqdmlk4jqm6xrwrzfdgs4mwk70barxhr2y83qbbdc0"))))
15018 (build-system python-build-system)
15019 (propagated-inputs
15020 `(("python-rst2ansi" ,python-rst2ansi)))
15021 (native-inputs
15022 `(("python-sphinx" ,python-sphinx-1.5.3)
15023 ("python-paramunittest" ,python-paramunittest)))
15024 (home-page "https://mando.readthedocs.org/")
15025 (synopsis
15026 "Wrapper around argparse, allowing creation of complete CLI applications")
15027 (description
15028 "This package is a wrapper around argparse, allowing you to write complete CLI
15029 applications in seconds while maintaining all the flexibility.")
15030 (license license:expat)))
15031
15032 (define-public python2-mando
15033 (package-with-python2 python-mando))
15034
15035 (define-public python-mando-0.3.1
15036 ;; python-radon (version 1.5.0) has a requirement
15037 ;; for mando<0.4,>=0.3
15038 (package
15039 (inherit python-mando)
15040 (name "python-mando")
15041 (version "0.3.1")
15042 (source
15043 (origin
15044 (method url-fetch)
15045 (uri (string-append "https://github.com/rubik/mando/archive/v"
15046 version
15047 ".tar.gz"))
15048 (sha256
15049 (base32
15050 "17jlkdpqw22z1nyml5ybslilqkzmnk0dxxjml8bfghav1l5hbwd2"))))))
15051
15052 (define-public python-fudge
15053 (package
15054 (name "python-fudge")
15055 ;; 0.9.6 is the latest version suitable for testing the "fabric" Python 2
15056 ;; package, which is currently the only use of this package.
15057 (version "0.9.6")
15058 (source
15059 (origin
15060 (method url-fetch)
15061 (uri (pypi-uri "fudge" version))
15062 (sha256
15063 (base32
15064 "185ia3vr3qk4f2s1a9hdxb8ci4qc0x0xidrad96pywg8j930qs9l"))))
15065 (build-system python-build-system)
15066 (arguments
15067 `(#:tests? #f)) ;XXX: Tests require the NoseJS Python package.
15068 (home-page "https://github.com/fudge-py/fudge")
15069 (synopsis "Replace real objects with fakes/mocks/stubs while testing")
15070 (description
15071 "Fudge is a Python module for using fake objects (mocks and stubs) to
15072 test real ones.
15073
15074 In readable Python code, you declare the methods available on your fake object
15075 and how they should be called. Then you inject that into your application and
15076 start testing. This declarative approach means you don’t have to record and
15077 playback actions and you don’t have to inspect your fakes after running code.
15078 If the fake object was used incorrectly then you’ll see an informative
15079 exception message with a traceback that points to the culprit.")
15080 (license license:expat)))
15081
15082 (define-public python2-fudge
15083 (package-with-python2 python-fudge))
15084
15085 (define-public python-oauth2client
15086 (package
15087 (name "python-oauth2client")
15088 (version "4.0.0")
15089 (source
15090 (origin
15091 (method url-fetch)
15092 (uri (pypi-uri "oauth2client" version))
15093 (sha256
15094 (base32
15095 "1irqqap2zibysf8dba8sklfqikia579srd0phm5n754ni0h59gl0"))))
15096 (build-system python-build-system)
15097 (arguments
15098 `(#:tests? #f))
15099 (propagated-inputs
15100 `(("python-httplib2" ,python-httplib2)
15101 ("python-pyasn1" ,python-pyasn1)
15102 ("python-pyasn1-modules" ,python-pyasn1-modules)
15103 ("python-rsa" ,python-rsa)
15104 ("python-six" ,python-six)))
15105 (home-page "http://github.com/google/oauth2client/")
15106 (synopsis "OAuth 2.0 client library")
15107 (description "@code{python-oauth2client} provides an OAuth 2.0 client
15108 library for Python")
15109 (license license:asl2.0)))
15110
15111 (define-public python-flask-oidc
15112 (package
15113 (name "python-flask-oidc")
15114 (version "1.1.1")
15115 (source
15116 (origin
15117 (method url-fetch)
15118 (uri (pypi-uri "flask-oidc" version))
15119 (sha256
15120 (base32
15121 "1ay5j0mf174bix7i67hclr95gv16z81fpx0dijvi0gydvdj3ddy2"))))
15122 (build-system python-build-system)
15123 (propagated-inputs
15124 `(("python-flask" ,python-flask)
15125 ("python-itsdangerous" ,python-itsdangerous)
15126 ("python-oauth2client" ,python-oauth2client)
15127 ("python-six" ,python-six)))
15128 (native-inputs
15129 `(("python-nose" ,python-nose)
15130 ("python-mock" ,python-mock)))
15131 (home-page "https://github.com/puiterwijk/flask-oidc")
15132 (synopsis "OpenID Connect extension for Flask")
15133 (description "@code{python-flask-oidc} provides an OpenID Connect extension
15134 for Flask.")
15135 (license license:bsd-2)))
15136
15137 (define-public python-mwclient
15138 (package
15139 (name "python-mwclient")
15140 (version "0.8.4")
15141 (source
15142 (origin
15143 (method url-fetch)
15144 ;; The PyPI version wouldn't contain tests.
15145 (uri (string-append "https://github.com/mwclient/mwclient/archive/"
15146 "v" version ".tar.gz"))
15147 (sha256
15148 (base32
15149 "1jj0yhilkjir00719fc7w133x7hdyhkxhk6xblla4asig45klsfv"))))
15150 (build-system python-build-system)
15151 (propagated-inputs
15152 `(("python-requests" ,python-requests)
15153 ("python-requests-oauthlib"
15154 ,python-requests-oauthlib)
15155 ("python-six" ,python-six)))
15156 (native-inputs
15157 `(("python-mock" ,python-mock)
15158 ("python-pytest" ,python-pytest)
15159 ("python-pytest-pep8" ,python-pytest-pep8)
15160 ("python-pytest-cache" ,python-pytest-cache)
15161 ("python-pytest-cov" ,python-pytest-cov)
15162 ("python-responses" ,python-responses)))
15163 (home-page "https://github.com/btongminh/mwclient")
15164 (synopsis "MediaWiki API client")
15165 (description "This package provides a MediaWiki API client.")
15166 (license license:expat)))
15167
15168 (define-public python2-mwclient
15169 (package-with-python2 python-mwclient))
15170
15171 (define-public python-pytest-warnings
15172 (package
15173 (name "python-pytest-warnings")
15174 (version "0.2.0")
15175 (source
15176 (origin
15177 (method url-fetch)
15178 (uri (pypi-uri "pytest-warnings" version))
15179 (sha256
15180 (base32
15181 "0gf2dpahpl5igb7jh1sr9acj3z3gp7zahqdqb69nk6wx01c8kc1g"))))
15182 (build-system python-build-system)
15183 (propagated-inputs
15184 `(("pytest" ,python-pytest-3.0)))
15185 (home-page "https://github.com/fschulze/pytest-warnings")
15186 (synopsis "Pytest plugin to list Python warnings in pytest report")
15187 (description
15188 "Python-pytest-warnings is a pytest plugin to list Python warnings in
15189 pytest report.")
15190 (license license:expat)))
15191
15192 (define-public python2-pytest-warnings
15193 (package-with-python2 python-pytest-warnings))
15194
15195 (define-public python-pytest-capturelog
15196 (package
15197 (name "python-pytest-capturelog")
15198 (version "0.7")
15199 (source
15200 (origin
15201 (method url-fetch)
15202 (uri (pypi-uri "pytest-capturelog" version ".tar.gz"))
15203 (sha256
15204 (base32
15205 "038049nyjl7di59ycnxvc9nydivc5m8np3hqq84j2iirkccdbs5n"))))
15206 (build-system python-build-system)
15207 (propagated-inputs
15208 `(("pytest" ,python-pytest-3.0)))
15209 (home-page "http://bitbucket.org/memedough/pytest-capturelog/overview")
15210 (synopsis "Pytest plugin to catch log messages")
15211 (description
15212 "Python-pytest-catchlog is a pytest plugin to catch log messages.")
15213 (license license:expat)))
15214
15215 (define-public python2-pytest-capturelog
15216 (package-with-python2 python-pytest-capturelog))
15217
15218 (define-public python-pytest-catchlog
15219 (package
15220 (name "python-pytest-catchlog")
15221 (version "1.2.2")
15222 (source
15223 (origin
15224 (method url-fetch)
15225 (uri (pypi-uri "pytest-catchlog" version ".zip"))
15226 (sha256
15227 (base32
15228 "1w7wxh27sbqwm4jgwrjr9c2gy384aca5jzw9c0wzhl0pmk2mvqab"))))
15229 (build-system python-build-system)
15230 (native-inputs
15231 `(("unzip" ,unzip)))
15232 (propagated-inputs
15233 `(("pytest" ,python-pytest-3.0)))
15234 (home-page "https://github.com/eisensheng/pytest-catchlog")
15235 (synopsis "Pytest plugin to catch log messages")
15236 (description
15237 "Python-pytest-catchlog is a pytest plugin to catch log messages. This is
15238 a fork of pytest-capturelog.")
15239 (license license:expat)))
15240
15241 (define-public python2-pytest-catchlog
15242 (package-with-python2 python-pytest-catchlog))
15243
15244 (define-public python-utils
15245 (package
15246 (name "python-utils")
15247 (version "2.1.0")
15248 (source (origin
15249 (method url-fetch)
15250 (uri (pypi-uri "python-utils" version))
15251 (sha256
15252 (base32
15253 "1mcsy6q5am4ya72rgkpb6kax6vv7c93cfkkas89xnpa4sj9zf28p"))))
15254 (build-system python-build-system)
15255 (native-inputs
15256 `(("pytest-runner" ,python-pytest-runner)
15257 ("pytest" ,python-pytest)
15258 ("six" ,python-six)))
15259 (home-page "https://github.com/WoLpH/python-utils")
15260 (synopsis "Convenient utilities not included with the standard Python install")
15261 (description
15262 "Python Utils is a collection of small Python functions and classes which
15263 make common patterns shorter and easier.")
15264 (license license:bsd-2)))
15265
15266 (define-public python2-utils
15267 (package-with-python2 python-utils))
15268
15269 (define-public python-webassets
15270 (package
15271 (name "python-webassets")
15272 (version "0.12.1")
15273 (source
15274 (origin
15275 (method url-fetch)
15276 (uri (pypi-uri "webassets" version))
15277 (sha256
15278 (base32
15279 "1nrqkpb7z46h2b77xafxihqv3322cwqv6293ngaky4j3ff4cing7"))))
15280 (build-system python-build-system)
15281 (native-inputs
15282 `(("python-jinja2" ,python-jinja2)
15283 ("python-mock" ,python-mock)
15284 ("python-nose" ,python-nose)
15285 ("python-pytest" ,python-pytest)))
15286 (home-page "https://github.com/miracle2k/webassets")
15287 (synopsis "Media asset management")
15288 (description "Merges, minifies and compresses Javascript and CSS files,
15289 supporting a variety of different filters, including YUI, jsmin, jspacker or
15290 CSS tidy. Also supports URL rewriting in CSS files.")
15291 (license license:bsd-2)))
15292
15293 (define-public python-sphinx-me
15294 (package
15295 (name "python-sphinx-me")
15296 (version "0.3")
15297 (source
15298 (origin
15299 (method url-fetch)
15300 (uri (pypi-uri "sphinx-me" version))
15301 (sha256
15302 (base32
15303 "06jzgp213zihnvpcy2y5jy3ykid3apc2ncp2pg6a2g05lhiziglq"))))
15304 (build-system python-build-system)
15305 (home-page "https://github.com/stephenmcd/sphinx-me")
15306 (synopsis "Create a Sphinx documentation shell")
15307 (description
15308 "Create a Sphinx documentation shell for your project and include the
15309 README file as the documentation index. It handles extracting the required
15310 meta data such as the project name, author and version from your project for
15311 use in your Sphinx docs.")
15312 (license license:bsd-2)))
15313
15314 (define-public python2-sphinx-me
15315 (package-with-python2 python-sphinx-me))
15316
15317 (define-public python-cssmin
15318 (package
15319 (name "python-cssmin")
15320 (version "0.2.0")
15321 (source
15322 (origin
15323 (method url-fetch)
15324 (uri (pypi-uri "cssmin" version))
15325 (sha256
15326 (base32
15327 "1dk723nfm2yf8cp4pj785giqlwv42l0kj8rk40kczvq1hk6g04p0"))))
15328 (build-system python-build-system)
15329 (home-page "https://github.com/zacharyvoase/cssmin")
15330 (synopsis "Python port of the YUI CSS Compressor")
15331 (description "Python port of the YUI CSS Compressor.")
15332 (license (list license:expat license:bsd-3))))
15333
15334 (define-public python2-cssmin
15335 (package-with-python2 python-cssmin))
15336
15337 (define-public python-diff-match-patch
15338 (package
15339 (name "python-diff-match-patch")
15340 (version "20121119")
15341 (source
15342 (origin
15343 (method url-fetch)
15344 (uri (pypi-uri "diff-match-patch" version))
15345 (sha256
15346 (base32
15347 "0k1f3v8nbidcmmrk65m7h8v41jqi37653za9fcs96y7jzc8mdflx"))))
15348 (build-system python-build-system)
15349 (home-page "https://code.google.com/p/google-diff-match-patch")
15350 (synopsis "Synchronize plain text")
15351 (description "Diff Match and Patch libraries offer robust algorithms to
15352 perform the operations required for synchronizing plain text.")
15353 (license license:asl2.0)))
15354
15355 (define-public python2-diff-match-patch
15356 (package-with-python2 python-diff-match-patch))
15357
15358 (define-public python-dirsync
15359 (package
15360 (name "python-dirsync")
15361 (version "2.2.2")
15362 (source
15363 (origin
15364 (method url-fetch)
15365 (uri (pypi-uri "dirsync" version ".zip"))
15366 (sha256
15367 (base32
15368 "1hcdvmkwd5512zbxpin0k7bx5bkgzy3swjx7d0kj1y45af6r75v2"))))
15369 (build-system python-build-system)
15370 (native-inputs
15371 `(("unzip" ,unzip)))
15372 (propagated-inputs
15373 `(("six" ,python-six)))
15374 (home-page "https://bitbucket.org/tkhyn/dirsync")
15375 (synopsis "Advanced directory tree synchronisation tool")
15376 (description "Advanced directory tree synchronisation tool.")
15377 (license license:expat)))
15378
15379 (define-public python2-dirsync
15380 (package-with-python2 python-dirsync))
15381
15382 (define-public python-nosexcover
15383 (package
15384 (name "python-nosexcover")
15385 (version "1.0.11")
15386 (source (origin
15387 (method url-fetch)
15388 (uri (pypi-uri "nosexcover" version))
15389 (sha256
15390 (base32
15391 "10xqr12qv62k2flxwqhh8cr00cjhn7sfjrm6p35gd1x5bmjkr319"))))
15392 (build-system python-build-system)
15393 (propagated-inputs
15394 `(("python-coverage" ,python-coverage)
15395 ("python-nose" ,python-nose)))
15396 (home-page "http://github.com/cmheisel/nose-xcover")
15397 (synopsis "Extends nose.plugins.cover to add Cobertura-style XML reports")
15398 (description "Nose-xcover is a companion to the built-in
15399 @code{nose.plugins.cover}. This plugin will write out an XML coverage report
15400 to a file named coverage.xml.
15401
15402 It will honor all the options you pass to the Nose coverage plugin,
15403 especially -cover-package.")
15404 (license license:expat)))
15405
15406 (define-public python2-nosexcover
15407 (package-with-python2 python-nosexcover))
15408
15409 (define-public python-elasticsearch
15410 (package
15411 (name "python-elasticsearch")
15412 (version "1.0.0")
15413 (source
15414 (origin
15415 (method url-fetch)
15416 (uri (pypi-uri "elasticsearch" version))
15417 (sha256
15418 (base32
15419 "1sdw1r05cw7ihnmng8ra9v968fj7bq6sji8i1dikymsnkcpgc69g"))))
15420 (build-system python-build-system)
15421 (native-inputs
15422 `(("python-mock" ,python-mock)
15423 ("python-nosexcover" ,python-nosexcover)
15424 ("python-pyaml" ,python-pyaml)
15425 ("python-requests" ,python-requests)))
15426 (propagated-inputs
15427 `(("urllib3" ,python-urllib3)))
15428 (arguments
15429 ;; tests require the test_elasticsearch module but it is not distributed.
15430 `(#:tests? #f))
15431 (home-page "https://github.com/elastic/elasticsearch-py")
15432 (synopsis "Low-level client for Elasticsearch")
15433 (description "Official low-level client for Elasticsearch. Its goal is to
15434 provide common ground for all Elasticsearch-related code in Python; because of
15435 this it tries to be opinion-free and very extendable.")
15436 (license license:expat)))
15437
15438 (define-public python2-elasticsearch
15439 (package-with-python2 python-elasticsearch))
15440
15441 (define-public python-levenshtein
15442 (package
15443 (name "python-levenshtein")
15444 (version "0.12.0")
15445 (source
15446 (origin
15447 (method url-fetch)
15448 (uri (pypi-uri "python-Levenshtein" version))
15449 (sha256
15450 (base32
15451 "1c9ybqcja31nghfcc8xxbbz9h60s9qi12b9hr4jyl69xbvg12fh3"))))
15452 (build-system python-build-system)
15453 (home-page "https://github.com/ztane/python-Levenshtein")
15454 (synopsis "Fast computation of Levenshtein distance and string similarity")
15455 (description
15456 "The Levenshtein Python C extension module contains functions for fast computation of
15457 @enumerate
15458 @item Levenshtein (edit) distance, and edit operations
15459 @item string similarity
15460 @item approximate median strings, and generally string averaging
15461 @item string sequence and set similarity
15462 @end enumerate
15463 It supports both normal and Unicode strings.")
15464 (license license:gpl2+)))
15465
15466 (define-public python2-levenshtein
15467 (package-with-python2 python-levenshtein))
15468
15469 (define-public python-scandir
15470 (package
15471 (name "python-scandir")
15472 (version "1.4")
15473 (source
15474 (origin
15475 (method url-fetch)
15476 (uri (pypi-uri "scandir" version))
15477 (sha256
15478 (base32 "0yjrgp0mxp3d8bjkq2m1ac2ys8n76wykksvgyjrnil9gr3fx7a5d"))))
15479 (build-system python-build-system)
15480 (home-page "https://github.com/benhoyt/scandir")
15481 (synopsis "Directory iteration function")
15482 (description
15483 "Directory iteration function like os.listdir(), except that instead of
15484 returning a list of bare filenames, it yields DirEntry objects that include
15485 file type and stat information along with the name. Using scandir() increases
15486 the speed of os.walk() by 2-20 times (depending on the platform and file
15487 system) by avoiding unnecessary calls to os.stat() in most cases.")
15488 (license license:bsd-3)))
15489
15490 (define-public python2-scandir
15491 (package-with-python2 python-scandir))
15492
15493 (define-public python2-stemming
15494 (package
15495 (name "python2-stemming")
15496 (version "1.0.1")
15497 (source
15498 (origin
15499 (method url-fetch)
15500 (uri (pypi-uri "stemming" version))
15501 (sha256
15502 (base32 "0ldwa24gnnxhniv0fhygkpc2mwgd93q10ag8rvzayv6hw418frsr"))))
15503 (build-system python-build-system)
15504 (arguments
15505 `(#:python ,python-2))
15506 (home-page "https://bitbucket.org/mchaput/stemming/overview")
15507 (synopsis "Python implementations of various stemming algorithms")
15508 (description
15509 "Python implementations of the Porter, Porter2, Paice-Husk, and Lovins
15510 stemming algorithms for English. These implementations are straightforward and
15511 efficient, unlike some Python versions of the same algorithms available on the
15512 Web. This package is an extraction of the stemming code included in the Whoosh
15513 search engine.")
15514 (license license:public-domain)))
15515
15516 (define-public python-factory-boy
15517 (package
15518 (name "python-factory-boy")
15519 (version "2.8.1")
15520 (source
15521 (origin
15522 (method url-fetch)
15523 (uri (pypi-uri "factory_boy" version))
15524 (sha256
15525 (base32 "1fvin6san5xsjh2c4y18caj2lnmwxlylyqm8mh1yc6rp38wlwr56"))))
15526 (build-system python-build-system)
15527 (arguments
15528 ;; Tests are not included in the tarball.
15529 `(#:tests? #f))
15530 (propagated-inputs
15531 `(("faker" ,python-faker)))
15532 (home-page "https://github.com/benhoyt/scandir")
15533 (synopsis "Versatile test fixtures replacement")
15534 (description
15535 "Factory_boy is a fixtures replacement based on thoughtbot’s factory_girl.
15536
15537 As a fixtures replacement tool, it aims to replace static, hard to maintain
15538 fixtures with easy-to-use factories for complex object.
15539
15540 Instead of building an exhaustive test setup with every possible combination
15541 of corner cases, factory_boy allows you to use objects customized for the
15542 current test, while only declaring the test-specific fields")
15543 (license license:expat)))
15544
15545 (define-public python2-factory-boy
15546 (package-with-python2 python-factory-boy))
15547
15548 (define-public python-translate-toolkit
15549 (package
15550 (name "python-translate-toolkit")
15551 (version "2.1.0")
15552 (source
15553 (origin
15554 (method url-fetch)
15555 (uri (pypi-uri "translate-toolkit" version ".tar.bz2"))
15556 (sha256
15557 (base32 "1vlkwrg83vb17jc36pmwh2b7jphwf390lz0jw8hakcg16qhwypvq"))))
15558 (build-system python-build-system)
15559 (native-inputs
15560 `(("python-pytest" ,python-pytest)
15561 ("python-sphinx" ,python-sphinx)))
15562 (propagated-inputs
15563 `(("python-babel" ,python-babel)
15564 ("python-beautifulsoup4" ,python-beautifulsoup4)
15565 ("python-chardet" ,python-chardet)
15566 ("python-diff-match-patch" ,python-diff-match-patch)
15567 ("python-levenshtein" ,python-levenshtein)
15568 ("python-lxml" ,python-lxml)
15569 ("python-six" ,python-six)
15570 ("python-vobject" ,python-vobject)
15571 ("python-pyyaml" ,python-pyyaml)))
15572 (arguments
15573 ;; TODO: tests are not run, because they end with
15574 ;; TypeError: parse() missing 2 required positional arguments: 'tree' and
15575 ;; 'parse_funcs'
15576 ;; during test setup.
15577 `(#:tests? #f))
15578 (home-page "http://toolkit.translatehouse.org")
15579 (synopsis "Tools and API for translation and localization engineering")
15580 (description
15581 "Tools and API for translation and localization engineering. It contains
15582 several utilities, as well as an API for building localization tools.")
15583 (license license:gpl2+)))
15584
15585 (define-public python2-translate-toolkit
15586 (package-with-python2 python-translate-toolkit))
15587
15588 (define-public python-mysqlclient
15589 (package
15590 (name "python-mysqlclient")
15591 (version "1.3.10")
15592 (source
15593 (origin
15594 (method url-fetch)
15595 (uri (pypi-uri "mysqlclient" version))
15596 (sha256
15597 (base32
15598 "0qkj570x4rbsblji6frvsvp2v1ap32dqzj1lq62zp9515ffsyaj5"))))
15599 (build-system python-build-system)
15600 (native-inputs
15601 `(("mariadb" ,mariadb)
15602 ("nose" ,python-nose)
15603 ("mock" ,python-mock)
15604 ("py.test" ,python-pytest)))
15605 (inputs
15606 `(("mysql" ,mysql)
15607 ("libz" ,zlib)
15608 ("openssl" ,openssl)))
15609 (home-page "https://github.com/PyMySQL/mysqlclient-python")
15610 (synopsis "MySQLdb is an interface to the popular MySQL database server for Python")
15611 (description "MySQLdb is an interface to the popular MySQL database server
15612 for Python. The design goals are:
15613 @enumerate
15614 @item Compliance with Python database API version 2.0 [PEP-0249],
15615 @item Thread-safety,
15616 @item Thread-friendliness (threads will not block each other).
15617 @end enumerate")
15618 (license license:gpl2)))
15619
15620 (define-public python2-mysqlclient
15621 (package-with-python2 python-mysqlclient))
15622
15623 (define-public python-hiredis
15624 (package
15625 (name "python-hiredis")
15626 (version "0.2.0")
15627 (source
15628 (origin
15629 (method url-fetch)
15630 (uri (pypi-uri "hiredis" version))
15631 (sha256
15632 (base32
15633 "1dfm2k9l9zar9nw9fwmm74zrgraxdxs04vx9li56fjcf289qx5fa"))))
15634 (build-system python-build-system)
15635 (arguments
15636 ;; no tests
15637 `(#:tests? #f))
15638 (home-page "https://github.com/redis/hiredis-py")
15639 (synopsis "Python extension that wraps protocol parsing code in hiredis")
15640 (description "Python-hiredis is a python extension that wraps protocol
15641 parsing code in hiredis. It primarily speeds up parsing of multi bulk replies.")
15642 (license license:bsd-3)))
15643
15644 (define-public python2-hiredis
15645 (package-with-python2 python-hiredis))
15646
15647 (define-public python-fakeredis
15648 (package
15649 (name "python-fakeredis")
15650 (version "0.8.2")
15651 (source
15652 (origin
15653 (method url-fetch)
15654 (uri (pypi-uri "fakeredis" version))
15655 (sha256
15656 (base32
15657 "0zncahj3byyasyfx9i7k991ph0n0lq8v3a21pqri5qxn9564bk9r"))))
15658 (build-system python-build-system)
15659 (arguments
15660 ;; no tests
15661 `(#:tests? #f))
15662 (home-page "https://github.com/jamesls/fakeredis")
15663 (synopsis "Fake implementation of redis API for testing purposes")
15664 (description "Fakeredis is a pure python implementation of the redis-py
15665 python client that simulates talking to a redis server. This was created for a
15666 single purpose: to write unittests. Setting up redis is not hard, but many time
15667 you want to write unittests that do not talk to an external server (such as
15668 redis). This module now allows tests to simply use this module as a reasonable
15669 substitute for redis.")
15670 (license license:bsd-3)))
15671
15672 (define-public python2-fakeredis
15673 (package-with-python2 python-fakeredis))
15674
15675 (define-public python-behave-web-api
15676 (package
15677 (name "python-behave-web-api")
15678 (version "1.0.6")
15679 (source
15680 (origin
15681 (method url-fetch)
15682 (uri (pypi-uri "behave-web-api" version))
15683 (sha256
15684 (base32
15685 "03kpq2xsy1gab3jy0dccbxlsg7vwfy4lagss0qldwmx3xz6b3i19"))))
15686 (build-system python-build-system)
15687 (arguments
15688 `(#:phases
15689 (modify-phases %standard-phases
15690 (add-after 'unpack 'fix-dependencies
15691 (lambda _
15692 (substitute* "setup.py"
15693 (("'wheel'") "") ; We don't use it.
15694 (("'ordereddict==1.1'") ""))))))) ; Python >= 2.7 has it built-in.
15695 (propagated-inputs
15696 `(("behave" ,behave)
15697 ("python-requests" ,python-requests)))
15698 (home-page "https://github.com/jefersondaniel/behave-web-api")
15699 (synopsis "Provides testing for JSON APIs with Behave for Python")
15700 (description "This package provides testing utility modules for testing
15701 JSON APIs with Behave.")
15702 (license license:expat)))
15703
15704 (define-public python2-behave-web-api
15705 (package-with-python2 python-behave-web-api))
15706
15707 (define-public python-flask-script
15708 (package
15709 (name "python-flask-script")
15710 (version "2.0.5")
15711 (source
15712 (origin
15713 (method url-fetch)
15714 (uri (pypi-uri "Flask-Script" version))
15715 (sha256
15716 (base32
15717 "0zqh2yq8zk7m9b4xw1ryqmrljkdigfb3hk5155a3b5hkfnn6xxyf"))))
15718 (build-system python-build-system)
15719 (propagated-inputs
15720 `(("python-flask" ,python-flask)
15721 ("python-argcomplete" ,python-argcomplete)
15722 ("python-werkzeug" ,python-werkzeug)))
15723 (native-inputs
15724 `(("python-pytest" ,python-pytest)))
15725 (home-page
15726 "http://github.com/smurfix/flask-script")
15727 (synopsis "Scripting support for Flask")
15728 (description "The Flask-Script extension provides support for writing
15729 external scripts in Flask. This includes running a development server,
15730 a customised Python shell, scripts to set up your database, cronjobs,
15731 and other command-line tasks that belong outside the web application
15732 itself.")
15733 (license license:bsd-3)))
15734
15735 (define-public python2-flask-script
15736 (package-with-python2 python-flask-script))
15737
15738 (define-public python-flask-migrate
15739 (package
15740 (name "python-flask-migrate")
15741 (version "2.0.3")
15742 (source
15743 (origin
15744 (method url-fetch)
15745 (uri (pypi-uri "Flask-Migrate" version))
15746 (sha256
15747 (base32
15748 "107x78lkqsnbg92dld3dkagg07jvchp3ib3y0sivc4ipz6n1y7rk"))))
15749 (build-system python-build-system)
15750 (propagated-inputs
15751 `(("python-flask" ,python-flask)
15752 ("python-alembic" ,python-alembic)
15753 ("python-sqlalchemy" ,python-sqlalchemy)
15754 ("python-flask-script" ,python-flask-script)
15755 ("python-flask-sqlalchemy" ,python-flask-sqlalchemy)))
15756 (home-page "http://github.com/miguelgrinberg/flask-migrate/")
15757 (synopsis "SQLAlchemy database migrations for Flask programs using
15758 Alembic")
15759 (description "This package contains SQLAlchemy database migration tools
15760 for Flask programs that are using @code{python-alembic}.")
15761 (license license:expat)))
15762
15763 (define-public python2-flask-migrate
15764 (package-with-python2 python-flask-migrate))
15765
15766 (define-public python-packaging
15767 (package
15768 (name "python-packaging")
15769 (version "16.8")
15770 (source
15771 (origin
15772 (method url-fetch)
15773 (uri (pypi-uri "packaging" version))
15774 (sha256
15775 (base32
15776 "17k1xbjshackwvbsnxqixbph8rbqhz4bf4g3al5xyzhavxgq6l2x"))))
15777 (build-system python-build-system)
15778 (native-inputs
15779 `(("python-pretend" ,python-pretend)
15780 ("python-pytest" ,python-pytest)))
15781 (propagated-inputs
15782 `(("python-pyparsing" ,python-pyparsing)
15783 ("python-six" ,python-six)))
15784 (home-page "https://github.com/pypa/packaging")
15785 (synopsis "Core utilities for Python packages")
15786 (description "Packaging is a Python module for dealing with Python packages.
15787 It offers an interface for working with package versions, names, and dependency
15788 information.")
15789 ;; From 'LICENSE': This software is made available under the terms of
15790 ;; *either* of the licenses found in LICENSE.APACHE or LICENSE.BSD.
15791 ;; Contributions to this software is made under the terms of *both* these
15792 ;; licenses.
15793 (license (list license:asl2.0 license:bsd-2))))
15794
15795 (define-public python2-packaging
15796 (package-with-python2 python-packaging))
15797
15798 (define-public python-sql
15799 (package
15800 (name "python-sql")
15801 (version "0.9")
15802 (source
15803 (origin
15804 (method url-fetch)
15805 (uri (pypi-uri "python-sql" version))
15806 (sha256
15807 (base32
15808 "0p6kaqj02vz0habmdx37zjk6hjxdfm8aw737zs059vvpr70ird87"))))
15809 (build-system python-build-system)
15810 (home-page "https://python-sql.tryton.org/")
15811 (synopsis "Library to write SQL queries in a pythonic way")
15812 (description "@code{python-sql} is a library to write SQL queries, that
15813 transforms idiomatic python function calls to well-formed SQL queries.")
15814 (license license:bsd-3)))
15815
15816 (define-public python2-sql
15817 (package-with-python2 python-sql))
15818
15819 (define-public python-genshi
15820 (package
15821 (name "python-genshi")
15822 (version "0.7")
15823 (source
15824 (origin
15825 (method url-fetch)
15826 (uri (string-append
15827 "https://ftp.edgewall.org/pub/genshi/Genshi-"
15828 version ".tar.gz"))
15829 (patches
15830 (search-patches
15831 ;; The first 4 patches are in the master branch upstream.
15832 ;; See this as a reference https://genshi.edgewall.org/ticket/582
15833 ;; The last 2 are NOT in any branch.
15834 ;; They were sent as attachments to a ticket opened at
15835 ;; https://genshi.edgewall.org/ticket/602#no1
15836 "python-genshi-stripping-of-unsafe-script-tags.patch"
15837 "python-genshi-disable-speedups-on-python-3.3.patch"
15838 "python-genshi-isstring-helper.patch"
15839 "python-genshi-add-support-for-python-3.4-AST.patch"
15840 "python-genshi-fix-tests-on-python-3.5.patch"
15841 "python-genshi-buildable-on-python-2.7.patch"))
15842 (sha256
15843 (base32
15844 "0lkkbp6fbwzv0zda5iqc21rr7rdldkwh3hfabfjl9i4bwq14858x"))))
15845 (build-system python-build-system)
15846 (home-page "https://genshi.edgewall.org/")
15847 (synopsis "Toolkit for generation of output for the web")
15848 (description "Genshi is a Python library that provides an integrated set
15849 of components for parsing, generating, and processing HTML, XML or other
15850 textual content for output generation on the web.")
15851 (license license:bsd-3)))
15852
15853 ;; The linter here claims that patch file names should start with the package
15854 ;; name. But, in this case the patches are inherited from python-genshi with
15855 ;; the "python-genshi-" prefix instead of "python2-genshi-".
15856 (define-public python2-genshi
15857 (package-with-python2 python-genshi))
15858
15859 (define-public python-relatorio
15860 (package
15861 (name "python-relatorio")
15862 (version "0.6.4")
15863 (source
15864 (origin
15865 (method url-fetch)
15866 (uri (pypi-uri "relatorio" version))
15867 (sha256
15868 (base32
15869 "0lincq79mzgazwd9gh41dybjh9c3n87r83pl8nk3j79aihyfk84z"))))
15870 (build-system python-build-system)
15871 (propagated-inputs
15872 `(("python-lxml" ,python-lxml)
15873 ("python-genshi" ,python-genshi)))
15874 (home-page "https://relatorio.tryton.org/")
15875 (synopsis "Templating library able to output ODT and PDF files")
15876 (description "Relatorio is a templating library which provides a way to
15877 easily output ODT, ODS, PNG, SVG and several other kinds of files. Support
15878 for more filetypes can be easily added by creating plugins for them.")
15879 (license license:gpl3+)))
15880
15881 (define-public python2-relatorio
15882 (package-with-python2 python-relatorio))
15883
15884 (define-public python-radon
15885 (package
15886 (name "python-radon")
15887 (version "1.5.0")
15888 (source
15889 (origin
15890 (method url-fetch)
15891 (uri (pypi-uri "radon" version))
15892 (sha256
15893 (base32
15894 "1h6jv36am0i827182a04ki6291lyx4kp957xfr5njgprj4nd0qsl"))))
15895 (build-system python-build-system)
15896 (propagated-inputs
15897 `(("python-colorama" ,python-colorama)
15898 ("python-flake8-polyfill" ,python-flake8-polyfill)
15899 ("python-mando" ,python-mando-0.3.1)))
15900 (native-inputs
15901 `(("python-flake8" ,python-flake8)
15902 ("python-tox" ,python-tox)
15903 ("python-pytest" ,python-pytest)
15904 ("python-paramunittest" ,python-paramunittest)))
15905 (home-page "https://radon.readthedocs.org/")
15906 (synopsis "Code Metrics in Python")
15907 (description "Radon is a Python tool which computes various code metrics.
15908 Supported metrics are:
15909 @itemize @bullet
15910 @item raw metrics: SLOC, comment lines, blank lines, &c.
15911 @item Cyclomatic Complexity (i.e. McCabe’s Complexity)
15912 @item Halstead metrics (all of them)
15913 @item the Maintainability Index (a Visual Studio metric)
15914 @end itemize")
15915 (license license:expat)))
15916
15917 (define-public python2-radon
15918 (package-with-python2 python-radon))
15919
15920 (define-public python-sure
15921 (package
15922 (name "python-sure")
15923 (version "1.4.6")
15924 (source
15925 (origin
15926 (method url-fetch)
15927 (uri (pypi-uri "sure" version))
15928 (sha256
15929 (base32
15930 "1iyqsy2d6radi88g1qf0lziy5b39h5cpb3g5jiqyb4xi46ig3x1z"))))
15931 (build-system python-build-system)
15932 (propagated-inputs
15933 `(("python-mock" ,python-mock)
15934 ("python-six" ,python-six)))
15935 (native-inputs
15936 `(("python-nose" ,python-nose)))
15937 (home-page "https://github.com/gabrielfalcao/sure")
15938 (synopsis "Automated testing library in python for python")
15939 (description
15940 "Sure is a python library that leverages a DSL for writing assertions.
15941 Sure is heavily inspired by @code{RSpec Expectations} and @code{should.js}.")
15942 (license license:gpl3+)))
15943
15944 (define-public python2-sure
15945 (package-with-python2 python-sure))
15946
15947 (define-public python2-couleur
15948 ;; This package does not seem to support python3 at all, hence,
15949 ;; only the python2 variant definition is provided.
15950 (package
15951 (name "python2-couleur")
15952 (version "0.6.2")
15953 (source
15954 (origin
15955 (method url-fetch)
15956 (uri (pypi-uri "couleur" version))
15957 (sha256
15958 (base32
15959 "1qqaxyqz74wvid0cr119dhcwz0h0if5b5by44zl49pd5z65v58k1"))))
15960 (build-system python-build-system)
15961 (arguments
15962 `(#:python ,python-2))
15963 (home-page "https://github.com/gabrielfalcao/couleur")
15964 (synopsis
15965 "ANSI terminal tool for python, colored shell and other handy fancy features")
15966 (description
15967 "@code{Couleur} provides python programs a way to use the ANSI features in a unix
15968 terminal such as coloured output in the shell, overwriting output, indentation, etc.")
15969 ;; README.md says ASL2.0, but all source code headers are LGPL3+.
15970 ;; https://github.com/gabrielfalcao/couleur/issues/11
15971 (license license:lgpl3+)))
15972
15973 (define-public python-misaka
15974 (package
15975 (name "python-misaka")
15976 (version "2.1.0")
15977 (source
15978 (origin
15979 (method url-fetch)
15980 (uri (pypi-uri "misaka" version))
15981 (sha256
15982 (base32
15983 "1yqrq3a5rracirmvk52n28nn6ckdaz897gnigv89a9gmyn87sqw7"))))
15984 (build-system python-build-system)
15985 (arguments
15986 `(;; Line 37 of setup.py calls self.run_command('develop')
15987 ;; in the 'check' phase. This command seems to be trying
15988 ;; to write to
15989 ;; /gnu/store/...-python-<version>/lib/python<version>/site-packages/
15990 ;; for which it does not have the permission to write.
15991 #:tests? #f))
15992 (propagated-inputs
15993 `(("python-cffi" ,python-cffi)))
15994 (home-page "https://github.com/FSX/misaka")
15995 (synopsis "Python binding for Hoedown")
15996 (description
15997 "@code{Misaka} is a CFFI-based binding for @code{Hoedown}, a fast markdown processing
15998 library written in C. It features a fast HTML renderer and functionality to make custom
15999 renderers (e.g. man pages or LaTeX).")
16000 (license license:expat)))
16001
16002 (define-public python2-misaka
16003 (package-with-python2 python-misaka))
16004
16005 (define-public python2-steadymark
16006 ;; This is forced into being a python2 only variant
16007 ;; due to its dependence on couleur that has no support
16008 ;; for python3
16009 (package
16010 (name "python2-steadymark")
16011 (version "0.7.3")
16012 (source
16013 (origin
16014 (method url-fetch)
16015 (uri (pypi-uri "steadymark" version))
16016 (sha256
16017 (base32
16018 "1640i9g8dycql3cc8j0bky0jkzj0q39blfbp4lsgpkprkfgcdk8v"))))
16019 (build-system python-build-system)
16020 (native-inputs
16021 `(("python-couleur" ,python2-couleur)
16022 ("python-sure" ,python2-sure)
16023 ("python-misaka" ,python2-misaka)))
16024 (arguments
16025 `(#:python ,python-2
16026 #:phases
16027 (modify-phases %standard-phases
16028 (add-before 'build 'patch-setup-py
16029 (lambda _
16030 ;; Update requirements from dependency==version
16031 ;; to dependency>=version
16032 (substitute* "setup.py"
16033 (("==") ">="))
16034 #t)))))
16035 (home-page "https://github.com/gabrielfalcao/steadymark")
16036 (synopsis "Markdown-based test runner for python")
16037 (description
16038 "@code{Steadymark} allows documentation to be written in github-flavoured
16039 markdown. The documentation may contain snippets of code surrounded by python
16040 code blocks and @code{Steadymark} will find these snippets and run them, making
16041 sure that there are no old malfunctional examples in the documentation examples.")
16042 (license license:expat)))
16043
16044 (define-public python-nose-randomly
16045 (package
16046 (name "python-nose-randomly")
16047 (version "1.2.5")
16048 (source
16049 (origin
16050 (method url-fetch)
16051 (uri (pypi-uri "nose-randomly" version))
16052 (sha256
16053 (base32
16054 "1cw9dlr1zh3w4i438kin7z0rm8092ki52hayisyc43h9pcplq7rn"))))
16055 (build-system python-build-system)
16056 (native-inputs
16057 `(("python-nose" ,python-nose)
16058 ("python-numpy" ,python-numpy)))
16059 (home-page "https://github.com/adamchainz/nose-randomly")
16060 (synopsis
16061 "Nose plugin to randomly order tests and control random.seed")
16062 (description
16063 "This is a @code{Nose} plugin to randomly order tests which can be quite
16064 powerful in discovering hidden flaws in the tests themselves, while helping to
16065 reduce inter-test dependencies. It also helps in controlling @code{random.seed},
16066 by resetting it to a repeatable number for each test, enabling the tests to
16067 create data based on random numbers and yet remain repeatable.")
16068 (license license:bsd-3)))
16069
16070 (define-public python2-nose-randomly
16071 (package-with-python2 python-nose-randomly))
16072
16073 (define-public python-jsonpointer
16074 (package
16075 (name "python-jsonpointer")
16076 (version "1.10")
16077 (source
16078 (origin
16079 (method url-fetch)
16080 (uri (pypi-uri "jsonpointer" version))
16081 (sha256
16082 (base32
16083 "1cg0gvgqjysydv6p45v4jywg1jb3v48c7m3cbpi57zgf6nndr9cz"))))
16084 (build-system python-build-system)
16085 (home-page "https://github.com/stefankoegl/python-json-pointer")
16086 (synopsis "Identify specific nodes in a JSON document")
16087 (description "@code{jsonpointer} allows you to access specific nodes
16088 by path in a JSON document (see RFC 6901).")
16089 (license license:bsd-3)))
16090
16091 (define-public python2-jsonpointer
16092 (package-with-python2 python-jsonpointer))
16093
16094 (define-public python-jsonpatch
16095 (package
16096 (name "python-jsonpatch")
16097 (version "1.16")
16098 (source
16099 (origin
16100 (method url-fetch)
16101 ;; pypi version lacks tests.js
16102 (uri (string-append "https://github.com/stefankoegl/python-json-patch/"
16103 "archive/v" version ".tar.gz"))
16104 (file-name (string-append name "-" version ".tar.gz"))
16105 (sha256
16106 (base32
16107 "085ykisl8v7mv9h7hvhdy3l2fjzs4214gx32r5k6nx4f76hbv6y5"))))
16108 (build-system python-build-system)
16109 (native-inputs
16110 `(("python-jsonpointer" ,python-jsonpointer)))
16111 (home-page "https://github.com/stefankoegl/python-json-patch")
16112 (synopsis "Applying JSON Patches in Python 2.6+ and 3.x")
16113 (description "@code{jsonpatch} is a library and program that allows
16114 applying JSON Patches according to RFC 6902.")
16115 (license license:bsd-3)))
16116
16117 (define-public python2-jsonpatch
16118 (package-with-python2 python-jsonpatch))
16119
16120 (define-public python-jsonpatch-0.4
16121 (package (inherit python-jsonpatch)
16122 (name "python-jsonpatch")
16123 (version "0.4")
16124 (source
16125 (origin
16126 (method url-fetch)
16127 (uri (string-append "https://github.com/stefankoegl/python-json-patch/"
16128 "archive/v" version ".tar.gz"))
16129 (file-name (string-append name "-" version ".tar.gz"))
16130 (sha256
16131 (base32
16132 "0j0cd9z9zyp8kppp464jxrfgrnbgkzl1yi10i5gsv8yz6d95929d"))))))
16133
16134 (define-public python2-jsonpatch-0.4
16135 (package-with-python2 python-jsonpatch-0.4))
16136
16137 (define-public python-rfc3987
16138 (package
16139 (name "python-rfc3987")
16140 (version "1.3.7")
16141 (source
16142 (origin
16143 (method url-fetch)
16144 (uri (pypi-uri "rfc3987" version))
16145 (sha256
16146 (base32
16147 "192pclzs2y0yaywqkrlvd0x73740q310kvqvm6jldhi619mq59wi"))))
16148 (build-system python-build-system)
16149 (home-page "http://pypi.python.org/pypi/rfc3987")
16150 (synopsis "Parsing and validation of URIs (RFC 3986) and IRIs (RFC 3987)")
16151 (description "@code{rfc3987} provides routines for parsing and
16152 validation of URIs (see RFC 3986) and IRIs (see RFC 3987).")
16153 (license license:gpl3+)))
16154
16155 (define-public python2-rfc3987
16156 (package-with-python2 python-rfc3987))
16157
16158 (define-public python-validate-email
16159 (package
16160 (name "python-validate-email")
16161 (version "1.3")
16162 (source
16163 (origin
16164 (method url-fetch)
16165 (uri (pypi-uri "validate_email" version))
16166 (sha256
16167 (base32
16168 "1bxffaf5yz2cph8ki55vdvdypbwkvn2xr1firlcy62vqbzf1jivq"))))
16169 (build-system python-build-system)
16170 (home-page "http://github.com/syrusakbary/validate_email")
16171 (synopsis "Verifies if an email address is valid and really exists")
16172 (description "@code{validate_email} can be used to verify if an email
16173 address is valid and really exists.")
16174 (license license:lgpl3+)))
16175
16176 (define-public python2-validate-email
16177 (package-with-python2 python-validate-email))
16178
16179 (define-public python-flex
16180 (package
16181 (name "python-flex")
16182 (version "6.10.0")
16183 (source
16184 (origin
16185 (method url-fetch)
16186 (uri (pypi-uri "flex" version))
16187 (sha256
16188 (base32
16189 "00pamnwla3khk8nyla7y28dq9jnh69swd7f4jfsl7sn1izs8n8zk"))))
16190 (build-system python-build-system)
16191 (propagated-inputs
16192 `(("python-click" ,python-click)
16193 ("python-iso8601" ,python-iso8601)
16194 ("python-jsonpointer" ,python-jsonpointer)
16195 ("python-pyyaml" ,python-pyyaml)
16196 ("python-requests" ,python-requests)
16197 ("python-rfc3987" ,python-rfc3987)
16198 ("python-six" ,python-six)
16199 ("python-validate-email" ,python-validate-email)))
16200 (home-page "https://github.com/pipermerriam/flex")
16201 (synopsis "Validates Swagger schemata")
16202 (description "@code{flex} can be used to validate Swagger schemata.")
16203 (license license:bsd-3)))
16204
16205 (define-public python2-flex
16206 (package-with-python2 python-flex))
16207
16208 (define-public python-marshmallow
16209 (package
16210 (name "python-marshmallow")
16211 (version "3.0.0b3")
16212 (source
16213 (origin
16214 (method url-fetch)
16215 (uri (pypi-uri "marshmallow" version))
16216 (sha256
16217 (base32
16218 "07mcrij1yvk85lvgx44wwr9pc80xryghvlgayb057g1cazcypysd"))))
16219 (build-system python-build-system)
16220 (propagated-inputs
16221 `(("python-dateutil" ,python-dateutil)
16222 ("python-simplejson" ,python-simplejson)))
16223 (native-inputs
16224 `(("python-pytest-3.0" ,python-pytest-3.0)
16225 ("python-pytz" ,python-pytz)))
16226 (home-page "https://github.com/marshmallow-code/marshmallow")
16227 (synopsis "Convert complex datatypes to and from native
16228 Python datatypes.")
16229 (description "@code{marshmallow} provides a library for converting
16230 complex datatypes to and from native Python datatypes.")
16231 (license license:expat)))
16232
16233 (define-public python2-marshmallow
16234 (package-with-python2 python-marshmallow))
16235
16236 (define-public python-bottle
16237 (package
16238 (name "python-bottle")
16239 (version "0.12.13")
16240 (source
16241 (origin
16242 (method url-fetch)
16243 (uri (pypi-uri "bottle" version))
16244 (sha256
16245 (base32
16246 "0m9k2a7yxvggc4kw8fsvj381vgsvfcdshg5nzy6vwrxiw2p53drr"))))
16247 (build-system python-build-system)
16248 (home-page "http://bottlepy.org/")
16249 (synopsis "WSGI framework for small web-applications.")
16250 (description "@code{python-bottle} is a WSGI framework for small web-applications.")
16251 (license license:expat)))
16252
16253 (define-public python2-bottle
16254 (package-with-python2 python-bottle))
16255
16256 (define-public python-apispec
16257 (package
16258 (name "python-apispec")
16259 (version "0.25.3")
16260 (source
16261 (origin
16262 (method url-fetch)
16263 (uri (pypi-uri "apispec" version))
16264 (sha256
16265 (base32
16266 "0kxa8723zbisx10363yh4mmmn4higxrspymbjfz5zq8f644zagm9"))))
16267 (build-system python-build-system)
16268 (propagated-inputs
16269 `(("python-pyyaml" ,python-pyyaml)))
16270 (native-inputs
16271 `(("python-pytest-3.0" ,python-pytest-3.0)
16272 ("python-flask" ,python-flask)
16273 ("python-marshmallow" ,python-marshmallow)
16274 ("python-tornado" ,python-tornado)
16275 ("python-bottle" ,python-bottle)
16276 ("python-mock" ,python-mock)))
16277 (home-page "https://github.com/marshmallow-code/apispec")
16278 (synopsis "Swagger 2.0 API specification generator")
16279 (description "@code{python-apispec} is a pluggable API specification
16280 generator. Currently supports the OpenAPI specification (f.k.a.
16281 Swagger 2.0).")
16282 (license license:expat)))
16283
16284 (define-public python2-apispec
16285 (package-with-python2 python-apispec))
16286
16287 (define-public python-flasgger
16288 (package
16289 (name "python-flasgger")
16290 (version "0.6.3")
16291 (source
16292 (origin
16293 (method url-fetch)
16294 (uri (string-append "https://github.com/rochacbruno/flasgger/archive/"
16295 version ".tar.gz"))
16296 (file-name (string-append name "-" version ".tar.gz"))
16297 (sha256
16298 (base32
16299 "1gqzlm0rb55fdpsy5ipkganlx9cnpi454fqyycr03jm22zql14ay"))))
16300 (build-system python-build-system)
16301 (arguments
16302 `(#:phases
16303 (modify-phases %standard-phases
16304 (replace 'check
16305 (lambda* (#:key inputs outputs #:allow-other-keys)
16306 (substitute* "Makefile"
16307 (("flake8 flasgger --ignore=F403")
16308 "flake8 flasgger --ignore=E731,F403"))
16309 (setenv "PYTHONPATH" (string-append (getcwd)
16310 ":"
16311 (getenv "PYTHONPATH")))
16312 (zero? (system* "py.test")))))))
16313 (propagated-inputs
16314 `(("python-flask" ,python-flask)
16315 ("python-pyyaml" ,python-pyyaml)
16316 ("python-jsonschema" ,python-jsonschema)
16317 ("python-mistune" ,python-mistune)
16318 ("python-six" ,python-six)))
16319 (native-inputs
16320 `(("python-decorator" ,python-decorator)
16321 ("python-flake8" ,python-flake8)
16322 ("python-flask-restful" ,python-flask-restful)
16323 ("python-flex" ,python-flex)
16324 ("python-pytest-3.0" ,python-pytest-3.0)
16325 ("python-pytest-cov" ,python-pytest-cov)
16326 ("python-marshmallow" ,python-marshmallow)
16327 ("python-apispec" ,python-apispec)))
16328 (home-page "https://github.com/rochacbruno/flasgger/")
16329 (synopsis "Extract Swagger specs from your Flask project")
16330 (description "@code{python-flasgger} allows extracting Swagger specs
16331 from your Flask project. It is a fork of Flask-Swagger.")
16332 (license license:expat)))
16333
16334 (define-public python2-flasgger
16335 (package-with-python2 python-flasgger))
16336
16337 (define-public python-swagger-spec-validator
16338 (package
16339 (name "python-swagger-spec-validator")
16340 (version "2.1.0")
16341 (source
16342 (origin
16343 (method url-fetch)
16344 (uri (pypi-uri "swagger-spec-validator" version))
16345 (sha256
16346 (base32
16347 "13hkpn2lycwr0468yqhjb3kwszqf7hjwlq61w7vdxq1caz31k4nw"))))
16348 (build-system python-build-system)
16349 (propagated-inputs
16350 `(("python-jsonschema" ,python-jsonschema)
16351 ("python-six" ,python-six)))
16352 (home-page
16353 "http://github.com/Yelp/swagger_spec_validator")
16354 (synopsis "Validation of Swagger specifications")
16355 (description "@code{swagger_spec_validator} provides a library for
16356 validating Swagger API specifications.")
16357 (license license:asl2.0)))
16358
16359 (define-public python2-swagger-spec-validator
16360 (package-with-python2 python-swagger-spec-validator))
16361
16362 (define-public python-apache-libcloud
16363 (package
16364 (name "python-apache-libcloud")
16365 (version "2.0.0")
16366 (source
16367 (origin
16368 (method url-fetch)
16369 (uri (pypi-uri "apache-libcloud" version))
16370 (sha256
16371 (base32
16372 "1a71z02ckcxld72k4qgmdnkjan52c4wczncs3p2mp5yafh7dsan7"))))
16373 (build-system python-build-system)
16374 (arguments
16375 `(#:phases
16376 (modify-phases %standard-phases
16377 (add-after 'unpack 'patch-ssh
16378 (lambda* (#:key inputs #:allow-other-keys)
16379 (substitute* "libcloud/compute/ssh.py"
16380 (("'ssh'") (string-append "'" (assoc-ref inputs "openssh")
16381 "/bin/ssh" "'")))
16382 #t))
16383 (add-after 'unpack 'patch-tests
16384 (lambda _
16385 (substitute* "./libcloud/test/test_file_fixtures.py"
16386 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-923>.
16387 (("def _ascii") "def _raw_data(self, method, url, body, headers):
16388 return (httplib.OK,
16389 \"1234abcd\",
16390 {\"test\": \"value\"},
16391 httplib.responses[httplib.OK])
16392 def _ascii"))
16393 (substitute* "libcloud/test/compute/test_ssh_client.py"
16394 (("class ShellOutSSHClientTests")
16395 "@unittest.skip(\"Guix container doesn't have ssh service\")
16396 class ShellOutSSHClientTests")
16397 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-924>.
16398 (("'.xf0.x90.x8d.x88'") "b'\\xF0\\x90\\x8D\\x88'")
16399 (("'.xF0', '.x90', '.x8D', '.x88'")
16400 "b'\\xF0', b'\\x90', b'\\x8D', b'\\x88'"))
16401 #t)))))
16402 (inputs
16403 `(("openssh" ,openssh)))
16404 (propagated-inputs
16405 `(("python-paramiko" ,python-paramiko)
16406 ("python-requests" ,python-requests)))
16407 (native-inputs
16408 `(("python-lockfile" ,python-lockfile)
16409 ("python-mock" ,python-mock)
16410 ("python-requests-mock" ,python-requests-mock)))
16411 (home-page "https://libcloud.apache.org/")
16412 (synopsis "Unified Cloud API")
16413 (description "@code{libcloud} is a Python library for interacting with
16414 many of the popular cloud service providers using a unified API.")
16415 (license license:asl2.0)))
16416
16417 (define-public python2-apache-libcloud
16418 (package-with-python2 python-apache-libcloud))
16419
16420 (define-public python-smmap2
16421 (package
16422 (name "python-smmap2")
16423 (version "2.0.3")
16424 (source
16425 (origin
16426 (method url-fetch)
16427 (uri (pypi-uri "smmap2" version))
16428 (sha256
16429 (base32
16430 "1hvn28p3zvxa98sbi9lrqvv2ps4q284j4jq9a619zw0m7yv0sly7"))))
16431 (build-system python-build-system)
16432 (native-inputs
16433 `(("python-nosexcover" ,python-nosexcover)))
16434 (home-page "https://github.com/Byron/smmap")
16435 (synopsis "Python sliding window memory map manager")
16436 (description "@code{smmap2} is a pure Python implementation of a sliding
16437 window memory map manager.")
16438 (license license:bsd-3)))
16439
16440 (define-public python2-smmap2
16441 (package-with-python2 python-smmap2))
16442
16443 (define-public python-regex
16444 (package
16445 (name "python-regex")
16446 (version "2017.06.07")
16447 (source (origin
16448 (method url-fetch)
16449 (uri (pypi-uri "regex" version))
16450 (sha256
16451 (base32
16452 "06r6b7yigikbj3a72whl85r2b64pj1r0ypmw9yalmkm0wnxq8mz4"))))
16453 (build-system python-build-system)
16454 (home-page "https://bitbucket.org/mrabarnett/mrab-regex")
16455 (synopsis "Alternative regular expression module")
16456 (description "This regular expression implementation is backwards-
16457 compatible with the standard @code{re} module, but offers additional
16458 functionality like full case-folding for case-insensitive matches in Unicode.")
16459 (license license:psfl)))
16460
16461 (define-public python2-regex
16462 (package-with-python2 python-regex))
16463
16464 (define-public python2-pyopengl
16465 (package
16466 (name "python2-pyopengl")
16467 (version "3.1.0")
16468 (source
16469 (origin
16470 (method url-fetch)
16471 (uri (pypi-uri "PyOpenGL" version))
16472 (sha256
16473 (base32
16474 "1byxjj6a8rwzhxhjqlc588zdad2qwxdd7vlam2653ylll31waiwv"))))
16475 (arguments
16476 `(#:python ,python-2))
16477 (build-system python-build-system)
16478 (home-page "http://pyopengl.sourceforge.net")
16479 (synopsis "Standard OpenGL bindings for Python")
16480 (description
16481 "PyOpenGL is the most common cross platform Python binding to OpenGL and
16482 related APIs. The binding is created using the standard @code{ctypes}
16483 library.")
16484 (license license:bsd-3)))
16485
16486 (define-public python-rencode
16487 (package
16488 (name "python-rencode")
16489 (version "1.0.3")
16490 (source
16491 (origin
16492 (method url-fetch)
16493 (uri (pypi-uri "rencode" version))
16494 (sha256
16495 (base32
16496 "08if5yax1xn5yfp8p3765ccjmfcv9di7i4m5jckgnwvdsgznwkbj"))))
16497 (build-system python-build-system)
16498 (native-inputs `(("pkg-config" ,pkg-config)
16499 ("python-cython", python-cython)))
16500 (home-page "https://github.com/aresch/rencode")
16501 (synopsis "Serialization of heterogeneous data structures")
16502 (description
16503 "The @code{rencode} module is a data structure serialization library,
16504 similar to @code{bencode} from the BitTorrent project. For complex,
16505 heterogeneous data structures with many small elements, r-encoding stake up
16506 significantly less space than b-encodings. This version of rencode is a
16507 complete rewrite in Cython to attempt to increase the performance over the
16508 pure Python module.")
16509 (license license:bsd-3)))
16510
16511 (define-public python2-rencode
16512 (package-with-python2 python-rencode))
16513
16514 (define-public python-xenon
16515 (package
16516 (name "python-xenon")
16517 (version "0.5.1")
16518 (source
16519 (origin
16520 (method url-fetch)
16521 (uri (pypi-uri "xenon" version))
16522 (sha256
16523 (base32
16524 "14kby2y48vp3sgwxqlm5d5789yibqwb1qli5fwcmdqg3iayrbklc"))))
16525 (build-system python-build-system)
16526 (native-inputs
16527 `(("python-pyyaml" ,python-pyyaml)
16528 ("python-radon" ,python-radon)
16529 ("python-requests" ,python-requests)
16530 ("python-flake8" ,python-flake8)
16531 ("python-tox" ,python-tox)))
16532 (arguments
16533 `(#:phases
16534 (modify-phases %standard-phases
16535 (add-before 'build 'patch-test-requirements
16536 (lambda* (#:key inputs #:allow-other-keys)
16537 ;; Update requirements from dependency==version to
16538 ;; dependency>=version.
16539 (substitute* "requirements.txt"
16540 (("==") ">=")
16541 ((",<1.5.0") ""))
16542 ;; Remove httpretty dependency for tests.
16543 (substitute* "setup.py"
16544 (("httpretty") ""))
16545 #t)))))
16546 (home-page "https://xenon.readthedocs.org/")
16547 (synopsis "Monitor code metrics for Python on your CI server")
16548 (description
16549 "Xenon is a monitoring tool based on Radon. It monitors code complexity.
16550 Ideally, @code{xenon} is run every time code is committed. Through command
16551 line options, various thresholds can be set for the complexity of code. It
16552 will fail (i.e. it will exit with a non-zero exit code) when any of these
16553 requirements is not met.")
16554 (license license:expat)))
16555
16556 (define-public python2-xenon
16557 (package-with-python2 python-xenon))
16558
16559 (define-public python-flask-principal
16560 (package
16561 (name "python-flask-principal")
16562 (version "0.4.0")
16563 (source
16564 (origin
16565 (method url-fetch)
16566 (uri (pypi-uri "Flask-Principal" version))
16567 (sha256
16568 (base32
16569 "0lwlr5smz8vfm5h9a9i7da3q1c24xqc6vm9jdywdpgxfbi5i7mpm"))))
16570 (build-system python-build-system)
16571 (propagated-inputs
16572 `(("python-blinker" ,python-blinker)))
16573 (native-inputs
16574 `(("python-flask" ,python-flask)
16575 ("python-nose" ,python-nose)))
16576 (home-page "http://packages.python.org/Flask-Principal/")
16577 (synopsis "Identity management for Flask")
16578 (description "@code{flask_principal} is a identity management library for
16579 Flask. It supports managing both authentication and authorization data in a
16580 thread-local variable.")
16581 (license license:expat)))
16582
16583 (define-public python2-flask-principal
16584 (package-with-python2 python-flask-principal))
16585
16586 (define-public python-flask-httpauth
16587 (package
16588 (name "python-flask-httpauth")
16589 (version "3.2.3")
16590 (source
16591 (origin
16592 (method url-fetch)
16593 (uri (pypi-uri "Flask-HTTPAuth" version))
16594 (sha256
16595 (base32
16596 "13gff5w1mqpzm5nccyg02v3ifb9ifqh5k866cssjhghhg6msfjsz"))))
16597 (build-system python-build-system)
16598 (native-inputs
16599 `(("python-flask" ,python-flask)))
16600 (home-page "http://github.com/miguelgrinberg/flask-httpauth/")
16601 (synopsis "Basic and Digest HTTP authentication for Flask routes")
16602 (description "@code{flask_httpauth} provides Basic and Digest HTTP
16603 authentication for Flask routes.")
16604 (license license:expat)))
16605
16606 (define-public python2-flask-httpauth
16607 (package-with-python2 python-flask-httpauth))
16608
16609 (define-public python-pysocks
16610 (package
16611 (name "python-pysocks")
16612 (version "1.6.7")
16613 (source
16614 (origin
16615 (method url-fetch)
16616 (uri (pypi-uri "PySocks" version))
16617 (sha256
16618 (base32
16619 "1krkiss578zqwcg4c8iqz1hwscwhsvy2djp3xyvps5gsgvr2j0yh"))))
16620 (build-system python-build-system)
16621 (arguments `(#:tests? #f))
16622 (home-page "https://github.com/Anorov/PySocks")
16623 (synopsis "SOCKS client module")
16624 (description "@code{pysocks} is an updated and semi-actively maintained
16625 version of @code{SocksiPy} with bug fixes and extra features.")
16626 (license license:bsd-3)))
16627
16628 (define-public python2-pysocks
16629 (package-with-python2 python-pysocks))
16630
16631 (define-public python-pyaes
16632 (package
16633 (name "python-pyaes")
16634 (version "1.6.0")
16635 (source
16636 (origin
16637 (method url-fetch)
16638 (uri (pypi-uri "pyaes" version))
16639 (sha256
16640 (base32
16641 "0bp9bjqy1n6ij1zb86wz9lqa1dhla8qr1d7w2kxyn7jbj56sbmcw"))))
16642 (build-system python-build-system)
16643 (home-page "https://github.com/ricmoo/pyaes")
16644 (synopsis "Implementation of AES in Python")
16645 (description "This package contains a pure-Python implementation of the
16646 AES block cipher algorithm and the common modes of operation (CBC, CFB, CTR,
16647 ECB and OFB).")
16648 (license license:expat)))
16649
16650 (define-public python2-pyaes
16651 (package-with-python2 python-pyaes))
16652
16653 (define-public python-uritemplate
16654 (package
16655 (name "python-uritemplate")
16656 (version "3.0.0")
16657 (source
16658 (origin
16659 (method url-fetch)
16660 (uri (pypi-uri "uritemplate" version))
16661 (sha256
16662 (base32
16663 "0781gm9g34wa0asc19dx81ng0nqq07igzv3bbvdqmz13pv7469n0"))))
16664 (build-system python-build-system)
16665 (home-page "https://uritemplate.readthedocs.org")
16666 (synopsis "Library to deal with URI Templates")
16667 (description "@code{uritemplate} provides Python library to deal with URI
16668 Templates.")
16669 (license license:bsd-2)))
16670
16671 (define-public python2-uritemplate
16672 (package-with-python2 python-uritemplate))
16673
16674 (define-public python-pydiff
16675 (package
16676 (name "python-pydiff")
16677 (version "0.2")
16678 (source
16679 (origin
16680 (method url-fetch)
16681 (uri (pypi-uri "pydiff" version))
16682 (sha256
16683 (base32
16684 "1als83h9w0gab24ipyna6khm390qmpnpkc5jksmdbs2xc8hp2z44"))))
16685 (build-system python-build-system)
16686 (home-page "https://github.com/myint/pydiff")
16687 (synopsis "Library to diff two Python files at the bytecode level")
16688 (description
16689 "@code{pydiff} makes it easy to look for actual code changes while
16690 ignoring formatting changes.")
16691 (license license:expat)))
16692
16693 (define-public python2-pydiff
16694 (package-with-python2 python-pydiff))
16695
16696 (define-public python-nose-timer
16697 (package
16698 (name "python-nose-timer")
16699 (version "0.7.0")
16700 (source
16701 (origin
16702 (method url-fetch)
16703 (uri (pypi-uri "nose-timer" version))
16704 (patches
16705 (search-patches
16706 ;; This patch will not be needed in the next version.
16707 ;; It is taken from the master branch.
16708 "python-nose-timer-drop-ordereddict.patch"))
16709 (sha256
16710 (base32
16711 "1s32ymsnby8lz2qk55ifj9zi50dqcg6swnj5cz2rmwxg2jsslsxp"))))
16712 (build-system python-build-system)
16713 (propagated-inputs
16714 `(("python-nose" ,python-nose)
16715 ("python-termcolor" ,python-termcolor)))
16716 (home-page "https://github.com/mahmoudimus/nose-timer")
16717 (synopsis "Timer plugin for nosetests")
16718 (description "Shows how much time was needed to run individual tests.")
16719 (license license:expat)))
16720
16721 (define-public python2-nose-timer
16722 (package-with-python2 python-nose-timer))
16723
16724 (define-public python-tqdm
16725 (package
16726 (name "python-tqdm")
16727 (version "4.15.0")
16728 (source
16729 (origin
16730 (method url-fetch)
16731 (uri (pypi-uri "tqdm" version))
16732 (sha256
16733 (base32
16734 "0lwrmby8qz23gvqwkpivfrv4q8nfh90cz9ml6slwvwmcxxsdrhbf"))))
16735 (build-system python-build-system)
16736 (native-inputs
16737 `(("python-flake8" ,python-flake8)
16738 ("python-nose" ,python-nose)
16739 ("python-nose-timer" ,python-nose-timer)
16740 ("python-coverage" ,python-coverage)
16741 ("python-virtualenv" ,python-virtualenv)))
16742 (home-page "https://github.com/tqdm/tqdm")
16743 (synopsis "Fast, extensible progress meter")
16744 (description
16745 "Make loops show a progress bar on the console by just wrapping any
16746 iterable with @code{|tqdm(iterable)|}. Offers many options to define
16747 design and layout.")
16748 (license (list license:mpl2.0 license:expat))))
16749
16750 (define-public python2-tqdm
16751 (package-with-python2 python-tqdm))
16752
16753 (define-public python-pkginfo
16754 (package
16755 (name "python-pkginfo")
16756 (version "1.4.1")
16757 (source
16758 (origin
16759 (method url-fetch)
16760 (uri (pypi-uri "pkginfo" version))
16761 (sha256
16762 (base32
16763 "17pqjfpq3c6xzdmk8pski6jcjgjv78q00zjf2bgzb668pzm6l6mv"))))
16764 (build-system python-build-system)
16765 (arguments
16766 ;; The tests are broken upstream.
16767 '(#:tests? #f))
16768 (home-page
16769 "https://code.launchpad.net/~tseaver/pkginfo/trunk")
16770 (synopsis
16771 "Query metadatdata from sdists, bdists, and installed packages")
16772 (description
16773 "API to query the distutils metadata written in @file{PKG-INFO} inside a
16774 source distriubtion (an sdist) or a binary distribution (e.g., created by
16775 running bdist_egg). It can also query the EGG-INFO directory of an installed
16776 distribution, and the *.egg-info stored in a \"development checkout\" (e.g,
16777 created by running @code{python setup.py develop}).")
16778 (license license:expat)))
16779
16780 (define-public python2-pkginfo
16781 (package-with-python2 python-pkginfo))
16782
16783 (define-public python-twine
16784 (package
16785 (name "python-twine")
16786 (version "1.9.1")
16787 (source
16788 (origin
16789 (method url-fetch)
16790 (uri (pypi-uri "twine" version))
16791 (sha256
16792 (base32
16793 "1ay1b6kdq6k4bfbjsvf6ymj41wrgpvinhxndb09355pwhxwmp96a"))))
16794 (build-system python-build-system)
16795 (propagated-inputs
16796 `(("python-tqdm" ,python-tqdm)
16797 ("python-pkginfo", python-pkginfo)
16798 ("python-requests" ,python-requests)
16799 ("python-requests-toolbelt" ,python-requests-toolbelt)))
16800 (home-page "https://github.com/pypa/twine")
16801 (synopsis "Collection of utilities for interacting with PyPI")
16802 (description
16803 "@code{twine} currently supports registering projects and uploading
16804 distributions. It authenticates the user over HTTPS, allows them to pre-sign
16805 their files and supports any packaging format (including wheels).")
16806 (license license:asl2.0)))
16807
16808 (define-public python2-twine
16809 (package-with-python2 python-twine))
16810
16811 (define-public python-linecache2
16812 (package
16813 (name "python-linecache2")
16814 (version "1.0.0")
16815 (source
16816 (origin
16817 (method url-fetch)
16818 (uri (pypi-uri "linecache2" version))
16819 (sha256
16820 (base32
16821 "0z79g3ds5wk2lvnqw0y2jpakjf32h95bd9zmnvp7dnqhf57gy9jb"))))
16822 (build-system python-build-system)
16823 (arguments
16824 `(;; The tests depend on unittest2, and our version is a bit too old.
16825 #:tests? #f))
16826 (native-inputs
16827 `(("python-pbr" ,python-pbr)))
16828 (home-page
16829 "https://github.com/testing-cabal/linecache2")
16830 (synopsis "Backports of the linecache module")
16831 (description
16832 "The linecache module allows one to get any line from any file, while
16833 attempting to optimize internally, using a cache, the common case where many
16834 lines are read from a single file.")
16835 (license license:psfl)))
16836
16837 (define-public python2-linecache2
16838 (package-with-python2 python-linecache2))
16839
16840 (define-public python-traceback2
16841 (package
16842 (name "python-traceback2")
16843 (version "1.4.0")
16844 (source
16845 (origin
16846 (method url-fetch)
16847 (uri (pypi-uri "traceback2" version))
16848 (sha256
16849 (base32
16850 "0c1h3jas1jp1fdbn9z2mrgn3jj0hw1x3yhnkxp7jw34q15xcdb05"))))
16851 (build-system python-build-system)
16852 (arguments
16853 `(;; python-traceback2 and python-unittest2 depend on one another.
16854 #:tests? #f))
16855 (native-inputs
16856 `(("python-pbr" ,python-pbr)))
16857 (propagated-inputs
16858 `(("python-linecache2" ,python-linecache2)))
16859 (home-page
16860 "https://github.com/testing-cabal/traceback2")
16861 (synopsis "Backports of the traceback module")
16862 (description
16863 "This module provides a standard interface to extract, format and print
16864 stack traces of Python programs. It exactly mimics the behavior of the Python
16865 interpreter when it prints a stack trace.")
16866 (license license:psfl)))
16867
16868 (define-public python2-traceback2
16869 (package-with-python2 python-traceback2))
16870
16871 (define-public python-ratelimiter
16872 (package
16873 (name "python-ratelimiter")
16874 (version "1.2.0")
16875 (source
16876 (origin
16877 (method url-fetch)
16878 (uri (pypi-uri "ratelimiter" version))
16879 (sha256
16880 (base32
16881 "1dhz85mj5bqd2mij84ncs6pz32hgidr79hay4aqfmzaa4rbb497p"))))
16882 (build-system python-build-system)
16883 (arguments
16884 '(#:tests? #f)) ; There are no tests in the pypi archive.
16885 (home-page "https://github.com/RazerM/ratelimiter")
16886 (synopsis "Simple rate limiting object")
16887 (description
16888 "The @code{ratelimiter} module ensures that an operation will not be
16889 executed more than a given number of times during a given period.")
16890 (license license:asl2.0)))
16891
16892 (define-public python2-ratelimiter
16893 (package-with-python2 python-ratelimiter))
16894
16895 (define-public python-dukpy
16896 (package
16897 (name "python-dukpy")
16898 (version "0.3")
16899 (source
16900 (origin
16901 (method url-fetch)
16902 (uri (string-append "https://github.com/kovidgoyal/dukpy/archive/v"
16903 version ".tar.gz"))
16904 (sha256
16905 (base32
16906 "0pj39rfwlzivqm5hkrsza7gssg6ggpxlq5ivc8f3h7x5pfgc6y6c"))))
16907 (build-system python-build-system)
16908 (home-page "https://github.com/kovidgoyal/dukpy")
16909 (synopsis "Run JavaScript in python")
16910 (description
16911 "dukpy is a JavaScript runtime environment for Python using the duktape
16912 embeddable JavaScript engine.")
16913 ;; Dukpy is licensed under MIT like the embedded duktape library,
16914 ;; with 'errors.c' as GPL3.
16915 (license (list license:expat license:gpl3))))
16916
16917 (define-public python2-dukpy
16918 (package-with-python2 python-dukpy))
16919
16920 (define-public python-jsonrpclib-pelix
16921 (package
16922 (name "python-jsonrpclib-pelix")
16923 (version "0.3.1")
16924 (source
16925 (origin
16926 (method url-fetch)
16927 (uri (pypi-uri "jsonrpclib-pelix" version))
16928 (sha256
16929 (base32
16930 "1qs95vxplxwspbrqy8bvc195s58iy43qkf75yrjfql2sim8b25sl"))))
16931 (build-system python-build-system)
16932 (home-page "https://github.com/tcalmant/jsonrpclib/")
16933 (synopsis "JSON-RPC 2.0 client library for Python")
16934 (description
16935 "This library implements the JSON-RPC v2.0
16936 specification (backwards-compatible) as a client library for Python. This
16937 version is a fork of jsonrpclib by Josh Marshall, usable with Pelix remote
16938 services.")
16939 (license license:asl2.0)))
16940
16941 (define-public python2-jsonrpclib-pelix
16942 (package-with-python2 python-jsonrpclib-pelix))