gnu: Add python-flask-httpauth.
[jackhill/guix/guix.git] / gnu / packages / python.scm
1 ;;; GNU Guix --- Functional package management for GNU
2 ;;; Copyright © 2013 Nikita Karetnikov <nikita@karetnikov.org>
3 ;;; Copyright © 2013, 2014, 2015, 2016, 2017 Ludovic Courtès <ludo@gnu.org>
4 ;;; Copyright © 2013, 2014, 2015, 2016 Andreas Enge <andreas@enge.fr>
5 ;;; Copyright © 2014, 2015 Mark H Weaver <mhw@netris.org>
6 ;;; Copyright © 2014, 2017 Eric Bavier <bavier@member.fsf.org>
7 ;;; Copyright © 2014, 2015 Federico Beffa <beffa@fbengineering.ch>
8 ;;; Copyright © 2015 Omar Radwan <toxemicsquire4@gmail.com>
9 ;;; Copyright © 2015 Pierre-Antoine Rault <par@rigelk.eu>
10 ;;; Copyright © 2015, 2016, 2017 Ricardo Wurmus <rekado@elephly.net>
11 ;;; Copyright © 2015, 2016 Christopher Allan Webber <cwebber@dustycloud.org>
12 ;;; Copyright © 2015 Eric Dvorsak <eric@dvorsak.fr>
13 ;;; Copyright © 2015, 2016 David Thompson <davet@gnu.org>
14 ;;; Copyright © 2015, 2016, 2017 Leo Famulari <leo@famulari.name>
15 ;;; Copyright © 2015 Ben Woodcroft <donttrustben@gmail.com>
16 ;;; Copyright © 2015, 2016 Erik Edrosa <erik.edrosa@gmail.com>
17 ;;; Copyright © 2015, 2016, 2017 Efraim Flashner <efraim@flashner.co.il>
18 ;;; Copyright © 2015 Kyle Meyer <kyle@kyleam.com>
19 ;;; Copyright © 2015, 2016 Chris Marusich <cmmarusich@gmail.com>
20 ;;; Copyright © 2016 Danny Milosavljevic <dannym+a@scratchpost.org>
21 ;;; Copyright © 2016 Lukas Gradl <lgradl@openmailbox.org>
22 ;;; Copyright © 2016 Hartmut Goebel <h.goebel@crazy-compilers.com>
23 ;;; Copyright © 2016 Daniel Pimentel <d4n1@d4n1.org>
24 ;;; Copyright © 2016 Sou Bunnbu <iyzsong@gmail.com>
25 ;;; Copyright © 2016 Troy Sankey <sankeytms@gmail.com>
26 ;;; Copyright © 2016, 2017 ng0 <contact.ng0@cryptolab.net>
27 ;;; Copyright © 2016 Dylan Jeffers <sapientech@sapientech@openmailbox.org>
28 ;;; Copyright © 2016 David Craven <david@craven.ch>
29 ;;; Copyright © 2016, 2017 Marius Bakke <mbakke@fastmail.com>
30 ;;; Copyright © 2016, 2017 Stefan Reichör <stefan@xsteve.at>
31 ;;; Copyright © 2016 Dylan Jeffers <sapientech@sapientech@openmailbox.org>
32 ;;; Copyright © 2016 Alex Vong <alexvong1995@gmail.com>
33 ;;; Copyright © 2016, 2017 Arun Isaac <arunisaac@systemreboot.net>
34 ;;; Copyright © 2016, 2017 Julien Lepiller <julien@lepiller.eu>
35 ;;; Copyright © 2016, 2017 Tobias Geerinckx-Rice <me@tobias.gr>
36 ;;; Copyright © 2016, 2017 Thomas Danckaert <post@thomasdanckaert.be>
37 ;;; Copyright © 2017 Carlo Zancanaro <carlo@zancanaro.id.au>
38 ;;; Copyright © 2017 Frederick M. Muriithi <fredmanglis@gmail.com>
39 ;;; Copyright © 2017 Adriano Peluso <catonano@gmail.com>
40 ;;; Copyright © 2017 Ben Sturmfels <ben@sturm.com.au>
41 ;;; Copyright © 2017 Mathieu Othacehe <m.othacehe@gmail.com>
42 ;;; Copyright © 2017 José Miguel Sánchez García <jmi2k@openmailbox.org>
43 ;;; Copyright © 2017 Roel Janssen <roel@gnu.org>
44 ;;; Copyright © 2017 Kei Kebreau <kei@openmailbox.org>
45 ;;; Copyright © 2017 Rutger Helling <rhelling@mykolab.com>
46 ;;; Copyright © 2017 Muriithi Frederick Muriuki <fredmanglis@gmail.com>
47 ;;;
48 ;;; This file is part of GNU Guix.
49 ;;;
50 ;;; GNU Guix is free software; you can redistribute it and/or modify it
51 ;;; under the terms of the GNU General Public License as published by
52 ;;; the Free Software Foundation; either version 3 of the License, or (at
53 ;;; your option) any later version.
54 ;;;
55 ;;; GNU Guix is distributed in the hope that it will be useful, but
56 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
57 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
58 ;;; GNU General Public License for more details.
59 ;;;
60 ;;; You should have received a copy of the GNU General Public License
61 ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
62
63 (define-module (gnu packages python)
64 #:use-module ((guix licenses) #:prefix license:)
65 #:use-module (gnu packages)
66 #:use-module (gnu packages algebra)
67 #:use-module (gnu packages adns)
68 #:use-module (gnu packages attr)
69 #:use-module (gnu packages backup)
70 #:use-module (gnu packages bash)
71 #:use-module (gnu packages compression)
72 #:use-module (gnu packages crypto)
73 #:use-module (gnu packages databases)
74 #:use-module (gnu packages django)
75 #:use-module (gnu packages file)
76 #:use-module (gnu packages fontutils)
77 #:use-module (gnu packages gcc)
78 #:use-module (gnu packages ghostscript)
79 #:use-module (gnu packages gl)
80 #:use-module (gnu packages glib)
81 #:use-module (gnu packages graphviz)
82 #:use-module (gnu packages gstreamer)
83 #:use-module (gnu packages gtk)
84 #:use-module (gnu packages icu4c)
85 #:use-module (gnu packages image)
86 #:use-module (gnu packages imagemagick)
87 #:use-module (gnu packages libevent)
88 #:use-module (gnu packages libffi)
89 #:use-module (gnu packages linux)
90 #:use-module (gnu packages man)
91 #:use-module (gnu packages maths)
92 #:use-module (gnu packages multiprecision)
93 #:use-module (gnu packages networking)
94 #:use-module (gnu packages ncurses)
95 #:use-module (gnu packages openstack)
96 #:use-module (gnu packages password-utils)
97 #:use-module (gnu packages pcre)
98 #:use-module (gnu packages perl)
99 #:use-module (gnu packages pkg-config)
100 #:use-module (gnu packages protobuf)
101 #:use-module (gnu packages qt)
102 #:use-module (gnu packages readline)
103 #:use-module (gnu packages sdl)
104 #:use-module (gnu packages search)
105 #:use-module (gnu packages shells)
106 #:use-module (gnu packages ssh)
107 #:use-module (gnu packages statistics)
108 #:use-module (gnu packages tex)
109 #:use-module (gnu packages texinfo)
110 #:use-module (gnu packages tls)
111 #:use-module (gnu packages version-control)
112 #:use-module (gnu packages video)
113 #:use-module (gnu packages web)
114 #:use-module (gnu packages base)
115 #:use-module (gnu packages xml)
116 #:use-module (gnu packages xorg)
117 #:use-module (gnu packages xdisorg)
118 #:use-module (gnu packages tcl)
119 #:use-module (gnu packages bdw-gc)
120 #:use-module (guix packages)
121 #:use-module (guix download)
122 #:use-module (guix git-download)
123 #:use-module (guix utils)
124 #:use-module (guix build-system gnu)
125 #:use-module (guix build-system cmake)
126 #:use-module (guix build-system python)
127 #:use-module (guix build-system trivial)
128 #:use-module (srfi srfi-1))
129
130 (define-public python-2.7
131 (package
132 (name "python")
133 (version "2.7.13")
134 (source
135 (origin
136 (method url-fetch)
137 (uri (string-append "https://www.python.org/ftp/python/"
138 version "/Python-" version ".tar.xz"))
139 (sha256
140 (base32
141 "0cgpk3zk0fgpji59pb4zy9nzljr70qzgv1vpz5hq5xw2d2c47m9m"))
142 (patches (search-patches "python-2.7-search-paths.patch"
143 "python-2-deterministic-build-info.patch"
144 "python-2.7-site-prefixes.patch"
145 "python-2.7-source-date-epoch.patch"
146 "python-2.7-getentropy-on-old-kernels.patch"))
147 (modules '((guix build utils)))
148 ;; suboptimal to delete failing tests here, but if we delete them in the
149 ;; arguments then we need to make sure to strip out that phase when it
150 ;; gets inherited by python and python-minimal.
151 (snippet
152 '(begin
153 (for-each delete-file
154 '("Lib/test/test_compileall.py"
155 "Lib/test/test_ctypes.py" ; fails on mips64el
156 "Lib/test/test_distutils.py"
157 "Lib/test/test_import.py"
158 "Lib/test/test_shutil.py"
159 "Lib/test/test_socket.py"
160 "Lib/test/test_subprocess.py"))
161 #t))))
162 (outputs '("out"
163 "tk")) ;tkinter; adds 50 MiB to the closure
164 (build-system gnu-build-system)
165 (arguments
166 `(;; 356 tests OK.
167 ;; 6 tests failed:
168 ;; test_compileall test_distutils test_import test_shutil test_socket
169 ;; test_subprocess
170 ;; 39 tests skipped:
171 ;; test_aepack test_al test_applesingle test_bsddb test_bsddb185
172 ;; test_bsddb3 test_cd test_cl test_codecmaps_cn test_codecmaps_hk
173 ;; test_codecmaps_jp test_codecmaps_kr test_codecmaps_tw test_curses
174 ;; test_dl test_gdb test_gl test_imageop test_imgfile test_ioctl
175 ;; test_kqueue test_linuxaudiodev test_macos test_macostools
176 ;; test_msilib test_ossaudiodev test_scriptpackages test_smtpnet
177 ;; test_socketserver test_startfile test_sunaudiodev test_timeout
178 ;; test_tk test_ttk_guionly test_urllib2net test_urllibnet
179 ;; test_winreg test_winsound test_zipfile64
180 ;; 4 skips unexpected on linux2:
181 ;; test_bsddb test_bsddb3 test_gdb test_ioctl
182 #:test-target "test"
183 #:configure-flags
184 (list "--enable-shared" ;allow embedding
185 "--with-system-ffi" ;build ctypes
186 "--with-ensurepip=install" ;install pip and setuptools
187 "--enable-unicode=ucs4"
188 (string-append "LDFLAGS=-Wl,-rpath="
189 (assoc-ref %outputs "out") "/lib"))
190
191 #:modules ((ice-9 ftw) (ice-9 match)
192 (guix build utils) (guix build gnu-build-system))
193 #:phases
194 (modify-phases %standard-phases
195 (add-before
196 'configure 'patch-lib-shells
197 (lambda _
198 ;; Filter for existing files, since some may not exist in all
199 ;; versions of python that are built with this recipe.
200 (substitute* (filter file-exists?
201 '("Lib/subprocess.py"
202 "Lib/popen2.py"
203 "Lib/distutils/tests/test_spawn.py"
204 "Lib/test/test_subprocess.py"))
205 (("/bin/sh") (which "sh")))
206
207 ;; Use zero as the timestamp in .pyc files so that builds are
208 ;; deterministic. TODO: Remove it when this variable is set in
209 ;; gnu-build-system.scm.
210 (setenv "SOURCE_DATE_EPOCH" "1")
211 #t))
212 (add-before 'configure 'do-not-record-configure-flags
213 (lambda* (#:key configure-flags #:allow-other-keys)
214 ;; Remove configure flags from the installed '_sysconfigdata.py'
215 ;; and 'Makefile' so we don't end up keeping references to the
216 ;; build tools.
217 ;;
218 ;; Preserve at least '--with-system-ffi' since otherwise the
219 ;; thing tries to build libffi, fails, and we end up with a
220 ;; Python that lacks ctypes.
221 (substitute* "configure"
222 (("^CONFIG_ARGS=.*$")
223 (format #f "CONFIG_ARGS='~a'\n"
224 (if (member "--with-system-ffi" configure-flags)
225 "--with-system-ffi"
226 ""))))
227 #t))
228 (add-before
229 'check 'pre-check
230 (lambda _
231 ;; 'Lib/test/test_site.py' needs a valid $HOME
232 (setenv "HOME" (getcwd))
233 #t))
234 (add-after
235 'unpack 'set-source-file-times-to-1980
236 ;; XXX One of the tests uses a ZIP library to pack up some of the
237 ;; source tree, and fails with "ZIP does not support timestamps
238 ;; before 1980". Work around this by setting the file times in the
239 ;; source tree to sometime in early 1980.
240 (lambda _
241 (let ((circa-1980 (* 10 366 24 60 60)))
242 (ftw "." (lambda (file stat flag)
243 (utime file circa-1980 circa-1980)
244 #t))
245 #t)))
246 (add-after 'install 'remove-tests
247 ;; Remove 25 MiB of unneeded unit tests. Keep test_support.*
248 ;; because these files are used by some libraries out there.
249 (lambda* (#:key outputs #:allow-other-keys)
250 (let ((out (assoc-ref outputs "out")))
251 (match (scandir (string-append out "/lib")
252 (lambda (name)
253 (string-prefix? "python" name)))
254 ((pythonX.Y)
255 (let ((testdir (string-append out "/lib/" pythonX.Y
256 "/test")))
257 (with-directory-excursion testdir
258 (for-each delete-file-recursively
259 (scandir testdir
260 (match-lambda
261 ((or "." "..") #f)
262 (file
263 (not
264 (string-prefix? "test_support."
265 file))))))
266 (call-with-output-file "__init__.py" (const #t))
267 #t)))))))
268 (add-before 'strip 'make-libraries-writable
269 (lambda* (#:key outputs #:allow-other-keys)
270 ;; Make .so files writable so they can be stripped.
271 (let ((out (assoc-ref outputs "out")))
272 (for-each (lambda (file)
273 (chmod file #o755))
274 (find-files (string-append out "/lib")
275 "\\.so"))
276 #t)))
277 (add-after 'install 'move-tk-inter
278 (lambda* (#:key outputs #:allow-other-keys)
279 ;; When Tkinter support is built move it to a separate output so
280 ;; that the main output doesn't contain a reference to Tcl/Tk.
281 (let ((out (assoc-ref outputs "out"))
282 (tk (assoc-ref outputs "tk")))
283 (when tk
284 (match (find-files out "tkinter.*\\.so")
285 ((tkinter.so)
286 ;; The .so is in OUT/lib/pythonX.Y/lib-dynload, but we
287 ;; want it under TK/lib/pythonX.Y/site-packages.
288 (let* ((len (string-length out))
289 (target (string-append
290 tk "/"
291 (string-drop
292 (dirname (dirname tkinter.so))
293 len)
294 "/site-packages")))
295 (install-file tkinter.so target)
296 (delete-file tkinter.so)))))
297 #t))))))
298 (inputs
299 `(("bzip2" ,bzip2)
300 ("gdbm" ,gdbm)
301 ("libffi" ,libffi) ; for ctypes
302 ("sqlite" ,sqlite) ; for sqlite extension
303 ("openssl" ,openssl)
304 ("readline" ,readline)
305 ("zlib" ,zlib)
306 ("tcl" ,tcl)
307 ("tk" ,tk))) ; for tkinter
308 (native-inputs
309 `(("pkg-config" ,pkg-config)))
310 (native-search-paths
311 (list (search-path-specification
312 (variable "PYTHONPATH")
313 (files '("lib/python2.7/site-packages")))))
314 (home-page "https://www.python.org")
315 (synopsis "High-level, dynamically-typed programming language")
316 (description
317 "Python is a remarkably powerful dynamic programming language that
318 is used in a wide variety of application domains. Some of its key
319 distinguishing features include: clear, readable syntax; strong
320 introspection capabilities; intuitive object orientation; natural
321 expression of procedural code; full modularity, supporting hierarchical
322 packages; exception-based error handling; and very high level dynamic
323 data types.")
324 (license license:psfl)))
325
326 ;; Current 2.x version.
327 (define-public python-2 python-2.7)
328
329 (define-public python-3.5
330 (package (inherit python-2)
331 (version "3.5.3")
332 (source (origin
333 (method url-fetch)
334 (uri (string-append "https://www.python.org/ftp/python/"
335 version "/Python-" version ".tar.xz"))
336 (patches (search-patches
337 "python-fix-tests.patch"
338 "python-3.5-fix-tests.patch"
339 "python-3.5-getentropy-on-old-kernels.patch"
340 "python-3-deterministic-build-info.patch"
341 "python-3-search-paths.patch"))
342 (patch-flags '("-p0"))
343 (sha256
344 (base32
345 "1c6v1n9nz4mlx9mw1125fxpmbrgniqdbbx9hnqx44maqazb2mzpf"))
346 (snippet
347 '(delete-file
348 "Lib/ctypes/test/test_win32.py")))) ; fails on aarch64
349 (arguments (substitute-keyword-arguments (package-arguments python-2)
350 ((#:tests? _) #t)))
351 (native-search-paths
352 (list (search-path-specification
353 (variable "PYTHONPATH")
354 (files (list (string-append "lib/python"
355 (version-major+minor version)
356 "/site-packages"))))))))
357
358 ;; Current 3.x version.
359 (define-public python-3 python-3.5)
360
361 ;; Current major version.
362 (define-public python python-3)
363
364 ;; Minimal variants of Python, mostly used to break the cycle between Tk and
365 ;; Python (Tk -> libxcb -> Python.)
366
367 (define-public python2-minimal
368 (package (inherit python-2)
369 (name "python-minimal")
370 (outputs '("out"))
371
372 ;; Keep zlib, which is used by 'pip' (via the 'zipimport' module), which
373 ;; is invoked upon 'make install'. 'pip' also expects 'ctypes' and thus
374 ;; libffi.
375 (inputs `(("libffi" ,libffi)
376 ("zlib" ,zlib)))))
377
378 (define-public python-minimal
379 (package (inherit python)
380 (name "python-minimal")
381 (outputs '("out"))
382
383 ;; Build fails due to missing ctypes without libffi.
384 ;; OpenSSL is a mandatory dependency of Python 3.x, for urllib;
385 ;; zlib is required by 'zipimport', used by pip.
386 (inputs `(("libffi" ,libffi)
387 ("openssl" ,openssl)
388 ("zlib" ,zlib)))))
389
390 (define* (wrap-python3 python
391 #:optional
392 (name (string-append (package-name python) "-wrapper")))
393 (package (inherit python)
394 (name name)
395 (source #f)
396 (build-system trivial-build-system)
397 (outputs '("out"))
398 (inputs `(("bash" ,bash)))
399 (propagated-inputs `(("python" ,python)))
400 (arguments
401 `(#:modules ((guix build utils))
402 #:builder
403 (begin
404 (use-modules (guix build utils))
405 (let ((bin (string-append (assoc-ref %outputs "out") "/bin"))
406 (python (string-append (assoc-ref %build-inputs "python") "/bin/")))
407 (mkdir-p bin)
408 (for-each
409 (lambda (old new)
410 (symlink (string-append python old)
411 (string-append bin "/" new)))
412 `("python3" ,"pydoc3" ,"idle3" ,"pip3")
413 `("python" ,"pydoc" ,"idle" ,"pip"))
414 ;; python-config outputs search paths based upon its location,
415 ;; use a bash wrapper to avoid changing its outputs.
416 (let ((bash (string-append (assoc-ref %build-inputs "bash")
417 "/bin/bash"))
418 (old (string-append python "python3-config"))
419 (new (string-append bin "/python-config")))
420 (with-output-to-file new
421 (lambda ()
422 (format #t "#!~a~%" bash)
423 (format #t "exec \"~a\" \"$@\"~%" old)
424 (chmod new #o755)
425 #t)))))))
426 (synopsis "Wrapper for the Python 3 commands")
427 (description
428 "This package provides wrappers for the commands of Python@tie{}3.x such
429 that they can be invoked under their usual name---e.g., @command{python}
430 instead of @command{python3}.")))
431
432 (define-public python-wrapper (wrap-python3 python))
433 (define-public python-minimal-wrapper (wrap-python3 python-minimal))
434
435 (define-public python-psutil
436 (package
437 (name "python-psutil")
438 (version "4.3.0")
439 (source
440 (origin
441 (method url-fetch)
442 (uri (pypi-uri "psutil" version))
443 (sha256
444 (base32
445 "1w4r09fvn6kd80m5mx4ws1wz100brkaq6hzzpwrns8cgjzjpl6c6"))))
446 (build-system python-build-system)
447 (arguments
448 ;; FIXME: some tests does not return and times out.
449 '(#:tests? #f))
450 (home-page "https://www.github.com/giampaolo/psutil")
451 (synopsis "Library for retrieving information on running processes")
452 (description
453 "psutil (Python system and process utilities) is a library for retrieving
454 information on running processes and system utilization (CPU, memory, disks,
455 network) in Python. It is useful mainly for system monitoring, profiling and
456 limiting process resources and management of running processes. It implements
457 many functionalities offered by command line tools such as: ps, top, lsof,
458 netstat, ifconfig, who, df, kill, free, nice, ionice, iostat, iotop, uptime,
459 pidof, tty, taskset, pmap.")
460 (license license:bsd-3)))
461
462 (define-public python2-psutil
463 (package-with-python2 python-psutil))
464
465 (define-public python-passlib
466 (package
467 (name "python-passlib")
468 (version "1.7.1")
469 (source
470 (origin
471 (method url-fetch)
472 (uri (pypi-uri "passlib" version))
473 (sha256
474 (base32
475 "1q2khqpj9rlcgdmkypjdq1kswvhjf72bq0zk2cv669cc2dj8z51x"))))
476 (build-system python-build-system)
477 (native-inputs
478 `(("python-nose" ,python-nose)))
479 (propagated-inputs
480 `(("python-py-bcrypt" ,python-py-bcrypt)))
481 (arguments
482 `(#:phases
483 (alist-cons-before
484 'check 'set-PYTHON_EGG_CACHE
485 ;; some tests require access to "$HOME/.cython"
486 (lambda* _ (setenv "PYTHON_EGG_CACHE" "/tmp"))
487 %standard-phases)))
488 (home-page "https://bitbucket.org/ecollins/passlib")
489 (synopsis
490 "Comprehensive password hashing framework")
491 (description
492 "Passlib is a password hashing library for Python 2 & 3, which provides
493 cross-platform implementations of over 30 password hashing algorithms, as well
494 as a framework for managing existing password hashes. It's designed to be
495 useful for a wide range of tasks, from verifying a hash found in /etc/shadow,
496 to providing full-strength password hashing for multi-user application.")
497 (license license:bsd-3)))
498
499 (define-public python2-passlib
500 (package-with-python2 python-passlib))
501
502 (define-public python-py-bcrypt
503 (package
504 (name "python-py-bcrypt")
505 (version "0.4")
506 (source
507 (origin
508 (method url-fetch)
509 (uri (string-append
510 "https://pypi.python.org/packages/source/p/py-bcrypt/py-bcrypt-"
511 version
512 ".tar.gz"))
513 (sha256
514 (base32
515 "0y6smdggwi5s72v6p1nn53dg6w05hna3d264cq6kas0lap73p8az"))))
516 (build-system python-build-system)
517 (home-page "https://code.google.com/p/py-bcrypt")
518 (synopsis
519 "Bcrypt password hashing and key derivation")
520 (description
521 "A python wrapper of OpenBSD's Blowfish password hashing code. This
522 system hashes passwords using a version of Bruce Schneier's Blowfish block
523 cipher with modifications designed to raise the cost of off-line password
524 cracking and frustrate fast hardware implementation. The computation cost of
525 the algorithm is parametised, so it can be increased as computers get faster.
526 The intent is to make a compromise of a password database less likely to
527 result in an attacker gaining knowledge of the plaintext passwords (e.g. using
528 John the Ripper).")
529 ;; "sha2.c" is under BSD-3;
530 ;; "blowfish.c" and "bcrypt.c" are under BSD-4;
531 ;; the rest is under ISC.
532 (license (list license:isc license:bsd-3 license:bsd-4))))
533
534 (define-public python2-py-bcrypt
535 (package-with-python2 python-py-bcrypt))
536
537
538 (define-public python-paramiko
539 (package
540 (name "python-paramiko")
541 (version "2.1.2")
542 (source
543 (origin
544 (method url-fetch)
545 (uri (pypi-uri "paramiko" version))
546 (sha256
547 (base32
548 "04734n0wy3hxk6rij4fr29in5jmr70nxpc7pqi2ksbjysfz4kbjz"))))
549 (build-system python-build-system)
550 (arguments
551 '(#:phases
552 (modify-phases %standard-phases
553 (replace 'check
554 (lambda _
555 (zero? (system* "python" "test.py")))))))
556 (propagated-inputs
557 `(("python-pyasn1" ,python-pyasn1)
558 ("python-cryptography" ,python-cryptography)))
559 (home-page "http://www.paramiko.org/")
560 (synopsis "SSHv2 protocol library")
561 (description "Paramiko is a python implementation of the SSHv2 protocol,
562 providing both client and server functionality. While it leverages a Python C
563 extension for low level cryptography (PyCrypto), Paramiko itself is a pure
564 Python interface around SSH networking concepts.")
565 (license license:lgpl2.1+)))
566
567 (define-public python2-paramiko
568 (package-with-python2 python-paramiko))
569
570
571 (define-public python-httplib2
572 (package
573 (name "python-httplib2")
574 (version "0.9.2")
575 (source
576 (origin
577 (method url-fetch)
578 (uri (pypi-uri "httplib2" version))
579 (sha256
580 (base32
581 "126rsryvw9vhbf3qmsfw9lf4l4xm2srmgs439lgma4cpag4s3ay3"))))
582 (build-system python-build-system)
583 (home-page "https://github.com/jcgregorio/httplib2")
584 (synopsis "Comprehensive HTTP client library")
585 (description
586 "A comprehensive HTTP client library supporting many features left out of
587 other HTTP libraries.")
588 (license license:expat)))
589
590 (define-public python2-httplib2
591 (package-with-python2 python-httplib2))
592
593 (define-public python-ecdsa
594 (package
595 (name "python-ecdsa")
596 (version "0.13")
597 (source
598 (origin
599 (method url-fetch)
600 (uri (string-append
601 "https://pypi.python.org/packages/source/e/ecdsa/ecdsa-"
602 version
603 ".tar.gz"))
604 (sha256
605 (base32
606 "1yj31j0asmrx4an9xvsaj2icdmzy6pw0glfpqrrkrphwdpi1xkv4"))))
607 (build-system python-build-system)
608 (inputs
609 `(("openssl" ,openssl)))
610 (home-page
611 "https://github.com/warner/python-ecdsa")
612 (synopsis
613 "ECDSA cryptographic signature library (pure python)")
614 (description
615 "This is an easy-to-use implementation of ECDSA cryptography (Elliptic
616 Curve Digital Signature Algorithm), implemented purely in Python. With this
617 library, you can quickly create keypairs (signing key and verifying key), sign
618 messages, and verify the signatures. The keys and signatures are very short,
619 making them easy to handle and incorporate into other protocols.")
620 (license license:expat)))
621
622 (define-public python2-ecdsa
623 (package-with-python2 python-ecdsa))
624
625 (define-public python-ccm
626 (package
627 (name "python-ccm")
628 (version "2.1.6")
629 (source
630 (origin
631 (method url-fetch)
632 (uri (pypi-uri "ccm" version))
633 (sha256
634 (base32
635 "177dfxsmk3k4cih6fh6v8d91bh4nqx7ns6pc07w7m7i3cvdx3c8n"))))
636 (build-system python-build-system)
637 (propagated-inputs
638 `(("python-pyyaml" ,python-pyyaml)
639 ;; Not listed in setup.py, but used in ccmlib/node.py for full
640 ;; functionality
641 ("python-psutil" ,python-psutil)
642 ("python-six" ,python-six)))
643 (home-page "https://github.com/pcmanus/ccm")
644 (synopsis "Cassandra Cluster Manager for Apache Cassandra clusters on
645 localhost")
646 (description "Cassandra Cluster Manager is a development tool for testing
647 local Cassandra clusters. It creates, launches and removes Cassandra clusters
648 on localhost.")
649 (license license:asl2.0)))
650
651 (define-public python2-ccm
652 (package-with-python2 python-ccm))
653
654 (define-public python-pytz
655 (package
656 (name "python-pytz")
657 (version "2017.2")
658 (source
659 (origin
660 (method url-fetch)
661 (uri (pypi-uri "pytz" version ".zip"))
662 (sha256
663 (base32
664 "12cmd3j46d2gcw08bspvp6s9icfcvx88zjz52n1bli9dyvl5dh7m"))))
665 (build-system python-build-system)
666 (native-inputs
667 `(("unzip" ,unzip)))
668 (home-page "http://pythonhosted.org/pytz")
669 (synopsis "Python timezone library")
670 (description "This library brings the Olson tz database into Python. It
671 allows accurate and cross platform timezone calculations using Python 2.4 or
672 higher. It also solves the issue of ambiguous times at the end of daylight
673 saving time. Almost all of the Olson timezones are supported.")
674 (license license:expat)))
675
676 (define-public python2-pytz
677 (package-with-python2 python-pytz))
678
679 (define-public python-clyent
680 (package
681 (name "python-clyent")
682 (version "1.2.1")
683 (source
684 (origin
685 (method url-fetch)
686 (uri (pypi-uri "clyent" version))
687 (sha256
688 (base32
689 "1r9987qmy1pz3hq54160bapqsywpq14waw4w9x3ly8hmq7kpgfbj"))))
690 (build-system python-build-system)
691 (native-inputs
692 `(("python-mock" ,python-mock)))
693 (home-page "https://github.com/binstar/clyent")
694 (synopsis "Command line client library")
695 (description "Clyent is a Python command line utiliy library. It is used
696 by @code{binstar}, @code{binstar-build} and @code{chalmers}.")
697 (license license:bsd-3)))
698
699 (define-public python2-clyent
700 (package-with-python2 python-clyent))
701
702 (define-public python-babel
703 (package
704 (name "python-babel")
705 (version "2.3.4")
706 (source
707 (origin
708 (method url-fetch)
709 (uri (pypi-uri "Babel" version))
710 (sha256
711 (base32
712 "0x98qqqw35xllpcama013a9788ly84z8dm1w2wwfpxh2710c8df5"))))
713 (build-system python-build-system)
714 (propagated-inputs
715 `(("python-pytz" ,python-pytz)))
716 (arguments `(#:tests? #f)) ; no test target
717 (home-page "http://babel.pocoo.org/")
718 (synopsis
719 "Tools for internationalizing Python applications")
720 (description
721 "Babel is composed of two major parts:
722 - tools to build and work with gettext message catalogs
723 - a Python interface to the CLDR (Common Locale Data Repository), providing
724 access to various locale display names, localized number and date formatting,
725 etc. ")
726 (license license:bsd-3)))
727
728 (define-public python2-babel
729 (package-with-python2 python-babel))
730
731 (define-public python2-backport-ssl-match-hostname
732 (package
733 (name "python2-backport-ssl-match-hostname")
734 (version "3.5.0.1")
735 (source
736 (origin
737 (method url-fetch)
738 (uri (string-append
739 "https://pypi.python.org/packages/source/b/"
740 "backports.ssl_match_hostname/backports.ssl_match_hostname-"
741 version ".tar.gz"))
742 (sha256
743 (base32
744 "1wndipik52cyqy0677zdgp90i435pmvwd89cz98lm7ri0y3xjajh"))))
745 (build-system python-build-system)
746 (arguments
747 `(#:python ,python-2
748 #:tests? #f)) ; no test target
749 (home-page "https://bitbucket.org/brandon/backports.ssl_match_hostname")
750 (synopsis "Backport of ssl.match_hostname() function from Python 3.5")
751 (description
752 "This backport brings the ssl.match_hostname() function to users of
753 earlier versions of Python. The function checks the hostname in the
754 certificate returned by the server to which a connection has been established,
755 and verifies that it matches the intended target hostname.")
756 (license license:psfl)))
757
758 (define-public python-hdf4
759 (package
760 (name "python-hdf4")
761 (version "0.9")
762 (source
763 (origin
764 (method url-fetch)
765 (uri (pypi-uri name version))
766 (sha256
767 (base32
768 "1hjiyrxvxk9817qyqky3nar4y3fs4z8wxz0n884zzb5wi6skrjks"))))
769 (build-system python-build-system)
770 (native-inputs `(("nose" ,python-nose)))
771 (propagated-inputs `(("numpy" ,python-numpy)))
772 (inputs
773 `(("hdf4" ,hdf4)
774 ("libjpeg" ,libjpeg)
775 ("zlib" ,zlib)))
776 (arguments
777 `(#:phases
778 (modify-phases %standard-phases
779 (replace 'check
780 (lambda _
781 ;; The 'runexamples' script sets PYTHONPATH to CWD, then goes
782 ;; on to import numpy. Somehow this works on their CI system.
783 ;; Let's just manage PYTHONPATH here instead.
784 (substitute* "runexamples.sh"
785 (("export PYTHONPATH=.*") ""))
786 (setenv "PYTHONPATH"
787 (string-append (getcwd) ":"
788 (getenv "PYTHONPATH")))
789 (and (zero? (system* "./runexamples.sh"))
790 (zero? (system* "nosetests" "-v"))))))))
791 (home-page "https://github.com/fhs/python-hdf4")
792 (synopsis "Python interface to the NCSA HDF4 library")
793 (description
794 "Python-HDF4 is a python wrapper around the NCSA HDF version 4 library,
795 which implements the SD (Scientific Dataset), VS (Vdata) and V (Vgroup) API’s.
796 NetCDF files can also be read and modified. Python-HDF4 is a fork of
797 @url{http://hdfeos.org/software/pyhdf.php,pyhdf}.")
798 (license license:expat)))
799
800 (define-public python2-hdf4
801 (package-with-python2 python-hdf4))
802
803 (define-public python-h5py
804 (package
805 (name "python-h5py")
806 (version "2.6.0")
807 (source
808 (origin
809 (method url-fetch)
810 (uri (pypi-uri "h5py" version))
811 (sha256
812 (base32
813 "0df46dg7i7xfking9lp221bfm8dbl974yvlrbi1w7r6m61ac7bxj"))))
814 (build-system python-build-system)
815 (arguments
816 `(#:tests? #f ; no test target
817 #:phases
818 (modify-phases %standard-phases
819 (add-after 'unpack 'fix-hdf5-paths
820 (lambda* (#:key inputs #:allow-other-keys)
821 (let ((prefix (assoc-ref inputs "hdf5")))
822 (substitute* "setup_build.py"
823 (("\\['/opt/local/lib', '/usr/local/lib'\\]")
824 (string-append "['" prefix "/lib" "']"))
825 (("'/opt/local/include', '/usr/local/include'")
826 (string-append "'" prefix "/include" "'")))
827 (substitute* "setup_configure.py"
828 (("\\['/usr/local/lib', '/opt/local/lib'\\]")
829 (string-append "['" prefix "/lib" "']")))
830 #t))))))
831 (propagated-inputs
832 `(("python-six" ,python-six)
833 ("python-numpy" ,python-numpy)))
834 (inputs
835 `(("hdf5" ,hdf5)))
836 (native-inputs
837 `(("python-cython" ,python-cython)
838 ("python-pkgconfig" ,python-pkgconfig)))
839 (home-page "http://www.h5py.org/")
840 (synopsis "Read and write HDF5 files from Python")
841 (description
842 "The h5py package provides both a high- and low-level interface to the
843 HDF5 library from Python. The low-level interface is intended to be a
844 complete wrapping of the HDF5 API, while the high-level component supports
845 access to HDF5 files, datasets and groups using established Python and NumPy
846 concepts.")
847 (license license:bsd-3)))
848
849 (define-public python2-h5py
850 (package-with-python2 python-h5py))
851
852 (define-public python-netcdf4
853 (package
854 (name "python-netcdf4")
855 (version "1.2.7")
856 (source
857 (origin
858 (method url-fetch)
859 (uri (pypi-uri "netCDF4" version))
860 (sha256
861 (base32
862 "1fllizmnpw0zkzzm4j9pgamarlzfn3kmv9zrm0w65q1y31h9ni0c"))))
863 (build-system python-build-system)
864 (native-inputs
865 `(("python-cython" ,python-cython)))
866 (propagated-inputs
867 `(("python-numpy" ,python-numpy)))
868 (inputs
869 `(("netcdf" ,netcdf)
870 ("hdf4" ,hdf4)
871 ("hdf5" ,hdf5)))
872 (arguments
873 '(#:phases
874 (modify-phases %standard-phases
875 (replace 'check
876 (lambda _
877 (setenv "NO_NET" "1") ; disable opendap tests
878 (with-directory-excursion "test"
879 (setenv "PYTHONPATH" ; find and add the library we just built
880 (string-append
881 (car (find-files "../build" "lib.*"
882 #:directories? #:t
883 #:fail-on-error? #:t))
884 ":" (getenv "PYTHONPATH")))
885 (zero? (system* "python" "run_all.py"))))))))
886 (home-page
887 "https://github.com/Unidata/netcdf4-python")
888 (synopsis "Python/numpy interface to the netCDF library")
889 (description "Netcdf4-python is a Python interface to the netCDF C
890 library. netCDF version 4 has many features not found in earlier
891 versions of the library and is implemented on top of HDF5. This module
892 can read and write files in both the new netCDF 4 and the old netCDF 3
893 format, and can create files that are readable by HDF5 clients. The
894 API is modelled after @code{Scientific.IO.NetCDF}, and should be familiar
895 to users of that module.")
896 ;; The software is mainly ISC, but includes some files covered
897 ;; by the Expat license.
898 (license (list license:isc license:expat))))
899
900 (define-public python2-netcdf4
901 (package-with-python2 python-netcdf4))
902
903 (define-public python-lockfile
904 (package
905 (name "python-lockfile")
906 (version "0.12.2")
907 (source
908 (origin
909 (method url-fetch)
910 (uri (string-append "https://pypi.python.org/packages/source/l/lockfile/"
911 "lockfile-" version ".tar.gz"))
912 (sha256
913 (base32
914 "16gpx5hm73ah5n1079ng0vy381hl802v606npkx4x8nb0gg05vba"))))
915 (build-system python-build-system)
916 (arguments '(#:test-target "check"))
917 (native-inputs
918 `(("python-pbr" ,python-pbr)))
919 (home-page "https://launchpad.net/pylockfile")
920 (synopsis "Platform-independent file locking module")
921 (description
922 "The lockfile package exports a LockFile class which provides a simple
923 API for locking files.")
924 (license license:expat)))
925
926 (define-public python2-lockfile
927 (package-with-python2 python-lockfile))
928
929 (define-public python-mock
930 (package
931 (name "python-mock")
932 (version "1.0.1")
933 (source
934 (origin
935 (method url-fetch)
936 (uri (pypi-uri "mock" version))
937 (sha256
938 (base32
939 "0kzlsbki6q0awf89rc287f3aj8x431lrajf160a70z0ikhnxsfdq"))))
940 (build-system python-build-system)
941 (arguments '(#:test-target "check"))
942 (home-page "https://github.com/testing-cabal/mock")
943 (synopsis "Python mocking and patching library for testing")
944 (description
945 "Mock is a library for testing in Python. It allows you to replace parts
946 of your system under test with mock objects and make assertions about how they
947 have been used.")
948 (license license:expat)))
949
950 (define-public python2-mock
951 (package-with-python2 python-mock))
952
953 ;;; Some packages (notably, certbot and python-acme) rely on this newer version
954 ;;; of python-mock. However, a large number of packages fail to build with
955 ;;; mock@2, so we add a new variable for now. Also, there may be a dependency
956 ;;; cycle between mock and six, so we avoid creating python2-mock@2 for now.
957 (define-public python-mock-2
958 (package
959 (inherit python-mock)
960 (version "2.0.0")
961 (source
962 (origin
963 (method url-fetch)
964 (uri (pypi-uri "mock" version))
965 (sha256
966 (base32
967 "1flbpksir5sqrvq2z0dp8sl4bzbadg21sj4d42w3klpdfvgvcn5i"))))
968 (propagated-inputs
969 `(("python-pbr" ,python-pbr-minimal)
970 ,@(package-propagated-inputs python-mock)))))
971
972 (define-public python-setuptools
973 (package
974 (name "python-setuptools")
975 (version "31.0.0")
976 (source
977 (origin
978 (method url-fetch)
979 (uri (pypi-uri "setuptools" version))
980 (sha256
981 (base32
982 "0ypybh4hx3bv4vhg2dc74xpj1g56ggnaffm87k4abhwjwq6wq608"))
983 (modules '((guix build utils)))
984 (snippet
985 '(begin
986 ;; Remove included binaries which are used to build self-extracting
987 ;; installers for Windows.
988 ;; TODO: Find some way to build them ourself so we can include them.
989 (for-each delete-file (find-files "setuptools" "^(cli|gui).*\\.exe$"))
990 #t))))
991 (build-system python-build-system)
992 ;; FIXME: Tests require pytest, which itself relies on setuptools.
993 ;; One could bootstrap with an internal untested setuptools.
994 (arguments
995 `(#:tests? #f))
996 (home-page "https://pypi.python.org/pypi/setuptools")
997 (synopsis
998 "Library designed to facilitate packaging Python projects")
999 (description
1000 "Setuptools is a fully-featured, stable library designed to facilitate
1001 packaging Python projects, where packaging includes:
1002 Python package and module definitions,
1003 distribution package metadata,
1004 test hooks,
1005 project installation,
1006 platform-specific details,
1007 Python 3 support.")
1008 ;; TODO: setuptools now bundles the following libraries:
1009 ;; packaging, pyparsing, six and appdirs. How to unbundle?
1010 (license (list license:psfl ; setuptools itself
1011 license:expat ; six, appdirs, pyparsing
1012 license:asl2.0 ; packaging is dual ASL2/BSD-2
1013 license:bsd-2))))
1014
1015 (define-public python2-setuptools
1016 (package-with-python2 python-setuptools))
1017
1018 (define-public python-uniseg
1019 (package
1020 (name "python-uniseg")
1021 (version "0.7.1")
1022 (source
1023 (origin
1024 (method url-fetch)
1025 (uri (string-append "https://bitbucket.org/emptypage/uniseg-python/"
1026 "get/rel-" version ".tar.gz"))
1027 (file-name (string-append name "-" version ".tar.gz"))
1028 (sha256
1029 (base32
1030 "1df4gddnj2a0v8z35wb2ra5vvh1f1qyxs8fgd25c8g64031mna6x"))))
1031 (build-system python-build-system)
1032 (arguments
1033 '(#:tests? #f)) ; The test suite requires network access.
1034 (home-page
1035 "https://bitbucket.org/emptypage/uniseg-python")
1036 (synopsis
1037 "Python library to determine Unicode text segmentations")
1038 (description
1039 "Uniseg is a Python package used to determine Unicode text segmentations.
1040 Supported segmentations include:
1041 @enumerate
1042 @item @dfn{Code point} (any value in the Unicode codespace)
1043 @item @dfn{Grapheme cluster} (user-perceived character made of a single or
1044 multiple Unicode code points, e.g. \"G\" + acute-accent)
1045 @item Word break
1046 @item Sentence break
1047 @item Line break
1048 @end enumerate")
1049 (license license:expat)))
1050
1051 (define-public python2-uniseg
1052 (package-with-python2 python-uniseg))
1053
1054 ;;; Pycrypto is abandoned upstream:
1055 ;;;
1056 ;;; https://github.com/dlitz/pycrypto/issues/173
1057 ;;;
1058 ;;; TODO Remove this package from GNU Guix.
1059 (define-public python-pycrypto
1060 (package
1061 (name "python-pycrypto")
1062 (version "2.6.1")
1063 (source
1064 (origin
1065 (method url-fetch)
1066 (uri (pypi-uri "pycrypto" version))
1067 (patches (search-patches "python-pycrypto-CVE-2013-7459.patch"))
1068 (sha256
1069 (base32
1070 "0g0ayql5b9mkjam8hym6zyg6bv77lbh66rv1fyvgqb17kfc1xkpj"))))
1071 (build-system python-build-system)
1072 (inputs
1073 `(("python" ,python)
1074 ("gmp" ,gmp)))
1075 (arguments
1076 `(#:phases
1077 (alist-cons-before
1078 'build 'set-build-env
1079 ;; pycrypto runs an autoconf configure script behind the scenes
1080 (lambda _
1081 (setenv "CONFIG_SHELL" (which "bash")))
1082 %standard-phases)))
1083 (home-page "http://www.pycrypto.org/")
1084 (synopsis "Cryptographic modules for Python")
1085 (description
1086 "Pycrypto is a collection of both secure hash functions (such as SHA256
1087 and RIPEMD160), and various encryption algorithms (AES, DES, RSA, ElGamal,
1088 etc.). The package is structured to make adding new modules easy.")
1089 (license license:public-domain)))
1090
1091 (define-public python2-pycrypto
1092 (let ((pycrypto (package-with-python2 python-pycrypto)))
1093 (package (inherit pycrypto)
1094 (inputs
1095 `(("python" ,python-2)
1096 ,@(alist-delete
1097 "python"
1098 (package-inputs pycrypto)))))))
1099
1100 (define-public python-eventlet
1101 (package
1102 (name "python-eventlet")
1103 (version "0.20.1")
1104 (source
1105 (origin
1106 (method url-fetch)
1107 (uri (pypi-uri "eventlet" version))
1108 (sha256
1109 (base32
1110 "0f3q55mq4n021wb7qa53pz3ix6i2py64sap66vsaqm2scjw83m9s"))))
1111 (build-system python-build-system)
1112 (propagated-inputs
1113 `(("python-greenlet" ,python-greenlet)))
1114 (arguments
1115 ;; TODO: Requires unpackaged 'enum-compat'.
1116 '(#:tests? #f))
1117 (home-page "http://eventlet.net")
1118 (synopsis "Concurrent networking library for Python")
1119 (description
1120 "Eventlet is a concurrent networking library for Python that
1121 allows you to change how you run your code, not how you write it.
1122 It uses @code{epoll} or @code{libevent} for highly scalable non-blocking I/O.
1123 Coroutines ensure that the developer uses a blocking style of programming
1124 that is similar to threading, but provide the benefits of non-blocking I/O.
1125 The event dispatch is implicit, which means you can easily use @code{Eventlet}
1126 from the Python interpreter, or as a small part of a larger application.")
1127 (license license:expat)))
1128
1129 (define-public python2-eventlet
1130 (let ((base (package-with-python2
1131 (strip-python2-variant python-eventlet))))
1132 (package (inherit base)
1133 (propagated-inputs
1134 `(("python2-enum34" ,python2-enum34)
1135 ,@(package-propagated-inputs base))))))
1136
1137 (define-public python-keyring
1138 (package
1139 (name "python-keyring")
1140 (version "8.7")
1141 (source
1142 (origin
1143 (method url-fetch)
1144 (uri (pypi-uri "keyring" version))
1145 (sha256
1146 (base32
1147 "0482rmi2x6p78wl2kz8qzyq21xz1sbbfwnv5x7dggar4vkwxhzfx"))))
1148 (build-system python-build-system)
1149 (native-inputs
1150 `(("python-setuptools-scm" ,python-setuptools-scm)))
1151 (propagated-inputs
1152 `(("python-pycrypto" ,python-pycrypto)))
1153 (arguments
1154 `(#:tests? #f)) ;TODO: tests require pytest
1155 (home-page "https://github.com/jaraco/keyring")
1156 (synopsis "Store and access your passwords safely")
1157 (description
1158 "The Python keyring lib provides a easy way to access the system keyring
1159 service from python. It can be used in any application that needs safe
1160 password storage.")
1161 ;; "MIT" and PSF dual license
1162 (license license:x11)))
1163
1164 (define-public python2-keyring
1165 (package-with-python2 python-keyring))
1166
1167 (define-public python-six
1168 (package
1169 (name "python-six")
1170 (version "1.10.0")
1171 (source
1172 (origin
1173 (method url-fetch)
1174 (uri (pypi-uri "six" version))
1175 (sha256
1176 (base32
1177 "0snmb8xffb3vsma0z67i0h0w2g2dy0p3gsgh9gi4i0kgc5l8spqh"))))
1178 (build-system python-build-system)
1179 (native-inputs
1180 `(("python-py" ,python-py)
1181 ("python-pytest" ,python-pytest)))
1182 (home-page "http://pypi.python.org/pypi/six/")
1183 (synopsis "Python 2 and 3 compatibility utilities")
1184 (description
1185 "Six is a Python 2 and 3 compatibility library. It provides utility
1186 functions for smoothing over the differences between the Python versions with
1187 the goal of writing Python code that is compatible on both Python versions.
1188 Six supports every Python version since 2.5. It is contained in only one
1189 Python file, so it can be easily copied into your project.")
1190 (license license:x11)))
1191
1192 (define-public python2-six
1193 (package-with-python2 python-six))
1194
1195 (define-public python-dateutil
1196 (package
1197 (name "python-dateutil")
1198 (version "2.6.0")
1199 (source
1200 (origin
1201 (method url-fetch)
1202 (uri (pypi-uri "python-dateutil" version))
1203 (sha256
1204 (base32
1205 "1lhq0hxjc3cfha101q02ld5ijlpfyjn2w1yh7wvpiy367pgzi8k2"))))
1206 (build-system python-build-system)
1207 (propagated-inputs
1208 `(("python-six" ,python-six)))
1209 (home-page "https://dateutil.readthedocs.io/en/stable/")
1210 (synopsis "Extensions to the standard datetime module")
1211 (description
1212 "The dateutil module provides powerful extensions to the standard
1213 datetime module, available in Python 2.3+.")
1214 (license license:bsd-3)))
1215
1216 (define-public python2-dateutil
1217 (package-with-python2 python-dateutil))
1218
1219 (define-public python-parsedatetime
1220 (package
1221 (name "python-parsedatetime")
1222 (version "2.4")
1223 (source
1224 (origin
1225 (method url-fetch)
1226 (uri (pypi-uri "parsedatetime" version))
1227 (sha256
1228 (base32
1229 "0jxqkjks7z9dn222cqgvskp4wr6d92aglinxq7pd2w4mzdc7r09x"))))
1230 (build-system python-build-system)
1231 (native-inputs
1232 `(("python-nose" ,python-nose)
1233 ("python-pyicu" ,python-pyicu)
1234 ("python-pytest" ,python-pytest)
1235 ("python-pytest-runner" ,python-pytest-runner)))
1236 (propagated-inputs
1237 `(("python-future" ,python-future)))
1238 (home-page "https://github.com/bear/parsedatetime/")
1239 (synopsis
1240 "Parse human-readable date/time text")
1241 (description
1242 "Parse human-readable date/time text.")
1243 (license license:asl2.0)))
1244
1245 (define-public python2-parsedatetime
1246 (package-with-python2 python-parsedatetime))
1247
1248 (define-public python-pandas
1249 (package
1250 (name "python-pandas")
1251 (version "0.19.2")
1252 (source
1253 (origin
1254 (method url-fetch)
1255 (uri (pypi-uri "pandas" version))
1256 (sha256
1257 (base32 "0540cnbwy2hc4hv2sxfs8i47xi91qzvzxfn80dl785ibiicly3vg"))
1258 (patches
1259 (search-patches "python-pandas-skip-failing-tests.patch"))))
1260 (build-system python-build-system)
1261 (propagated-inputs
1262 `(("python-numpy" ,python-numpy)
1263 ("python-pytz" ,python-pytz)
1264 ("python-dateutil" ,python-dateutil)))
1265 (native-inputs
1266 `(("python-nose" ,python-nose)
1267 ("python-cython" ,python-cython)))
1268 (home-page "http://pandas.pydata.org")
1269 (synopsis "Data structures for data analysis, time series, and statistics")
1270 (description
1271 "Pandas is a Python package providing fast, flexible, and expressive data
1272 structures designed to make working with structured (tabular,
1273 multidimensional, potentially heterogeneous) and time series data both easy
1274 and intuitive. It aims to be the fundamental high-level building block for
1275 doing practical, real world data analysis in Python.")
1276 (license license:bsd-3)))
1277
1278 (define-public python2-pandas
1279 (package-with-python2 python-pandas))
1280
1281 (define-public python-tzlocal
1282 (package
1283 (name "python-tzlocal")
1284 (version "1.2.2")
1285 (source
1286 (origin
1287 (method url-fetch)
1288 (uri (pypi-uri "tzlocal" version))
1289 (sha256
1290 (base32
1291 "0paj7vlsb0np8b5sp4bv64wxv7qk2piyp7xg29pkhdjwsbls9fnb"))))
1292 (build-system python-build-system)
1293 (propagated-inputs
1294 `(("python-pytz" ,python-pytz)))
1295 (home-page "https://github.com/regebro/tzlocal")
1296 (synopsis
1297 "Local timezone information for Python")
1298 (description
1299 "Tzlocal returns a tzinfo object with the local timezone information.
1300 This module attempts to fix a glaring hole in pytz, that there is no way to
1301 get the local timezone information, unless you know the zoneinfo name, and
1302 under several distributions that's hard or impossible to figure out.")
1303 (license license:cc0)))
1304
1305 (define-public python2-pysqlite
1306 (package
1307 (name "python2-pysqlite")
1308 (version "2.8.3")
1309 (source
1310 (origin
1311 (method url-fetch)
1312 (uri (pypi-uri "pysqlite" version))
1313 (sha256
1314 (base32
1315 "1424gwq9sil2ffmnizk60q36vydkv8rxs6m7xs987kz8cdc37lqp"))))
1316 (build-system python-build-system)
1317 (inputs
1318 `(("sqlite" ,sqlite)))
1319 (arguments
1320 `(#:python ,python-2 ; incompatible with Python 3
1321 #:tests? #f)) ; no test target
1322 (home-page "https://github.com/ghaering/pysqlite")
1323 (synopsis "SQLite bindings for Python")
1324 (description
1325 "Pysqlite provides SQLite bindings for Python that comply to the
1326 Database API 2.0T.")
1327 (license license:zlib)))
1328
1329
1330 (define-public python2-mechanize
1331 (package
1332 (name "python2-mechanize")
1333 (version "0.2.5")
1334 (source
1335 (origin
1336 (method url-fetch)
1337 (uri (string-append "https://pypi.python.org/packages/source/m/mechanize/mechanize-"
1338 version ".tar.gz"))
1339 (sha256
1340 (base32
1341 "0rj7r166i1dyrq0ihm5rijfmvhs8a04im28lv05c0c3v206v4rrf"))))
1342 (build-system python-build-system)
1343 (arguments
1344 `(#:python ,python-2 ; apparently incompatible with Python 3
1345 #:tests? #f))
1346 ;; test fails with message
1347 ;; AttributeError: 'module' object has no attribute 'test_pullparser'
1348 ;; (python-3.3.2) or
1349 ;; AttributeError: 'module' object has no attribute 'test_urllib2_localnet'
1350 ;; (python-2.7.5).
1351 ;; The source code is from March 2011 and probably not up-to-date
1352 ;; with respect to python unit tests.
1353 (home-page "http://wwwsearch.sourceforge.net/mechanize/")
1354 (synopsis
1355 "Stateful programmatic web browsing in Python")
1356 (description
1357 "Mechanize implements stateful programmatic web browsing in Python,
1358 after Andy Lester’s Perl module WWW::Mechanize.")
1359 (license (license:non-copyleft
1360 "file://COPYING"
1361 "See COPYING in the distribution."))))
1362
1363
1364 (define-public python-simplejson
1365 (package
1366 (name "python-simplejson")
1367 (version "3.10.0")
1368 (source
1369 (origin
1370 (method url-fetch)
1371 (uri (pypi-uri "simplejson" version))
1372 (sha256
1373 (base32
1374 "1qhwsykjlb85igb4cfl6v6gkprzbbg8gyqdd7zscc8w3x0ifcfwm"))))
1375 (build-system python-build-system)
1376 (home-page "http://simplejson.readthedocs.org/en/latest/")
1377 (synopsis
1378 "Json library for Python")
1379 (description
1380 "JSON (JavaScript Object Notation) is a subset of JavaScript
1381 syntax (ECMA-262 3rd edition) used as a lightweight data interchange
1382 format.
1383
1384 Simplejson exposes an API familiar to users of the standard library marshal
1385 and pickle modules. It is the externally maintained version of the json
1386 library contained in Python 2.6, but maintains compatibility with Python 2.5
1387 and (currently) has significant performance advantages, even without using
1388 the optional C extension for speedups. Simplejson is also supported on
1389 Python 3.3+.")
1390 (license license:x11)))
1391
1392 (define-public python2-simplejson
1393 (package-with-python2 python-simplejson))
1394
1395
1396 (define-public python-pyicu
1397 (package
1398 (name "python-pyicu")
1399 (version "1.9.5")
1400 (source
1401 (origin
1402 (method url-fetch)
1403 (uri (pypi-uri "PyICU" version))
1404 (sha256
1405 (base32
1406 "16rmxy9y0qhqqna2v49i7nzwm09as699rbyvh4raw7w602w55c3k"))))
1407 (build-system python-build-system)
1408 (arguments
1409 '(#:phases
1410 (modify-phases %standard-phases
1411 (add-before 'check 'delete-failing-test
1412 (lambda _
1413 ;; XXX: These tests require locales that are unavailable
1414 ;; in the build environment.
1415 (delete-file "test/test_DateTimeParserGenerator.py")
1416 #t)))))
1417 (inputs
1418 `(("icu4c" ,icu4c)))
1419 (home-page "http://pyicu.osafoundation.org/")
1420 (synopsis "Python extension wrapping the ICU C++ API")
1421 (description
1422 "PyICU is a python extension wrapping the ICU C++ API.")
1423 (license license:x11)))
1424
1425 (define-public python2-pyicu
1426 (package-with-python2 python-pyicu))
1427
1428 (define-public python2-dogtail
1429 ;; Python 2 only, as it leads to "TabError: inconsistent use of tabs and
1430 ;; spaces in indentation" with Python 3.
1431 (package
1432 (name "python2-dogtail")
1433 (version "0.9.9")
1434 (source (origin
1435 (method url-fetch)
1436 (uri (pypi-uri "dogtail" version))
1437 (sha256
1438 (base32
1439 "0p5wfssvzr9w0bvhllzbbd8fnp4cca2qxcpcsc33dchrmh5n552x"))))
1440 (build-system python-build-system)
1441 (arguments `(#:python ,python-2
1442 #:tests? #f)) ; invalid command "test"
1443 ;; Currently no offical homepage.
1444 (home-page "https://pypi.python.org/pypi/dogtail/")
1445 (synopsis "GUI test tool and automation framework written in Python")
1446 (description
1447 "Dogtail is a GUI test tool and automation framework written in Python.
1448 It uses Accessibility (a11y) technologies to communicate with desktop
1449 applications. dogtail scripts are written in Python and executed like any
1450 other Python program.")
1451 (license license:gpl2+)))
1452
1453 (define-public python2-empy
1454 (package
1455 (name "python2-empy")
1456 (version "3.3")
1457 (source (origin
1458 (method url-fetch)
1459 (uri (string-append "http://www.alcyone.com/software/empy/empy-"
1460 version ".tar.gz"))
1461 (sha256
1462 (base32
1463 "01g8mmkfnvjdmlhsihwyx56lrg7r5m5d2fg6mnxsvy6g0dnl69f6"))))
1464 (build-system python-build-system)
1465 (arguments
1466 `(#:python ,python-2
1467 #:phases (alist-replace
1468 'check
1469 (lambda _
1470 (zero? (system* "./test.sh")))
1471 %standard-phases)))
1472 (home-page "http://www.alcyone.com/software/empy/")
1473 (synopsis "Templating system for Python")
1474 (description
1475 "EmPy is a system for embedding Python expressions and statements in
1476 template text; it takes an EmPy source file, processes it, and produces
1477 output. This is accomplished via expansions, which are special signals to the
1478 EmPy system and are set off by a special prefix (by default the at sign, @@).
1479 EmPy can expand arbitrary Python expressions and statements in this way, as
1480 well as a variety of special forms. Textual data not explicitly delimited in
1481 this way is sent unaffected to the output, allowing Python to be used in
1482 effect as a markup language. Also supported are callbacks via hooks,
1483 recording and playback via diversions, and dynamic, chainable filters. The
1484 system is highly configurable via command line options and embedded
1485 commands.")
1486 (license license:lgpl2.1+)))
1487
1488 (define-public python2-element-tree
1489 (package
1490 (name "python2-element-tree")
1491 (version "1.2.6")
1492 (source (origin
1493 (method url-fetch)
1494 (uri (string-append
1495 "http://effbot.org/media/downloads/elementtree-"
1496 version "-20050316.tar.gz"))
1497 (sha256
1498 (base32
1499 "016bphqnlg0l4vslahhw4r0aanw95bpypy65r1i1acyb2wj5z7dj"))))
1500 (build-system python-build-system)
1501 (arguments
1502 `(#:python ,python-2 ; seems to be part of Python 3
1503 #:tests? #f)) ; no 'test' sub-command
1504 (synopsis "Toolkit for XML processing in Python")
1505 (description
1506 "ElementTree is a Python library supporting lightweight XML processing.")
1507 (home-page "http://effbot.org/zone/element-index.htm")
1508 (license (license:x11-style
1509 "http://docs.python.org/2/license.html"
1510 "Like \"CWI LICENSE AGREEMENT FOR PYTHON 0.9.0 THROUGH 1.2\"."))))
1511
1512 (define-public python2-pybugz
1513 (package
1514 (name "python2-pybugz")
1515 (version "0.6.11")
1516 (source (origin
1517 (method url-fetch)
1518 (uri (string-append
1519 "http://bits.liquidx.net/projects/pybugz/pybugz-"
1520 version ".tar.gz"))
1521 (sha256
1522 (base32
1523 "17ni00p08gp5lkxlrrcnvi3x09fmajnlbz4da03qcgl9q21ym4jd"))
1524 (patches (search-patches "pybugz-stty.patch"
1525 "pybugz-encode-error.patch"))))
1526 (build-system python-build-system)
1527 (arguments
1528 `(#:python ,python-2 ; SyntaxError with Python 3
1529 #:tests? #f)) ; no 'test' sub-command
1530 (propagated-inputs
1531 `(("element-tree" ,python2-element-tree)))
1532 (synopsis "Python and command-line interface to Bugzilla")
1533 (description
1534 "PyBugz is a Python library and command-line tool to query the Bugzilla
1535 bug tracking system. It is meant as an aid to speed up interaction with the
1536 bug tracker.")
1537 (home-page "http://www.liquidx.net/pybugz/")
1538 (license license:gpl2)))
1539
1540 (define-public python-enum34
1541 (package
1542 (name "python-enum34")
1543 (version "1.1.6")
1544 (source
1545 (origin
1546 (method url-fetch)
1547 (uri (pypi-uri "enum34" version))
1548 (sha256
1549 (base32
1550 "1cgm5ng2gcfrkrm3hc22brl6chdmv67b9zvva9sfs7gn7dwc9n4a"))))
1551 (build-system python-build-system)
1552 (home-page "https://pypi.python.org/pypi/enum34")
1553 (synopsis "Backported Python 3.4 Enum")
1554 (description
1555 "Enum34 is the new Python stdlib enum module available in Python 3.4
1556 backported for previous versions of Python from 2.4 to 3.3.")
1557 (license license:bsd-3)))
1558
1559 (define-public python2-enum34
1560 (package-with-python2 python-enum34))
1561
1562 (define-public python-parse-type
1563 (package
1564 (name "python-parse-type")
1565 (version "0.3.4")
1566 (source
1567 (origin
1568 (method url-fetch)
1569 (uri (string-append "https://pypi.python.org/packages/source/p/"
1570 "parse_type/parse_type-" version ".tar.gz"))
1571 (sha256
1572 (base32
1573 "0iv1c34npr4iynwpgv1vkjx9rjd18a85ir8c01gc5f7wp8iv7l1x"))))
1574 (build-system python-build-system)
1575 (arguments
1576 `(#:phases
1577 (modify-phases %standard-phases
1578 (add-after 'unpack 'patch-tests
1579 (lambda _
1580 (substitute* "tests/test_parse_type_parse.py"
1581 ;; Newer Python versions don't have the problem this test tests.
1582 (("self[.]assertRaises[(]parse.TooManyFields, p.parse, ''[)]")
1583 ""))
1584 #t)))))
1585 (propagated-inputs
1586 `(("python-six" ,python-six)
1587 ("python-parse" ,python-parse)))
1588 (native-inputs
1589 `(("python-pytest" ,python-pytest)
1590 ("python-pytest-runner" ,python-pytest-runner)))
1591 (home-page "https://github.com/jenisys/parse_type")
1592 (synopsis "Extended parse module")
1593 (description
1594 "Parse_type extends the python parse module.")
1595 (properties
1596 `((python2-variant . ,(delay python2-parse-type))))
1597 (license license:bsd-3)))
1598
1599 (define-public python2-parse-type
1600 (let ((base (package-with-python2
1601 (strip-python2-variant python-parse-type))))
1602 (package (inherit base)
1603 (propagated-inputs
1604 `(("python2-enum34" ,python2-enum34)
1605 ,@(package-propagated-inputs base))))))
1606
1607 (define-public python-parse
1608 (package
1609 (name "python-parse")
1610 (version "1.6.6")
1611 (source
1612 (origin
1613 (method url-fetch)
1614 (uri (pypi-uri "parse" version))
1615 (sha256
1616 (base32
1617 "0y31i3mwgv35qn0kzzjn9q8jqfdqmbi6sr6yfvn8rq4lqjm5lhvi"))
1618 (patches (search-patches "python-parse-too-many-fields.patch"))))
1619 (build-system python-build-system)
1620 (arguments
1621 `(#:phases
1622 (modify-phases %standard-phases
1623 (replace 'check
1624 (lambda _ (zero? (system* "python" "test_parse.py")))))))
1625 (home-page "https://github.com/r1chardj0n3s/parse")
1626 (synopsis "Parse strings")
1627 (description
1628 "Parse strings using a specification based on the Python format()
1629 syntax.")
1630 (license license:x11)))
1631
1632 (define-public python-polib
1633 (package
1634 (name "python-polib")
1635 (version "1.0.8")
1636 (source (origin
1637 (method url-fetch)
1638 (uri (pypi-uri "polib" version))
1639 (sha256
1640 (base32
1641 "1pq2hbm3m2q0cjdszk8mc4qa1vl3wcblh5nfyirlfnzb2pcy7zss"))))
1642 (build-system python-build-system)
1643 (home-page "https://bitbucket.org/izi/polib/wiki/Home")
1644 (synopsis "Manipulate, create and modify gettext files")
1645 (description "Polib can manipulate any gettext format (po, pot and mo)
1646 files. It can be used to create po files from scratch or to modify
1647 existing ones.")
1648 (license license:expat)))
1649
1650 (define-public python2-polib
1651 (let ((base (package-with-python2 (strip-python2-variant python-polib))))
1652 (package
1653 (inherit base)
1654 (arguments `(,@(package-arguments base)
1655 ;; Tests don't work with python2.
1656 #:tests? #f)))))
1657
1658 (define-public scons
1659 (package
1660 (name "scons")
1661 (version "2.5.1")
1662 (source (origin
1663 (method url-fetch)
1664 (uri (string-append "mirror://sourceforge/scons/scons/" version
1665 "/scons-" version ".tar.gz"))
1666 (sha256
1667 (base32
1668 "1wji1z9jdkhnmm99apx6fhld9cs52rr56aigniyrcsmlwy52298b"))))
1669 (build-system python-build-system)
1670 (arguments
1671 ;; With Python 3.x, fails to build with a syntax error.
1672 `(#:python ,python-2
1673 #:use-setuptools? #f ; still relies on distutils
1674 #:tests? #f)) ; no 'python setup.py test' command
1675 (home-page "http://scons.org/")
1676 (synopsis "Software construction tool written in Python")
1677 (description
1678 "SCons is a software construction tool. Think of SCons as an improved,
1679 cross-platform substitute for the classic Make utility with integrated
1680 functionality similar to autoconf/automake and compiler caches such as ccache.
1681 In short, SCons is an easier, more reliable and faster way to build
1682 software.")
1683 (license license:x11)))
1684
1685 (define-public python-extras
1686 (package
1687 (name "python-extras")
1688 (version "0.0.3")
1689 (source
1690 (origin
1691 (method url-fetch)
1692 (uri (string-append
1693 "https://pypi.python.org/packages/source/e/extras/extras-"
1694 version ".tar.gz"))
1695 (sha256
1696 (base32
1697 "1h7zx4dfyclalg0fqnfjijpn0f793a9mx8sy3b27gd31nr6dhq3s"))))
1698 (build-system python-build-system)
1699 (arguments
1700 ;; error in setup.cfg: command 'test' has no such option 'buffer'
1701 '(#:tests? #f))
1702 (home-page "https://github.com/testing-cabal/extras")
1703 (synopsis "Useful extensions to the Python standard library")
1704 (description
1705 "Extras is a set of extensions to the Python standard library.")
1706 (license license:expat)))
1707
1708 (define-public python2-extras
1709 (package-with-python2 python-extras))
1710
1711 (define-public python-mimeparse
1712 (package
1713 (name "python-mimeparse")
1714 (version "0.1.4")
1715 (source
1716 (origin
1717 (method url-fetch)
1718 (uri (string-append
1719 "https://pypi.python.org/packages/source/p/python-mimeparse/python-mimeparse-"
1720 version ".tar.gz"))
1721 (sha256
1722 (base32
1723 "1hyxg09kaj02ri0rmwjqi86wk4nd1akvv7n0dx77azz76wga4s9w"))))
1724 (build-system python-build-system)
1725 (arguments
1726 '(#:tests? #f)) ; no setup.py test command
1727 (home-page
1728 "https://github.com/dbtsai/python-mimeparse")
1729 (synopsis "Python library for parsing MIME types")
1730 (description
1731 "Mimeparse provides basic functions for parsing MIME type names and
1732 matching them against a list of media-ranges.")
1733 (license license:expat)))
1734
1735 (define-public python2-mimeparse
1736 (package-with-python2 python-mimeparse))
1737
1738 (define-public python-nose
1739 (package
1740 (name "python-nose")
1741 (version "1.3.7")
1742 (source
1743 (origin
1744 (method url-fetch)
1745 (uri (pypi-uri "nose" version))
1746 (sha256
1747 (base32
1748 "164a43k7k2wsqqk1s6vavcdamvss4mz0vd6pwzv2h9n8rgwzxgzi"))))
1749 (build-system python-build-system)
1750 (arguments
1751 '(#:tests? #f)) ; FIXME: test suite fails
1752 (home-page "http://readthedocs.org/docs/nose/")
1753 (synopsis "Python testing library")
1754 (description
1755 "Nose extends the unittest library to make testing easier.")
1756 (license license:lgpl2.0+)))
1757
1758 (define-public python2-nose
1759 (package-with-python2 python-nose))
1760
1761 (define-public python-nose2
1762 (package
1763 (name "python-nose2")
1764 (version "0.6.5")
1765 (source
1766 (origin
1767 (method url-fetch)
1768 (uri (pypi-uri "nose2" version))
1769 (sha256
1770 (base32
1771 "1x4zjq1zlyrh8b9ba0cmafd3w94pxhid408kibyjd3s6h1lap6s7"))))
1772 (build-system python-build-system)
1773 (arguments `(#:tests? #f)) ; 'module' object has no attribute 'collector'
1774 (propagated-inputs
1775 `(("python-cov-core" ,python-cov-core)
1776 ("python-pytest-cov" ,python-pytest-cov)
1777 ("python-six" ,python-six)))
1778 (home-page "https://github.com/nose-devs/nose2")
1779 (synopsis "Next generation of nicer testing for Python")
1780 (description
1781 "Nose2 is the next generation of nicer testing for Python, based on the
1782 plugins branch of unittest2. Nose2 aims to improve on nose by providing a
1783 better plugin api, being easier for users to configure, and simplifying internal
1784 interfaces and processes.")
1785 (license license:bsd-2)))
1786
1787 (define-public python2-nose2
1788 (package-with-python2 python-nose2))
1789
1790 (define-public python-unittest2
1791 (package
1792 (name "python-unittest2")
1793 (version "0.5.1")
1794 (source
1795 (origin
1796 (method url-fetch)
1797 (uri (string-append
1798 "https://pypi.python.org/packages/source/u/unittest2py3k/unittest2py3k-"
1799 version ".tar.gz"))
1800 (sha256
1801 (base32
1802 "00yl6lskygcrddx5zspkhr0ibgvpknl4678kkm6s626539grq93q"))))
1803 (build-system python-build-system)
1804 (home-page "http://pypi.python.org/pypi/unittest2")
1805 (synopsis "Python unit testing library")
1806 (description
1807 "Unittest2 is a replacement for the unittest module in the Python
1808 standard library.")
1809 (license license:psfl)))
1810
1811 (define-public python2-unittest2
1812 (package (inherit python-unittest2)
1813 (name "python2-unittest2")
1814 (version "0.5.1")
1815 (source
1816 (origin
1817 (method url-fetch)
1818 (uri (string-append
1819 "https://pypi.python.org/packages/source/u/unittest2/unittest2-"
1820 version ".tar.gz"))
1821 (sha256
1822 (base32
1823 "0wbs4i4x3x7klr3v35ss6p9mcqz883i1xgcpkhvl7n2lyv6yhpda"))))
1824 (arguments
1825 `(#:python ,python-2
1826 #:tests? #f)))) ; no setup.py test command
1827
1828 (define-public python-pafy
1829 (package
1830 (name "python-pafy")
1831 (version "0.5.3.1")
1832 (source
1833 (origin
1834 (method url-fetch)
1835 (uri (pypi-uri "pafy" version))
1836 (sha256
1837 (base32
1838 "1a7dxi95m1043rxx1r5x3ngb66nwlq6aqcasyqqjzmmmjps4zrim"))))
1839 (build-system python-build-system)
1840 (arguments
1841 `(#:tests? #f)) ; Currently pafy can not find itself in the tests
1842 (propagated-inputs
1843 ;; Youtube-dl is a python package which is imported in the file
1844 ;; "backend_youtube_dl.py", therefore it needs to be propagated.
1845 `(("youtube-dl" ,youtube-dl)))
1846 (home-page "https://np1.github.io/pafy/")
1847 (synopsis "Retrieve YouTube content and metadata")
1848 (description
1849 "@code{pafy} is a python library to retrieve YouTube content and metadata.")
1850 (license license:lgpl3+)))
1851
1852 (define-public python-py
1853 (package
1854 (name "python-py")
1855 (version "1.4.32")
1856 (source
1857 (origin
1858 (method url-fetch)
1859 (uri (pypi-uri "py" version))
1860 (sha256
1861 (base32
1862 "19s1pql9pq85h1qzsdwgyb8a3k1qgkvh33b02m8kfqhizz8rzf64"))))
1863 (build-system python-build-system)
1864 (arguments
1865 ;; FIXME: "ImportError: 'test' module incorrectly imported from
1866 ;; '/gnu/store/...-python-pytest-mimimal-3.0.5/lib/python3.5/site-packages'.
1867 ;; Expected '/tmp/guix-build-python-py-1.4.31.drv-0/py-1.4.31/py'.
1868 ;; Is this module globally installed?"
1869 '(#:tests? #f))
1870 (home-page "http://pylib.readthedocs.org/")
1871 (synopsis "Python library for parsing, I/O, instrospection, and logging")
1872 (description
1873 "Py is a Python library for file name parsing, .ini file parsing, I/O,
1874 code introspection, and logging.")
1875 (license license:expat)))
1876
1877 (define-public python2-py
1878 (package-with-python2 python-py))
1879
1880 (define-public python-pytest
1881 (package
1882 (name "python-pytest")
1883 (version "2.7.3")
1884 (source
1885 (origin
1886 (method url-fetch)
1887 (uri (string-append
1888 "https://pypi.python.org/packages/source/p/pytest/pytest-"
1889 version ".tar.gz"))
1890 (sha256
1891 (base32
1892 "1z4yi986f9n0p8qmzmn21m21m8j1x78hk3505f89baqm6pdw7afm"))
1893 (modules '((guix build utils)))
1894 (snippet
1895 ;; One of the tests involves the /usr directory, so it fails.
1896 '(substitute* "testing/test_argcomplete.py"
1897 (("def test_remove_dir_prefix\\(self\\):")
1898 "@pytest.mark.xfail\n def test_remove_dir_prefix(self):")))))
1899 (build-system python-build-system)
1900 (propagated-inputs
1901 `(("python-py" ,python-py)))
1902 (native-inputs
1903 `(("python-nose" ,python-nose)
1904 ("python-mock" ,python-mock)))
1905 (home-page "http://pytest.org")
1906 (synopsis "Python testing library")
1907 (description
1908 "Pytest is a testing tool that provides auto-discovery of test modules
1909 and functions, detailed info on failing assert statements, modular fixtures,
1910 and many external plugins.")
1911 (license license:expat)))
1912
1913 (define-public python2-pytest
1914 (package-with-python2 python-pytest))
1915
1916 ;; Some packages require a newer pytest.
1917 (define-public python-pytest-3.0
1918 (package
1919 (inherit python-pytest)
1920 (name "python-pytest")
1921 (version "3.0.7")
1922 (source (origin
1923 (method url-fetch)
1924 (uri (pypi-uri "pytest" version))
1925 (sha256
1926 (base32
1927 "1asc4b2nd2a4f0g3r12y97rslq5wliji7b73wwkvdrm5s7mrc1mp"))))
1928 (arguments
1929 `(#:phases
1930 (modify-phases %standard-phases
1931 (add-before 'check 'disable-invalid-test
1932 (lambda _
1933 (substitute* "testing/test_argcomplete.py"
1934 (("def test_remove_dir_prefix" line)
1935 (string-append "@pytest.mark.skip"
1936 "(reason=\"Assumes that /usr exists.\")\n "
1937 line)))
1938 #t)))))
1939 (native-inputs
1940 `(("python-nose" ,python-nose)
1941 ("python-mock" ,python-mock)
1942 ("python-hypothesis" ,python-hypothesis)))
1943 (properties `((python2-variant . ,(delay python2-pytest-3.0))))))
1944
1945 (define-public python2-pytest-3.0
1946 (let ((base (package-with-python2
1947 (strip-python2-variant python-pytest-3.0))))
1948 (package (inherit base)
1949 (native-inputs
1950 `(("python2-enum34" ,python2-enum34)
1951 ,@(package-native-inputs base))))))
1952
1953 (define-public python-pytest-cov
1954 (package
1955 (name "python-pytest-cov")
1956 (version "2.4.0")
1957 (source
1958 (origin
1959 (method url-fetch)
1960 (uri (pypi-uri "pytest-cov" version))
1961 (sha256
1962 (base32
1963 "03c2qc42r4bczyw93gd7n0qi1h1jfhw7fnbhi33c3vp1hs81gm2k"))))
1964 (build-system python-build-system)
1965 (arguments
1966 `(#:phases
1967 (modify-phases %standard-phases
1968 (replace 'check
1969 (lambda _
1970 ;; options taken from tox.ini
1971 ;; TODO: make "--restructuredtext" tests pass. They currently fail
1972 ;; with "Duplicate implicit target name"
1973 (zero? (system* "python" "./setup.py" "check"
1974 "--strict" "--metadata")))))))
1975 (propagated-inputs
1976 `(("python-coverage" ,python-coverage)
1977 ("python-pytest" ,python-pytest)))
1978 (home-page "https://github.com/pytest-dev/pytest-cov")
1979 (synopsis "Pytest plugin for measuring coverage")
1980 (description
1981 "Pytest-cov produces coverage reports. It supports centralised testing and
1982 distributed testing in both @code{load} and @code{each} modes. It also
1983 supports coverage of subprocesses.")
1984 (license license:expat)))
1985
1986 (define-public python2-pytest-cov
1987 (package-with-python2 python-pytest-cov))
1988
1989 (define-public python-pytest-runner
1990 (package
1991 (name "python-pytest-runner")
1992 (version "2.11.1")
1993 (source
1994 (origin
1995 (method url-fetch)
1996 (uri (pypi-uri "pytest-runner" version))
1997 (sha256
1998 (base32
1999 "1cw978kqqcq916b9gfns1qjqvg33c5ail5jhw9054dsynkm32flq"))))
2000 (build-system python-build-system)
2001 (arguments
2002 `(#:phases
2003 (modify-phases %standard-phases
2004 ;; The fancy way of setting the version with setuptools_scm does not
2005 ;; seem to work here.
2006 (add-after 'unpack 'set-version
2007 (lambda _
2008 (substitute* "docs/conf.py"
2009 (("version = setuptools_scm\\.get_version\\(root='\\.\\.')")
2010 (string-append "version = \"" ,version "\"")))
2011 #t)))))
2012 (native-inputs
2013 `(("python-pytest" ,python-pytest)
2014 ("python-setuptools-scm" ,python-setuptools-scm)))
2015 (home-page "https://github.com/pytest-dev/pytest-runner")
2016 (synopsis "Invoke py.test as a distutils command")
2017 (description
2018 "This package provides a @command{pytest-runner} command that
2019 @file{setup.py} files can use to run tests.")
2020 (license license:expat)))
2021
2022 (define-public python2-pytest-runner
2023 (package-with-python2 python-pytest-runner))
2024
2025 (define-public python-pytest-mock
2026 (package
2027 (name "python-pytest-mock")
2028 (version "1.2")
2029 (source
2030 (origin
2031 (method url-fetch)
2032 (uri (pypi-uri "pytest-mock" version ".zip"))
2033 (sha256
2034 (base32
2035 "03zxar5drzm7ksqyrwypjaza3cri6wqvpr6iam92djvg6znp32gp"))))
2036 (build-system python-build-system)
2037 (native-inputs
2038 `(("unzip" ,unzip)))
2039 (propagated-inputs
2040 `(("python-pytest" ,python-pytest)))
2041 (home-page "https://github.com/pytest-dev/pytest-mock/")
2042 (synopsis "Thin-wrapper around the mock package for easier use with py.test")
2043 (description
2044 "This plugin installs a @code{mocker} fixture which is a thin-wrapper
2045 around the patching API provided by the @code{mock} package, but with the
2046 benefit of not having to worry about undoing patches at the end of a test.
2047 The mocker fixture has the same API as @code{mock.patch}, supporting the
2048 same arguments.")
2049 (properties `((python2-variant . ,(delay python2-pytest-mock))))
2050 (license license:expat)))
2051
2052 (define-public python2-pytest-mock
2053 (let ((base (package-with-python2
2054 (strip-python2-variant python-pytest-mock))))
2055 (package (inherit base)
2056 (propagated-inputs
2057 `(("python2-mock" ,python2-mock)
2058 ,@(package-propagated-inputs base))))))
2059
2060 (define-public python-pytest-xdist
2061 (package
2062 (name "python-pytest-xdist")
2063 (version "1.14")
2064 (source
2065 (origin
2066 (method url-fetch)
2067 (uri (pypi-uri "pytest-xdist" version ".zip"))
2068 (sha256
2069 (base32
2070 "08rn2l39ds60xshs4js787l84pfckksqklfq2wq9x8ig2aci2pja"))
2071 (modules '((guix build utils)))
2072 (snippet
2073 '(begin
2074 ;; Remove pre-compiled .pyc files from source.
2075 (for-each delete-file-recursively
2076 (find-files "." "__pycache__" #:directories? #t))
2077 (for-each delete-file (find-files "." "\\.pyc$"))
2078 #t))))
2079 (build-system python-build-system)
2080 (arguments
2081 '(#:tests? #f)) ;FIXME: Some tests are failing.
2082 ;; #:phases
2083 ;; (modify-phases %standard-phases
2084 ;; (delete 'check)
2085 ;; (add-after 'install 'check
2086 ;; (lambda* (#:key inputs outputs #:allow-other-keys)
2087 ;; (add-installed-pythonpath inputs outputs)
2088 ;; (zero? (system* "py.test" "-v")))))
2089 (native-inputs
2090 `(("unzip" ,unzip)
2091 ("python-setuptools-scm" ,python-setuptools-scm)))
2092 (propagated-inputs
2093 `(("python-execnet" ,python-execnet)
2094 ("python-pytest" ,python-pytest)
2095 ("python-py" ,python-py)))
2096 (home-page
2097 "https://github.com/pytest-dev/pytest-xdist")
2098 (synopsis
2099 "Plugin for py.test with distributed testing and loop-on-failing modes")
2100 (description
2101 "The pytest-xdist plugin extends py.test with some unique test execution
2102 modes: parallelization, running tests in boxed subprocesses, the ability
2103 to run tests repeatedly when failed, and the ability to run tests on multiple
2104 Python interpreters or platforms. It uses rsync to copy the existing
2105 program code to a remote location, executes there, and then syncs the
2106 result back.")
2107 (license license:expat)))
2108
2109 (define-public python2-pytest-xdist
2110 (package-with-python2 python-pytest-xdist))
2111
2112 (define-public python-scripttest
2113 (package
2114 (name "python-scripttest")
2115 (version "1.3")
2116 (source
2117 (origin
2118 (method url-fetch)
2119 (uri (string-append
2120 "https://pypi.python.org/packages/source/s/scripttest/scripttest-"
2121 version ".tar.gz"))
2122 (sha256
2123 (base32
2124 "0f4w84k8ck82syys7yg9maz93mqzc8p5ymis941x034v44jzq74m"))))
2125 (build-system python-build-system)
2126 (native-inputs
2127 `(("python-pytest" ,python-pytest)))
2128 (home-page "http://pythonpaste.org/scripttest/")
2129 (synopsis "Python library to test command-line scripts")
2130 (description "Scripttest is a Python helper library for testing
2131 interactive command-line applications. With it you can run a script in a
2132 subprocess and see the output as well as any file modifications.")
2133 (license license:expat)))
2134
2135 (define-public python2-scripttest
2136 (package-with-python2 python-scripttest))
2137
2138 (define-public python-testtools
2139 (package
2140 (name "python-testtools")
2141 (version "1.4.0")
2142 (source
2143 (origin
2144 (method url-fetch)
2145 (uri (pypi-uri "testtools" version))
2146 (sha256
2147 (base32
2148 "1vw8yljnd75d396hhw6s2hrf4cclzy845ifd5am0lxsl235z3i8c"))))
2149 (build-system python-build-system)
2150 (arguments
2151 `(#:phases
2152 (modify-phases %standard-phases
2153 (add-after 'unpack 'fix-module-imports
2154 (lambda _
2155 (substitute* "setup.py"
2156 (("'unittest2>=0.8.0',") ""))
2157 (substitute* '("testtools/testcase.py"
2158 "testtools/testsuite.py"
2159 "testtools/run.py"
2160 "testtools/tests/test_run.py"
2161 "testtools/tests/test_testsuite.py"
2162 "testtools/tests/test_deferredruntest.py")
2163 ;; unittest2 is a backport of Python2.7 features to Python 2.4.
2164 (("import unittest2 as unittest") "import unittest")
2165 (("import unittest2") "import unittest as unittest2")
2166 (("from unittest2 import") "from unittest import"))
2167 (substitute* "testtools/tests/test_testresult.py"
2168 ;; NUL in source code is not allowed (raises ValueError).
2169 (("\\x00\\x04") "\\x04"))
2170 #t)))))
2171 (propagated-inputs
2172 `(("python-mimeparse" ,python-mimeparse)
2173 ("python-extras" ,python-extras)))
2174 (home-page "https://github.com/testing-cabal/testtools")
2175 (synopsis
2176 "Extensions to the Python standard library unit testing framework")
2177 (description
2178 "Testtools extends the Python standard library unit testing framework to
2179 provide matchers, more debugging information, and cross-Python
2180 compatibility.")
2181 (license license:psfl)))
2182
2183 (define-public python2-testtools
2184 (package-with-python2 python-testtools))
2185
2186 (define-public python-testscenarios
2187 (package
2188 (name "python-testscenarios")
2189 (version "0.4")
2190 (source
2191 (origin
2192 (method url-fetch)
2193 (uri (string-append
2194 "https://pypi.python.org/packages/source/t/testscenarios/testscenarios-"
2195 version ".tar.gz"))
2196 (sha256
2197 (base32
2198 "1671jvrvqlmbnc42j7pc5y6vc37q44aiwrq0zic652pxyy2fxvjg"))))
2199 (build-system python-build-system)
2200 (propagated-inputs
2201 `(("python-testtools" ,python-testtools)))
2202 (home-page "https://launchpad.net/testscenarios")
2203 (synopsis "Pyunit extension for dependency injection")
2204 (description
2205 "Testscenarios provides clean dependency injection for Python unittest
2206 style tests.")
2207 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2208
2209 (define-public python2-testscenarios
2210 (package-with-python2 python-testscenarios))
2211
2212 (define-public python-testresources
2213 (package
2214 (name "python-testresources")
2215 (version "0.2.7")
2216 (source
2217 (origin
2218 (method url-fetch)
2219 (uri (string-append
2220 "https://pypi.python.org/packages/source/t/testresources/testresources-"
2221 version ".tar.gz"))
2222 (sha256
2223 (base32
2224 "0cbj3plbllyz42c4b5xxgwaa7mml54lakslrn4kkhinxhdri22md"))))
2225 (build-system python-build-system)
2226 (home-page "https://launchpad.net/testresources")
2227 (synopsis
2228 "Pyunit extension for managing test resources")
2229 (description
2230 "Testresources is an extension to Python's unittest to allow declarative
2231 use of resources by test cases.")
2232 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2233
2234 (define-public python2-testresources
2235 (package-with-python2 python-testresources))
2236
2237 (define-public python-subunit
2238 (package
2239 (name "python-subunit")
2240 (version "0.0.21")
2241 (source
2242 (origin
2243 (method url-fetch)
2244 (uri (string-append
2245 "https://pypi.python.org/packages/source/p/python-subunit/python-subunit-"
2246 version ".tar.gz"))
2247 (sha256
2248 (base32
2249 "1nkw9wfbvizmpajbj3in8ns07g7lwkiv8hip14jjlwk3cacls6jv"))))
2250 (build-system python-build-system)
2251 (propagated-inputs
2252 `(("python-extras" ,python-extras)
2253 ("python-mimeparse" ,python-mimeparse)))
2254 (native-inputs
2255 `(("python-testscenarios" ,python-testscenarios)))
2256 (home-page "http://launchpad.net/subunit")
2257 (synopsis "Python implementation of the subunit protocol")
2258 (description
2259 "Python-subunit is a Python implementation of the subunit test streaming
2260 protocol.")
2261 (license (list license:bsd-3 license:asl2.0)))) ; at the user's option
2262
2263 (define-public python2-subunit
2264 (package-with-python2 python-subunit))
2265
2266 ;; Recent versions of python-fixtures and python-testrepository need
2267 ;; python-pbr for packaging, which itself needs these two packages for
2268 ;; testing.
2269 ;; To fix this circular dependency, we use a build of python-pbr, based on the
2270 ;; same source, just without any test dependencies and with tests disabled.
2271 ;; python-pbr-minmal is then used to package python-fixtures and
2272 ;; python-testrepository.
2273 ;; Strictly speaking we currently could remove the test-requirements from the
2274 ;; normal python-pbr package (and save this package) since test are disabled
2275 ;; there anyway. But this may change in future.
2276 (define python-pbr-minimal
2277 (package
2278 (name "python-pbr-minimal")
2279 (version "3.0.1")
2280 (source
2281 (origin
2282 (method url-fetch)
2283 (uri (pypi-uri "pbr" version))
2284 (sha256
2285 (base32
2286 "14fs5acnalnb3h62s7q7av239j541fk0n0z0lawh4h09b1s93s6p"))))
2287 (build-system python-build-system)
2288 (arguments
2289 `(#:tests? #f))
2290 (home-page "http://docs.openstack.org/developer/pbr/")
2291 (synopsis "Minimal build of python-pbr used for bootstrapping")
2292 (description
2293 "Used only for bootstrapping python2-pbr, you should not need this.")
2294 (license license:asl2.0)))
2295
2296 (define python2-pbr-minimal
2297 (package-with-python2 python-pbr-minimal))
2298
2299 (define-public python-pbr
2300 (package
2301 (inherit python-pbr-minimal)
2302 (name "python-pbr")
2303 (arguments
2304 `(#:tests? #f)) ;; Most tests seem to use the Internet.
2305 (propagated-inputs
2306 `(("git" ,git))) ;; pbr actually uses the "git" binary.
2307 (native-inputs
2308 `(("python-fixtures" ,python-fixtures)
2309 ;; discover, coverage, hacking, subunit
2310 ("python-mock" ,python-mock)
2311 ("python-six" ,python-six)
2312 ("python-sphinx" ,python-sphinx)
2313 ("python-testrepository" ,python-testrepository)
2314 ("python-testresources" ,python-testresources)
2315 ("python-testscenarios" ,python-testscenarios)
2316 ("python-testtools" ,python-testtools)
2317 ("python-virtualenv" ,python-virtualenv)))
2318 (synopsis "Enhance the default behavior of Python’s setuptools")
2319 (description
2320 "Python Build Reasonableness (PBR) is a library that injects some useful
2321 and sensible default behaviors into your setuptools run. It will set
2322 versions, process requirements files and generate AUTHORS and ChangeLog file
2323 from git information.
2324 ")))
2325
2326 (define-public python2-pbr
2327 (package-with-python2 python-pbr))
2328
2329 (define-public python-fixtures
2330 (package
2331 (name "python-fixtures")
2332 (version "1.4.0")
2333 (source
2334 (origin
2335 (method url-fetch)
2336 (uri (pypi-uri "fixtures" version))
2337 (sha256
2338 (base32
2339 "0djxvdwm8s60dbfn7bhf40x6g818p3b3mlwijm1c3bqg7msn271y"))))
2340 (build-system python-build-system)
2341 (arguments
2342 '(#:phases
2343 (modify-phases %standard-phases
2344 (replace 'check
2345 (lambda _
2346 (zero? (system* "python" "-m" "testtools.run"
2347 "fixtures.test_suite")))))))
2348 (propagated-inputs
2349 `(("python-six" ,python-six)))
2350 (native-inputs
2351 `(("python-mock" ,python-mock)
2352 ("python-pbr-minimal" ,python-pbr-minimal)
2353 ("python-testtools" ,python-testtools)))
2354 (home-page "https://launchpad.net/python-fixtures")
2355 (synopsis "Python test fixture library")
2356 (description
2357 "Fixtures provides a way to create reusable state, useful when writing
2358 Python tests.")
2359 (license (list license:bsd-3 license:asl2.0)))) ; at user's option
2360
2361 (define-public python2-fixtures
2362 (package-with-python2 python-fixtures))
2363
2364 (define-public python-testrepository
2365 (package
2366 (name "python-testrepository")
2367 (version "0.0.20")
2368 (source
2369 (origin
2370 (method url-fetch)
2371 (uri (string-append
2372 "https://pypi.python.org/packages/source/t/testrepository/testrepository-"
2373 version ".tar.gz"))
2374 (sha256
2375 (base32
2376 "1ssqb07c277010i6gzzkbdd46gd9mrj0bi0i8vn560n2k2y4j93m"))))
2377 (build-system python-build-system)
2378 (arguments
2379 ;; FIXME: Many tests are failing.
2380 '(#:tests? #f))
2381 (propagated-inputs
2382 `(("python-fixtures" ,python-fixtures)
2383 ("python-subunit" ,python-subunit)
2384 ("python-testtools" ,python-testtools)))
2385 (native-inputs
2386 `(("python-pbr-minimal" ,python-pbr-minimal) ;; same as for building fixture
2387 ("python-mimeparse" ,python-mimeparse)))
2388 (home-page "https://launchpad.net/testrepository")
2389 (synopsis "Database for Python test results")
2390 (description "Testrepository provides a database of test results which can
2391 be used as part of a developer's workflow to check things such as what tests
2392 have failed since the last commit or what tests are currently failing.")
2393 (license (list license:bsd-3 license:asl2.0)))) ; at user's option
2394
2395 (define-public python2-testrepository
2396 (package-with-python2 python-testrepository))
2397
2398 (define-public python-coverage
2399 (package
2400 (name "python-coverage")
2401 (version "4.1")
2402 (source
2403 (origin
2404 (method url-fetch)
2405 (uri (pypi-uri "coverage" version))
2406 (sha256
2407 (base32
2408 "01rbr4br4lsk0lwn8fb96zwd2xr4f0mg1w7iq3j11i8f5ig2nqs1"))))
2409 (build-system python-build-system)
2410 (arguments
2411 ;; FIXME: 95 tests failed, 539 passed, 6 skipped, 2 errors.
2412 '(#:tests? #f))
2413 (home-page "http://nedbatchelder.com/code/coverage")
2414 (synopsis "Code coverage measurement for Python")
2415 (description
2416 "Coverage measures code coverage, typically during test execution. It
2417 uses the code analysis tools and tracing hooks provided in the Python standard
2418 library to determine which lines are executable, and which have been
2419 executed.")
2420 (license license:bsd-3)))
2421
2422 (define-public python2-coverage
2423 (package-with-python2 python-coverage))
2424
2425 (define-public python-cov-core
2426 (package
2427 (name "python-cov-core")
2428 (version "1.15.0")
2429 (source
2430 (origin
2431 (method url-fetch)
2432 (uri (pypi-uri "cov-core" version))
2433 (sha256
2434 (base32
2435 "0k3np9ymh06yv1ib96sb6wfsxjkqhmik8qfsn119vnhga9ywc52a"))))
2436 (build-system python-build-system)
2437 (propagated-inputs
2438 `(("python-coverage" ,python-coverage)))
2439 (home-page "https://github.com/schlamar/cov-core")
2440 (synopsis "Coverage plugin core for pytest-cov, nose-cov and nose2-cov")
2441 (description
2442 "This is a library package for use by @code{pytest-cov}, @code{nose-cov}
2443 and @code{nose2-cov}. It is useful for developing coverage plugins for these
2444 testing frameworks.")
2445 (license license:expat)))
2446
2447 (define-public python2-cov-core
2448 (package-with-python2 python-cov-core))
2449
2450 (define-public python-discover
2451 (package
2452 (name "python-discover")
2453 (version "0.4.0")
2454 (source
2455 (origin
2456 (method url-fetch)
2457 (uri (string-append
2458 "https://pypi.python.org/packages/source/d/discover/discover-"
2459 version ".tar.gz"))
2460 (sha256
2461 (base32
2462 "0y8d0zwiqar51kxj8lzmkvwc3b8kazb04gk5zcb4nzg5k68zmhq5"))))
2463 (build-system python-build-system)
2464 (home-page "http://pypi.python.org/pypi/discover/")
2465 (synopsis
2466 "Python test discovery for unittest")
2467 (description
2468 "Discover provides test discovery for unittest, a feature that has been
2469 backported from Python 2.7 for Python 2.4+.")
2470 (license license:bsd-3)))
2471
2472 (define-public python2-discover
2473 (package-with-python2 python-discover))
2474
2475 (define-public behave
2476 (package
2477 (name "behave")
2478 (version "1.2.5")
2479 (source (origin
2480 (method url-fetch)
2481 (uri (pypi-uri "behave" version ".tar.bz2"))
2482 (sha256
2483 (base32
2484 "1iypp6z46r19n4xmgx6m1lwmlpfjh8vapq8izigrqlaarvp2y64c"))))
2485 (build-system python-build-system)
2486 (propagated-inputs
2487 `(("python-six" ,python-six)
2488 ("python-parse" ,python-parse)
2489 ("python-parse-type" ,python-parse-type)))
2490 (arguments `(#:tests? #f)) ;TODO: tests require nose>=1.3 and
2491 ;PyHamcrest>=1.8
2492 (home-page "https://github.com/behave/behave")
2493 (synopsis "Python behavior-driven development")
2494 (description
2495 "Behave is a tool for behavior-driven development in python.
2496 Behavior-driven development (or BDD) is an agile software development
2497 technique that encourages collaboration between developers, QA and
2498 non-technical or business participants in a software project. Behave uses
2499 tests written in a natural language style, backed up by Python code.")
2500 (license license:x11)))
2501
2502 (define-public python-exif-read
2503 (package
2504 (name "python-exif-read")
2505 (version "2.1.2")
2506 (source (origin
2507 (method url-fetch)
2508 (uri (pypi-uri "ExifRead" version))
2509 (sha256
2510 (base32
2511 "1b90jf6m9vxh9nanhpyvqdq7hmfx5iggw1l8kq10jrs6xgr49qkr"))))
2512 (build-system python-build-system)
2513 (arguments `(#:tests? #f)) ; no tests
2514 (home-page "https://github.com/ianare/exif-py")
2515 (synopsis "Python library to extract EXIF data from image files")
2516 (description
2517 "ExifRead is a Python library to extract EXIF data from tiff and jpeg
2518 files.")
2519 (license license:bsd-3)))
2520
2521 (define-public python2-exif-read
2522 (package-with-python2 python-exif-read))
2523
2524 (define-public python-pyld
2525 (package
2526 (name "python-pyld")
2527 (version "0.7.1")
2528 (source (origin
2529 (method url-fetch)
2530 (uri (pypi-uri "PyLD" version))
2531 (sha256
2532 (base32
2533 "1m0fs6897vxfkf7awah5i66i7b7smm5fnywf1w50fpzyfbfhr156"))))
2534 (build-system python-build-system)
2535 (arguments `(#:tests? #f)) ; no tests
2536 (home-page "https://github.com/digitalbazaar/pyld")
2537 (synopsis "Python implementation of the JSON-LD specification")
2538 (description
2539 "PyLD is an implementation of the JSON-LD specification.")
2540 (license license:bsd-3)))
2541
2542 (define-public python2-pyld
2543 (package-with-python2 python-pyld))
2544
2545 (define-public python-certifi
2546 (package
2547 (name "python-certifi")
2548 (version "2017.1.23")
2549 (source (origin
2550 (method url-fetch)
2551 (uri (pypi-uri "certifi" version))
2552 (sha256
2553 (base32
2554 "1klrzl3hgvcf2mjk00g0k3kk1p2z27vzwnxivwar4vhjmjvpz1w1"))))
2555 (build-system python-build-system)
2556 (home-page "https://certifi.io/")
2557 (synopsis "Python CA certificate bundle")
2558 (description
2559 "Certifi is a Python library that contains a CA certificate bundle, which
2560 is used by the Requests library to verify HTTPS requests.")
2561 (license license:asl2.0)))
2562
2563 (define-public python2-certifi
2564 (package-with-python2 python-certifi))
2565
2566 (define-public python-click
2567 (package
2568 (name "python-click")
2569 (version "6.7")
2570 (source
2571 (origin
2572 (method url-fetch)
2573 (uri (pypi-uri "click" version))
2574 (sha256
2575 (base32
2576 "02qkfpykbq35id8glfgwc38yc430427yd05z1wc5cnld8zgicmgi"))))
2577 (build-system python-build-system)
2578 (arguments
2579 `(#:phases
2580 (modify-phases %standard-phases
2581 (add-after 'unpack 'fix-paths
2582 (lambda* (#:key inputs #:allow-other-keys)
2583 (let ((glibc (assoc-ref inputs ,(if (%current-target-system)
2584 "cross-libc" "libc"))))
2585 (substitute* "click/_unicodefun.py"
2586 (("'locale'")
2587 (string-append "'" glibc "/bin/locale'"))))
2588 #t))
2589 (replace 'check
2590 (lambda _
2591 (zero? (system* "make" "test")))))))
2592 (native-inputs
2593 `(("python-pytest" ,python-pytest)))
2594 (home-page "http://click.pocoo.org")
2595 (synopsis "Command line library for Python")
2596 (description
2597 "Click is a Python package for creating command line interfaces in a
2598 composable way with as little code as necessary. Its name stands for
2599 \"Command Line Interface Creation Kit\". It's highly configurable but comes
2600 with sensible defaults out of the box.")
2601 (license license:bsd-3)))
2602
2603 (define-public python2-click
2604 (package-with-python2 python-click))
2605
2606 (define-public python-wheel
2607 (package
2608 (name "python-wheel")
2609 (version "0.30.0a0")
2610 (source
2611 (origin
2612 (method url-fetch)
2613 (uri (pypi-uri "wheel" version))
2614 (sha256
2615 (base32
2616 "1nm6mn8isny0hr86rhbfrpfj867c0phf001xgsd69xfp9ady1wwq"))))
2617 (build-system python-build-system)
2618 (native-inputs
2619 `(("python-jsonschema" ,python-jsonschema)
2620 ("python-pytest-cov" ,python-pytest-cov)))
2621 (home-page "https://bitbucket.org/pypa/wheel/")
2622 (synopsis "Format for built Python packages")
2623 (description
2624 "A wheel is a ZIP-format archive with a specially formatted filename and
2625 the @code{.whl} extension. It is designed to contain all the files for a PEP
2626 376 compatible install in a way that is very close to the on-disk format. Many
2627 packages will be properly installed with only the @code{Unpack} step and the
2628 unpacked archive preserves enough information to @code{Spread} (copy data and
2629 scripts to their final locations) at any later time. Wheel files can be
2630 installed with a newer @code{pip} or with wheel's own command line utility.")
2631 (license license:expat)
2632 (properties `((python2-variant . ,(delay python2-wheel))))))
2633
2634 (define-public python2-wheel
2635 (let ((wheel (package-with-python2
2636 (strip-python2-variant python-wheel))))
2637 (package (inherit wheel)
2638 (native-inputs `(("python2-functools32" ,python2-functools32)
2639 ,@(package-native-inputs wheel))))))
2640
2641
2642 (define-public python-requests
2643 (package
2644 (name "python-requests")
2645 (version "2.13.0")
2646 (source (origin
2647 (method url-fetch)
2648 (uri (pypi-uri "requests" version))
2649 (sha256
2650 (base32
2651 "1s0wg4any4dsv5l3hqjxqk2zgb7pdbqhy9rhc8kh3aigfq4ws8jp"))))
2652 ;; TODO: unbundle urllib3 and chardet.
2653 (build-system python-build-system)
2654 (arguments
2655 ;; FIXME: Some tests require network access.
2656 '(#:tests? #f))
2657 (home-page "http://python-requests.org/")
2658 (synopsis "Python HTTP library")
2659 (description
2660 "Requests is a Python HTTP client library. It aims to be easier to use
2661 than Python’s urllib2 library.")
2662 (license license:asl2.0)))
2663
2664 ;; Some software requires an older version of Requests, notably Docker
2665 ;; Compose.
2666 (define-public python-requests-2.7
2667 (package (inherit python-requests)
2668 (version "2.7.0")
2669 (source (origin
2670 (method url-fetch)
2671 (uri (pypi-uri "requests" version))
2672 (sha256
2673 (base32
2674 "0gdr9dxm24amxpbyqpbh3lbwxc2i42hnqv50sigx568qssv3v2ir"))))))
2675
2676 (define-public python2-requests
2677 (package-with-python2 python-requests))
2678
2679 (define-public python-vcversioner
2680 (package
2681 (name "python-vcversioner")
2682 (version "2.16.0.0")
2683 (source
2684 (origin
2685 (method url-fetch)
2686 (uri (pypi-uri "vcversioner" version))
2687 (sha256
2688 (base32
2689 "16z10sm78jd7ca3jbkgc3q5i8a8q7y1h21q1li21yy3rlhbhrrns"))))
2690 (build-system python-build-system)
2691 (synopsis "Python library for version number discovery")
2692 (description "Vcversioner is a Python library that inspects tagging
2693 information in a variety of version control systems in order to discover
2694 version numbers.")
2695 (home-page "https://github.com/habnabit/vcversioner")
2696 (license license:isc)))
2697
2698 (define-public python2-vcversioner
2699 (package-with-python2 python-vcversioner))
2700
2701 (define-public python-jsonschema
2702 (package
2703 (name "python-jsonschema")
2704 (version "2.5.1")
2705 (source (origin
2706 (method url-fetch)
2707 (uri
2708 (string-append
2709 "https://pypi.python.org/packages/source/j/jsonschema/jsonschema-"
2710 version ".tar.gz"))
2711 (sha256
2712 (base32
2713 "0hddbqjm4jq63y8jf44nswina1crjs16l9snb6m3vvgyg31klrrn"))))
2714 (build-system python-build-system)
2715 (arguments
2716 '(#:phases
2717 (modify-phases %standard-phases
2718 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
2719 (native-inputs
2720 `(("python-nose" ,python-nose)
2721 ("python-vcversioner" ,python-vcversioner)))
2722 (home-page "https://github.com/Julian/jsonschema")
2723 (synopsis "Implementation of JSON Schema for Python")
2724 (description
2725 "Jsonschema is an implementation of JSON Schema for Python.")
2726 (license license:expat)
2727 (properties `((python2-variant . ,(delay python2-jsonschema))))))
2728
2729 (define-public python2-jsonschema
2730 (let ((jsonschema (package-with-python2
2731 (strip-python2-variant python-jsonschema))))
2732 (package (inherit jsonschema)
2733 (native-inputs
2734 `(("python2-mock" ,python2-mock)
2735 ,@(package-native-inputs jsonschema)))
2736 (propagated-inputs
2737 `(("python2-functools32" ,python2-functools32))))))
2738
2739 (define-public python-schema
2740 (package
2741 (name "python-schema")
2742 (version "0.6.6")
2743 (source
2744 (origin
2745 (method url-fetch)
2746 (uri (pypi-uri "schema" version))
2747 (sha256
2748 (base32
2749 "1lw28j9w9vxyigg7vkfkvi6ic9lgjkdnfvnxdr7pklslqvzmk2vm"))))
2750 (build-system python-build-system)
2751 (native-inputs
2752 `(("python-pytest" ,python-pytest)))
2753 (home-page "https://github.com/keleshev/schema")
2754 (synopsis "Simple data validation library")
2755 (description
2756 "@code{python-schema} is a library for validating Python data
2757 structures, such as those obtained from config-files, forms, external
2758 services or command-line parsing, converted from JSON/YAML (or
2759 something else) to Python data-types.")
2760 (license license:psfl)))
2761
2762 (define-public python2-schema
2763 (package-with-python2 python-schema))
2764
2765 (define-public python-schema-0.5
2766 (package (inherit python-schema)
2767 (version "0.5.0")
2768 (source
2769 (origin
2770 (method url-fetch)
2771 (uri (pypi-uri "schema" version))
2772 (sha256
2773 (base32
2774 "10zqvpaky51kgb8nd42bk7jwl8cn2zvayxjpdc1wwmpybj92x67s"))))))
2775
2776 (define-public python2-schema-0.5
2777 (package-with-python2 python-schema-0.5))
2778
2779 (define-public python-kitchen
2780 (package
2781 (name "python-kitchen")
2782 (version "1.2.4")
2783 (source
2784 (origin
2785 (method url-fetch)
2786 (uri (pypi-uri "kitchen" version))
2787 (sha256
2788 (base32
2789 "0ggv3p4x8jvmmzhp0xm00h6pvh1g0gmycw71rjwagnrj8n23vxrq"))))
2790 (build-system python-build-system)
2791 (propagated-inputs
2792 `(("python-chardet" ,python-chardet)))
2793 (home-page "https://github.com/fedora-infra/kitchen")
2794 (synopsis "Python API for snippets")
2795 (description "@code{kitchen} module provides a python API for all sorts of
2796 little useful snippets of code that everybody ends up writing for their projects
2797 but never seem big enough to build an independent release. Use kitchen and stop
2798 cutting and pasting that code over and over.")
2799 (license (list license:lgpl2.1+
2800 ;; subprocess.py, test_subprocess.py,
2801 ;; kitchen/pycompat25/defaultdict.py:
2802 license:psfl))))
2803
2804 (define-public python2-kitchen
2805 (package-with-python2 python-kitchen))
2806
2807 (define-public python-unidecode
2808 (package
2809 (name "python-unidecode")
2810 (version "0.04.20")
2811 (source (origin
2812 (method url-fetch)
2813 (uri (pypi-uri "Unidecode" version))
2814 (sha256
2815 (base32
2816 "1q00i8gpsq3d9r0q8wk4b290fxl0kqlsdk7iadvli45in6s1hi7d"))))
2817 (build-system python-build-system)
2818 (home-page "https://pypi.python.org/pypi/Unidecode")
2819 (synopsis "ASCII transliterations of Unicode text")
2820 (description
2821 "Unidecode provides ASCII transliterations of Unicode text. Unidecode is
2822 useful when integrating with legacy code that doesn't support Unicode, or for
2823 ease of entry of non-Roman names on a US keyboard, or when constructing ASCII
2824 machine identifiers from human-readable Unicode strings that should still be
2825 somewhat intelligeble.")
2826 (license license:gpl2+)))
2827
2828 (define-public python2-unidecode
2829 (package-with-python2 python-unidecode))
2830
2831 (define-public python-pyjwt
2832 (package
2833 (name "python-pyjwt")
2834 (version "1.4.0")
2835 (source
2836 (origin
2837 (method url-fetch)
2838 (uri (pypi-uri "PyJWT" version))
2839 (sha256
2840 (base32
2841 "1556v2jppd8mjkkj66pxb5rcazm35jq81r233mdl8hfmz9n3icp1"))))
2842 (build-system python-build-system)
2843 (native-inputs
2844 `(("python-pytest" ,python-pytest)
2845 ("python-pytest-cov" ,python-pytest-cov)
2846 ("python-pytest-runner" ,python-pytest-runner)))
2847 (home-page "https://github.com/progrium/pyjwt")
2848 (synopsis "JSON Web Token implementation in Python")
2849 (description
2850 "PyJWT is a JSON Web Token implementation written in Python.")
2851 (license license:expat)))
2852
2853 (define-public python2-pyjwt
2854 (package-with-python2 python-pyjwt))
2855
2856 (define-public python-pykka
2857 (package
2858 (name "python-pykka")
2859 (version "1.2.1")
2860 (source
2861 (origin
2862 (method url-fetch)
2863 (uri (pypi-uri "Pykka" version))
2864 (sha256
2865 (base32
2866 "049w3r0mdnnw7xv19jiq7rvls9k7xs73x05b4qs5d6z4vvmgyiz8"))))
2867 (build-system python-build-system)
2868 (native-inputs
2869 `(("python-mock" ,python-mock)
2870 ("python-nose" ,python-nose)
2871 ("python-gevent" ,python-gevent)
2872 ("python-eventlet" ,python-eventlet)))
2873 (home-page "https://www.pykka.org/")
2874 (synopsis "Pykka is a Python implementation of the actor model")
2875 (description
2876 "Pykka is a Python implementation of the actor model.
2877 The actor model introduces some simple rules to control the sharing
2878 of state and cooperation between execution units, which makes it
2879 easier to build concurrent applications.")
2880 (license license:asl2.0)))
2881
2882 (define-public python2-pykka
2883 (package-with-python2 python-pykka))
2884
2885 (define-public python-oauthlib
2886 (package
2887 (name "python-oauthlib")
2888 (version "1.0.3")
2889 (source (origin
2890 (method url-fetch)
2891 (uri (pypi-uri "oauthlib" version))
2892 (sha256
2893 (base32
2894 "1bfrj70vdjxjw74khbyh6f0dksv7p5rh2346jnlrffyacd3gwjzg"))))
2895 (build-system python-build-system)
2896 (native-inputs
2897 `(("python-nose" ,python-nose)
2898 ("python-mock" ,python-mock)
2899 ("python-cryptography" ,python-cryptography)
2900 ("python-pyjwt" ,python-pyjwt)
2901 ("python-blinker" ,python-blinker)))
2902 (home-page "https://github.com/idan/oauthlib")
2903 (synopsis "OAuth implementation for Python")
2904 (description
2905 "Oauthlib is a generic, spec-compliant, thorough implementation of the
2906 OAuth request-signing logic.")
2907 (license license:bsd-3)
2908 (properties `((python2-variant . ,(delay python2-oauthlib))))))
2909
2910 (define-public python2-oauthlib
2911 (let ((base (package-with-python2 (strip-python2-variant python-oauthlib))))
2912 (package
2913 (inherit base)
2914 (native-inputs `(("python2-unittest2" ,python2-unittest2)
2915 ,@(package-native-inputs base))))))
2916
2917 (define-public python-itsdangerous
2918 (package
2919 (name "python-itsdangerous")
2920 (version "0.24")
2921 (source
2922 (origin
2923 (method url-fetch)
2924 (uri (string-append
2925 "https://pypi.python.org/packages/source/i/itsdangerous/itsdangerous-"
2926 version ".tar.gz"))
2927 (sha256
2928 (base32
2929 "06856q6x675ly542ig0plbqcyab6ksfzijlyf1hzhgg3sgwgrcyb"))))
2930 (build-system python-build-system)
2931 (home-page "https://github.com/mitsuhiko/itsdangerous")
2932 (synopsis "Python library for passing data to/from untrusted environments")
2933 (description
2934 "Itsdangerous provides various helpers to pass trusted data to untrusted
2935 environments and back.")
2936 (license license:bsd-3)))
2937
2938 (define-public python2-itsdangerous
2939 (package-with-python2 python-itsdangerous))
2940
2941 (define-public python-pyyaml
2942 (package
2943 (name "python-pyyaml")
2944 (version "3.12")
2945 (source
2946 (origin
2947 (method url-fetch)
2948 (uri (pypi-uri "PyYAML" version))
2949 (sha256
2950 (base32
2951 "1aqjl8dk9amd4zr99n8v2qxzgmr2hdvqfma4zh7a41rj6336c9sr"))))
2952 (build-system python-build-system)
2953 (inputs
2954 `(("libyaml" ,libyaml)))
2955 (home-page "http://pyyaml.org/wiki/PyYAML")
2956 (synopsis "YAML parser and emitter for Python")
2957 (description
2958 "PyYAML is a YAML parser and emitter for Python. PyYAML features a
2959 complete YAML 1.1 parser, Unicode support, pickle support, capable extension
2960 API, and sensible error messages. PyYAML supports standard YAML tags and
2961 provides Python-specific tags that allow to represent an arbitrary Python
2962 object.")
2963 (license license:expat)))
2964
2965 (define-public python2-pyyaml
2966 (package-with-python2 python-pyyaml))
2967
2968 (define-public python-virtualenv
2969 (package
2970 (name "python-virtualenv")
2971 (version "15.0.3")
2972 (source
2973 (origin
2974 (method url-fetch)
2975 (uri (pypi-uri "virtualenv" version))
2976 (sha256
2977 (base32
2978 "07cbajzk8l05k5zhlw0b9wbf2is65bl9v6zrn2a0iyn57w6pd73d"))))
2979 (build-system python-build-system)
2980 (arguments
2981 `(#:phases
2982 (modify-phases %standard-phases
2983 (replace 'check
2984 (lambda _
2985 ;; Disable failing test. See upstream bug report
2986 ;; https://github.com/pypa/virtualenv/issues/957
2987 (substitute* "tests/test_virtualenv.py"
2988 (("skipif.*") "skipif(True, reason=\"Guix\")\n"))
2989 (zero? (system* "py.test")))))))
2990 (native-inputs
2991 `(("python-mock" ,python-mock)
2992 ("python-pytest" ,python-pytest)))
2993 (home-page "https://virtualenv.pypa.io/")
2994 (synopsis "Virtual Python environment builder")
2995 (description
2996 "Virtualenv is a tool to create isolated Python environments.")
2997 (license license:expat)))
2998
2999 (define-public python2-virtualenv
3000 (package-with-python2 python-virtualenv))
3001
3002 (define-public python-markupsafe
3003 (package
3004 (name "python-markupsafe")
3005 (version "0.23")
3006 (source
3007 (origin
3008 (method url-fetch)
3009 (uri (string-append
3010 "https://pypi.python.org/packages/source/M/MarkupSafe/MarkupSafe-"
3011 version ".tar.gz"))
3012 (sha256
3013 (base32
3014 "1hvip33wva3fnmvfp9x5klqri7hpl1hkgqmjbss18nmrb7zimv54"))))
3015 (build-system python-build-system)
3016 (home-page "https://github.com/mitsuhiko/markupsafe")
3017 (synopsis "XML/HTML/XHTML markup safe string implementation for Python")
3018 (description
3019 "Markupsafe provides an XML/HTML/XHTML markup safe string implementation
3020 for Python.")
3021 (license license:bsd-3)))
3022
3023 (define-public python2-markupsafe
3024 (package-with-python2 python-markupsafe))
3025
3026 (define-public python-jinja2
3027 (package
3028 (name "python-jinja2")
3029 (version "2.8")
3030 (source
3031 (origin
3032 (method url-fetch)
3033 (uri (pypi-uri "Jinja2" version))
3034 (sha256
3035 (base32
3036 "1x0v41lp5m1pjix3l46zx02b7lqp2hflgpnxwkywxynvi3zz47xw"))))
3037 (build-system python-build-system)
3038 (propagated-inputs
3039 `(("python-markupsafe" ,python-markupsafe)))
3040 (home-page "http://jinja.pocoo.org/")
3041 (synopsis "Python template engine")
3042 (description
3043 "Jinja2 is a small but fast and easy to use stand-alone template engine
3044 written in pure Python.")
3045 (license license:bsd-3)))
3046
3047 (define-public python2-jinja2
3048 (package-with-python2 python-jinja2))
3049
3050 (define-public python-pystache
3051 (package
3052 (name "python-pystache")
3053 (version "0.5.4")
3054 (source (origin
3055 (method url-fetch)
3056 (uri (pypi-uri "pystache" version))
3057 (sha256
3058 (base32
3059 "0nmqsfmiw4arjxqkmf9z66ml950pcdjk6aq4gin4sywmzdjw5fzp"))))
3060 (build-system python-build-system)
3061 (arguments
3062 '(#:tests? #f)) ; FIXME: Python 3 tests are failing.
3063 (home-page "http://defunkt.io/pystache/")
3064 (synopsis "Python logic-less template engine")
3065 (description
3066 "Pystache is a Python implementation of the framework agnostic,
3067 logic-free templating system Mustache.")
3068 (license license:expat)
3069 (properties `((python2-variant . ,(delay python2-pystache))))))
3070
3071 (define-public python2-pystache
3072 (package (inherit (package-with-python2
3073 (strip-python2-variant python-pystache)))
3074 (arguments
3075 `(#:python ,python-2
3076 #:phases
3077 (modify-phases %standard-phases
3078 (replace 'check
3079 (lambda _
3080 (zero? (system* "python" "test_pystache.py")))))))))
3081
3082 (define-public python-joblib
3083 (package
3084 (name "python-joblib")
3085 (version "0.10.3")
3086 (source (origin
3087 (method url-fetch)
3088 (uri (pypi-uri "joblib" version))
3089 (sha256
3090 (base32
3091 "0787k919zlfmgymprz5bzv0v1df5bbirlf3awrghmjgvkrd9dci9"))
3092 (modules '((guix build utils)))
3093 (snippet
3094 '(begin
3095 ;; Remove pre-compiled .pyc files from source.
3096 (for-each delete-file-recursively
3097 (find-files "." "__pycache__" #:directories? #t))
3098 (for-each delete-file (find-files "." "\\.pyc$"))
3099 #t))))
3100 (build-system python-build-system)
3101 (arguments
3102 `(#:phases
3103 (modify-phases %standard-phases
3104 (add-before 'check 'disable-failing-tests
3105 (lambda _
3106 ;; This numpydoc tests fails for unknown reasons
3107 (delete-file "doc/sphinxext/numpydoc/tests/test_docscrape.py")
3108 ;; This numpydoc test depends on matplotlib, which is not a
3109 ;; required input.
3110 (delete-file "doc/sphinxext/numpydoc/tests/test_plot_directive.py")
3111 ;; These tests fail to execute sys.executable
3112 (substitute* "joblib/test/test_parallel.py"
3113 (("import nose" line)
3114 (string-append "from nose.plugins.skip import SkipTest\n" line))
3115 (("def test_nested_parallel_warnings" line)
3116 (string-append "@SkipTest\n" line))
3117 (("def test_parallel_with_interactively_defined_functions" line)
3118 (string-append "@SkipTest\n" line)))
3119 #t)))))
3120 ;; Provide nose to enable tests command
3121 (native-inputs
3122 `(("python-nose" ,python-nose)
3123 ("python-sphinx" ,python-sphinx)
3124 ("python-docutils" ,python-docutils)
3125 ("python-numpydoc" ,python-numpydoc)))
3126 (home-page "http://pythonhosted.org/joblib/")
3127 (synopsis "Using Python functions as pipeline jobs")
3128 (description
3129 "Joblib is a set of tools to provide lightweight pipelining in Python.
3130 In particular, joblib offers: transparent disk-caching of the output values
3131 and lazy re-evaluation (memoize pattern), easy simple parallel computing
3132 logging and tracing of the execution.")
3133 (license license:bsd-3)))
3134
3135 (define-public python2-joblib
3136 (package-with-python2 python-joblib))
3137
3138 (define-public python-docutils
3139 (package
3140 (name "python-docutils")
3141 (version "0.13.1")
3142 (source
3143 (origin
3144 (method url-fetch)
3145 (uri (pypi-uri "docutils" version))
3146 (sha256
3147 (base32
3148 "1gkma47i609jfs7dssxn4y9vsz06qi0l5q41nws0zgkpnrghz33i"))))
3149 (build-system python-build-system)
3150 (arguments
3151 '(#:tests? #f)) ; no setup.py test command
3152 (home-page "http://docutils.sourceforge.net/")
3153 (synopsis "Python Documentation Utilities")
3154 (description
3155 "Docutils is a modular system for processing documentation into useful
3156 formats, such as HTML, XML, and LaTeX. For input Docutils supports
3157 reStructuredText.")
3158 ;; Most of the source code is public domain, but some source files are
3159 ;; licensed under the PFSL, BSD 2-clause, and GPLv3+ licenses.
3160 (license (list license:public-domain license:psfl license:bsd-2 license:gpl3+))))
3161
3162 (define-public python2-docutils
3163 (package-with-python2 python-docutils))
3164
3165 (define-public python-pygments
3166 (package
3167 (name "python-pygments")
3168 (version "2.1.3")
3169 (source
3170 (origin
3171 (method url-fetch)
3172 (uri (pypi-uri "Pygments" version))
3173 (sha256
3174 (base32
3175 "10axnp2wpjnq9g8wg53fx0c70dfxqrz498jyz8mrdx9a3flwir48"))))
3176 (build-system python-build-system)
3177 (arguments
3178 ;; FIXME: Tests require sphinx, which depends on this.
3179 '(#:tests? #f))
3180 (home-page "http://pygments.org/")
3181 (synopsis "Syntax highlighting")
3182 (description
3183 "Pygments is a syntax highlighting package written in Python.")
3184 (license license:bsd-2)))
3185
3186 (define-public python2-pygments
3187 (package-with-python2 python-pygments))
3188
3189 (define-public python-sphinxcontrib-websupport
3190 (package
3191 (name "python-sphinxcontrib-websupport")
3192 (version "1.0.1")
3193 (source (origin
3194 (method url-fetch)
3195 (uri (pypi-uri "sphinxcontrib-websupport" version))
3196 (sha256
3197 (base32
3198 "1f9f0wjpi9nhikbyaz6d19s7qvzdf1nq2g5dsh640fma4q9rd1bs"))))
3199 (build-system python-build-system)
3200 (propagated-inputs
3201 `(("python-mock" ,python-mock)
3202 ("python-pytest" ,python-pytest)
3203 ("python-xapian-bindings" ,python-xapian-bindings)))
3204 ;; Needed for running the test suite
3205 (native-inputs
3206 `(("python-six" ,python-six)
3207 ("python-jinja2" ,python-jinja2)
3208 ("python-docutils" ,python-docutils)
3209 ("python-sphinx" ,python-sphinx)
3210 ("python-sqlalchemy" ,python-sqlalchemy)
3211 ("python-whoosh" ,python-whoosh)))
3212 (home-page "http://sphinx-doc.org/")
3213 (synopsis "Sphinx API for web applications")
3214 (description "This package provides a Python API to easily integrate
3215 Sphinx documentation into your web application. It provides tools to
3216 integrate Sphinx documents in web templates and to handle searches.")
3217 (license license:bsd-3)))
3218
3219 (define-public python-sphinx
3220 (package
3221 (name "python-sphinx")
3222 (version "1.5.1")
3223 (source
3224 (origin
3225 (method url-fetch)
3226 (uri (pypi-uri "Sphinx" version))
3227 (sha256
3228 (base32
3229 "1i8p9idnli4gr0y4x67yakbdk5w6a0xjzhrg6bg51y9d1fi7fslf"))))
3230 (build-system python-build-system)
3231 (arguments
3232 `(#:phases
3233 (modify-phases %standard-phases
3234 (replace 'check
3235 (lambda _
3236 ;; Requires Internet access.
3237 (delete-file "tests/test_build_linkcheck.py")
3238 (zero? (system* "make" "test")))))))
3239 (propagated-inputs
3240 `(("python-imagesize" ,python-imagesize)
3241 ("python-sphinx-alabaster-theme"
3242 ,python-sphinx-alabaster-theme)
3243 ("python-babel" ,python-babel)
3244 ("python-snowballstemmer" ,python-snowballstemmer)
3245 ("python-docutils" ,python-docutils)
3246 ("python-jinja2" ,python-jinja2)
3247 ("python-pygments" ,python-pygments)
3248 ("python-requests" ,python-requests)
3249 ("python-six" ,python-six)))
3250 (native-inputs
3251 `(("graphviz" ,graphviz)
3252 ("python-html5lib" ,python-html5lib)
3253 ("python-mock" ,python-mock)
3254 ("python-nose" ,python-nose)))
3255 (home-page "http://sphinx-doc.org/")
3256 (synopsis "Python documentation generator")
3257 (description "Sphinx is a tool that makes it easy to create documentation
3258 for Python projects or other documents consisting of multiple reStructuredText
3259 sources.")
3260 (license license:bsd-3)
3261 (properties `((python2-variant . ,(delay python2-sphinx))))))
3262
3263 (define-public python-sphinx-1.6
3264 (package (inherit python-sphinx)
3265 (name "python-sphinx")
3266 (version "1.6.3")
3267 (source (origin
3268 (method url-fetch)
3269 (uri (pypi-uri "Sphinx" version))
3270 (sha256
3271 (base32
3272 "1rj6f3i8hmrx2qlkshi5kp5xcy98dlynwlyl05yvflj5f66dp2xg"))))
3273 (arguments
3274 `(#:phases
3275 (modify-phases %standard-phases
3276 (replace 'check
3277 (lambda _
3278 ;; Requires Internet access.
3279 (delete-file "tests/test_build_linkcheck.py")
3280 (substitute* "tests/test_build_latex.py"
3281 (("@pytest.mark.sphinx\\('latex', testroot='images'\\)")
3282 "@pytest.mark.skip()"))
3283 (zero? (system* "make" "test")))))))
3284 (propagated-inputs
3285 `(("python-sphinxcontrib-websupport" ,python-sphinxcontrib-websupport)
3286 ,@(package-propagated-inputs python-sphinx)))
3287 (native-inputs
3288 `(("python-pytest" ,python-pytest-3.0)
3289 ("imagemagick" ,imagemagick) ; for "convert"
3290 ,@(package-native-inputs python-sphinx)))
3291 (properties '())))
3292
3293 (define-public python-sphinx-1.5.3
3294 (package
3295 (inherit python-sphinx)
3296 (name "python-sphinx")
3297 (version "1.5.3")
3298 (source
3299 (origin
3300 (method url-fetch)
3301 (uri (pypi-uri "Sphinx" version))
3302 (sha256
3303 (base32
3304 "0kw1axswbvaavr8ggyf4qr6hnisnrzlbkkcdada69vk1x9xjassg"))))
3305 (native-inputs
3306 `(("python-pytest" ,python-pytest-3.0)
3307 ,@(package-native-inputs python-sphinx)))))
3308
3309 (define-public python2-sphinx
3310 (let ((base (package-with-python2 (strip-python2-variant python-sphinx))))
3311 (package
3312 (inherit base)
3313 (native-inputs `(("python2-mock" ,python2-mock)
3314 ("python2-enum34" ,python2-enum34)
3315 ,@(package-native-inputs base)))
3316 (propagated-inputs `(("python2-pytz" ,python2-pytz)
3317 ,@(package-propagated-inputs base))))))
3318
3319 (define-public python-sphinx-rtd-theme
3320 (package
3321 (name "python-sphinx-rtd-theme")
3322 (version "0.2.4")
3323 (source
3324 (origin
3325 (method url-fetch)
3326 (uri (pypi-uri "sphinx_rtd_theme" version))
3327 (sha256
3328 (base32
3329 "05rlhjzdyapr2w74jjs7mrm8hi69qskcr5vya9f9drpsys7lpxrd"))))
3330 (build-system python-build-system)
3331 (arguments '(#:tests? #f)) ; No tests.
3332 (propagated-inputs
3333 `(("python-sphinx" ,python-sphinx)))
3334 (home-page "https://github.com/snide/sphinx_rtd_theme/")
3335 (synopsis "ReadTheDocs.org theme for Sphinx")
3336 (description "A theme for Sphinx used by ReadTheDocs.org.")
3337 (license license:expat)))
3338
3339 (define-public python2-sphinx-rtd-theme
3340 (package-with-python2 python-sphinx-rtd-theme))
3341
3342 (define-public python-rst.linker
3343 (package
3344 (name "python-rst.linker")
3345 (version "1.7")
3346 (source
3347 (origin
3348 (method url-fetch)
3349 (uri (pypi-uri "rst.linker" version))
3350 (sha256
3351 (base32
3352 "0bh4lnj2p1nh0wf5pgxgfbrp27xhb1rinahkb5j7s3qprq6qn0sr"))))
3353 (build-system python-build-system)
3354 (propagated-inputs
3355 `(("python-dateutil" ,python-dateutil)
3356 ("python-six" ,python-six)))
3357 (native-inputs
3358 `(("python-setuptools-scm" ,python-setuptools-scm)))
3359 ;; Test would require path.py, which would introduce a cyclic dependence.
3360 (arguments `(#:tests? #f))
3361 ;; Note: As of version 1.7 the documentation is not worth building.
3362 (home-page "https://github.com/jaraco/rst.linker")
3363 (synopsis "Sphinx plugin to add links and timestamps")
3364 (description "rst.linker allows to automatically replace text by a
3365 reStructuredText external reference or timestamps. It's primary purpose is to
3366 augment the changelog, but it can be used for other documents, too.")
3367 (license license:expat)))
3368
3369 (define-public python2-rst.linker
3370 (package-with-python2 python-rst.linker))
3371
3372 (define-public python-feedgenerator
3373 (package
3374 (name "python-feedgenerator")
3375 (version "1.9")
3376 (source
3377 (origin
3378 (method url-fetch)
3379 (uri (pypi-uri "feedgenerator" version))
3380 (sha256
3381 (base32
3382 "01mirwkm7xfx539hmvj7g9da1j51gw5lsx74dr0glizskjm5vq2s"))
3383 (modules '((guix build utils)))
3384 (snippet
3385 '(begin
3386 ;; Remove pre-compiled .pyc files from source.
3387 (for-each delete-file-recursively
3388 (find-files "." "__pycache__" #:directories? #t))
3389 (for-each delete-file (find-files "." "\\.pyc$"))
3390 #t))))
3391 (build-system python-build-system)
3392 (propagated-inputs
3393 `(("python-pytz" ,python-pytz)
3394 ("python-six" ,python-six)))
3395 (home-page "https://github.com/getpelican/feedgenerator")
3396 (synopsis
3397 "Standalone version of Django's Atom/RSS feed generator")
3398 (description
3399 "Feedgenerator-py3k is a standalone version of Django's feedgenerator,
3400 which can produce feeds in RSS 2.0, RSS 0.91, and Atom formats.")
3401 (license license:bsd-3)))
3402
3403 (define-public python2-feedgenerator
3404 (package-with-python2 python-feedgenerator))
3405
3406 (define-public python-blinker
3407 (package
3408 (name "python-blinker")
3409 (version "1.4")
3410 (source
3411 (origin
3412 (method url-fetch)
3413 (uri (pypi-uri "blinker" version))
3414 (sha256
3415 (base32
3416 "1dpq0vb01p36jjwbhhd08ylvrnyvcc82yxx3mwjx6awrycjyw6j7"))))
3417 (build-system python-build-system)
3418 (home-page "http://pythonhosted.org/blinker/")
3419 (synopsis "Fast, simple object-to-object and broadcast signaling")
3420 (description
3421 "Blinker provides a fast dispatching system that allows any number of
3422 interested parties to subscribe to events, or \"signals\".")
3423 (license license:expat)))
3424
3425 (define-public python2-blinker
3426 (package-with-python2 python-blinker))
3427
3428 (define-public pelican
3429 (package
3430 (name "pelican")
3431 (version "3.6.3")
3432 (source
3433 (origin
3434 (method url-fetch)
3435 (uri (pypi-uri "pelican" version))
3436 (sha256
3437 (base32
3438 "1hn94rb4q3zmcq16in055xikal4dba5hfx3zznq7warllcgc9f8k"))))
3439 (build-system python-build-system)
3440 (propagated-inputs
3441 `(("python-feedgenerator" ,python-feedgenerator)
3442 ("python-jinja2" ,python-jinja2)
3443 ("python-pygments" ,python-pygments)
3444 ("python-docutils" ,python-docutils)
3445 ("python-pytz" ,python-pytz)
3446 ("python-blinker" ,python-blinker)
3447 ("python-unidecode" ,python-unidecode)
3448 ("python-six" ,python-six)
3449 ("python-dateutil" ,python-dateutil)))
3450 (home-page "http://getpelican.com/")
3451 (arguments
3452 `(;; XXX Requires a lot more packages to do unit tests :P
3453 #:tests? #f
3454 #:phases (modify-phases %standard-phases
3455 (add-before
3456 'install 'adjust-requires
3457 ;; Since feedgenerator is installed from git, it doesn't
3458 ;; conform to the version requirements.
3459 ;;
3460 ;; We *do have* "feedgenerator >= 1.6", but strip off the
3461 ;; version requirement so setuptools doesn't get confused.
3462 (lambda _
3463 (substitute* "setup.py"
3464 (("['\"]feedgenerator.*?['\"]")
3465 "'feedgenerator'")))))))
3466 (synopsis "Python-based static site publishing system")
3467 (description
3468 "Pelican is a tool to generate a static blog from reStructuredText,
3469 Markdown input files, and more. Pelican uses Jinja2 for templating
3470 and is very extensible.")
3471 (license license:agpl3+)))
3472
3473 (define-public python-scikit-learn
3474 (package
3475 (name "python-scikit-learn")
3476 (version "0.18.1")
3477 (source
3478 (origin
3479 (method url-fetch)
3480 (uri (string-append
3481 "https://github.com/scikit-learn/scikit-learn/archive/"
3482 version ".tar.gz"))
3483 (file-name (string-append name "-" version ".tar.gz"))
3484 (sha256
3485 (base32
3486 "1hwswckdmd27f7k1jvwdc0m4mqrgxl2s245yq1scq34v124bjqgq"))))
3487 (build-system python-build-system)
3488 (arguments
3489 `(#:phases
3490 (modify-phases %standard-phases
3491 (delete 'check)
3492 (add-after 'install 'check
3493 ;; Running tests from the source directory requires
3494 ;; an "inplace" build with paths relative to CWD.
3495 ;; http://scikit-learn.org/stable/developers/advanced_installation.html#testing
3496 ;; Use the installed version instead.
3497 (lambda* (#:key inputs outputs #:allow-other-keys)
3498 (add-installed-pythonpath inputs outputs)
3499 ;; some tests require access to "$HOME"
3500 (setenv "HOME" "/tmp")
3501 ;; Step out of the source directory just to be sure.
3502 (chdir "..")
3503 (zero? (system* "nosetests" "-v" "sklearn")))))))
3504 (inputs
3505 `(("openblas" ,openblas)))
3506 (native-inputs
3507 `(("python-nose" ,python-nose)
3508 ("python-cython" ,python-cython)))
3509 (propagated-inputs
3510 `(("python-numpy" ,python-numpy)
3511 ("python-scipy" ,python-scipy)))
3512 (home-page "http://scikit-learn.org/")
3513 (synopsis "Machine Learning in Python")
3514 (description
3515 "Scikit-learn provides simple and efficient tools for data
3516 mining and data analysis.")
3517 (license license:bsd-3)))
3518
3519 (define-public python2-scikit-learn
3520 (package-with-python2 python-scikit-learn))
3521
3522 (define-public python-scikit-image
3523 (package
3524 (name "python-scikit-image")
3525 (version "0.11.3")
3526 (source
3527 (origin
3528 (method url-fetch)
3529 (uri (string-append
3530 "https://pypi.python.org/packages/source/s/scikit-image/scikit-image-"
3531 version ".tar.gz"))
3532 (sha256
3533 (base32 "0jz416fqvpahqyffw8plmszzfj669w8wvf3y9clnr5lr6a7md3kn"))))
3534 (build-system python-build-system)
3535 (arguments
3536 ;; TODO: Some tests require running X11 server. Disable them?
3537 '(#:tests? #f))
3538 ;; See DEPENDS.txt for the list of build and run time requiremnts
3539 (propagated-inputs
3540 `(("python-matplotlib" ,python-matplotlib)
3541 ("python-networkx" ,python-networkx)
3542 ("python-scipy" ,python-scipy)
3543 ("python-pillow" ,python-pillow)))
3544 (native-inputs
3545 `(("python-numpy" ,python-numpy)
3546 ("python-cython" ,python-cython)
3547 ("python-six" ,python-six)))
3548 (home-page "http://scikit-image.org/")
3549 (synopsis "Image processing in Python")
3550 (description
3551 "Scikit-image is a collection of algorithms for image processing.")
3552 (license license:bsd-3)))
3553
3554 (define-public python2-scikit-image
3555 (package-with-python2 python-scikit-image))
3556
3557 (define-public python-redis
3558 (package
3559 (name "python-redis")
3560 (version "2.10.5")
3561 (source
3562 (origin
3563 (method url-fetch)
3564 (uri (pypi-uri "redis" version))
3565 (sha256
3566 (base32 "0csmrkxb29x7xs9b51zplwkkq2hwnbh9jns1g85dykn5rxmaxysx"))))
3567 (build-system python-build-system)
3568 ;; Tests require a running Redis server
3569 (arguments '(#:tests? #f))
3570 ;; As long as we are not running test, we do not need this input :-)
3571 ;;(native-inputs
3572 ;; `(("python-pytest" ,python-pytest)))
3573 (home-page "https://github.com/andymccurdy/redis-py")
3574 (synopsis "Redis Python client")
3575 (description
3576 "This package provides a Python interface to the Redis key-value store.")
3577 (license license:expat)))
3578
3579 (define-public python2-redis
3580 (package-with-python2 python-redis))
3581
3582 (define-public python-rq
3583 (package
3584 (name "python-rq")
3585 (version "0.7.1")
3586 (source
3587 (origin
3588 (method url-fetch)
3589 (uri (pypi-uri "rq" version))
3590 (sha256
3591 (base32 "0gaq5pnh0zy46r8jvygi0ifbvz3pq6i7xla78ijcgjw0x77qzsdh"))))
3592 (build-system python-build-system)
3593 (propagated-inputs
3594 `(("python-click" ,python-click)
3595 ("python-redis" ,python-redis)))
3596 (home-page "http://python-rq.org/")
3597 (synopsis "Simple job queues for Python")
3598 (description
3599 "RQ (Redis Queue) is a simple Python library for queueing jobs and
3600 processing them in the background with workers. It is backed by Redis and it
3601 is designed to have a low barrier to entry.")
3602 (license license:bsd-2)))
3603
3604 (define-public python2-rq
3605 (package-with-python2 python-rq))
3606
3607 (define-public python-cython
3608 (package
3609 (name "python-cython")
3610 (version "0.25.2")
3611 (source
3612 (origin
3613 (method url-fetch)
3614 (uri (pypi-uri "Cython" version))
3615 (patches (search-patches "python-cython-fix-tests-32bit.patch"))
3616 (sha256
3617 (base32
3618 "01h3lrf6d98j07iakifi81qjszh6faa37ibx7ylva1vsqbwx2hgi"))))
3619 (build-system python-build-system)
3620 ;; we need the full python package and not just the python-wrapper
3621 ;; because we need libpython3.3m.so
3622 (inputs
3623 `(("python" ,python)))
3624 (arguments
3625 `(#:phases
3626 (modify-phases %standard-phases
3627 (add-before 'check 'set-HOME
3628 ;; some tests require access to "$HOME/.cython"
3629 (lambda _ (setenv "HOME" "/tmp")))
3630 (replace 'check
3631 (lambda _ (zero? (system* "python" "runtests.py" "-vv")))))))
3632 (home-page "http://cython.org/")
3633 (synopsis "C extensions for Python")
3634 (description "Cython is an optimising static compiler for both the Python
3635 programming language and the extended Cython programming language. It makes
3636 writing C extensions for Python as easy as Python itself.")
3637 (license license:asl2.0)
3638 (properties `((python2-variant . ,(delay python2-cython))))))
3639
3640 (define-public python2-cython
3641 (package (inherit (package-with-python2
3642 (strip-python2-variant python-cython)))
3643 (name "python2-cython")
3644 (inputs
3645 `(("python-2" ,python-2))))) ; this is not automatically changed
3646
3647 ;; The RPython toolchain currently does not support Python 3.
3648 (define-public python2-rpython
3649 (package
3650 (name "python2-rpython")
3651 (version "0.1.4")
3652 (source
3653 (origin
3654 (method url-fetch)
3655 (uri (pypi-uri "rpython" version))
3656 (sha256
3657 (base32
3658 "07pps06fq4c4wmi5ii0sgh9zgwniz5y7frqhm28g3a154l163fxc"))))
3659 (build-system python-build-system)
3660 (arguments `(#:python ,python-2))
3661 (native-inputs
3662 `(("python2-pytest" ,python2-pytest))) ; needed for running tests
3663 (home-page "https://rpython.readthedocs.org")
3664 (synopsis "Framework for implementing interpreters and virtual machines")
3665 (description "RPython is a translation and support framework for
3666 producing implementations of dynamic languages, emphasizing a clean separation
3667 between language specification and implementation aspects.")
3668 (license license:expat)))
3669
3670 (define-public python-numpy
3671 (package
3672 (name "python-numpy")
3673 (version "1.12.0")
3674 (source
3675 (origin
3676 (method url-fetch)
3677 (uri (string-append
3678 "https://github.com/numpy/numpy/archive/v" version ".tar.gz"))
3679 (file-name (string-append name "-" version ".tar.gz"))
3680 (sha256
3681 (base32
3682 "025d4j4aakcp8w5i5diqh812cbbjgac7jszx1j56ivrbi1i8vv7d"))))
3683 (build-system python-build-system)
3684 (inputs
3685 `(("openblas" ,openblas)
3686 ("lapack" ,lapack)))
3687 (native-inputs
3688 `(("python-cython" ,python-cython)
3689 ("python-nose" ,python-nose)
3690 ("gfortran" ,gfortran)))
3691 (arguments
3692 `(#:phases
3693 (modify-phases %standard-phases
3694 (add-before 'build 'set-environment-variables
3695 (lambda* (#:key inputs #:allow-other-keys)
3696 (call-with-output-file "site.cfg"
3697 (lambda (port)
3698 (format port
3699 "[openblas]
3700 libraries = openblas
3701 library_dirs = ~a/lib
3702 include_dirs = ~a/include
3703
3704 # backslash-n to make emacs happy
3705 \n[lapack]
3706 lapack_libs = lapack
3707 library_dirs = ~a/lib
3708 include_dirs = ~a/include
3709 "
3710 (assoc-ref inputs "openblas")
3711 (assoc-ref inputs "openblas")
3712 (assoc-ref inputs "lapack")
3713 (assoc-ref inputs "lapack"))))
3714 ;; Use "gcc" executable, not "cc".
3715 (substitute* "numpy/distutils/system_info.py"
3716 (("c = distutils\\.ccompiler\\.new_compiler\\(\\)")
3717 "c = distutils.ccompiler.new_compiler(); c.set_executables(compiler='gcc',compiler_so='gcc',linker_exe='gcc',linker_so='gcc -shared')"))
3718 #t))
3719 ;; Tests can only be run after the library has been installed and not
3720 ;; within the source directory.
3721 (delete 'check)
3722 (add-after 'install 'check
3723 (lambda* (#:key outputs inputs #:allow-other-keys)
3724 ;; Make installed package available for running the tests
3725 (add-installed-pythonpath inputs outputs)
3726 (with-directory-excursion "/tmp"
3727 (zero? (system* "python" "-c"
3728 "import numpy; numpy.test(verbose=2)"))))))))
3729 (home-page "http://www.numpy.org/")
3730 (synopsis "Fundamental package for scientific computing with Python")
3731 (description "NumPy is the fundamental package for scientific computing
3732 with Python. It contains among other things: a powerful N-dimensional array
3733 object, sophisticated (broadcasting) functions, tools for integrating C/C++
3734 and Fortran code, useful linear algebra, Fourier transform, and random number
3735 capabilities.")
3736 (license license:bsd-3)))
3737
3738 (define-public python2-numpy
3739 (package-with-python2 python-numpy))
3740
3741 (define-public python-munch
3742 (package
3743 (name "python-munch")
3744 (version "2.0.4")
3745 (source
3746 (origin
3747 (method url-fetch)
3748 (uri (pypi-uri "munch" version))
3749 (sha256
3750 (base32
3751 "1cmqg91xnqx8gvnh4pmp0bfl1dfcm65d5p9mg73zz8pkjhx6h80l"))))
3752 (build-system python-build-system)
3753 (home-page "https://github.com/Infinidat/munch")
3754 (synopsis "Dot-accessible dictionary")
3755 (description "Munch is a dot-accessible dictionary similar to JavaScript
3756 objects.")
3757 (license license:expat)))
3758
3759 (define-public python2-munch
3760 (package-with-python2 python-munch))
3761
3762 (define-public python2-fastlmm
3763 (package
3764 (name "python2-fastlmm")
3765 (version "0.2.21")
3766 (source
3767 (origin
3768 (method url-fetch)
3769 (uri (pypi-uri "fastlmm" version ".zip"))
3770 (sha256
3771 (base32
3772 "1q8c34rpmwkfy3r4d5172pzdkpfryj561897z9r3x22gq7813x1m"))))
3773 (build-system python-build-system)
3774 (arguments
3775 `(#:python ,python-2)) ; only Python 2.7 is supported
3776 (propagated-inputs
3777 `(("python2-numpy" ,python2-numpy)
3778 ("python2-scipy" ,python2-scipy)
3779 ("python2-matplotlib" ,python2-matplotlib)
3780 ("python2-pandas" ,python2-pandas)
3781 ("python2-scikit-learn" ,python2-scikit-learn)
3782 ("python2-pysnptools" ,python2-pysnptools)))
3783 (native-inputs
3784 `(("unzip" ,unzip)
3785 ("python2-cython" ,python2-cython)
3786 ("python2-mock" ,python2-mock)
3787 ("python2-nose" ,python2-nose)))
3788 (home-page "http://research.microsoft.com/en-us/um/redmond/projects/mscompbio/fastlmm/")
3789 (synopsis "Perform genome-wide association studies on large data sets")
3790 (description
3791 "FaST-LMM, which stands for Factored Spectrally Transformed Linear Mixed
3792 Models, is a program for performing both single-SNP and SNP-set genome-wide
3793 association studies (GWAS) on extremely large data sets.")
3794 (license license:asl2.0)))
3795
3796 (define-public python-numpy-documentation
3797 (package
3798 (name "python-numpy-documentation")
3799 (version (package-version python-numpy))
3800 (source (package-source python-numpy))
3801 (build-system python-build-system)
3802 (native-inputs
3803 `(("python-matplotlib" ,python-matplotlib)
3804 ("python-numpy" ,python-numpy)
3805 ("pkg-config" ,pkg-config)
3806 ("python-sphinx" ,python-sphinx)
3807 ("python-numpydoc" ,python-numpydoc)
3808 ("texlive" ,(texlive-union (list texlive-fonts-amsfonts
3809 texlive-fonts-ec
3810 texlive-generic-ifxetex
3811 texlive-generic-pdftex
3812 texlive-latex-amsfonts
3813 texlive-latex-capt-of
3814 texlive-latex-cmap
3815 texlive-latex-environ
3816 texlive-latex-eqparbox
3817 texlive-latex-etoolbox
3818 texlive-latex-expdlist
3819 texlive-latex-fancyhdr
3820 texlive-latex-fancyvrb
3821 texlive-latex-fncychap
3822 texlive-latex-float
3823 texlive-latex-framed
3824 texlive-latex-geometry
3825 texlive-latex-graphics
3826 texlive-latex-hyperref
3827 texlive-latex-mdwtools
3828 texlive-latex-multirow
3829 texlive-latex-oberdiek
3830 texlive-latex-parskip
3831 texlive-latex-preview
3832 texlive-latex-tabulary
3833 texlive-latex-threeparttable
3834 texlive-latex-titlesec
3835 texlive-latex-trimspaces
3836 texlive-latex-ucs
3837 texlive-latex-upquote
3838 texlive-latex-url
3839 texlive-latex-varwidth
3840 texlive-latex-wrapfig)))
3841 ("texinfo" ,texinfo)
3842 ("perl" ,perl)
3843 ("scipy-sphinx-theme"
3844 ,(origin ; The build script expects scipy-sphinx-theme as a git submodule
3845 (method git-fetch)
3846 (uri (git-reference
3847 (url "https://github.com/scipy/scipy-sphinx-theme.git")
3848 (commit "c466764e2231ba132c09826b5b138fffa1cfcec3")))
3849 (sha256
3850 (base32
3851 "0q2y87clwlsgc7wvlsn9pzyssybcq10plwhq2w1ydykfsyyqbmkl"))))
3852 ,@(package-native-inputs python-numpy)))
3853 (arguments
3854 `(#:tests? #f ; we're only generating the documentation
3855 #:phases
3856 (modify-phases %standard-phases
3857 (delete 'build)
3858 (replace 'install
3859 (lambda* (#:key inputs outputs #:allow-other-keys)
3860 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
3861 (doc (string-append
3862 data "/doc/" ,name "-"
3863 ,(package-version python-numpy)))
3864 (info-reader (string-append data "/info"))
3865 (html (string-append doc "/html"))
3866 (scipy-sphinx-theme "scipy-sphinx-theme")
3867 (sphinx-theme-checkout (assoc-ref inputs scipy-sphinx-theme))
3868 (pyver ,(string-append "PYVER=")))
3869
3870 ;; FIXME: this is needed to for texlive-union to generate
3871 ;; fonts, which are not found.
3872 (setenv "HOME" "/tmp")
3873
3874 (with-directory-excursion "doc"
3875 (copy-recursively sphinx-theme-checkout scipy-sphinx-theme)
3876 (mkdir-p html)
3877 (system* "make" "html" pyver)
3878 (system* "make" "latex" "PAPER=a4" pyver)
3879 (system* "make" "-C" "build/latex"
3880 "all-pdf" "PAPER=a4" pyver)
3881 ;; FIXME: Generation of the info file fails.
3882 ;; (system* "make" "info" pyver)
3883 ;; (mkdir-p info)
3884 ;; (copy-file "build/texinfo/numpy.info"
3885 ;; (string-append info "/numpy.info"))
3886 (for-each (lambda (file)
3887 (copy-file (string-append "build/latex" file)
3888 (string-append doc file)))
3889 '("/numpy-ref.pdf" "/numpy-user.pdf"))
3890 (with-directory-excursion "build/html"
3891 (for-each (lambda (file)
3892 (let* ((dir (dirname file))
3893 (tgt-dir (string-append html "/" dir)))
3894 (unless (equal? "." dir)
3895 (mkdir-p tgt-dir))
3896 (install-file file html)))
3897 (find-files "." ".*")))))
3898 #t)))))
3899 (home-page (package-home-page python-numpy))
3900 (synopsis "Documentation for the python-numpy package")
3901 (description (package-description python-numpy))
3902 (license (package-license python-numpy))))
3903
3904 (define-public python2-numpy-documentation
3905 (let ((numpy-documentation (package-with-python2 python-numpy-documentation)))
3906 (package
3907 (inherit numpy-documentation)
3908 (native-inputs `(("python2-functools32" ,python2-functools32)
3909 ,@(package-native-inputs numpy-documentation))))))
3910
3911 (define-public python-pygit2
3912 (package
3913 (name "python-pygit2")
3914 (version "0.25.0")
3915 (source
3916 (origin
3917 (method url-fetch)
3918 (uri (pypi-uri "pygit2" version))
3919 (sha256
3920 (base32
3921 "0wf5rp0fvrw7j3j18dvwjq6xqlbm611wd55aphrfpps0v1gxh3ny"))
3922 (patches
3923 (search-patches "python-pygit2-disable-network-tests.patch"))))
3924 (build-system python-build-system)
3925 (propagated-inputs
3926 `(("python-six" ,python-six)
3927 ("python-cffi" ,python-cffi)
3928 ("libgit2" ,libgit2)
3929 ("python-tox" ,python-tox)))
3930 (home-page "https://github.com/libgit2/pygit2")
3931 (synopsis "Python bindings for libgit2")
3932 (description "Pygit2 is a set of Python bindings to the libgit2 shared
3933 library, libgit2 implements Git plumbing.")
3934 ;; GPL2.0 only, with linking exception.
3935 (license license:gpl2)))
3936
3937 (define-public python2-pygit2
3938 (package-with-python2 python-pygit2))
3939
3940 (define-public python-pyparsing
3941 (package
3942 (name "python-pyparsing")
3943 (version "2.2.0")
3944 (source
3945 (origin
3946 (method url-fetch)
3947 (uri (string-append "mirror://sourceforge/pyparsing/pyparsing"
3948 "/pyparsing-" version
3949 "/pyparsing-" version ".tar.gz"))
3950 (sha256
3951 (base32
3952 "016b9gh606aa44sq92jslm89bg874ia0yyiyb643fa6dgbsbqch8"))))
3953 (build-system python-build-system)
3954 (outputs '("out" "doc"))
3955 (arguments
3956 `(#:tests? #f ; no test target
3957 #:phases
3958 (modify-phases %standard-phases
3959 (add-after 'install 'install-doc
3960 (lambda* (#:key outputs #:allow-other-keys)
3961 (let* ((doc (string-append (assoc-ref outputs "doc")
3962 "/share/doc/" ,name "-" ,version))
3963 (html-doc (string-append doc "/html"))
3964 (examples (string-append doc "/examples")))
3965 (mkdir-p html-doc)
3966 (mkdir-p examples)
3967 (for-each
3968 (lambda (dir tgt)
3969 (map (lambda (file)
3970 (install-file file tgt))
3971 (find-files dir ".*")))
3972 (list "docs" "htmldoc" "examples")
3973 (list doc html-doc examples))
3974 #t))))))
3975 (home-page "http://pyparsing.wikispaces.com")
3976 (synopsis "Python parsing class library")
3977 (description
3978 "The pyparsing module is an alternative approach to creating and
3979 executing simple grammars, vs. the traditional lex/yacc approach, or the use
3980 of regular expressions. The pyparsing module provides a library of classes
3981 that client code uses to construct the grammar directly in Python code.")
3982 (license license:expat)))
3983
3984 (define-public python2-pyparsing
3985 (package-with-python2 python-pyparsing))
3986
3987 (define-public python-numpydoc
3988 (package
3989 (name "python-numpydoc")
3990 (version "0.5")
3991 (source
3992 (origin
3993 (method url-fetch)
3994 (uri (string-append
3995 "https://pypi.python.org/packages/source/n/numpydoc/numpydoc-"
3996 version ".tar.gz"))
3997 (sha256
3998 (base32
3999 "0d4dnifaxkll50jx6czj05y8cb4ny60njd2wz299sj2jxfy51w4k"))
4000 (modules '((guix build utils)))
4001 (snippet
4002 '(begin
4003 ;; Drop a test requiring matplotlib, which we cannot add as an
4004 ;; input since it would create a circular dependency: Extend the
4005 ;; test for Python 3, where it is already dropped, to Python 2.
4006 (substitute* "numpydoc/tests/test_plot_directive.py"
4007 (("3") "2"))))))
4008 (build-system python-build-system)
4009 (propagated-inputs
4010 `(("python-sphinx" ,python-sphinx)))
4011 (native-inputs
4012 `(("python-nose" ,python-nose)))
4013 (home-page "https://pypi.python.org/pypi/numpydoc")
4014 (synopsis
4015 "Numpy's Sphinx extensions")
4016 (description
4017 "Sphinx extension to support docstrings in Numpy format.")
4018 (license license:bsd-2)))
4019
4020 (define-public python2-numpydoc
4021 (package-with-python2 python-numpydoc))
4022
4023 (define-public python-numexpr
4024 (package
4025 (name "python-numexpr")
4026 (version "2.6.1")
4027 (source
4028 (origin
4029 (method url-fetch)
4030 (uri (pypi-uri "numexpr" version))
4031 (sha256
4032 (base32
4033 "01lsja72m32z0i5p8rwxbfyzk4mplh72k2a140nwh8vv4wpyfbnv"))))
4034 (build-system python-build-system)
4035 (arguments `(#:tests? #f)) ; no tests included
4036 (propagated-inputs
4037 `(("python-numpy" ,python-numpy)))
4038 (home-page "https://github.com/pydata/numexpr")
4039 (synopsis "Fast numerical expression evaluator for NumPy")
4040 (description
4041 "Numexpr is a fast numerical expression evaluator for NumPy. With it,
4042 expressions that operate on arrays are accelerated and use less memory than
4043 doing the same calculation in Python. In addition, its multi-threaded
4044 capabilities can make use of all your cores, which may accelerate
4045 computations, most specially if they are not memory-bounded (e.g. those using
4046 transcendental functions).")
4047 (license license:expat)))
4048
4049 (define-public python2-numexpr
4050 (package-with-python2 python-numexpr))
4051
4052 (define-public python-cycler
4053 (package
4054 (name "python-cycler")
4055 (version "0.10.0")
4056 (source (origin
4057 (method url-fetch)
4058 (uri (pypi-uri "cycler" version))
4059 (sha256
4060 (base32
4061 "1n69n23fak1gjxlrbhqisi2b9pv3ckrfj98llx3p53953082syyd"))))
4062 (build-system python-build-system)
4063 (arguments
4064 ;; XXX: The current version requires 'coveralls' which we don't have.
4065 ;; Enable this for the next release which uses 'python-pytest'.
4066 '(#:tests? #f))
4067 (propagated-inputs
4068 `(("python-six" ,python-six)))
4069 (home-page "http://matplotlib.org/cycler/")
4070 (synopsis "Composable keyword argument iterator")
4071 (description
4072 "When using @code{matplotlib} and plotting more than one line, it is
4073 common to want to be able to want to be able to cycle over one or more artist
4074 styles; but the plotting logic can quickly become involved.
4075 To address this and enable easy cycling over arbitrary @code{kwargs}, the
4076 @code{Cycler} class was developed.")
4077 (license license:bsd-3)))
4078
4079 (define-public python2-cycler
4080 (package-with-python2 python-cycler))
4081
4082 (define-public python-colorspacious
4083 (package
4084 (name "python-colorspacious")
4085 (version "1.1.0")
4086 (source
4087 (origin
4088 (method url-fetch)
4089 (uri (string-append "https://github.com/njsmith/colorspacious/archive/v"
4090 version ".tar.gz"))
4091 (file-name (string-append name "-" version))
4092 (sha256
4093 (base32 "1vflh5jm32qb0skza2i8pjacv09w6gq84fqpp2nj77s0rbmzgr4k"))))
4094 (build-system python-build-system)
4095 (propagated-inputs
4096 `(("python-numpy" ,python-numpy)))
4097 (native-inputs
4098 `(("python-nose" ,python-nose)))
4099 (arguments
4100 `(#:phases
4101 (modify-phases %standard-phases
4102 (replace 'check
4103 (lambda _
4104 (zero? (system* "nosetests" "--all-modules" "-v" "colorspacious")))))))
4105 (home-page "https://github.com/njsmith/colorspacious")
4106 (synopsis "Python library for colorspace conversions")
4107 (description "@code{colorspacious} is a Python library that lets you
4108 convert between colorspaces like sRGB, XYZ, CIEL*a*b*, CIECAM02, CAM02-UCS, etc.")
4109 (license license:expat)))
4110
4111 (define-public python2-colorspacious
4112 (package-with-python2 python-colorspacious))
4113
4114 (define-public python-matplotlib
4115 (package
4116 (name "python-matplotlib")
4117 (version "2.0.2")
4118 (source
4119 (origin
4120 (method url-fetch)
4121 (uri (pypi-uri "matplotlib" version))
4122 (sha256
4123 (base32
4124 "1w8z2a1l7s72p1byfz7g03wqhygqxi8w82619dqb3a1lm97w9yqg"))))
4125 (build-system python-build-system)
4126 (propagated-inputs ; the following packages are all needed at run time
4127 `(("python-cycler" ,python-cycler)
4128 ("python-pyparsing" ,python-pyparsing)
4129 ("python-pygobject" ,python-pygobject)
4130 ("gobject-introspection" ,gobject-introspection)
4131 ("python-tkinter" ,python "tk")
4132 ("python-dateutil" ,python-dateutil)
4133 ("python-numpy" ,python-numpy)
4134 ("python-pillow" ,python-pillow)
4135 ("python-pytz" ,python-pytz)
4136 ("python-six" ,python-six)
4137 ;; The 'gtk+' package (and 'gdk-pixbuf', 'atk' and 'pango' propagated
4138 ;; from 'gtk+') provides the required 'typelib' files used by
4139 ;; 'gobject-introspection'. The location of these files is set with the
4140 ;; help of the environment variable GI_TYPELIB_PATH. At build time this
4141 ;; is done automatically by a 'native-search-path' procedure. However,
4142 ;; at run-time the user must set this variable as follows:
4143 ;;
4144 ;; export GI_TYPELIB_PATH=~/.guix-profile/lib/girepository-1.0
4145 ("gtk+" ,gtk+)
4146 ;; From version 1.4.0 'matplotlib' makes use of 'cairocffi' instead of
4147 ;; 'pycairo'. However, 'pygobject' makes use of a 'pycairo' 'context'
4148 ;; object. For this reason we need to import both libraries.
4149 ;; https://pythonhosted.org/cairocffi/cffi_api.html#converting-pycairo
4150 ("python-pycairo" ,python-pycairo)
4151 ("python-cairocffi" ,python-cairocffi)))
4152 (inputs
4153 `(("libpng" ,libpng)
4154 ("imagemagick" ,imagemagick)
4155 ("freetype" ,freetype)
4156 ("cairo" ,cairo)
4157 ("glib" ,glib)
4158 ;; FIXME: Add backends when available.
4159 ;("python-wxpython" ,python-wxpython)
4160 ("python-pyqt" ,python-pyqt)
4161 ("tcl" ,tcl)
4162 ("tk" ,tk)))
4163 (native-inputs
4164 `(("pkg-config" ,pkg-config)
4165 ("python-nose" ,python-nose)
4166 ("python-mock" ,python-mock)))
4167 (arguments
4168 `(#:phases
4169 (modify-phases %standard-phases
4170 (add-before 'build 'configure-environment
4171 (lambda* (#:key outputs inputs #:allow-other-keys)
4172 (let ((cairo (assoc-ref inputs "cairo"))
4173 (gtk+ (assoc-ref inputs "gtk+")))
4174 ;; Setting these directories in the 'basedirlist' of 'setup.cfg'
4175 ;; has not effect.
4176 (setenv "LD_LIBRARY_PATH"
4177 (string-append cairo "/lib:" gtk+ "/lib"))
4178 (setenv "HOME" (getcwd))
4179 (call-with-output-file "setup.cfg"
4180 (lambda (port)
4181 (format port "[directories]~%
4182 basedirlist = ~a,~a~%
4183 [rc_options]~%
4184 backend = TkAgg~%"
4185 (assoc-ref inputs "tcl")
4186 (assoc-ref inputs "tk")))))
4187 #t)))))
4188 (home-page "http://matplotlib.org")
4189 (synopsis "2D plotting library for Python")
4190 (description
4191 "Matplotlib is a Python 2D plotting library which produces publication
4192 quality figures in a variety of hardcopy formats and interactive environments
4193 across platforms. Matplotlib can be used in Python scripts, the python and
4194 ipython shell, web application servers, and six graphical user interface
4195 toolkits.")
4196 (license license:psfl)
4197 (properties `((python2-variant . ,(delay python2-matplotlib))))))
4198
4199 (define-public python2-matplotlib
4200 (let ((matplotlib (package-with-python2
4201 (strip-python2-variant python-matplotlib))))
4202 (package (inherit matplotlib)
4203 ;; Make sure to use special packages for Python 2 instead
4204 ;; of those automatically rewritten by package-with-python2.
4205 (propagated-inputs
4206 `(("python2-pycairo" ,python2-pycairo)
4207 ("python2-functools32" ,python2-functools32)
4208 ("python2-pygobject-2" ,python2-pygobject-2)
4209 ("python2-subprocess32" ,python2-subprocess32)
4210 ("python2-tkinter" ,python-2 "tk")
4211 ,@(fold alist-delete (package-propagated-inputs matplotlib)
4212 '("python-pycairo" "python-pygobject" "python-tkinter")))))))
4213
4214 (define-public python-matplotlib-documentation
4215 (package
4216 (name "python-matplotlib-documentation")
4217 (version (package-version python-matplotlib))
4218 (source (package-source python-matplotlib))
4219 (build-system python-build-system)
4220 (native-inputs
4221 `(("python-matplotlib" ,python-matplotlib)
4222 ("python-colorspacious" ,python-colorspacious)
4223 ("python-sphinx" ,python-sphinx)
4224 ("python-numpydoc" ,python-numpydoc)
4225 ("python-ipython" ,python-ipython)
4226 ("python-mock" ,python-mock)
4227 ("graphviz" ,graphviz)
4228 ("texlive" ,texlive)
4229 ("texinfo" ,texinfo)
4230 ,@(package-native-inputs python-matplotlib)))
4231 (arguments
4232 `(#:tests? #f ; we're only generating documentation
4233 #:phases
4234 (modify-phases %standard-phases
4235 (replace 'build
4236 (lambda _
4237 (chdir "doc")
4238 ;; Produce pdf in 'A4' format.
4239 (substitute* "conf.py"
4240 (("latex_paper_size = 'letter'") "")
4241 ;; latex_paper_size is deprecated -> set paper size using
4242 ;; latex_elements
4243 (("latex_elements\\['pointsize'\\] = '11pt'" match)
4244 ;; insert at a point where latex_elements{} is defined:
4245 (string-append match "\nlatex_elements['papersize'] = 'a4paper'")))
4246 (zero? (system* "python" "make.py" "html" "latex" "texinfo"))))
4247 (replace 'install
4248 (lambda* (#:key inputs outputs #:allow-other-keys)
4249 (let* ((data (string-append (assoc-ref outputs "out") "/share"))
4250 (doc (string-append data "/doc/python-matplotlib-" ,version))
4251 (info (string-append data "/info"))
4252 (html (string-append doc "/html")))
4253 (mkdir-p html)
4254 (mkdir-p info)
4255 (copy-recursively "build/html" html)
4256 (symlink (string-append html "/_images")
4257 (string-append info "/matplotlib-figures"))
4258 (with-directory-excursion "build/texinfo"
4259 (substitute* "matplotlib.texi"
4260 (("@image\\{([^,]*)" all file)
4261 (string-append "@image{matplotlib-figures/" file)))
4262 (symlink (string-append html "/_images")
4263 "./matplotlib-figures")
4264 (system* "makeinfo" "--no-split"
4265 "-o" "matplotlib.info" "matplotlib.texi"))
4266 (copy-file "build/texinfo/matplotlib.info"
4267 (string-append info "/matplotlib.info"))
4268 (copy-file "build/latex/Matplotlib.pdf"
4269 (string-append doc "/Matplotlib.pdf")))
4270 #t)))))
4271 (home-page (package-home-page python-matplotlib))
4272 (synopsis "Documentation for the python-matplotlib package")
4273 (description (package-description python-matplotlib))
4274 (license (package-license python-matplotlib))))
4275
4276 (define-public python2-matplotlib-documentation
4277 (package-with-python2 python-matplotlib-documentation))
4278
4279 (define-public python2-pysnptools
4280 (package
4281 (name "python2-pysnptools")
4282 (version "0.3.9")
4283 (source
4284 (origin
4285 (method url-fetch)
4286 (uri (pypi-uri "pysnptools" version ".zip"))
4287 (sha256
4288 (base32
4289 "1wybggjzz8zw7aav4pjsg2h22xp17a1lghrprza1pxwlm7wf96y2"))))
4290 (build-system python-build-system)
4291 (arguments
4292 `(#:python ,python-2)) ; only Python 2.7 is supported
4293 (propagated-inputs
4294 `(("python2-numpy" ,python2-numpy)
4295 ("python2-scipy" ,python2-scipy)
4296 ("python2-pandas" ,python2-pandas)))
4297 (native-inputs
4298 `(("python2-cython" ,python2-cython)))
4299 (native-inputs
4300 `(("unzip" ,unzip)))
4301 (home-page "http://research.microsoft.com/en-us/um/redmond/projects/mscompbio/")
4302 (synopsis "Library for reading and manipulating genetic data")
4303 (description
4304 "PySnpTools is a library for reading and manipulating genetic data. It
4305 can, for example, efficiently read whole PLINK *.bed/bim/fam files or parts of
4306 those files. It can also efficiently manipulate ranges of integers using set
4307 operators such as union, intersection, and difference.")
4308 (license license:asl2.0)))
4309
4310 (define-public python-rpy2
4311 (package
4312 (name "python-rpy2")
4313 (version "2.7.6")
4314 (source
4315 (origin
4316 (method url-fetch)
4317 (uri (pypi-uri "rpy2" version))
4318 (sha256
4319 (base32
4320 "0nhan2qvrw7b7gg5zddwa22kybdv3x1g26vkd7q8lvnkgzrs4dga"))))
4321 (build-system python-build-system)
4322 (arguments
4323 '(#:phases
4324 (modify-phases %standard-phases
4325 (delete 'check)
4326 (add-after 'install 'check
4327 (lambda* (#:key outputs inputs #:allow-other-keys)
4328 ;; It's easier to run tests after install.
4329 ;; Make installed package available for running the tests
4330 (add-installed-pythonpath inputs outputs)
4331 (zero? (system* "python" "-m" "rpy2.tests" "-v")))))))
4332 (propagated-inputs
4333 `(("python-six" ,python-six)))
4334 (inputs
4335 `(("readline" ,readline)
4336 ("icu4c" ,icu4c)
4337 ("pcre" ,pcre)
4338 ("r-minimal" ,r-minimal)
4339 ("r-survival" ,r-survival)))
4340 (native-inputs
4341 `(("zlib" ,zlib)))
4342 (home-page "http://rpy.sourceforge.net/")
4343 (synopsis "Python interface to the R language")
4344 (description "rpy2 is a redesign and rewrite of rpy. It is providing a
4345 low-level interface to R from Python, a proposed high-level interface,
4346 including wrappers to graphical libraries, as well as R-like structures and
4347 functions.")
4348 (license license:gpl3+)))
4349
4350 (define-public python2-rpy2
4351 (let ((rpy2 (package-with-python2 python-rpy2)))
4352 (package (inherit rpy2)
4353 (propagated-inputs
4354 `(("python2-singledispatch" ,python2-singledispatch)
4355 ,@(package-propagated-inputs rpy2))))))
4356
4357 (define-public python-scipy
4358 (package
4359 (name "python-scipy")
4360 (version "0.19.1")
4361 (source
4362 (origin
4363 (method url-fetch)
4364 (uri (pypi-uri "scipy" version))
4365 (sha256
4366 (base32
4367 "1rl411bvla6q7qfdb47fpdnyjhfgzl6smpha33n9ar1klykjr6m1"))))
4368 (build-system python-build-system)
4369 (propagated-inputs
4370 `(("python-numpy" ,python-numpy)
4371 ("python-matplotlib" ,python-matplotlib)
4372 ("python-pyparsing" ,python-pyparsing)))
4373 (inputs
4374 `(("lapack" ,lapack)
4375 ("openblas" ,openblas)))
4376 (native-inputs
4377 `(("python-cython" ,python-cython)
4378 ("python-nose" ,python-nose)
4379 ("python-sphinx" ,python-sphinx)
4380 ("python-numpydoc" ,python-numpydoc)
4381 ("gfortran" ,gfortran)
4382 ("perl" ,perl)))
4383 (outputs '("out" "doc"))
4384 (arguments
4385 `(#:phases
4386 (modify-phases %standard-phases
4387 (add-before 'build 'configure-openblas
4388 (lambda* (#:key inputs #:allow-other-keys)
4389 (call-with-output-file "site.cfg"
4390 (lambda (port)
4391 (format port
4392 "[blas]
4393 libraries = openblas
4394 library_dirs = ~a/lib
4395 include_dirs = ~a/include
4396
4397 # backslash-n to make emacs happy
4398 \n[atlas]
4399 library_dirs = ~a/lib
4400 atlas_libs = openblas
4401 "
4402 (assoc-ref inputs "openblas")
4403 (assoc-ref inputs "openblas")
4404 (assoc-ref inputs "openblas"))))
4405 #t))
4406 (add-after 'install 'install-doc
4407 (lambda* (#:key inputs outputs #:allow-other-keys)
4408 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
4409 (doc (string-append data "/doc/" ,name "-" ,version))
4410 (html (string-append doc "/html"))
4411 (pyver ,(string-append "PYVER=")))
4412 ;; Make installed package available for building the
4413 ;; documentation
4414 (add-installed-pythonpath inputs outputs)
4415 (with-directory-excursion "doc"
4416 ;; Fix generation of images for mathematical expressions.
4417 (substitute* (find-files "source" "conf\\.py")
4418 (("pngmath_use_preview = True")
4419 "pngmath_use_preview = False"))
4420 (mkdir-p html)
4421 (system* "make" "html" pyver)
4422 (with-directory-excursion "build/html"
4423 (for-each (lambda (file)
4424 (let* ((dir (dirname file))
4425 (tgt-dir (string-append html "/" dir)))
4426 (install-file file html)))
4427 (find-files "." ".*")))))
4428 #t))
4429 (add-after 'unpack 'fix-tests
4430 (lambda _
4431 (substitute* "scipy/integrate/tests/test_quadpack.py"
4432 (("libm.so") "libm.so.6"))
4433 #t))
4434 ;; Tests can only be run after the library has been installed and not
4435 ;; within the source directory.
4436 (delete 'check)
4437 (add-after 'install 'check
4438 (lambda* (#:key inputs outputs #:allow-other-keys)
4439 (add-installed-pythonpath inputs outputs)
4440 (with-directory-excursion "/tmp"
4441 (zero? (system* "python" "-c"
4442 "import scipy; scipy.test('full')")))
4443 #t)))))
4444 (home-page "http://www.scipy.org/")
4445 (synopsis "The Scipy library provides efficient numerical routines")
4446 (description "The SciPy library is one of the core packages that make up
4447 the SciPy stack. It provides many user-friendly and efficient numerical
4448 routines such as routines for numerical integration and optimization.")
4449 (properties `((python2-variant . ,(delay python2-scipy))))
4450 (license license:bsd-3)))
4451
4452 (define-public python2-scipy
4453 (package-with-python2
4454 (strip-python2-variant python-scipy)))
4455
4456 (define-public python-sockjs-tornado
4457 (package
4458 (name "python-sockjs-tornado")
4459 (version "1.0.3")
4460 (source
4461 (origin
4462 (method url-fetch)
4463 (uri (pypi-uri "sockjs-tornado" version))
4464 (sha256
4465 (base32
4466 "16cff40nniqsyvda1pb2j3b4zwmrw7y2g1vqq78lp20xpmhnwwkd"))))
4467 (build-system python-build-system)
4468 (arguments
4469 `(;; There are no tests, and running the test phase requires missing
4470 ;; dependencies
4471 #:tests? #f))
4472 (propagated-inputs
4473 `(("python-tornado" ,python-tornado)))
4474 (home-page "http://github.com/mrjoes/sockjs-tornado/")
4475 (synopsis
4476 "SockJS python server implementation on top of Tornado framework")
4477 (description
4478 "SockJS-tornado provides the server side counterpart to a SockJS client
4479 library, through the Tornado framework.
4480
4481 SockJS provides a low latency, full duplex, cross-domain communication channel
4482 between a web browser and web server.")
4483 (license license:expat)))
4484
4485 (define-public python2-sockjs-tornado
4486 (package-with-python2 python-sockjs-tornado))
4487
4488 (define-public python-socksipy-branch
4489 (package
4490 (name "python-socksipy-branch")
4491 (version "1.01")
4492 (source
4493 (origin
4494 (method url-fetch)
4495 (uri (pypi-uri "SocksiPy-branch" version))
4496 (sha256
4497 (base32
4498 "01l41v4g7fy9fzvinmjxy6zcbhgqaif8dhdqm4w90fwcw9h51a8p"))))
4499 (build-system python-build-system)
4500 (arguments
4501 `(#:tests? #f)) ; There are no tests
4502 (home-page "https://code.google.com/archive/p/socksipy-branch/")
4503 (synopsis "Python SOCKS module")
4504 (description
4505 "SocksiPy - A Python SOCKS client module. It provides a
4506 socket-like interface that supports connections to any TCP
4507 service through the use of a SOCKS4, SOCKS5 or HTTP proxy.
4508 The original version was developed by Dan Haim, this is a
4509 branch created by Mario Vilas to address some open issues,
4510 as the original project seems to have been abandoned circa 2007.")
4511 (license license:bsd-3)))
4512
4513 (define-public python2-socksipy-branch
4514 (package-with-python2 python-socksipy-branch))
4515
4516 (define-public python-sqlalchemy
4517 (package
4518 (name "python-sqlalchemy")
4519 (version "1.0.12")
4520 (source
4521 (origin
4522 (method url-fetch)
4523 (uri (string-append "https://pypi.python.org/packages/source/S/"
4524 "SQLAlchemy/SQLAlchemy-" version ".tar.gz"))
4525 (sha256
4526 (base32
4527 "1l8qclhd0s90w3pvwhi5mjxdwr5j7gw7cjka2fx6f2vqmq7f4yb6"))))
4528 (build-system python-build-system)
4529 (native-inputs
4530 `(("python-cython" ,python-cython) ;for c extensions
4531 ("python-pytest" ,python-pytest)
4532 ("python-mock" ,python-mock))) ;for tests
4533 (arguments
4534 `(#:phases (alist-replace
4535 'check
4536 (lambda _ (zero? (system* "py.test")))
4537 %standard-phases)))
4538 (home-page "http://www.sqlalchemy.org")
4539 (synopsis "Database abstraction library")
4540 (description
4541 "SQLAlchemy is the Python SQL toolkit and Object Relational Mapper that
4542 gives application developers the full power and flexibility of SQL. It
4543 provides a full suite of well known enterprise-level persistence patterns,
4544 designed for efficient and high-performing database access, adapted into a
4545 simple and Pythonic domain language.")
4546 (license license:x11)))
4547
4548 (define-public python2-sqlalchemy
4549 (package-with-python2 python-sqlalchemy))
4550
4551 (define-public python-pycodestyle
4552 (package
4553 (name "python-pycodestyle")
4554 (version "2.3.1")
4555 (source
4556 (origin
4557 (method url-fetch)
4558 (uri (pypi-uri "pycodestyle" version))
4559 (sha256
4560 (base32
4561 "0rk78b66p57ala26mdldl9lafr48blv5s659sah9q50qnfjmc8k8"))))
4562 (build-system python-build-system)
4563 (home-page "https://pycodestyle.readthedocs.io/")
4564 (synopsis "Python style guide checker")
4565 (description "@code{pycodestyle} (formerly pep8) is a tool to check
4566 Python code against some of the style conventions in
4567 @url{http://www.python.org/dev/peps/pep-0008/,PEP 8}.")
4568 (license license:expat)))
4569
4570 (define-public python2-pycodestyle
4571 (package-with-python2 python-pycodestyle))
4572
4573 (define-public python-orderedmultidict
4574 (package
4575 (name "python-orderedmultidict")
4576 (version "0.7.11")
4577 (source
4578 (origin
4579 (method url-fetch)
4580 (uri (pypi-uri "orderedmultidict" version))
4581 (sha256
4582 (base32
4583 "0dls862ibm7qbq4fnvwx0xn1v9hwyzywbff8xjjdr42dd75208yw"))))
4584 (build-system python-build-system)
4585 (arguments
4586 `(#:phases
4587 (modify-phases %standard-phases
4588 (add-after 'unpack 'fix-tests
4589 (lambda _
4590 ;; The package uses nosetest for running the tests.
4591 ;; Adding this initfile allows to run the test suite
4592 ;; without requiring nosetest.
4593 (zero? (system* "touch" "tests/__init__.py")))))))
4594 (propagated-inputs
4595 `(("python-six" ,python-six)))
4596 (native-inputs
4597 `(("python-pycodestyle" ,python-pycodestyle)))
4598 (home-page "https://github.com/gruns/orderedmultidict")
4599 (synopsis "Python Ordered Multivalue Dictionary - omdict")
4600 (description "This package contains a library for ordered multivalue
4601 dictionaries. A multivalue dictionary is a dictionary that can store
4602 multiple values for the same key. An ordered multivalue dictionary is a
4603 multivalue dictionary that retains the order of insertions and deletions.")
4604 (license license:unlicense)))
4605
4606 (define-public python2-orderedmultidict
4607 (package-with-python2 python-orderedmultidict))
4608
4609 (define-public python-furl
4610 (package
4611 (name "python-furl")
4612 (version "0.5.6")
4613 (source
4614 (origin
4615 (method url-fetch)
4616 (uri (pypi-uri "furl" version))
4617 (sha256
4618 (base32
4619 "0lzpfpm686hvz3sr1mcrnd1b3lgmnw8v59gb43wfi98r3b671pqc"))))
4620 (build-system python-build-system)
4621 (propagated-inputs
4622 `(("python-six" ,python-six)
4623 ("python-orderedmultidict" ,python-orderedmultidict)))
4624 (native-inputs
4625 `(("python-pycodestyle" ,python-pycodestyle)))
4626 (home-page "https://github.com/gruns/furl")
4627 (synopsis "URL manipulation in Python")
4628 (description "Furl provides an easy-to-use alternative to the
4629 @code{urllib} and @code{urlparse} modules for manipulating URLs.")
4630 (license license:unlicense)))
4631
4632 (define-public python2-furl
4633 (package-with-python2 python-furl))
4634
4635 (define-public python-flaky
4636 (package
4637 (name "python-flaky")
4638 (version "3.4.0")
4639 (source (origin
4640 (method url-fetch)
4641 (uri (pypi-uri "flaky" version))
4642 (sha256
4643 (base32
4644 "18pkmf79rfkfpy1d2rrx3v55nxj762ilyk9rvd6s6dccxw58imsa"))))
4645 (build-system python-build-system)
4646 (arguments
4647 ;; TODO: Tests require 'coveralls' and 'genty' which are not in Guix yet.
4648 '(#:tests? #f))
4649 (home-page "https://github.com/box/flaky")
4650 (synopsis "Automatically rerun flaky tests")
4651 (description
4652 "Flaky is a plugin for @code{nose} or @code{py.test} that automatically
4653 reruns flaky tests.
4654
4655 Ideally, tests reliably pass or fail, but sometimes test fixtures must rely
4656 on components that aren't 100% reliable. With flaky, instead of removing
4657 those tests or marking them to @code{@@skip}, they can be automatically
4658 retried.")
4659 (license license:asl2.0)))
4660
4661 (define-public python2-flaky
4662 (package-with-python2 python-flaky))
4663
4664 (define-public python-flask-babel
4665 (package
4666 (name "python-flask-babel")
4667 (version "0.11.1")
4668 (source
4669 (origin
4670 (method url-fetch)
4671 (uri (pypi-uri "Flask-Babel" version))
4672 (sha256
4673 (base32
4674 "16b80cipdba9xj3jlaiaq6wgrgpjb70w3j01jjy9hbp4k71kd6yj"))))
4675 (build-system python-build-system)
4676 (propagated-inputs
4677 `(("python-flask" ,python-flask)
4678 ("python-babel" ,python-babel)
4679 ("python-jinja2" ,python-jinja2)
4680 ("python-pytz" ,python-pytz)))
4681 (home-page "https://github.com/python-babel/flask-babel")
4682 (synopsis "Add i18n/l10n support to Flask applications")
4683 (description "This package implements internationalization and localization
4684 support for Flask. This is based on the Python babel module as well as pytz -
4685 both of which are installed automatically if you install this library.")
4686 (license license:bsd-3)))
4687
4688 (define-public python2-flask-babel
4689 (package-with-python2 python-flask-babel))
4690
4691 (define-public python-sqlalchemy-utils
4692 (package
4693 (name "python-sqlalchemy-utils")
4694 (version "0.32.13")
4695 (source
4696 (origin
4697 (method url-fetch)
4698 (uri (pypi-uri "SQLAlchemy-Utils" version))
4699 (sha256
4700 (base32
4701 "0vsib7gidjamzsz6w4s5pdhxzxsrkghjnm4sqwk94igjrl3i5ixj"))))
4702 (build-system python-build-system)
4703 (arguments
4704 '(#:tests? #f)) ; FIXME: Many tests require a running database server.
4705 ;; #:phases
4706 ;; (modify-phases %standard-phases
4707 ;; (replace 'check
4708 ;; (lambda _
4709 ;; (zero? (system* "py.test" "sqlalchemy_utils" "tests")))))
4710 (propagated-inputs
4711 `(("python-six" ,python-six)
4712 ("python-sqlalchemy" ,python-sqlalchemy)))
4713 (native-inputs
4714 `(("python-dateutil" ,python-dateutil)
4715 ("python-flexmock" ,python-flexmock)
4716 ("python-psycopg2" ,python-psycopg2)
4717 ("python-pytest" ,python-pytest)
4718 ("python-pytz" ,python-pytz)))
4719 (home-page "https://github.com/kvesteri/sqlalchemy-utils")
4720 (synopsis "Various utility functions for SQLAlchemy")
4721 (description
4722 "SQLAlchemy-utils provides various utility functions and custom data types
4723 for SQLAlchemy. SQLAlchemy is an SQL database abstraction library for Python.
4724
4725 You might also want to install the following optional dependencies:
4726 @enumerate
4727 @item @code{python-passlib}
4728 @item @code{python-babel}
4729 @item @code{python-cryptography}
4730 @item @code{python-pytz}
4731 @item @code{python-psycopg2}
4732 @item @code{python-furl}
4733 @item @code{python-flask-babel}
4734 @end enumerate
4735 ")
4736 (license license:bsd-3)))
4737
4738 (define-public python2-sqlalchemy-utils
4739 (package-with-python2 python-sqlalchemy-utils))
4740
4741 (define-public python-alembic
4742 (package
4743 (name "python-alembic")
4744 (version "0.8.10")
4745 (source
4746 (origin
4747 (method url-fetch)
4748 (uri (pypi-uri "alembic" version))
4749 (sha256
4750 (base32
4751 "06br9sfqypnjlal6fsbnky3zb0askwcn3diz8k3kwa0qcblm0fqf"))))
4752 (build-system python-build-system)
4753 (native-inputs
4754 `(("python-mock" ,python-mock)
4755 ("python-pytest-cov" ,python-pytest-cov)))
4756 (propagated-inputs
4757 `(("python-sqlalchemy" ,python-sqlalchemy)
4758 ("python-mako" ,python-mako)
4759 ("python-editor" ,python-editor)))
4760 (home-page "http://bitbucket.org/zzzeek/alembic")
4761 (synopsis
4762 "Database migration tool for SQLAlchemy")
4763 (description
4764 "Alembic is a lightweight database migration tool for usage with the
4765 SQLAlchemy Database Toolkit for Python.")
4766 (license license:expat)))
4767
4768 (define-public python2-alembic
4769 (package-with-python2 python-alembic))
4770
4771 (define-public python-autopep8
4772 (package
4773 (name "python-autopep8")
4774 (version "1.2.4")
4775 (source
4776 (origin
4777 (method url-fetch)
4778 (uri (pypi-uri "autopep8" version))
4779 (sha256
4780 (base32
4781 "18parm383lfn42a00wklv3qf20p4v277f1x3cn58x019dqk1xqrq"))))
4782 (build-system python-build-system)
4783 (propagated-inputs
4784 `(("python-pep8" ,python-pep8)))
4785 (home-page "https://github.com/hhatto/autopep8")
4786 (synopsis "Format Python code according to the PEP 8 style guide")
4787 (description
4788 "@code{autopep8} automatically formats Python code to conform to
4789 the PEP 8 style guide. It uses the pycodestyle utility to determine
4790 what parts of the code needs to be formatted. @code{autopep8} is
4791 capable of fixing most of the formatting issues that can be reported
4792 by pycodestyle.")
4793 (license (license:non-copyleft
4794 "https://github.com/hhatto/autopep8/blob/master/LICENSE"))))
4795
4796 (define-public python2-autopep8
4797 (package-with-python2 python-autopep8))
4798
4799 (define-public python-distutils-extra
4800 (package
4801 (name "python-distutils-extra")
4802 (version "2.38")
4803 (source
4804 (origin
4805 (method url-fetch)
4806 (uri (string-append "https://launchpad.net/python-distutils-extra/trunk/"
4807 version "/+download/python-distutils-extra-"
4808 version ".tar.gz"))
4809 (sha256
4810 (base32
4811 "0lx15kcbby9zisx33p2h5hgakgwh2bvh0ibag8z0px4j6ifhs41x"))))
4812 (build-system python-build-system)
4813 (home-page "https://launchpad.net/python-distutils-extra/")
4814 (synopsis "Enhancements to Python's distutils")
4815 (description
4816 "The python-distutils-extra module enables you to easily integrate
4817 gettext support, themed icons, and scrollkeeper-based documentation into
4818 Python's distutils.")
4819 (license license:gpl2)))
4820
4821 (define-public python2-distutils-extra
4822 (package-with-python2 python-distutils-extra))
4823
4824 (define-public python2-elib.intl
4825 (package
4826 (name "python2-elib.intl")
4827 (version "0.0.3")
4828 (source
4829 (origin
4830 ;; This project doesn't tag releases or publish tarballs, so we take
4831 ;; source from a (semi-arbitrary, i.e. latest as of now) git commit.
4832 (method git-fetch)
4833 (uri (git-reference
4834 (url "https://github.com/dieterv/elib.intl.git")
4835 (commit "d09997cfef")))
4836 (sha256
4837 (base32
4838 "0y7vzff9xgbnaay7m0va1arl6g68ncwrvbgwl7jqlclsahzzb09d"))))
4839 (build-system python-build-system)
4840 (arguments
4841 ;; incompatible with Python 3 (exception syntax)
4842 `(#:python ,python-2
4843 #:tests? #f))
4844 (home-page "https://github.com/dieterv/elib.intl")
4845 (synopsis "Enhanced internationalization for Python")
4846 (description
4847 "The elib.intl module provides enhanced internationalization (I18N)
4848 services for your Python modules and applications.")
4849 (license license:lgpl3+)))
4850
4851 (define-public python-pillow
4852 (package
4853 (name "python-pillow")
4854 (version "3.3.3")
4855 (source
4856 (origin
4857 (method url-fetch)
4858 (uri (pypi-uri "Pillow" version))
4859 (patches (search-patches "python-pillow-freetype-2.7-test-failure.patch"))
4860 (sha256
4861 (base32
4862 "0xkv0p1d73gz0a1qaasf0ai4262g8f334j07vd60bjrxs2wr3nmj"))))
4863 (build-system python-build-system)
4864 (native-inputs
4865 `(("python-nose" ,python-nose)))
4866 (inputs
4867 `(("freetype" ,freetype)
4868 ("lcms" ,lcms)
4869 ("zlib" ,zlib)
4870 ("libjpeg" ,libjpeg)
4871 ("openjpeg" ,openjpeg)
4872 ("libtiff" ,libtiff)
4873 ("libwebp" ,libwebp)))
4874 (arguments
4875 `(#:phases (modify-phases %standard-phases
4876 (add-after
4877 'install 'check-installed
4878 (lambda* (#:key outputs inputs #:allow-other-keys)
4879 (begin
4880 (setenv "HOME" (getcwd))
4881 ;; Make installed package available for running the
4882 ;; tests
4883 (add-installed-pythonpath inputs outputs)
4884 (and (zero? (system* "python" "selftest.py"
4885 "--installed"))
4886 (zero? (system* "python" "test-installed.py"))))))
4887 (delete 'check))))
4888 (home-page "https://pypi.python.org/pypi/Pillow")
4889 (synopsis "Fork of the Python Imaging Library")
4890 (description
4891 "The Python Imaging Library adds image processing capabilities to your
4892 Python interpreter. This library provides extensive file format support, an
4893 efficient internal representation, and fairly powerful image processing
4894 capabilities. The core image library is designed for fast access to data
4895 stored in a few basic pixel formats. It should provide a solid foundation for
4896 a general image processing tool.")
4897 (license (license:x11-style
4898 "http://www.pythonware.com/products/pil/license.htm"
4899 "The PIL Software License"))))
4900
4901 (define-public python2-pillow
4902 (package-with-python2 python-pillow))
4903
4904 (define-public python-pycparser
4905 (package
4906 (name "python-pycparser")
4907 (version "2.17")
4908 (source
4909 (origin
4910 (method url-fetch)
4911 (uri (pypi-uri "pycparser" version))
4912 (sha256
4913 (base32
4914 "1dkkjri0miidqb1zcqhqljfa34fcy9k5akasgwsv6k622zlk3b0a"))))
4915 (outputs '("out" "doc"))
4916 (build-system python-build-system)
4917 (native-inputs
4918 `(("pkg-config" ,pkg-config)))
4919 (arguments
4920 `(#:phases
4921 (modify-phases %standard-phases
4922 (replace 'check
4923 (lambda _
4924 (with-directory-excursion "tests"
4925 (zero? (system* "python" "all_tests.py")))))
4926 (add-after 'install 'install-doc
4927 (lambda* (#:key outputs #:allow-other-keys)
4928 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
4929 (doc (string-append data "/doc/" ,name "-" ,version))
4930 (examples (string-append doc "/examples")))
4931 (mkdir-p examples)
4932 (for-each (lambda (file)
4933 (copy-file (string-append "." file)
4934 (string-append doc file)))
4935 '("/README.rst" "/CHANGES" "/LICENSE"))
4936 (copy-recursively "examples" examples)))))))
4937 (home-page "https://github.com/eliben/pycparser")
4938 (synopsis "C parser in Python")
4939 (description
4940 "Pycparser is a complete parser of the C language, written in pure Python
4941 using the PLY parsing library. It parses C code into an AST and can serve as
4942 a front-end for C compilers or analysis tools.")
4943 (license license:bsd-3)))
4944
4945 (define-public python2-pycparser
4946 (package-with-python2 python-pycparser))
4947
4948 (define-public python-cffi
4949 (package
4950 (name "python-cffi")
4951 (version "1.10.0")
4952 (source
4953 (origin
4954 (method url-fetch)
4955 (uri (pypi-uri "cffi" version))
4956 (sha256
4957 (base32 "1mffyilq4qycm8gs4wkgb18rnqil8a9blqq77chdlshzxc8jkc5k"))))
4958 (build-system python-build-system)
4959 (outputs '("out" "doc"))
4960 (inputs
4961 `(("libffi" ,libffi)))
4962 (propagated-inputs ; required at run-time
4963 `(("python-pycparser" ,python-pycparser)))
4964 (native-inputs
4965 `(("pkg-config" ,pkg-config)
4966 ("python-sphinx" ,python-sphinx)
4967 ("python-pytest" ,python-pytest)))
4968 (arguments
4969 `(#:modules ((ice-9 ftw)
4970 (srfi srfi-26)
4971 (guix build utils)
4972 (guix build python-build-system))
4973 #:phases
4974 (modify-phases %standard-phases
4975 (replace 'check
4976 (lambda _
4977 (setenv "PYTHONPATH"
4978 (string-append
4979 (getenv "PYTHONPATH")
4980 ":" (getcwd) "/build/"
4981 (car (scandir "build" (cut string-prefix? "lib." <>)))))
4982
4983 ;; XXX The "normal" approach of setting CC and friends does
4984 ;; not work here. Is this the correct way of doing things?
4985 (substitute* "testing/embedding/test_basic.py"
4986 (("c = distutils\\.ccompiler\\.new_compiler\\(\\)")
4987 (string-append "c = distutils.ccompiler.new_compiler();"
4988 "c.set_executables(compiler='gcc',"
4989 "compiler_so='gcc',linker_exe='gcc',"
4990 "linker_so='gcc -shared')")))
4991 (substitute* "testing/cffi0/test_ownlib.py"
4992 (("'cc testownlib") "'gcc testownlib"))
4993 (zero? (system* "py.test" "-v" "c/" "testing/"))))
4994 (add-after 'install 'install-doc
4995 (lambda* (#:key outputs #:allow-other-keys)
4996 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
4997 (doc (string-append data "/doc/" ,name "-" ,version))
4998 (html (string-append doc "/html")))
4999 (with-directory-excursion "doc"
5000 (system* "make" "html")
5001 (mkdir-p html)
5002 (copy-recursively "build/html" html))
5003 (copy-file "LICENSE" (string-append doc "/LICENSE"))
5004 #t))))))
5005 (home-page "http://cffi.readthedocs.org")
5006 (synopsis "Foreign function interface for Python")
5007 (description
5008 "Foreign Function Interface for Python calling C code.")
5009 (license license:expat)))
5010
5011 (define-public python2-cffi
5012 (package-with-python2 python-cffi))
5013
5014 (define-public python-xcffib
5015 (package
5016 (name "python-xcffib")
5017 (version "0.5.1")
5018 (source
5019 (origin
5020 (method url-fetch)
5021 (uri (pypi-uri "xcffib" version))
5022 (sha256
5023 (base32
5024 "09gbnmr5vn58mm8xi3fmd7fz6743cks6c46dphnxzwax6zsxmy60"))))
5025 (build-system python-build-system)
5026 (inputs
5027 `(("libxcb" ,libxcb)))
5028 (propagated-inputs
5029 `(("python-cffi" ,python-cffi) ; used at run time
5030 ("python-six" ,python-six)))
5031 (arguments
5032 `(;; FIXME: Tests need more work. See ".travis.yml" in the repository.
5033 #:tests? #f
5034 #:phases
5035 (modify-phases %standard-phases
5036 (add-after 'unpack 'fix-libxcb-path
5037 (lambda* (#:key inputs #:allow-other-keys)
5038 (let ((libxcb (assoc-ref inputs "libxcb")))
5039 (substitute* '("xcffib/__init__.py")
5040 (("^soname = \"") (string-append "soname = \"" libxcb "/lib/")))
5041 #t)))
5042 (add-after 'install 'install-doc
5043 (lambda* (#:key outputs #:allow-other-keys)
5044 (let ((doc (string-append (assoc-ref outputs "out") "/share"
5045 "/doc/" ,name "-" ,version)))
5046 (mkdir-p doc)
5047 (copy-file "README.md"
5048 (string-append doc "/README.md"))
5049 #t))))))
5050 (home-page "https://github.com/tych0/xcffib")
5051 (synopsis "XCB Python bindings")
5052 (description
5053 "Xcffib is a replacement for xpyb, an XCB Python bindings. It adds
5054 support for Python 3 and PyPy. It is based on cffi.")
5055 (license license:expat)))
5056
5057 (define-public python2-xcffib
5058 (package-with-python2 python-xcffib))
5059
5060 (define-public python-cairocffi
5061 (package
5062 (name "python-cairocffi")
5063 (version "0.8.0")
5064 (source
5065 (origin
5066 (method url-fetch)
5067 ;; The archive on pypi is missing the 'utils' directory!
5068 (uri (string-append "https://github.com/Kozea/cairocffi/archive/v"
5069 version ".tar.gz"))
5070 (file-name (string-append name "-" version ".tar.gz"))
5071 (sha256
5072 (base32
5073 "1rk2dvy3fxrga6bvvxc2fi5lbaynm5h4a0w0aaxyn3bc77rszjg9"))))
5074 (build-system python-build-system)
5075 (outputs '("out" "doc"))
5076 (inputs
5077 `(("gdk-pixbuf" ,gdk-pixbuf)
5078 ("cairo" ,cairo)))
5079 (native-inputs
5080 `(("pkg-config" ,pkg-config)
5081 ("python-sphinx" ,python-sphinx)
5082 ("python-docutils" ,python-docutils)))
5083 (propagated-inputs
5084 `(("python-xcffib" ,python-xcffib))) ; used at run time
5085 (arguments
5086 `(;; FIXME: Tests cannot find 'libcairo.so.2'.
5087 #:tests? #f
5088 #:phases
5089 (modify-phases %standard-phases
5090 (add-after 'install 'install-doc
5091 (lambda* (#:key inputs outputs #:allow-other-keys)
5092 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5093 (doc (string-append data "/doc/" ,name "-" ,version))
5094 (html (string-append doc "/html")))
5095 (setenv "LD_LIBRARY_PATH"
5096 (string-append (assoc-ref inputs "cairo") "/lib" ":"
5097 (assoc-ref inputs "gdk-pixbuf") "/lib"))
5098 (setenv "LANG" "en_US.UTF-8")
5099 (mkdir-p html)
5100 (for-each (lambda (file)
5101 (copy-file (string-append "." file)
5102 (string-append doc file)))
5103 '("/README.rst" "/CHANGES" "/LICENSE"))
5104 (system* "python" "setup.py" "build_sphinx")
5105 (copy-recursively "docs/_build/html" html)
5106 #t))))))
5107 (home-page "https://github.com/Kozea/cairocffi")
5108 (synopsis "Python bindings and object-oriented API for Cairo")
5109 (description
5110 "Cairocffi is a CFFI-based drop-in replacement for Pycairo, a set of
5111 Python bindings and object-oriented API for cairo. Cairo is a 2D vector
5112 graphics library with support for multiple backends including image buffers,
5113 PNG, PostScript, PDF, and SVG file output.")
5114 (license license:bsd-3)))
5115
5116 (define-public python2-cairocffi
5117 (package-with-python2 python-cairocffi))
5118
5119 (define-public python-decorator
5120 (package
5121 (name "python-decorator")
5122 (version "4.0.10")
5123 (source
5124 (origin
5125 (method url-fetch)
5126 (uri (pypi-uri "decorator" version))
5127 (sha256
5128 (base32 "0w7hg59hlpq74jpyja4yfryap0ccjvchgpkfp20rhj9krgnrhvlw"))))
5129 (build-system python-build-system)
5130 (arguments '(#:tests? #f)) ; no test target
5131 (home-page "https://pypi.python.org/pypi/decorator/")
5132 (synopsis "Python module to simplify usage of decorators")
5133 (description
5134 "The aim of the decorator module is to simplify the usage of decorators
5135 for the average programmer, and to popularize decorators usage giving examples
5136 of useful decorators, such as memoize, tracing, redirecting_stdout, locked,
5137 etc. The core of this module is a decorator factory.")
5138 (license license:expat)))
5139
5140 (define-public python2-decorator
5141 (package-with-python2 python-decorator))
5142
5143 (define-public python-drmaa
5144 (package
5145 (name "python-drmaa")
5146 (version "0.7.7")
5147 (source
5148 (origin
5149 (method url-fetch)
5150 (uri (pypi-uri "drmaa" version))
5151 (sha256
5152 (base32 "0xzqriqyvk5b8hszbavsyxd29wm3sxirm8zvvdm73rs2iq7w4hkx"))))
5153 (build-system python-build-system)
5154 ;; The test suite requires libdrmaa which is provided by the cluster
5155 ;; environment. At runtime the environment variable DRMAA_LIBRARY_PATH
5156 ;; should be set to the path of the libdrmaa library.
5157 (arguments '(#:tests? #f))
5158 (native-inputs
5159 `(("python-nose" ,python-nose)))
5160 (home-page "https://pypi.python.org/pypi/drmaa")
5161 (synopsis "Python bindings for the DRMAA library")
5162 (description
5163 "A Python package for Distributed Resource Management (DRM) job
5164 submission and control. This package is an implementation of the DRMAA 1.0
5165 Python language binding specification.")
5166 (license license:bsd-3)))
5167
5168 (define-public python2-drmaa
5169 (package-with-python2 python-drmaa))
5170
5171 (define-public python-grako
5172 (package
5173 (name "python-grako")
5174 (version "3.99.9")
5175 (source
5176 (origin
5177 (method url-fetch)
5178 (uri
5179 (pypi-uri "grako" version ".zip"))
5180 (sha256
5181 (base32
5182 "0r63i68wcnv63rfjkasq1ah81frz61a6mzbcnaxhrkdpx84p7hzw"))))
5183 (build-system python-build-system)
5184 (arguments '(#:tests? #f)) ; Test file 'grako.ebnf' is missing from archive.
5185 (native-inputs
5186 `(("unzip" ,unzip)
5187 ("python-pytest" ,python-pytest-3.0)
5188 ("python-pytest-runner" ,python-pytest-runner)))
5189 (home-page "https://bitbucket.org/neogeny/grako")
5190 (synopsis "EBNF parser generator")
5191 (description
5192 "Grako takes a grammar in a variation of EBNF as input, and outputs a
5193 memoizing PEG/Packrat parser in Python.")
5194 (license license:bsd-3)))
5195
5196 (define-public python2-grako
5197 (package-with-python2 python-grako))
5198
5199 (define-public python-gridmap
5200 (package
5201 (name "python-gridmap")
5202 (version "0.13.0")
5203 (source
5204 (origin
5205 (method url-fetch)
5206 (uri (string-append
5207 "https://github.com/pygridtools/gridmap/archive/v"
5208 version ".tar.gz"))
5209 (file-name (string-append name "-" version ".tar.gz"))
5210 (sha256
5211 (base32 "1gzjg2k6f14i1msm2b0ax8d9ds1hvk6qd5nlaivg8m4cxqp4cp1x"))))
5212 (build-system python-build-system)
5213 (arguments
5214 '(#:tests? #f)) ; FIXME: Requires python-cherrypy.
5215 (propagated-inputs
5216 `(("python-psutil" ,python-psutil)
5217 ("python-drmaa" ,python-drmaa)
5218 ("python-pyzmq" ,python-pyzmq)))
5219 (home-page "https://github.com/pygridtools/gridmap")
5220 (synopsis "Create jobs on a cluster directly from Python")
5221 (description
5222 "Gridmap is a Python package to allow you to easily create jobs on the
5223 cluster directly from Python. You can directly map Python functions onto the
5224 cluster without needing to write any wrapper code yourself.")
5225 (license license:gpl3+)))
5226
5227 (define-public python2-gridmap
5228 (package-with-python2 python-gridmap))
5229
5230 (define-public python-pexpect
5231 (package
5232 (name "python-pexpect")
5233 (version "4.2.1")
5234 (source
5235 (origin
5236 (method url-fetch)
5237 (uri (pypi-uri "pexpect" version))
5238 (sha256
5239 (base32 "14ls7k99pwvl21zqv65kzrhccv50j89m5ij1hf0slmsvlxjj84rx"))))
5240 (build-system python-build-system)
5241 (arguments
5242 `(#:phases
5243 (modify-phases %standard-phases
5244 (add-before 'check 'prepare-tests
5245 (lambda _
5246 (substitute* (find-files "tests")
5247 (("/bin/ls") (which "ls"))
5248 (("/bin/echo") (which "echo"))
5249 (("/bin/which") (which "which"))
5250 ;; Many tests try to use the /bin directory which
5251 ;; is not present in the build environment.
5252 ;; Use one that's non-empty and unlikely to change.
5253 (("/bin'") "/dev'"))
5254 ;; XXX: Socket connection test gets "Connection reset by peer".
5255 ;; Why does it not work? Delete for now.
5256 (delete-file "tests/test_socket.py")
5257 #t))
5258 (replace 'check (lambda _ (zero? (system* "nosetests" "-v")))))))
5259 (native-inputs
5260 `(("python-nose" ,python-nose)
5261 ("python-pytest" ,python-pytest-3.0)
5262 ("man-db" ,man-db)
5263 ("which" ,which)))
5264 (propagated-inputs
5265 `(("python-ptyprocess" ,python-ptyprocess)))
5266 (home-page "http://pexpect.readthedocs.org/")
5267 (synopsis "Controlling interactive console applications")
5268 (description
5269 "Pexpect is a pure Python module for spawning child applications;
5270 controlling them; and responding to expected patterns in their output.
5271 Pexpect works like Don Libes’ Expect. Pexpect allows your script to spawn a
5272 child application and control it as if a human were typing commands.")
5273 (license license:isc)))
5274
5275 (define-public python2-pexpect
5276 (package-with-python2 python-pexpect))
5277
5278 (define-public python-setuptools-scm
5279 (package
5280 (name "python-setuptools-scm")
5281 (version "1.15.0")
5282 (source (origin
5283 (method url-fetch)
5284 (uri (pypi-uri "setuptools_scm" version))
5285 (sha256
5286 (base32
5287 "0bwyc5markib0i7i2qlyhdzxhiywzxbkfiapldma8m91m82jvwfs"))))
5288 (build-system python-build-system)
5289 (home-page "https://github.com/pypa/setuptools_scm/")
5290 (synopsis "Manage Python package versions in SCM metadata")
5291 (description
5292 "Setuptools_scm handles managing your Python package versions in
5293 @dfn{software configuration management} (SCM) metadata instead of declaring
5294 them as the version argument or in a SCM managed file.")
5295 (license license:expat)))
5296
5297 (define-public python2-setuptools-scm
5298 (package-with-python2 python-setuptools-scm))
5299
5300 (define-public python-pathpy
5301 (package
5302 (name "python-pathpy")
5303 (version "8.1.1")
5304 (source
5305 (origin
5306 (method url-fetch)
5307 (uri (string-append "https://pypi.python.org/packages/source/p/"
5308 "path.py/path.py-" version ".tar.gz"))
5309 (sha256
5310 (base32 "1p8s1l2vfkqhqxdhqlj0g1jjw4f1as2frr35sjcpjjpd5a89y41f"))))
5311 (outputs '("out" "doc"))
5312 (build-system python-build-system)
5313 (propagated-inputs
5314 `(("python-appdirs" ,python-appdirs)))
5315 (native-inputs
5316 `(("python-setuptools-scm" ,python-setuptools-scm)
5317 ("python-sphinx" ,python-sphinx)
5318 ("python-rst.linker" ,python-rst.linker)
5319 ("python-pytest" ,python-pytest)
5320 ("python-pytest-runner" ,python-pytest-runner)))
5321 (arguments
5322 `(#:phases
5323 (modify-phases %standard-phases
5324 (add-after 'build 'build-doc
5325 (lambda _
5326 (setenv "LANG" "en_US.UTF-8")
5327 (zero? (system* "python" "setup.py" "build_sphinx"))))
5328 (add-after 'install 'install-doc
5329 (lambda* (#:key outputs #:allow-other-keys)
5330 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5331 (doc (string-append data "/doc/" ,name "-" ,version))
5332 (html (string-append doc "/html")))
5333 (mkdir-p html)
5334 (for-each (lambda (file)
5335 (copy-file file (string-append doc "/" file)))
5336 '("README.rst" "CHANGES.rst"))
5337 (copy-recursively "build/sphinx/html" html)))))))
5338 (home-page "https://github.com/jaraco/path.py")
5339 (synopsis "Python module wrapper for built-in os.path")
5340 (description
5341 "@code{path.py} implements path objects as first-class entities, allowing
5342 common operations on files to be invoked on those path objects directly.")
5343 (license license:expat)))
5344
5345 (define-public python2-pathpy
5346 (package-with-python2 python-pathpy))
5347
5348 (define-public python-pickleshare
5349 (package
5350 (name "python-pickleshare")
5351 (version "0.5")
5352 (source
5353 (origin
5354 (method url-fetch)
5355 (uri (string-append "https://pypi.python.org/packages/source/p/"
5356 "pickleshare/pickleshare-" version ".tar.gz"))
5357 (sha256
5358 (base32 "11ljr90j3p6qswdrbl7p4cjb2i93f6vn0vx9anzpshsx0d2mggn0"))))
5359 (build-system python-build-system)
5360 (propagated-inputs
5361 `(("python-pathpy" ,python-pathpy)))
5362 (home-page "https://github.com/vivainio/pickleshare")
5363 (synopsis "Tiny key value database with concurrency support")
5364 (description
5365 "PickleShare is a small ‘shelve’-like datastore with concurrency support.
5366 Like shelve, a PickleShareDB object acts like a normal dictionary. Unlike
5367 shelve, many processes can access the database simultaneously. Changing a
5368 value in database is immediately visible to other processes accessing the same
5369 database. Concurrency is possible because the values are stored in separate
5370 files. Hence the “database” is a directory where all files are governed by
5371 PickleShare.")
5372 (license license:expat)))
5373
5374 (define-public python2-pickleshare
5375 (package-with-python2 python-pickleshare))
5376
5377 (define-public python-simplegeneric
5378 (package
5379 (name "python-simplegeneric")
5380 (version "0.8.1")
5381 (source
5382 (origin
5383 (method url-fetch)
5384 (uri (string-append "https://pypi.python.org/packages/source/s/"
5385 "simplegeneric/simplegeneric-" version ".zip"))
5386 (sha256
5387 (base32 "0wwi1c6md4vkbcsfsf8dklf3vr4mcdj4mpxkanwgb6jb1432x5yw"))))
5388 (build-system python-build-system)
5389 (native-inputs
5390 `(("unzip" ,unzip)))
5391 (home-page "http://cheeseshop.python.org/pypi/simplegeneric")
5392 (synopsis "Python module for simple generic functions")
5393 (description
5394 "The simplegeneric module lets you define simple single-dispatch generic
5395 functions, akin to Python’s built-in generic functions like @code{len()},
5396 @code{iter()} and so on. However, instead of using specially-named methods,
5397 these generic functions use simple lookup tables, akin to those used by
5398 e.g. @code{pickle.dump()} and other generic functions found in the Python
5399 standard library.")
5400 (license license:zpl2.1)))
5401
5402 (define-public python2-simplegeneric
5403 (package-with-python2 python-simplegeneric))
5404
5405 (define-public python-ipython-genutils
5406 ;; TODO: This package is retired, check if can be removed, see description.
5407 (package
5408 (name "python-ipython-genutils")
5409 (version "0.1.0")
5410 (source
5411 (origin
5412 (method url-fetch)
5413 (uri (string-append "https://pypi.python.org/packages/source/i/"
5414 "ipython_genutils/ipython_genutils-"
5415 version ".tar.gz"))
5416 (sha256
5417 (base32 "19l2pp1c64ansr89l3cqh19jdi2ixhssdzx0vz4n6r52a6i281is"))))
5418 (build-system python-build-system)
5419 (arguments `(#:tests? #f)) ; no tests
5420 (home-page "http://ipython.org")
5421 (synopsis "Vestigial utilities from IPython")
5422 (description
5423 "This package provides retired utilities from IPython. No packages
5424 outside IPython/Jupyter should depend on it.
5425
5426 This package shouldn't exist. It contains some common utilities shared by
5427 Jupyter and IPython projects during The Big Split. As soon as possible, those
5428 packages will remove their dependency on this, and this package will go
5429 away.")
5430 (license license:bsd-3)))
5431
5432 (define-public python2-ipython-genutils
5433 (package-with-python2 python-ipython-genutils))
5434
5435 (define-public python-traitlets
5436 (package
5437 (name "python-traitlets")
5438 (version "4.2.0")
5439 (source
5440 (origin
5441 (method url-fetch)
5442 (uri (pypi-uri "traitlets" version))
5443 (sha256
5444 (base32
5445 "1afy08sa5n9gnkvh3da49c16zkyv598vchv0p1hp7zzjy8895hz4"))))
5446 (build-system python-build-system)
5447 (arguments
5448 `(#:phases
5449 (modify-phases %standard-phases
5450 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
5451 (propagated-inputs
5452 `(("python-ipython-genutils" ,python-ipython-genutils)
5453 ("python-decorator" ,python-decorator)))
5454 (native-inputs
5455 `(("python-mock" ,python-mock)
5456 ("python-nose" ,python-nose)))
5457 (home-page "http://ipython.org")
5458 (synopsis "Configuration system for Python applications")
5459 (description
5460 "Traitlets is a framework that lets Python classes have attributes with
5461 type checking, dynamically calculated default values, and ‘on change’
5462 callbacks. The package also includes a mechanism to use traitlets for
5463 configuration, loading values from files or from command line arguments. This
5464 is a distinct layer on top of traitlets, so you can use traitlets in your code
5465 without using the configuration machinery.")
5466 (license license:bsd-3)))
5467
5468 (define-public python2-traitlets
5469 (package-with-python2 python-traitlets))
5470
5471 (define-public python-jupyter-core
5472 (package
5473 (name "python-jupyter-core")
5474 (version "4.2.1")
5475 (source
5476 (origin
5477 (method url-fetch)
5478 (uri (string-append (pypi-uri "jupyter_core" version)))
5479 (sha256
5480 (base32
5481 "1cy7inv218dgh4m1fbzbsiqpz733ylgjrj62jxqpfzs3r2cm7ic9"))))
5482 (build-system python-build-system)
5483 ;; FIXME: not sure how to run the tests
5484 (arguments `(#:tests? #f))
5485 (propagated-inputs
5486 `(("python-traitlets" ,python-traitlets)))
5487 (home-page "http://jupyter.org/")
5488 (synopsis "Jupyter base package")
5489 (description
5490 "Jupyter core is the base package on which Jupyter projects rely.")
5491 (license license:bsd-3)))
5492
5493 (define-public python2-jupyter-core
5494 (package-with-python2 python-jupyter-core))
5495
5496 (define-public python-jupyter-client
5497 (package
5498 (name "python-jupyter-client")
5499 (version "4.4.0")
5500 (source
5501 (origin
5502 (method url-fetch)
5503 (uri (pypi-uri "jupyter_client" version))
5504 (sha256
5505 (base32
5506 "1vjjrpjw7k5sh982pbjnslv7byfbfazjw9g92jvs7dz5qbx556n9"))))
5507 (build-system python-build-system)
5508 ;; Tests fail because of missing native python kernel which I assume is
5509 ;; provided by the ipython package, which we cannot use because it would
5510 ;; cause a dependency cycle.
5511 (arguments `(#:tests? #f))
5512 (propagated-inputs
5513 `(("python-pyzmq" ,python-pyzmq)
5514 ("python-traitlets" ,python-traitlets)
5515 ("python-jupyter-core" ,python-jupyter-core)))
5516 (home-page "http://jupyter.org/")
5517 (synopsis "Jupyter protocol implementation and client libraries")
5518 (description
5519 "The @code{jupyter_client} package contains the reference implementation
5520 of the Jupyter protocol. It also provides client and kernel management APIs
5521 for working with kernels, and the @code{jupyter kernelspec} entrypoint for
5522 installing @code{kernelspec}s for use with Jupyter frontends.")
5523 (license license:bsd-3)))
5524
5525 (define-public python2-jupyter-client
5526 (package-with-python2 python-jupyter-client))
5527
5528 (define-public python-ipykernel
5529 (package
5530 (name "python-ipykernel")
5531 (version "4.5.2")
5532 (source
5533 (origin
5534 (method url-fetch)
5535 (uri (pypi-uri "ipykernel" version))
5536 (sha256
5537 (base32 "0qllv0k6zzv1r1cj1x2ygxmlrrqhbslzj8rc6r6fg3kc1rgz4m2s"))))
5538 (build-system python-build-system)
5539 ;; The tests load a submodule of IPython. However, IPython itself depends
5540 ;; on ipykernel.
5541 (arguments `(#:tests? #f))
5542 (propagated-inputs
5543 ;; imported at runtime during connect
5544 `(("python-jupyter-client" ,python-jupyter-client)))
5545 (home-page "http://ipython.org")
5546 (synopsis "IPython Kernel for Jupyter")
5547 (description
5548 "This package provides the IPython kernel for Jupyter.")
5549 (license license:bsd-3)))
5550
5551 (define-public python2-ipykernel
5552 (package-with-python2 python-ipykernel))
5553
5554 (define-public python-testpath
5555 (package
5556 (name "python-testpath")
5557 (version "0.2")
5558 (source
5559 (origin
5560 (method url-fetch)
5561 (uri (string-append "https://github.com/jupyter/testpath/archive/"
5562 version ".tar.gz"))
5563 (file-name (string-append name "-" version ".tar.gz"))
5564 (sha256
5565 (base32
5566 "04kh3fgvmqz6cfcw79q70qwjz7ib7lxm27cc548iy2rpr33qqf55"))))
5567 (build-system python-build-system)
5568 (arguments
5569 `(#:tests? #f ; this package does not even have a setup.py
5570 #:modules ((guix build python-build-system)
5571 (guix build utils)
5572 (srfi srfi-1))
5573 #:imported-modules (,@%python-build-system-modules
5574 (srfi srfi-1))
5575 #:phases
5576 (modify-phases %standard-phases
5577 (delete 'install)
5578 (replace 'build
5579 (lambda* (#:key inputs outputs #:allow-other-keys)
5580 (let* ((version (last
5581 (string-split (assoc-ref inputs "python") #\-)))
5582 (x.y (string-join (take (string-split version #\.) 2)
5583 "."))
5584 (dir (string-append
5585 (assoc-ref outputs "out")
5586 "/lib/python" x.y "/site-packages/testpath")))
5587 (mkdir-p dir)
5588 (copy-recursively "testpath" dir))
5589 #t)))))
5590 (home-page "https://github.com/takluyver/testpath")
5591 (synopsis "Test utilities for code working with files and commands")
5592 (description
5593 "Testpath is a collection of utilities for Python code working with files
5594 and commands. It contains functions to check things on the filesystem, and
5595 tools for mocking system commands and recording calls to those.")
5596 (license license:expat)))
5597
5598 (define-public python2-testpath
5599 (package-with-python2 python-testpath))
5600
5601 (define-public python-ipython
5602 (package
5603 (name "python-ipython")
5604 (version "5.2.2")
5605 (source
5606 (origin
5607 (method url-fetch)
5608 (uri (pypi-uri "ipython" version ".tar.gz"))
5609 (sha256
5610 (base32 "1qhjwa9cyz1np7rhv3p4ip13lkgbqsad62l24xkwiq1ic2gwiqbf"))))
5611 (build-system python-build-system)
5612 (outputs '("out" "doc"))
5613 (propagated-inputs
5614 `(("python-pyzmq" ,python-pyzmq)
5615 ("python-prompt-toolkit" ,python-prompt-toolkit)
5616 ("python-terminado" ,python-terminado)
5617 ("python-matplotlib" ,python-matplotlib)
5618 ("python-numpy" ,python-numpy)
5619 ("python-numpydoc" ,python-numpydoc)
5620 ("python-jinja2" ,python-jinja2)
5621 ("python-mistune" ,python-mistune)
5622 ("python-pexpect" ,python-pexpect)
5623 ("python-pickleshare" ,python-pickleshare)
5624 ("python-simplegeneric" ,python-simplegeneric)
5625 ("python-jsonschema" ,python-jsonschema)
5626 ("python-traitlets" ,python-traitlets)
5627 ("python-ipykernel" ,python-ipykernel)
5628 ("python-nbformat" ,python-nbformat)
5629 ("python-pygments" ,python-pygments)))
5630 (inputs
5631 `(("readline" ,readline)
5632 ("which" ,which)))
5633 (native-inputs
5634 `(("graphviz" ,graphviz)
5635 ("pkg-config" ,pkg-config)
5636 ("python-requests" ,python-requests) ;; for tests
5637 ("python-testpath" ,python-testpath)
5638 ("python-nose" ,python-nose)
5639 ("python-sphinx" ,python-sphinx)
5640 ("python-shpinx-rtd-theme" ,python-sphinx-rtd-theme)
5641 ;; FIXME: It's possible that a smaller union would work just as well.
5642 ("texlive" ,(texlive-union (list texlive-fonts-amsfonts
5643 texlive-fonts-ec
5644 texlive-generic-ifxetex
5645 texlive-generic-pdftex
5646 texlive-latex-amsfonts
5647 texlive-latex-capt-of
5648 texlive-latex-cmap
5649 texlive-latex-environ
5650 texlive-latex-eqparbox
5651 texlive-latex-etoolbox
5652 texlive-latex-expdlist
5653 texlive-latex-fancyhdr
5654 texlive-latex-fancyvrb
5655 texlive-latex-fncychap
5656 texlive-latex-float
5657 texlive-latex-framed
5658 texlive-latex-geometry
5659 texlive-latex-graphics
5660 texlive-latex-hyperref
5661 texlive-latex-mdwtools
5662 texlive-latex-multirow
5663 texlive-latex-oberdiek
5664 texlive-latex-parskip
5665 texlive-latex-preview
5666 texlive-latex-tabulary
5667 texlive-latex-threeparttable
5668 texlive-latex-titlesec
5669 texlive-latex-trimspaces
5670 texlive-latex-ucs
5671 texlive-latex-upquote
5672 texlive-latex-url
5673 texlive-latex-varwidth
5674 texlive-latex-wrapfig)))
5675 ("texinfo" ,texinfo)))
5676 (arguments
5677 `(#:phases
5678 (modify-phases %standard-phases
5679 (add-after
5680 'install 'install-doc
5681 (lambda* (#:key inputs outputs #:allow-other-keys)
5682 (let* ((data (string-append (assoc-ref outputs "doc") "/share"))
5683 (doc (string-append data "/doc/" ,name "-" ,version))
5684 (html (string-append doc "/html"))
5685 (man1 (string-append data "/man/man1"))
5686 (info (string-append data "/info"))
5687 (examples (string-append doc "/examples"))
5688 (python-arg (string-append "PYTHON=" (which "python"))))
5689 (setenv "LANG" "en_US.utf8")
5690 ;; Make installed package available for running the tests
5691 (add-installed-pythonpath inputs outputs)
5692 (with-directory-excursion "docs"
5693 ;; FIXME: pdf fails to build
5694 ;;(system* "make" "pdf" "PAPER=a4")
5695 (system* "make" python-arg "html")
5696 (system* "make" python-arg "info"))
5697 (copy-recursively "docs/man" man1)
5698 (copy-recursively "examples" examples)
5699 (copy-recursively "docs/build/html" html)
5700 ;; (copy-file "docs/build/latex/ipython.pdf"
5701 ;; (string-append doc "/ipython.pdf"))
5702 (mkdir-p info)
5703 (copy-file "docs/build/texinfo/ipython.info"
5704 (string-append info "/ipython.info"))
5705 (copy-file "COPYING.rst" (string-append doc "/COPYING.rst")))))
5706 ;; Tests can only be run after the library has been installed and not
5707 ;; within the source directory.
5708 (delete 'check)
5709 (add-after
5710 'install 'check
5711 (lambda* (#:key inputs outputs tests? #:allow-other-keys)
5712 (if tests?
5713 (with-directory-excursion "/tmp"
5714 ;; Make installed package available for running the tests
5715 (add-installed-pythonpath inputs outputs)
5716 (setenv "HOME" "/tmp/") ;; required by a test
5717 (zero? (system* (string-append (assoc-ref outputs "out")
5718 "/bin/iptest"))))
5719 #t)))
5720 (add-before
5721 'install 'fix-tests
5722 (lambda* (#:key inputs #:allow-other-keys)
5723 (substitute* "./IPython/utils/_process_posix.py"
5724 (("/usr/bin/env', 'which") (which "which")))
5725 (substitute* "./IPython/core/tests/test_inputtransformer.py"
5726 (("#!/usr/bin/env python")
5727 (string-append "#!" (which "python"))))
5728 ;; Disable 1 failing test
5729 (substitute* "./IPython/core/tests/test_magic.py"
5730 (("def test_dirops\\(\\):" all)
5731 (string-append "@dec.skipif(True)\n" all))))))))
5732 (home-page "http://ipython.org")
5733 (synopsis "IPython is a tool for interactive computing in Python")
5734 (description
5735 "IPython provides a rich architecture for interactive computing with:
5736 Powerful interactive shells, a browser-based notebook, support for interactive
5737 data visualization, embeddable interpreters and tools for parallel
5738 computing.")
5739 (license license:bsd-3)
5740 (properties `((python2-variant . ,(delay python2-ipython))))))
5741
5742 (define-public python2-ipython
5743 (let ((ipython (package-with-python2 (strip-python2-variant python-ipython))))
5744 (package
5745 (inherit ipython)
5746 ;; FIXME: add pyreadline once available.
5747 (propagated-inputs
5748 `(("python2-backports-shutil-get-terminal-size"
5749 ,python2-backports-shutil-get-terminal-size)
5750 ("python2-pathlib2" ,python2-pathlib2)
5751 ,@(package-propagated-inputs ipython)))
5752 (native-inputs
5753 `(("python2-mock" ,python2-mock)
5754 ,@(package-native-inputs ipython))))))
5755
5756 (define-public python-isodate
5757 (package
5758 (name "python-isodate")
5759 (version "0.5.4")
5760 (source
5761 (origin
5762 (method url-fetch)
5763 (uri (pypi-uri "isodate" version))
5764 (sha256
5765 (base32
5766 "0cafaiwixgpxwh9dsd28qb0dbzsj6xpxjdkyk30ns91ps10mq422"))))
5767 (build-system python-build-system)
5768 (home-page
5769 "http://cheeseshop.python.org/pypi/isodate")
5770 (synopsis
5771 "Python date parser and formatter")
5772 (description
5773 "Python-isodate is a python module for parsing and formatting
5774 ISO 8601 dates, time and duration.")
5775 (license license:bsd-3)))
5776
5777 (define-public python2-isodate
5778 (package-with-python2 python-isodate))
5779
5780 (define-public python-html5lib
5781 (package
5782 (name "python-html5lib")
5783 (version "1.0b10")
5784 (source
5785 (origin
5786 (method url-fetch)
5787 (uri (pypi-uri "html5lib" version))
5788 (sha256
5789 (base32
5790 "1yd068a5c00wd0ajq0hqimv7fd82lhrw0w3s01vbhy9bbd6xapqd"))))
5791 (build-system python-build-system)
5792 (propagated-inputs
5793 `(("python-six" ,python-six)
5794 ("python-webencodings" ,python-webencodings)))
5795 (arguments
5796 `(#:test-target "check"))
5797 (home-page
5798 "https://github.com/html5lib/html5lib-python")
5799 (synopsis
5800 "Python HTML parser based on the WHATWG HTML specifcation")
5801 (description
5802 "Html5lib is an HTML parser based on the WHATWG HTML specifcation
5803 and written in Python.")
5804 (license license:expat)))
5805
5806 (define-public python2-html5lib
5807 (package-with-python2 python-html5lib))
5808
5809 ;; Needed for python-bleach, a dependency of python-notebook
5810 (define-public python-html5lib-0.9
5811 (package
5812 (inherit python-html5lib)
5813 (version "0.999")
5814 (source
5815 (origin
5816 (method url-fetch)
5817 (uri (pypi-uri "html5lib" version))
5818 (sha256
5819 (base32
5820 "17n4zfsj6ynmbwdwviywmj8r6nzr3xvfx2zs0xhndmvm51z7z263"))))))
5821
5822 (define-public python2-html5lib-0.9
5823 (package-with-python2 python-html5lib-0.9))
5824
5825 (define-public python-webencodings
5826 (package
5827 (name "python-webencodings")
5828 (version "0.5")
5829 (source (origin
5830 (method url-fetch)
5831 (uri (pypi-uri "webencodings" version))
5832 (sha256
5833 (base32
5834 "015rw7662lkpb9aqiqah2hbizk6w531badqwjpz41rr47glmxid5"))))
5835 (build-system python-build-system)
5836 (arguments
5837 '(#:phases
5838 (modify-phases %standard-phases
5839 (replace 'check
5840 (lambda _
5841 (zero? (system* "py.test" "-v" "webencodings/tests.py")))))))
5842 (native-inputs
5843 `(("python-pytest" ,python-pytest)))
5844 (home-page "https://github.com/SimonSapin/python-webencodings")
5845 (synopsis "Character encoding aliases for legacy web content")
5846 (description
5847 "In order to be compatible with legacy web content when interpreting
5848 something like @code{Content-Type: text/html; charset=latin1}, tools need
5849 to use a particular set of aliases for encoding labels as well as some
5850 overriding rules. For example, @code{US-ASCII} and @code{iso-8859-1} on
5851 the web are actually aliases for @code{windows-1252}, and an @code{UTF-8}
5852 or @code{UTF-16} BOM takes precedence over any other encoding declaration.
5853 The WHATWG @url{https://encoding.spec.whatwg.org/,Encoding} standard
5854 defines all such details so that implementations do not have to
5855 reverse-engineer each other.
5856
5857 This module implements the Encoding standard and has encoding labels and
5858 BOM detection, but the actual implementation for encoders and decoders
5859 is Python’s.")
5860 (license license:bsd-3)))
5861
5862 (define-public python2-webencodings
5863 (package-with-python2 python-webencodings))
5864
5865 (define-public python-urwid
5866 (package
5867 (name "python-urwid")
5868 (version "1.3.1")
5869 (source
5870 (origin
5871 (method url-fetch)
5872 (uri (pypi-uri "urwid" version))
5873 (sha256
5874 (base32
5875 "18cnd1wdjcas08x5qwa5ayw6jsfcn33w4d9f7q3s29fy6qzc1kng"))))
5876 (build-system python-build-system)
5877 (arguments
5878 `(#:phases
5879 (modify-phases %standard-phases
5880 ;; Disable failing test. Bug filed upstream:
5881 ;; https://github.com/wardi/urwid/issues/164
5882 ;; TODO: check again for python-urwid > 1.3.1 or python > 3.4.3.
5883 (add-after 'unpack 'disable-failing-test
5884 (lambda _
5885 (substitute* "urwid/tests/test_event_loops.py"
5886 (("test_remove_watch_file")
5887 "disable_remove_watch_file")))))))
5888 (home-page "http://urwid.org")
5889 (synopsis "Console user interface library for Python")
5890 (description
5891 "Urwid is a curses-based UI/widget library for Python. It includes many
5892 features useful for text console applications.")
5893 (license license:lgpl2.1+)))
5894
5895 (define-public python2-urwid
5896 (let ((python2-urwid (package-with-python2 python-urwid)))
5897 (package
5898 (inherit python2-urwid)
5899 (arguments
5900 (append
5901 `(;; Explicitly using Python 2 is necessary due the argument list being
5902 ;; built from only the 'delete-test_vterm.py' phase and python-urwid's
5903 ;; package arguments, which by default assumes the use of Python 3.
5904 #:python ,python-2
5905 #:phases
5906 (modify-phases %standard-phases
5907 ;; Disable the vterm tests because of non-deterministic failures
5908 ;; with Python 2. See https://github.com/urwid/urwid/issues/230.
5909 (add-after 'unpack 'delete-test_vterm.py
5910 (delete-file "urwid/tests/test_vterm.py"))))
5911 (package-arguments python-urwid))))))
5912
5913 (define-public python-openid
5914 (package
5915 (name "python-openid")
5916 (version "3.0.10")
5917 (source
5918 (origin
5919 (method url-fetch)
5920 (uri (pypi-uri "python3-openid" version))
5921 (sha256
5922 (base32
5923 "1x3nh3fycqfn43jp5j5pb4q4y2jxp4mdka4absaa3bc0078qd758"))))
5924 (build-system python-build-system)
5925 (arguments
5926 `(#:phases
5927 (modify-phases %standard-phases
5928 (replace 'check
5929 (lambda _
5930 (zero? (system* "./admin/runtests")))))))
5931 (properties `((python2-variant . ,(delay python2-openid))))
5932 (propagated-inputs
5933 `(("python-defusedxml" ,python-defusedxml)))
5934 (native-inputs
5935 `(("python-psycopg2" ,python-psycopg2)
5936 ("python-django" ,python-django)))
5937 (home-page "https://github.com/necaris/python3-openid")
5938 (synopsis "OpenID support for servers and consumers")
5939 (description "This library provides OpenID authentication for Python, both
5940 for clients and servers.")
5941 (license license:asl2.0)))
5942
5943 (define-public python2-openid
5944 (package
5945 (name "python2-openid")
5946 (version "2.2.5")
5947 (source
5948 (origin
5949 (method url-fetch)
5950 (uri (pypi-uri "python-openid" version))
5951 (sha256
5952 (base32
5953 "1vvhxlghjan01snfdc4k7ykd80vkyjgizwgg9bncnin8rqz1ricj"))))
5954 (build-system python-build-system)
5955 (arguments
5956 ;; Python 3 support is in `python3-openid`, a separate package.
5957 `(#:python ,python-2))
5958 (home-page "https://github.com/openid/python-openid")
5959 (synopsis "OpenID support for servers and consumers")
5960 (description "This library provides OpenID authentication for Python, both
5961 for clients and servers.")
5962 (license license:asl2.0)))
5963
5964 (define-public python-urwidtrees
5965 (package
5966 (name "python-urwidtrees")
5967 (version "1.0.2")
5968 (source
5969 (origin
5970 (method url-fetch)
5971 ;; package author intends on distributing via github rather than pypi:
5972 ;; https://github.com/pazz/alot/issues/877#issuecomment-230173331
5973 (uri (string-append "https://github.com/pazz/urwidtrees/archive/"
5974 version ".tar.gz"))
5975 (file-name (string-append name "-" version ".tar.gz"))
5976 (sha256
5977 (base32
5978 "0d30lyd3s2a97rhqfax5w9ssqds2z6aydqx3c6j2c2lk3cb4ngvh"))))
5979 (build-system python-build-system)
5980 (arguments
5981 '(#:tests? #f)) ; no tests
5982 (propagated-inputs `(("python-urwid" ,python-urwid)))
5983 (home-page "https://github.com/pazz/urwidtrees")
5984 (synopsis "Tree widgets for urwid")
5985 (description "Urwidtrees is a Widget Container API for the @code{urwid}
5986 toolkit. Use it to build trees of widgets.")
5987 (license license:gpl3+)))
5988
5989 (define-public python2-urwidtrees
5990 (package-with-python2 python-urwidtrees))
5991
5992 (define-public python-dbus
5993 (package
5994 (name "python-dbus")
5995 (version "1.2.0")
5996 (source
5997 (origin
5998 (method url-fetch)
5999 (uri (string-append
6000 "https://dbus.freedesktop.org/releases/dbus-python/dbus-python-"
6001 version ".tar.gz"))
6002 (sha256
6003 (base32 "1py62qir966lvdkngg0v8k1khsqxwk5m4s8nflpk1agk5f5nqb71"))))
6004 (build-system gnu-build-system)
6005 (arguments
6006 '(#:phases
6007 (modify-phases %standard-phases
6008 (add-before
6009 'check 'pre-check
6010 (lambda _
6011 ;; XXX: For the missing '/etc/machine-id'.
6012 (substitute* "test/run-test.sh"
6013 (("DBUS_FATAL_WARNINGS=1")
6014 "DBUS_FATAL_WARNINGS=0"))
6015 #t)))))
6016 (native-inputs
6017 `(("pkg-config" ,pkg-config)))
6018 (inputs
6019 `(("python" ,python)
6020 ("dbus-glib" ,dbus-glib)))
6021 (synopsis "Python bindings for D-bus")
6022 (description "python-dbus provides bindings for libdbus, the reference
6023 implementation of D-Bus.")
6024 (home-page "http://www.freedesktop.org/wiki/Software/DBusBindings/")
6025 (license license:expat)))
6026
6027 (define-public python2-dbus
6028 (package (inherit python-dbus)
6029 (name "python2-dbus")
6030 (inputs `(("python" ,python-2)
6031 ,@(alist-delete "python"
6032 (package-inputs python-dbus)
6033 equal?)))
6034 ;; FIXME: on Python 2, the test_utf8 fails with:
6035 ;; "ValueError: unichr() arg not in range(0x10000) (narrow Python build)"
6036 (arguments `(#:tests? #f))))
6037
6038 (define-public python-apsw
6039 (package
6040 (name "python-apsw")
6041 (version "3.9.2-r1")
6042 (source
6043 (origin
6044 (method url-fetch)
6045 (uri (pypi-uri "apsw" version))
6046 (sha256
6047 (base32
6048 "0w4jb0wpx785qw42r3h4fh7gl5w2968q48i7gygybsfxck8nzffs"))))
6049 (build-system python-build-system)
6050 (inputs
6051 `(("sqlite" ,sqlite)))
6052 (arguments
6053 `(#:phases
6054 (modify-phases %standard-phases
6055 (delete 'check)
6056 (add-after 'install 'check
6057 (lambda* (#:key inputs outputs #:allow-other-keys)
6058 (add-installed-pythonpath inputs outputs)
6059 (zero? (system* "python" "setup.py" "test")))))))
6060 (home-page "https://github.com/rogerbinns/apsw/")
6061 (synopsis "Another Python SQLite Wrapper")
6062 (description "APSW is a Python wrapper for the SQLite
6063 embedded relational database engine. In contrast to other wrappers such as
6064 pysqlite it focuses on being a minimal layer over SQLite attempting just to
6065 translate the complete SQLite API into Python.")
6066 (license license:zlib)))
6067
6068 (define-public python2-apsw
6069 (package-with-python2 python-apsw))
6070
6071 (define-public python-lxml
6072 (package
6073 (name "python-lxml")
6074 (version "3.6.0")
6075 (source
6076 (origin
6077 (method url-fetch)
6078 (uri (pypi-uri "lxml" version))
6079 (sha256
6080 (base32
6081 "1pvbmiy2m7jwv493kilbghhj2pkh8wy1na3ji350vhzhlwlclx4w"))))
6082 (build-system python-build-system)
6083 (inputs
6084 `(("libxml2" ,libxml2)
6085 ("libxslt" ,libxslt)))
6086 (home-page "http://lxml.de/")
6087 (synopsis
6088 "Python XML processing library")
6089 (description
6090 "The lxml XML toolkit is a Pythonic binding for the C libraries
6091 libxml2 and libxslt.")
6092 (license license:bsd-3))) ; and a few more, see LICENSES.txt
6093
6094 (define-public python2-lxml
6095 (package-with-python2 python-lxml))
6096
6097 ;; beautifulsoup4 has a totally different namespace than 3.x,
6098 ;; and pypi seems to put it under its own name, so I guess we should too
6099 (define-public python-beautifulsoup4
6100 (package
6101 (name "python-beautifulsoup4")
6102 (version "4.5.3")
6103 (source
6104 (origin
6105 (method url-fetch)
6106 (uri (pypi-uri "beautifulsoup4" version))
6107 (sha256
6108 (base32
6109 "0glaw1vyxnbp03fni7h5496n6iib0n5iim4gax1n0ngscs9s075j"))))
6110 (build-system python-build-system)
6111 (arguments
6112 `(#:phases
6113 (modify-phases %standard-phases
6114 ;; The Python 2 source is the definitive source of beautifulsoup4. We
6115 ;; must use this conversion script when building with Python 3. The
6116 ;; conversion script also runs the tests.
6117 ;; For more information, see the file 'convert-py3k' in the source
6118 ;; distribution.
6119 (replace 'check
6120 (lambda _ (zero? (system* "./convert-py3k")))))))
6121 (home-page
6122 "http://www.crummy.com/software/BeautifulSoup/bs4/")
6123 (synopsis
6124 "Python screen-scraping library")
6125 (description
6126 "Beautiful Soup is a Python library designed for rapidly setting up
6127 screen-scraping projects. It offers Pythonic idioms for navigating,
6128 searching, and modifying a parse tree, providing a toolkit for
6129 dissecting a document and extracting what you need. It automatically
6130 converts incoming documents to Unicode and outgoing documents to UTF-8.")
6131 (license license:expat)
6132 (properties `((python2-variant . ,(delay python2-beautifulsoup4))))))
6133
6134 (define-public python2-beautifulsoup4
6135 (package
6136 (inherit (package-with-python2
6137 (strip-python2-variant python-beautifulsoup4)))
6138 (arguments `(#:python ,python-2))))
6139
6140 (define-public python-cssutils
6141 (package
6142 (name "python-cssutils")
6143 (version "1.0.1")
6144 (source
6145 (origin
6146 (method url-fetch)
6147 (uri (pypi-uri "cssutils" version))
6148 (sha256
6149 (base32
6150 "0qwha9x1wml2qmipbcz03gndnlwhzrjdvw9i09si247a90l8p8fq"))))
6151 (build-system python-build-system)
6152 (native-inputs
6153 `(("unzip" ,unzip))) ; for unpacking the source
6154 (arguments
6155 `(#:tests? #f)) ;tests require python-pbr < 1.7.0
6156 (home-page "http://cthedot.de/cssutils/")
6157 (synopsis
6158 "CSS Cascading Style Sheets library for Python")
6159 (description
6160 "Cssutils is a Python package for parsing and building CSS
6161 Cascading Style Sheets. Currently it provides a DOM only and no rendering
6162 options.")
6163 (license license:lgpl3+)))
6164
6165 (define-public python2-cssutils
6166 (package-with-python2 python-cssutils))
6167
6168 (define-public python-cssselect
6169 (package
6170 (name "python-cssselect")
6171 (version "0.9.2")
6172 (source
6173 (origin
6174 (method url-fetch)
6175 (uri (pypi-uri "cssselect" version))
6176 (sha256
6177 (base32
6178 "1xg6gbva1yswghiycmgincv6ab4bn7hpm720ndbj40h8xycmnfvi"))))
6179 (build-system python-build-system)
6180 (arguments
6181 ;; tests fail with message
6182 ;; AttributeError: 'module' object has no attribute 'tests'
6183 `(#:tests? #f))
6184 (home-page
6185 "https://pythonhosted.org/cssselect/")
6186 (synopsis
6187 "CSS3 selector parser and translator to XPath 1.0")
6188 (description
6189 "Cssselect ia a Python module that parses CSS3 Selectors and translates
6190 them to XPath 1.0 expressions. Such expressions can be used in lxml or
6191 another XPath engine to find the matching elements in an XML or HTML document.")
6192 (license license:bsd-3)))
6193
6194 (define-public python2-cssselect
6195 (package-with-python2 python-cssselect))
6196
6197 (define-public python-openid-cla
6198 (package
6199 (name "python-openid-cla")
6200 (version "1.2")
6201 (source
6202 (origin
6203 (method url-fetch)
6204 (uri (pypi-uri "python-openid-cla" version))
6205 (sha256
6206 (base32
6207 "102hy2qisvjxp5s0v9lvwqi4f2dk0dhns40vjgn008yxc7k0h3cr"))))
6208 (build-system python-build-system)
6209 (arguments '(#:tests? #f)) ; No tests.
6210 (home-page "https://github.com/puiterwijk/python-openid-cla/")
6211 (synopsis "Implementation of the OpenID CLA extension for python-openid")
6212 (description "@code{openid-cla} is an implementation of the OpenID
6213 contributor license agreement extension for python-openid.")
6214 (license license:bsd-3)))
6215
6216 (define-public python2-openid-cla
6217 (package-with-python2 python-openid-cla))
6218
6219 (define-public python-openid-teams
6220 (package
6221 (name "python-openid-teams")
6222 (version "1.1")
6223 (source
6224 (origin
6225 (method url-fetch)
6226 (uri (pypi-uri "python-openid-teams" version))
6227 (sha256
6228 (base32
6229 "05zrh78alav24rxkbqlpbad6d3x2nljk6z6j7kflxf3vdqa7w969"))))
6230 (build-system python-build-system)
6231 (arguments '(#:tests? #f)) ; No tests.
6232 (home-page "https://github.com/puiterwijk/python-openid-teams/")
6233 (synopsis "Implementation of the OpenID teams extension for python-openid")
6234 (description
6235 "@code{openid-teams} is an implementation of the OpenID
6236 teams extension for python-openid.")
6237 (license license:bsd-3)))
6238
6239 (define-public python2-openid-teams
6240 (package-with-python2 python-openid-teams))
6241
6242 (define-public python-netifaces
6243 (package
6244 (name "python-netifaces")
6245 (version "0.10.4")
6246 (source
6247 (origin
6248 (method url-fetch)
6249 (uri (string-append
6250 "https://pypi.python.org/packages/source/n/netifaces/netifaces-"
6251 version
6252 ".tar.gz"))
6253 (sha256
6254 (base32
6255 "1plw237a4zib4z8s62g0mrs8gm3kjfrp5sxh6bbk9nl3rdls2mln"))))
6256 (build-system python-build-system)
6257 (home-page
6258 "https://bitbucket.org/al45tair/netifaces")
6259 (synopsis
6260 "Python module for portable network interface information")
6261 (description
6262 "Netifaces is a Python module providing information on network
6263 interfaces in an easy and portable manner.")
6264 (license license:expat)))
6265
6266 (define-public python2-netifaces
6267 (package-with-python2 python-netifaces))
6268
6269 (define-public python-networkx
6270 (package
6271 (name "python-networkx")
6272 (version "1.11")
6273 (source
6274 (origin
6275 (method url-fetch)
6276 (uri (pypi-uri "networkx" version))
6277 (sha256
6278 (base32 "1f74s56xb4ggixiq0vxyfxsfk8p20c7a099lpcf60izv1php03hd"))))
6279 (build-system python-build-system)
6280 ;; python-decorator is needed at runtime
6281 (propagated-inputs
6282 `(("python-decorator" ,python-decorator)))
6283 (native-inputs
6284 `(("python-nose" ,python-nose)))
6285 (home-page "http://networkx.github.io/")
6286 (synopsis "Python module for creating and manipulating graphs and networks")
6287 (description
6288 "NetworkX is a Python package for the creation, manipulation, and study
6289 of the structure, dynamics, and functions of complex networks.")
6290 (license license:bsd-3)))
6291
6292 (define-public python2-networkx
6293 (package-with-python2 python-networkx))
6294
6295 (define-public snakemake
6296 (package
6297 (name "snakemake")
6298 (version "3.13.3")
6299 (source
6300 (origin
6301 (method url-fetch)
6302 (uri (pypi-uri "snakemake" version))
6303 (sha256
6304 (base32 "1nixb944r4hlskwkzc4wjs34b40xpxpw9gmhhm5p09gvmm22ap5d"))))
6305 (build-system python-build-system)
6306 (arguments
6307 ;; TODO: Package missing test dependencies.
6308 '(#:tests? #f
6309 #:phases
6310 (modify-phases %standard-phases
6311 ;; For cluster execution Snakemake will call Python. Since there is
6312 ;; no suitable PYTHONPATH set, cluster execution will fail. We fix
6313 ;; this by calling the snakemake wrapper instead.
6314 (add-after 'unpack 'call-wrapper-not-wrapped-snakemake
6315 (lambda* (#:key outputs #:allow-other-keys)
6316 (substitute* "snakemake/executors.py"
6317 (("\\{sys.executable\\} -m snakemake")
6318 (string-append (assoc-ref outputs "out")
6319 "/bin/snakemake")))
6320 #t)))))
6321 (propagated-inputs
6322 `(("python-wrapt" ,python-wrapt)
6323 ("python-requests" ,python-requests)))
6324 (home-page "https://bitbucket.org/snakemake/snakemake/wiki/Home")
6325 (synopsis "Python-based execution environment for make-like workflows")
6326 (description
6327 "Snakemake aims to reduce the complexity of creating workflows by
6328 providing a clean and modern domain specific specification language (DSL) in
6329 Python style, together with a fast and comfortable execution environment.")
6330 (license license:expat)))
6331
6332 (define-public python-seaborn
6333 (package
6334 (name "python-seaborn")
6335 (version "0.7.1")
6336 (source
6337 (origin
6338 (method url-fetch)
6339 (uri (pypi-uri "seaborn" version))
6340 (sha256
6341 (base32 "0pawrqc3mxpwd5g9pvi9gba02637bh5c8ldpp8izfwpfn52469zs"))))
6342 (build-system python-build-system)
6343 (arguments
6344 '(#:tests? #f)) ; Tests requires a running X11 server.
6345 (propagated-inputs
6346 `(("python-pandas" ,python-pandas)
6347 ("python-matplotlib" ,python-matplotlib)
6348 ("python-scipy" ,python-scipy)))
6349 (home-page "http://stanford.edu/~mwaskom/software/seaborn/")
6350 (synopsis "Statistical data visualization")
6351 (description
6352 "Seaborn is a library for making attractive and informative statistical
6353 graphics in Python. It is built on top of matplotlib and tightly integrated
6354 with the PyData stack, including support for numpy and pandas data structures
6355 and statistical routines from scipy and statsmodels.")
6356 (license license:bsd-3)
6357 (properties `((python2-variant . ,(delay python2-seaborn))))))
6358
6359 (define-public python2-seaborn
6360 (let ((base (package-with-python2 (strip-python2-variant python-seaborn))))
6361 (package
6362 (inherit base)
6363 (propagated-inputs `(("python2-pytz" ,python2-pytz)
6364 ,@(package-propagated-inputs base))))))
6365
6366 (define-public python-mpmath
6367 (package
6368 (name "python-mpmath")
6369 (version "0.19")
6370 (source (origin
6371 (method url-fetch)
6372 (uri (string-append "http://mpmath.org/files/mpmath-"
6373 version ".tar.gz"))
6374 (sha256
6375 (base32
6376 "08ijsr4ifrqv3cjc26mkw0dbvyygsa99in376hr4b96ddm1gdpb8"))))
6377 (build-system python-build-system)
6378 (arguments
6379 '(#:phases
6380 (modify-phases %standard-phases
6381 (replace 'check
6382 (lambda _
6383 (zero?
6384 (system* "python" "mpmath/tests/runtests.py" "-local")))))))
6385 (home-page "http://mpmath.org")
6386 (synopsis "Arbitrary-precision floating-point arithmetic in python")
6387 (description
6388 "@code{mpmath} can be used as an arbitrary-precision substitute for
6389 Python's float/complex types and math/cmath modules, but also does much
6390 more advanced mathematics.")
6391 (license license:bsd-3)))
6392
6393 (define-public python2-mpmath
6394 (package-with-python2 python-mpmath))
6395
6396 (define-public python-sympy
6397 (package
6398 (name "python-sympy")
6399 (version "1.0")
6400 (source
6401 (origin
6402 (method url-fetch)
6403 (uri (string-append
6404 "https://github.com/sympy/sympy/releases/download/sympy-"
6405 version "/sympy-" version ".tar.gz"))
6406 (sha256
6407 (base32 "1bpzjwr9hrr7w88v4vgnj9lr6vxcldc94si13n8xpr1rv08d5b1y"))))
6408 (build-system python-build-system)
6409 (propagated-inputs
6410 `(("python-mpmath" ,python-mpmath)))
6411 (home-page "http://www.sympy.org/")
6412 (synopsis "Python library for symbolic mathematics")
6413 (description
6414 "SymPy is a Python library for symbolic mathematics. It aims to become a
6415 full-featured computer algebra system (CAS) while keeping the code as simple
6416 as possible in order to be comprehensible and easily extensible.")
6417 (license license:bsd-3)))
6418
6419 (define-public python2-sympy
6420 (package-with-python2 python-sympy))
6421
6422 (define-public python-q
6423 (package
6424 (name "python-q")
6425 (version "2.6")
6426 (source
6427 (origin
6428 (method url-fetch)
6429 (uri (pypi-uri "q" version))
6430 (sha256
6431 (base32
6432 "1mgfazh8fkizh6walra2zv885f3lcgr3nb02v1frfm4p8ddcy3yy"))))
6433 (build-system python-build-system)
6434 (home-page "https://github.com/zestyping/q")
6435 (synopsis "Quick-and-dirty debugging output for tired programmers")
6436 (description
6437 "q is a Python module for \"print\" style of debugging Python code. It
6438 provides convenient short API for print out of values, tracebacks, and
6439 falling into the Python interpreter.")
6440 (license license:asl2.0)))
6441
6442 (define-public python2-q
6443 (package-with-python2 python-q))
6444
6445 (define-public python-testlib
6446 (package
6447 (name "python-testlib")
6448 (version "0.6.5")
6449 (source
6450 (origin
6451 (method url-fetch)
6452 (uri (string-append
6453 "https://pypi.python.org/packages/source/t/testlib/testlib-"
6454 version ".zip"))
6455 (sha256
6456 (base32 "1mz26cxn4x8bbgv0rn0mvj2z05y31rkc8009nvdlb3lam5b4mj3y"))))
6457 (build-system python-build-system)
6458 (native-inputs
6459 `(("unzip" ,unzip))) ; for unpacking the source
6460 (synopsis "Python micro test suite harness")
6461 (description "A micro unittest suite harness for Python.")
6462 (home-page "https://github.com/trentm/testlib")
6463 (license license:expat)))
6464
6465 (define-public python2-testlib
6466 (package-with-python2 python-testlib))
6467
6468 (define-public python2-xlib
6469 (package
6470 (name "python2-xlib")
6471 (version "0.14")
6472 (source (origin
6473 (method url-fetch)
6474 (uri (string-append "mirror://sourceforge/python-xlib/python-xlib"
6475 "/" version "/"
6476 "python-xlib-" version ".tar.gz"))
6477 (sha256
6478 (base32
6479 "1sv0447j0rx8cgs3jhjl695p5pv13ihglcjlrrz1kq05lsvb0wa7"))))
6480 (build-system python-build-system)
6481 (arguments
6482 `(#:python ,python-2 ;Python 2 only
6483 #:tests? #f)) ;no tests
6484 (home-page "http://python-xlib.sourceforge.net/")
6485 (synopsis "Python X11 client library")
6486 (description
6487 "The Python X Library is intended to be a fully functional X client
6488 library for Python programs. It is useful to implement low-level X clients.
6489 It is written entirely in Python.")
6490 (license license:gpl2+)))
6491
6492 (define-public python-singledispatch
6493 (package
6494 (name "python-singledispatch")
6495 (version "3.4.0.3")
6496 (source
6497 (origin
6498 (method url-fetch)
6499 (uri (pypi-uri "singledispatch" version))
6500 (sha256
6501 (base32
6502 "171b7ip0hsq5qm83np40h3phlr36ym18w0lay0a8v08kvy3sy1jv"))))
6503 (build-system python-build-system)
6504 (native-inputs
6505 `(("python-six" ,python-six))) ; required for conversion, not at run-time
6506 (home-page
6507 "http://docs.python.org/3/library/functools.html#functools.singledispatch")
6508 (synopsis "Backport of singledispatch feature from Python 3.4")
6509 (description
6510 "This library brings functools.singledispatch from Python 3.4 to Python
6511 2.6-3.3.")
6512 (license license:expat)))
6513
6514 (define-public python2-singledispatch
6515 (package-with-python2 python-singledispatch))
6516
6517 (define-public python-tornado
6518 (package
6519 (name "python-tornado")
6520 (version "4.5.1")
6521 (source
6522 (origin
6523 (method url-fetch)
6524 (uri (pypi-uri "tornado" version))
6525 (sha256
6526 (base32 "1zbkgcdfq81k298awrm8p0xwbwwn2p3nbizdglzfbkskhai082fv"))))
6527 (build-system python-build-system)
6528 (arguments
6529 '(;; FIXME: Two tests error out with:
6530 ;; AssertionError: b'Error in atexit._run_exitfuncs:\nFileNotF[44 chars]ry\n' != b''
6531 ;; #:phases
6532 ;; (modify-phases %standard-phases
6533 ;; (replace 'check
6534 ;; (lambda _
6535 ;; ;; 'setup.py test' hits an AssertionError on BSD-specific
6536 ;; ;; "tornado/platform/kqueue.py". This is the supported method:
6537 ;; (zero? (system* "python" "-m" "tornado.test")))))
6538 #:tests? #f))
6539 (native-inputs
6540 `(("python-certifi" ,python-certifi)))
6541 (propagated-inputs
6542 `(("python-backports-abc" ,python-backports-abc)))
6543 (home-page "http://www.tornadoweb.org/")
6544 (synopsis "Python web framework and asynchronous networking library")
6545 (description
6546 "Tornado is a Python web framework and asynchronous networking library,
6547 originally developed at FriendFeed. By using non-blocking network I/O,
6548 Tornado can scale to tens of thousands of open connections, making it ideal
6549 for long polling, WebSockets, and other applications that require a long-lived
6550 connection to each user.")
6551 (license license:asl2.0)
6552 (properties `((python2-variant . ,(delay python2-tornado))))))
6553
6554 (define-public python2-tornado
6555 (let ((tornado (package-with-python2 (strip-python2-variant python-tornado))))
6556 (package (inherit tornado)
6557 (propagated-inputs
6558 `(("python2-backport-ssl-match-hostname"
6559 ,python2-backport-ssl-match-hostname)
6560 ("python2-singledispatch" ,python2-singledispatch)
6561 ,@(package-propagated-inputs tornado))))))
6562
6563 ;; the python- version can be removed with python-3.5
6564 (define-public python-backports-abc
6565 (package
6566 (name "python-backports-abc")
6567 (version "0.5")
6568 (source
6569 (origin
6570 (method url-fetch)
6571 (uri (pypi-uri "backports_abc" version))
6572 (sha256
6573 (base32
6574 "1pkv8d1zxj5f9i227dxbjczncbv7ks7ywnjwyxfjagm02i2yafq3"))))
6575 (build-system python-build-system)
6576 (home-page "https://github.com/cython/backports_abc")
6577 (synopsis "Backport of additions to the 'collections.abc' module")
6578 (description
6579 "Python-backports-abc provides a backport of additions to the
6580 'collections.abc' module in Python-3.5.")
6581 (license license:psfl)))
6582
6583 (define-public python2-backports-abc
6584 (package-with-python2 python-backports-abc))
6585
6586 (define-public python-backports-csv
6587 (package
6588 (name "python-backports-csv")
6589 (version "1.0.5")
6590 (source
6591 (origin
6592 (method url-fetch)
6593 (uri (pypi-uri "backports.csv" version))
6594 (sha256
6595 (base32
6596 "1imzbrradkfn8s2m1qcimyn74dn1mz2p3j381jljn166rf2i6hlc"))))
6597 (build-system python-build-system)
6598 (home-page "https://github.com/ryanhiebert/backports.csv")
6599 (synopsis "Backport of Python 3's csv module for Python 2")
6600 (description
6601 "Provides a backport of Python 3's @code{csv} module for parsing
6602 comma separated values. The API of the @code{csv} module in Python 2
6603 is drastically different from the @code{csv} module in Python 3.
6604 This is due, for the most part, to the difference between str in
6605 Python 2 and Python 3.")
6606 (license license:psfl)))
6607
6608 (define-public python2-backports-csv
6609 (package-with-python2 python-backports-csv))
6610
6611 (define-public python2-backports-shutil-get-terminal-size
6612 (package
6613 (name "python2-backports-shutil-get-terminal-size")
6614 (version "1.0.0")
6615 (source
6616 (origin
6617 (method url-fetch)
6618 (uri (pypi-uri "backports.shutil_get_terminal_size" version))
6619 (sha256
6620 (base32
6621 "107cmn7g3jnbkp826zlj8rrj19fam301qvaqf0f3905f5217lgki"))))
6622 (build-system python-build-system)
6623 (arguments
6624 `(#:python ,python-2
6625 #:phases
6626 (modify-phases %standard-phases
6627 (replace 'check
6628 (lambda _
6629 (zero? (system* "py.test" "-v")))))))
6630 (native-inputs
6631 `(("python2-pytest" ,python2-pytest)))
6632 (home-page "https://github.com/chrippa/backports.shutil_get_terminal_size")
6633 (synopsis "Backport of Python 3.3's @code{shutil.get_terminal_size}")
6634 (description
6635 "This package provides a backport of the @code{get_terminal_size
6636 function} from Python 3.3's @code{shutil}.
6637 Unlike the original version it is written in pure Python rather than C,
6638 so it might be a tiny bit slower.")
6639 (license license:expat)))
6640
6641 (define-public python-waf
6642 (package
6643 (name "python-waf")
6644 (version "1.9.8")
6645 (source (origin
6646 (method url-fetch)
6647 (uri (string-append "https://waf.io/"
6648 "waf-" version ".tar.bz2"))
6649 (sha256
6650 (base32
6651 "0wl4cnmp06lfxqjxaan58bqxn27smhydz0sg5prrfbl3bsw4gv6q"))))
6652 (build-system python-build-system)
6653 (arguments
6654 '(#:phases
6655 (modify-phases %standard-phases
6656 (replace 'build
6657 (lambda _
6658 (zero? (system* "python" "waf-light" "configure" "build"))))
6659 (replace 'check
6660 (lambda _
6661 (zero? (system* "python" "waf" "--version"))))
6662 (replace 'install
6663 (lambda _
6664 (copy-file "waf" %output))))))
6665 (home-page "https://waf.io/")
6666 (synopsis "Python-based build system")
6667 (description
6668 "Waf is a Python-based framework for configuring, compiling and installing
6669 applications.")
6670 (license license:bsd-3)))
6671
6672 (define-public python2-waf
6673 (package-with-python2 python-waf))
6674
6675 (define-public python-pyzmq
6676 (package
6677 (name "python-pyzmq")
6678 (version "15.1.0")
6679 (source
6680 (origin
6681 (method url-fetch)
6682 (uri (pypi-uri "pyzmq" version))
6683 (sha256
6684 (base32 "13fhwnlvsvxv72kfhqbpn6qi7msh8mc8377mpabv32skk2cjfnxx"))))
6685 (build-system python-build-system)
6686 (arguments
6687 `(#:configure-flags
6688 (list (string-append "--zmq=" (assoc-ref %build-inputs "zeromq")))
6689 ;; FIXME: You must build pyzmq with 'python setup.py build_ext
6690 ;; --inplace' for 'python setup.py test' to work.
6691 #:tests? #f))
6692 (inputs
6693 `(("zeromq" ,zeromq)))
6694 (native-inputs
6695 `(("pkg-config" ,pkg-config)
6696 ("python-nose" ,python-nose)))
6697 (home-page "https://github.com/zeromq/pyzmq")
6698 (synopsis "Python bindings for 0MQ")
6699 (description
6700 "PyZMQ is the official Python binding for the ZeroMQ messaging library.")
6701 (license license:bsd-4)))
6702
6703 (define-public python2-pyzmq
6704 (package-with-python2 python-pyzmq))
6705
6706 (define-public python-pep8
6707 (package
6708 (name "python-pep8")
6709 (version "1.7.0")
6710 (source
6711 (origin
6712 (method url-fetch)
6713 (uri (pypi-uri "pep8" version))
6714 (sha256
6715 (base32
6716 "002rkl4lsn6x2mxmf8ar00l0m8i3mzrc6pnzz77blyksmpsxa4x1"))))
6717 (build-system python-build-system)
6718 (home-page "http://pep8.readthedocs.org/")
6719 (synopsis "Python style guide checker")
6720 (description
6721 "This tools checks Python code against some of the style conventions in
6722 PEP 8.")
6723 (license license:expat)))
6724
6725 (define-public python2-pep8
6726 (package-with-python2 python-pep8))
6727
6728 (define-public python-pyflakes
6729 (package
6730 (name "python-pyflakes")
6731 (version "1.0.0")
6732 (source
6733 (origin
6734 (method url-fetch)
6735 (uri (pypi-uri "pyflakes" version))
6736 (sha256
6737 (base32
6738 "0qs2sgqszq7wcplis8509wk2ygqcrwzbs1ghfj3svvivq2j377pk"))))
6739 (build-system python-build-system)
6740 (home-page
6741 "https://github.com/pyflakes/pyflakes")
6742 (synopsis "Passive checker of Python programs")
6743 (description
6744 "Pyflakes statically checks Python source code for common errors.")
6745 (license license:expat)))
6746
6747 (define-public python2-pyflakes
6748 (package-with-python2 python-pyflakes))
6749
6750 (define-public python-mccabe
6751 (package
6752 (name "python-mccabe")
6753 (version "0.4.0")
6754 (source
6755 (origin
6756 (method url-fetch)
6757 (uri (pypi-uri "mccabe" version))
6758 (sha256
6759 (base32
6760 "0yr08a36h8lqlif10l4xcikbbig7q8f41gqywir7rrvnv3mi4aws"))))
6761 (build-system python-build-system)
6762 (native-inputs
6763 `(("python-pytest" ,python-pytest)
6764 ("python-pytest-runner" ,python-pytest-runner)))
6765 (home-page "https://github.com/flintwork/mccabe")
6766 (synopsis "McCabe checker, plugin for flake8")
6767 (description
6768 "This package provides a Flake8 plug-in to compute the McCabe cyclomatic
6769 complexity of Python source code.")
6770 (license license:expat)))
6771
6772 (define-public python2-mccabe
6773 (package-with-python2 python-mccabe))
6774
6775 (define-public python-mccabe-0.2.1
6776 (package (inherit python-mccabe)
6777 (version "0.2.1")
6778 (source
6779 (origin
6780 (method url-fetch)
6781 (uri (pypi-uri "mccabe" version))
6782 (sha256
6783 (base32
6784 "0fi4a81kr5bcv5p4xgibqr595hyj5dafkqgsmfk96mfy8w71fajs"))))))
6785
6786 (define-public python2-mccabe-0.2.1
6787 (package-with-python2 python-mccabe-0.2.1))
6788
6789 ;; Flake8 2.4.1 requires an older version of pep8.
6790 ;; This should be removed ASAP.
6791 (define-public python-pep8-1.5.7
6792 (package (inherit python-pep8)
6793 (version "1.5.7")
6794 (source
6795 (origin
6796 (method url-fetch)
6797 (uri (string-append
6798 "https://pypi.python.org/packages/source/p/pep8/pep8-"
6799 version
6800 ".tar.gz"))
6801 (sha256
6802 (base32
6803 "12b9bbdbwnspxgak14xg58c130x2n0blxzlms5jn2dszn8qj3d0m"))))
6804 (arguments
6805 ;; XXX Tests not compatible with Python 3.5.
6806 '(#:tests? #f))))
6807
6808 (define-public python2-pep8-1.5.7
6809 (package-with-python2 python-pep8-1.5.7))
6810
6811 ;; Flake8 2.4.1 requires an older version of pyflakes.
6812 ;; This should be removed ASAP.
6813 (define-public python-pyflakes-0.8.1
6814 (package (inherit python-pyflakes)
6815 (version "0.8.1")
6816 (source
6817 (origin
6818 (method url-fetch)
6819 (uri (string-append
6820 "https://pypi.python.org/packages/source/p/pyflakes/pyflakes-"
6821 version
6822 ".tar.gz"))
6823 (sha256
6824 (base32
6825 "0sbpq6pqm1i9wqi41mlfrsc5rk92jv4mskvlyxmnhlbdnc80ma1z"))))
6826 (arguments
6827 ;; XXX Tests not compatible with Python 3.5.
6828 '(#:tests? #f))))
6829
6830 (define-public python2-pyflakes-0.8.1
6831 (package-with-python2 python-pyflakes-0.8.1))
6832
6833 (define-public python-flake8
6834 (package
6835 (name "python-flake8")
6836 (version "2.5.4")
6837 (source
6838 (origin
6839 (method url-fetch)
6840 (uri (pypi-uri "flake8" version))
6841 (sha256
6842 (base32
6843 "0bs9cz4fr99r2rwig1b8jwaadl1nan7kgpdzqwj0bwbckwbmh7nc"))
6844 (modules '((guix build utils)))
6845 (snippet
6846 '(begin
6847 ;; Remove pre-compiled .pyc files from source.
6848 (for-each delete-file-recursively
6849 (find-files "." "__pycache__" #:directories? #t))
6850 (for-each delete-file (find-files "." "\\.pyc$"))
6851 #t))))
6852 (build-system python-build-system)
6853 (propagated-inputs
6854 `(("python-pep8" ,python-pep8)
6855 ("python-pyflakes" ,python-pyflakes)
6856 ("python-mccabe" ,python-mccabe)))
6857 (native-inputs
6858 `(("python-mock" ,python-mock) ; TODO: only required for < 3.3
6859 ("python-nose" ,python-nose)))
6860 (home-page "https://gitlab.com/pycqa/flake8")
6861 (synopsis
6862 "The modular source code checker: pep8, pyflakes and co")
6863 (description
6864 "Flake8 is a wrapper around PyFlakes, pep8 and python-mccabe.")
6865 (license license:expat)))
6866
6867 (define-public python2-flake8
6868 (package-with-python2 python-flake8))
6869
6870 (define-public python-flake8-polyfill
6871 (package
6872 (name "python-flake8-polyfill")
6873 (version "1.0.1")
6874 (source
6875 (origin
6876 (method url-fetch)
6877 (uri (pypi-uri "flake8-polyfill" version))
6878 (sha256
6879 (base32
6880 "02gn2wxvh9vnf7m7dld7ca4l60mg5c370hv3swwppkngwaqmcw67"))))
6881 (build-system python-build-system)
6882 (arguments
6883 '(#:phases
6884 (modify-phases %standard-phases
6885 (replace 'check
6886 (lambda _
6887 (setenv "PYTHONPATH"
6888 (string-append (getcwd) "/build/lib:"
6889 (getenv "PYTHONPATH")))
6890 (zero? (system* "py.test" "-v")))))))
6891 (native-inputs
6892 `(("python-flake8" ,python-flake8)
6893 ("python-mock" ,python-mock)
6894 ("python-pycodestyle" ,python-pycodestyle)
6895 ("python-pytest" ,python-pytest)))
6896 (home-page "https://gitlab.com/pycqa/flake8-polyfill")
6897 (synopsis "Polyfill package for Flake8 plugins")
6898 (description
6899 "This package that provides some compatibility helpers for Flake8
6900 plugins that intend to support Flake8 2.x and 3.x simultaneously.")
6901 (license license:expat)))
6902
6903 (define-public python2-flake8-polyfill
6904 (package-with-python2 python-flake8-polyfill))
6905
6906 (define-public python-mistune
6907 (package
6908 (name "python-mistune")
6909 (version "0.7.3")
6910 (source
6911 (origin
6912 (method url-fetch)
6913 (uri (pypi-uri "mistune" version))
6914 (sha256
6915 (base32
6916 "04xpk1zvslhq3xpnf01g3ag0dy9wfv4z28p093r8k49vvxlyil11"))))
6917 (build-system python-build-system)
6918 (native-inputs
6919 `(("python-nose" ,python-nose)
6920 ("python-cython" ,python-cython)))
6921 (home-page "https://github.com/lepture/mistune")
6922 (synopsis "Markdown parser in pure Python")
6923 (description "This package provides a fast markdown parser in pure
6924 Python.")
6925 (license license:bsd-3)))
6926
6927 (define-public python2-mistune
6928 (package-with-python2 python-mistune))
6929
6930 (define-public python-markdown
6931 (package
6932 (name "python-markdown")
6933 (version "2.6.8")
6934 (source
6935 (origin
6936 (method url-fetch)
6937 (uri (pypi-uri "Markdown" version))
6938 (sha256
6939 (base32
6940 "0cqfhr1km2s5d8jm6hbwgkrrj9hvkjf2gab3s2axlrw1clgaij0a"))))
6941 (build-system python-build-system)
6942 (arguments
6943 `(#:phases
6944 (modify-phases %standard-phases
6945 (replace 'check
6946 (lambda _
6947 (zero? (system* "python" "run-tests.py")))))))
6948 (native-inputs
6949 `(("python-nose" ,python-nose)
6950 ("python-pyyaml" ,python-pyyaml)))
6951 (home-page "https://pythonhosted.org/Markdown/")
6952 (synopsis "Python implementation of Markdown")
6953 (description
6954 "This package provides a Python implementation of John Gruber's
6955 Markdown. The library features international input, various Markdown
6956 extensions, and several HTML output formats. A command line wrapper
6957 markdown_py is also provided to convert Markdown files to HTML.")
6958 (license license:bsd-3)))
6959
6960 (define-public python2-markdown
6961 (package-with-python2 python-markdown))
6962
6963 (define-public python-ptyprocess
6964 (package
6965 (name "python-ptyprocess")
6966 (version "0.5.1")
6967 (source
6968 (origin
6969 (method url-fetch)
6970 (uri (string-append
6971 "https://pypi.python.org/packages/source/p/ptyprocess/ptyprocess-"
6972 version ".tar.gz"))
6973 (sha256
6974 (base32
6975 "19l1xrjn4l9gjz01s3vg92gn2dd9d8mw1v86ppkzlnr9m5iwwc05"))))
6976 (build-system python-build-system)
6977 (native-inputs
6978 `(("python-nose" ,python-nose)))
6979 (arguments
6980 `(#:phases
6981 (modify-phases %standard-phases
6982 (replace 'check
6983 (lambda _
6984 (zero? (system* "nosetests")))))))
6985 (home-page "https://github.com/pexpect/ptyprocess")
6986 (synopsis "Run a subprocess in a pseudo terminal")
6987 (description
6988 "This package provides a Python library used to launch a subprocess in a
6989 pseudo terminal (pty), and interact with both the process and its pty.")
6990 (license license:isc)))
6991
6992 (define-public python2-ptyprocess
6993 (package-with-python2 python-ptyprocess))
6994
6995 (define-public python-cram
6996 (package
6997 (name "python-cram")
6998 (version "0.7")
6999 (home-page "https://bitheap.org/cram/")
7000 (source (origin
7001 (method url-fetch)
7002 (uri (list (string-append home-page "cram-"
7003 version ".tar.gz")
7004 (pypi-uri "cram" version)))
7005 (sha256
7006 (base32
7007 "0bvz6fwdi55rkrz3f50zsy35gvvwhlppki2yml5bj5ffy9d499vx"))))
7008 (arguments
7009 '(#:phases
7010 (modify-phases %standard-phases
7011 (add-after 'unpack 'patch-source
7012 (lambda _
7013 (substitute* (find-files "cram" ".*\\.py$")
7014 ;; Replace default shell path.
7015 (("/bin/sh") (which "sh")))
7016 (substitute* (find-files "tests" ".*\\.t$")
7017 (("md5") "md5sum")
7018 (("/bin/bash") (which "bash"))
7019 (("/bin/sh") (which "sh")))
7020 (substitute* "cram/_test.py"
7021 ;; This hack works around a bug triggered by substituting
7022 ;; the /bin/sh paths. "tests/usage.t" compares the output of
7023 ;; "cram -h", which breaks the output at 80 characters. This
7024 ;; causes the line showing the default shell to break into two
7025 ;; lines, but the test expects a single line...
7026 (("env\\['COLUMNS'\\] = '80'")
7027 "env['COLUMNS'] = '160'"))
7028 #t))
7029 (delete 'check)
7030 (add-after 'install 'check
7031 ;; The test phase uses the built library and executable.
7032 ;; It's easier to run it after install since the build
7033 ;; directory contains version-specific PATH.
7034 (lambda* (#:key inputs outputs #:allow-other-keys)
7035 (add-installed-pythonpath inputs outputs)
7036 (setenv "PATH" (string-append (getenv "PATH") ":"
7037 (assoc-ref outputs "out") "/bin"))
7038 (zero? (system* "make" "test")))))))
7039 (build-system python-build-system)
7040 (native-inputs
7041 `(("python-coverage" ,python-coverage)
7042 ("which" ,which)))
7043 (synopsis "Simple testing framework for command line applications")
7044 (description
7045 "Cram is a functional testing framework for command line applications.
7046 Cram tests look like snippets of interactive shell sessions. Cram runs each
7047 command and compares the command output in the test with the command’s actual
7048 output.")
7049 (license license:gpl2+)))
7050
7051 (define-public python2-cram
7052 (package-with-python2 python-cram))
7053
7054 (define-public python-terminado
7055 (package
7056 (name "python-terminado")
7057 (version "0.6")
7058 (source
7059 (origin
7060 (method url-fetch)
7061 (uri (pypi-uri "terminado" version))
7062 (sha256
7063 (base32
7064 "09h1kwi86g5mrk14s4pgbhshd602zry29lnpxamcqz864kva22rc"))))
7065 (build-system python-build-system)
7066 (propagated-inputs
7067 `(("python-tornado" ,python-tornado)
7068 ("python-ptyprocess" ,python-ptyprocess)))
7069 (native-inputs
7070 `(("python-nose" ,python-nose)))
7071 (arguments
7072 `(#:phases
7073 (modify-phases %standard-phases
7074 (replace 'check
7075 (lambda _
7076 (zero? (system* "nosetests")))))))
7077 (home-page "https://github.com/takluyver/terminado")
7078 (synopsis "Terminals served to term.js using Tornado websockets")
7079 (description "This package provides a Tornado websocket backend for the
7080 term.js Javascript terminal emulator library.")
7081 (license license:bsd-2)
7082 (properties `((python2-variant . ,(delay python2-terminado))))))
7083
7084 (define-public python2-terminado
7085 (let ((terminado (package-with-python2 (strip-python2-variant python-terminado))))
7086 (package (inherit terminado)
7087 (propagated-inputs
7088 `(("python2-backport-ssl-match-hostname"
7089 ,python2-backport-ssl-match-hostname)
7090 ,@(package-propagated-inputs terminado))))))
7091
7092 (define-public python-straight-plugin
7093 (package
7094 (name "python-straight-plugin")
7095 (version "1.4.1")
7096 (source
7097 (origin
7098 (method url-fetch)
7099 (uri (pypi-uri "straight.plugin" version))
7100 (sha256
7101 (base32
7102 "069pjll4383p4kkgvcc40hgyvf79j2wdbpgwz77yigzxksh1gj62"))))
7103 (build-system python-build-system)
7104 (home-page "https://github.com/ironfroggy/straight.plugin")
7105 (synopsis "Simple namespaced plugin facility")
7106 (description "Straight Plugin provides a type of plugin you can create from
7107 almost any existing Python modules, and an easy way for outside developers to
7108 add functionality and customization to your projects with their own plugins.")
7109 (license license:expat)))
7110
7111 (define-public python2-straight-plugin
7112 (package-with-python2 python-straight-plugin))
7113
7114 (define-public python-fonttools
7115 (package
7116 (name "python-fonttools")
7117 (version "2.5")
7118 (source (origin
7119 (method url-fetch)
7120 (uri (string-append
7121 "https://pypi.python.org/packages/source/F/FontTools/"
7122 "fonttools-" version ".tar.gz"))
7123 (sha256
7124 (base32
7125 "08ay3x4ijarwhl60gqx2i9jzq6pxs20p4snc2d1q5jagh4rn39lb"))))
7126 (build-system python-build-system)
7127 (arguments
7128 '(#:test-target "check"
7129 #:phases
7130 (modify-phases %standard-phases
7131 (add-after 'unpack 'patch-setuppy
7132 ;; Remove the undocumented "extra_path" argument, which adds an
7133 ;; intervening directories between site-packages and the package
7134 ;; directory.
7135 (lambda _
7136 (substitute* "setup.py"
7137 (("^[ \t]*extra_path *= *'FontTools',") ""))
7138 #t)))))
7139 (home-page "https://github.com/behdad/fonttools")
7140 (synopsis "Tools to manipulate font files")
7141 (description
7142 "FontTools/TTX is a library to manipulate font files from Python. It
7143 supports reading and writing of TrueType/OpenType fonts, reading and writing
7144 of AFM files, reading (and partially writing) of PS Type 1 fonts. The package
7145 also contains a tool called “TTX” which converts TrueType/OpenType fonts to and
7146 from an XML-based format.")
7147 (license (license:non-copyleft
7148 "file://LICENSE.txt"
7149 "See LICENSE.txt in the distribution."))))
7150
7151 (define-public python2-fonttools
7152 (package-with-python2 python-fonttools))
7153
7154 (define-public python-ly
7155 (package
7156 (name "python-ly")
7157 (version "0.9.4")
7158 (source
7159 (origin
7160 (method url-fetch)
7161 (uri (string-append "https://pypi.python.org/packages/57/4f/"
7162 "889579244947368f28eda66b782331b1e75f83fd72e63f9ece93cd7a18f9"
7163 "/python-ly-" version ".tar.gz"))
7164 (sha256
7165 (base32
7166 "0g6n288l83sfwavxh1aryi0aqvsr3sp7v6f903mckwqa4scpky62"))))
7167 (build-system python-build-system)
7168 (arguments
7169 ;; FIXME: Some tests need network access.
7170 '(#:tests? #f))
7171 (synopsis "Tool and library for manipulating LilyPond files")
7172 (description "This package provides a Python library to parse, manipulate
7173 or create documents in LilyPond format. A command line program ly is also
7174 provided that can be used to do various manipulations with LilyPond files.")
7175 (home-page "https://pypi.python.org/pypi/python-ly")
7176 (license license:gpl2+)))
7177
7178 (define-public python-appdirs
7179 (package
7180 (name "python-appdirs")
7181 (version "1.4.3")
7182 (source
7183 (origin
7184 (method url-fetch)
7185 (uri (pypi-uri "appdirs" version))
7186 (sha256
7187 (base32
7188 "14id6wxi12lgyw0mg3bcfnf888ad07jz9yj46gfzhn186z8rcn4y"))))
7189 (build-system python-build-system)
7190 (home-page "https://github.com/ActiveState/appdirs")
7191 (synopsis
7192 "Determine platform-specific dirs, e.g. a \"user data dir\"")
7193 (description
7194 "This module provides a portable way of finding out where user data
7195 should be stored on various operating systems.")
7196 (license license:expat)))
7197
7198 (define-public python2-appdirs
7199 (package-with-python2 python-appdirs))
7200
7201 (define-public python-llfuse
7202 (package
7203 (name "python-llfuse")
7204 (version "1.2")
7205 (source (origin
7206 (method url-fetch)
7207 (uri (string-append
7208 "https://bitbucket.org/nikratio/python-llfuse/downloads/"
7209 "llfuse-" version ".tar.bz2"))
7210 (sha256
7211 (base32
7212 "11hms1x68bf1bqbqy7w3wpffqsd3jkgricmzrc1hrnwkswfzzlr4"))))
7213 (build-system python-build-system)
7214 (inputs
7215 `(("fuse" ,fuse)
7216 ("attr" ,attr)))
7217 (native-inputs
7218 `(("pkg-config" ,pkg-config)))
7219 (synopsis "Python bindings for FUSE")
7220 (description
7221 "Python-LLFUSE is a set of Python bindings for the low level FUSE API.")
7222 (home-page "https://bitbucket.org/nikratio/python-llfuse/")
7223 (license license:lgpl2.0+)
7224 (properties `((python2-variant . ,(delay python2-llfuse))))))
7225
7226 (define-public python2-llfuse
7227 (package (inherit (package-with-python2
7228 (strip-python2-variant python-llfuse)))
7229 (propagated-inputs `(("python2-contextlib2" ,python2-contextlib2)))))
7230
7231 ;; For attic-0.16
7232 (define-public python-llfuse-0.41
7233 (package (inherit python-llfuse)
7234 (version "0.41.1")
7235 (source (origin
7236 (method url-fetch)
7237 (uri (string-append
7238 "https://bitbucket.org/nikratio/python-llfuse/downloads/"
7239 "llfuse-" version ".tar.bz2"))
7240 (sha256
7241 (base32
7242 "1imlqw9b73086y97izr036f58pgc5akv4ihc2rrf8j5h75jbrlaa"))))
7243 ;; Python-LLFUSE < 0.42 includes underscore.js, which is MIT (expat)
7244 ;; licensed. The rest of the package is licensed under LGPL2.0 or later.
7245 (license (list license:expat license:lgpl2.0+))))
7246
7247 (define-public python-msgpack
7248 (package
7249 (name "python-msgpack")
7250 (version "0.4.8")
7251 (source (origin
7252 (method url-fetch)
7253 (uri (pypi-uri "msgpack-python" version))
7254 (sha256
7255 (base32
7256 "11pqk5braa6wndpnr1dhg64js82vjgxnm0lzy73rwl831zgijaqs"))))
7257 (build-system python-build-system)
7258 (synopsis "MessagePack (de)serializer")
7259 (description "MessagePack is a fast, compact binary serialization format,
7260 suitable for similar data to JSON. This package provides CPython bindings for
7261 reading and writing MessagePack data.")
7262 (home-page "https://pypi.python.org/pypi/msgpack-python/")
7263 (license license:asl2.0)))
7264
7265 (define-public python2-msgpack
7266 (package-with-python2 python-msgpack))
7267
7268 (define-public python-netaddr
7269 (package
7270 (name "python-netaddr")
7271 (version "0.7.18")
7272 (source
7273 (origin
7274 (method url-fetch)
7275 (uri (string-append
7276 "https://pypi.python.org/packages/source/n/netaddr/netaddr-"
7277 version
7278 ".tar.gz"))
7279 (sha256
7280 (base32
7281 "06dxjlbcicq7q3vqy8agq11ra01kvvd47j4mk6dmghjsyzyckxd1"))))
7282 (build-system python-build-system)
7283 (arguments `(#:tests? #f)) ;; No tests.
7284 (home-page "https://github.com/drkjam/netaddr/")
7285 (synopsis "Pythonic manipulation of network addresses")
7286 (description
7287 "A Python library for representing and manipulating IPv4, IPv6, CIDR, EUI
7288 and MAC network addresses.")
7289 (license license:bsd-3)))
7290
7291 (define-public python2-netaddr
7292 (package-with-python2 python-netaddr))
7293
7294 (define-public python-wrapt
7295 (package
7296 (name "python-wrapt")
7297 (version "1.10.8")
7298 (source
7299 (origin
7300 (method url-fetch)
7301 (uri (pypi-uri "wrapt" version))
7302 (sha256
7303 (base32
7304 "0wrcm1mydvfivbkzz0h81ygzdchnscshi6xvy5n3r21r9s0px8af"))))
7305 (build-system python-build-system)
7306 (arguments
7307 ;; Tests are not included in the tarball, they are only available in the
7308 ;; git repository.
7309 `(#:tests? #f))
7310 (home-page "https://github.com/GrahamDumpleton/wrapt")
7311 (synopsis "Module for decorators, wrappers and monkey patching")
7312 (description
7313 "The aim of the wrapt module is to provide a transparent object proxy for
7314 Python, which can be used as the basis for the construction of function
7315 wrappers and decorator functions.")
7316 (license license:bsd-2)))
7317
7318 (define-public python2-wrapt
7319 (package-with-python2 python-wrapt))
7320
7321 (define-public python-iso8601
7322 (package
7323 (name "python-iso8601")
7324 (version "0.1.11")
7325 (source
7326 (origin
7327 (method url-fetch)
7328 (uri (pypi-uri "iso8601" version))
7329 (sha256
7330 (base32
7331 "0c7gh3lsdjds262h0v1sqc66l7hqgfwbakn96qrhdbl0i3vm5yz8"))))
7332 (build-system python-build-system)
7333 (native-inputs
7334 `(("python-pytest" ,python-pytest)))
7335 (home-page "https://bitbucket.org/micktwomey/pyiso8601")
7336 (synopsis "Module to parse ISO 8601 dates")
7337 (description
7338 "This module parses the most common forms of ISO 8601 date strings (e.g.
7339 @code{2007-01-14T20:34:22+00:00}) into @code{datetime} objects.")
7340 (license license:expat)))
7341
7342 (define-public python2-iso8601
7343 (package-with-python2 python-iso8601))
7344
7345 (define-public python-monotonic
7346 (package
7347 (name "python-monotonic")
7348 (version "0.3")
7349 (source
7350 (origin
7351 (method url-fetch)
7352 (uri (string-append
7353 "https://pypi.python.org/packages/source/m/monotonic/monotonic-"
7354 version
7355 ".tar.gz"))
7356 (sha256
7357 (base32
7358 "0yz0bcbwx8r2c01czzfpbrxddynxyk9k95jj8h6sgcb7xmfvl998"))))
7359 (build-system python-build-system)
7360 (home-page "https://github.com/atdt/monotonic")
7361 (synopsis "Implementation of time.monotonic() for Python 2 & < 3.3")
7362 (description
7363 "This module provides a monotonic() function which returns the value (in
7364 fractional seconds) of a clock which never goes backwards.")
7365 (license license:asl2.0)))
7366
7367 (define-public python2-monotonic
7368 (package-with-python2 python-monotonic))
7369
7370 (define-public python-webob
7371 (package
7372 (name "python-webob")
7373 (version "1.5.1")
7374 (source
7375 (origin
7376 (method url-fetch)
7377 (uri (pypi-uri "WebOb" version))
7378 (sha256
7379 (base32
7380 "02bhhzijfhv8hmi1i54d4b0v43liwhnywhflvxsv4x3zax9s3afq"))))
7381 (build-system python-build-system)
7382 (native-inputs
7383 `(("python-nose" ,python-nose)))
7384 (home-page "http://webob.org/")
7385 (synopsis "WSGI request and response object")
7386 (description
7387 "WebOb provides wrappers around the WSGI request environment, and an
7388 object to help create WSGI responses.")
7389 (license license:expat)))
7390
7391 (define-public python2-webob
7392 (package-with-python2 python-webob))
7393
7394 (define-public python-xlrd
7395 (package
7396 (name "python-xlrd")
7397 (version "1.0.0")
7398 (source (origin
7399 (method url-fetch)
7400 (uri (pypi-uri "xlrd" version))
7401 (sha256
7402 (base32
7403 "0s8hjiz01vbhy85xalrz0qlsmd9ypf36zjqrf97hh984spapvy0g"))))
7404 (build-system python-build-system)
7405 (arguments
7406 `(#:phases
7407 (modify-phases %standard-phases
7408 ;; Current test in setup.py does not work as of 1.0.0, so use nose to
7409 ;; run tests instead for now.
7410 (replace 'check (lambda _ (zero? (system* "nosetests")))))))
7411 (native-inputs `(("python-nose" ,python-nose)))
7412 (home-page "http://www.python-excel.org/")
7413 (synopsis "Library for extracting data from Excel files")
7414 (description "This packages provides a library to extract data from
7415 spreadsheets using Microsoft Excel proprietary file formats @samp{.xls} and
7416 @samp{.xlsx} (versions 2.0 onwards). It has support for Excel dates and is
7417 Unicode-aware. It is not intended as an end-user tool.")
7418 (license license:bsd-3)))
7419
7420 (define-public python2-xlrd
7421 (package-with-python2 python-xlrd))
7422
7423 (define-public python-prettytable
7424 (package
7425 (name "python-prettytable")
7426 (version "0.7.2")
7427 (source
7428 (origin
7429 (method url-fetch)
7430 (uri (string-append
7431 "https://pypi.python.org/packages/source/P/PrettyTable/"
7432 "prettytable-" version ".tar.bz2"))
7433 (sha256
7434 (base32
7435 "0diwsicwmiq2cpzpxri7cyl5fmsvicafw6nfqf6p6p322dji2g45"))))
7436 (build-system python-build-system)
7437 (home-page "http://code.google.com/p/prettytable/")
7438 (synopsis "Display tabular data in an ASCII table format")
7439 (description
7440 "A library designed to represent tabular data in visually appealing ASCII
7441 tables. PrettyTable allows for selection of which columns are to be printed,
7442 independent alignment of columns (left or right justified or centred) and
7443 printing of sub-tables by specifying a row range.")
7444 (license license:bsd-3)))
7445
7446 (define-public python2-prettytable
7447 (package-with-python2 python-prettytable))
7448
7449 (define-public python-tables
7450 (package
7451 (name "python-tables")
7452 (version "3.2.2")
7453 (source
7454 (origin
7455 (method url-fetch)
7456 (uri (pypi-uri "tables" version))
7457 (sha256
7458 (base32
7459 "117s6w7s3yxafpmf3zz3svana7xfrsviw01va1xp7h8ylx8v6r1m"))
7460 (modules '((guix build utils)))
7461 (snippet
7462 '(begin
7463 ;; Remove pre-compiled .pyc files from source.
7464 (for-each delete-file-recursively
7465 (find-files "." "__pycache__" #:directories? #t))
7466 (for-each delete-file (find-files "." "\\.pyc$"))
7467 #t))))
7468 (build-system python-build-system)
7469 (arguments
7470 `(;; FIXME: python-build-system does not pass configure-flags to "build"
7471 ;; or "check", so we must override the build and check phases.
7472 #:phases
7473 (modify-phases %standard-phases
7474 (add-after 'unpack 'use-gcc
7475 (lambda _
7476 (substitute* "setup.py"
7477 (("compiler = new_compiler\\(\\)" line)
7478 (string-append line
7479 "\ncompiler.set_executables(compiler='gcc',"
7480 "compiler_so='gcc',"
7481 "linker_exe='gcc',"
7482 "linker_so='gcc -shared')")))
7483 #t))
7484 (replace 'build
7485 (lambda* (#:key inputs #:allow-other-keys)
7486 (zero? (system* "python" "setup.py" "build"
7487 (string-append "--hdf5="
7488 (assoc-ref inputs "hdf5"))))))
7489 (replace 'check
7490 (lambda* (#:key inputs #:allow-other-keys)
7491 (zero? (system* "python" "setup.py" "check"
7492 (string-append "--hdf5="
7493 (assoc-ref inputs "hdf5")))))))))
7494 (propagated-inputs
7495 `(("python-numexpr" ,python-numexpr)
7496 ("python-numpy" ,python-numpy)))
7497 (native-inputs
7498 `(("python-cython" ,python-cython)
7499 ("pkg-config" ,pkg-config)))
7500 (inputs
7501 `(("hdf5" ,hdf5)
7502 ("bzip2" ,bzip2)
7503 ("zlib" ,zlib)))
7504 (home-page "http://www.pytables.org/")
7505 (synopsis "Hierarchical datasets for Python")
7506 (description "PyTables is a package for managing hierarchical datasets and
7507 designed to efficiently cope with extremely large amounts of data.")
7508 (license license:bsd-3)))
7509
7510 (define-public python2-tables
7511 (package-with-python2 python-tables))
7512
7513 (define-public python-pyasn1
7514 (package
7515 (name "python-pyasn1")
7516 (version "0.2.3")
7517 (source
7518 (origin
7519 (method url-fetch)
7520 (uri (pypi-uri "pyasn1" version))
7521 (sha256
7522 (base32
7523 "1b86yx23c1x74clai05a5ma8c8nfmhlx3j1mxq0ff657i2ylx33k"))))
7524 (build-system python-build-system)
7525 (home-page "http://pyasn1.sourceforge.net/")
7526 (synopsis "ASN.1 types and codecs")
7527 (description
7528 "This is an implementation of ASN.1 types and codecs in Python. It is
7529 suitable for a wide range of protocols based on the ASN.1 specification.")
7530 (license license:bsd-2)))
7531
7532 (define-public python2-pyasn1
7533 (package-with-python2 python-pyasn1))
7534
7535 (define-public python-pyasn1-modules
7536 (package
7537 (name "python-pyasn1-modules")
7538 (version "0.0.8")
7539 (source
7540 (origin
7541 (method url-fetch)
7542 (uri (pypi-uri "pyasn1-modules" version))
7543 (sha256
7544 (base32
7545 "0drqgw81xd3fxdlg89kgd79zzrabvfncvkbybi2wr6w2y4s1jmhh"))))
7546 (build-system python-build-system)
7547 (propagated-inputs
7548 `(("python-pyasn1" ,python-pyasn1)))
7549 (home-page "https://sourceforge.net/projects/pyasn1/")
7550 (synopsis "ASN.1 codec implementations")
7551 (description
7552 "Pyasn1-modules is a collection of Python modules providing ASN.1 types and
7553 implementations of ASN.1-based codecs and protocols.")
7554 (license license:bsd-3)))
7555
7556 (define-public python2-pyasn1-modules
7557 (package-with-python2 python-pyasn1-modules))
7558
7559 (define-public python-ipaddress
7560 (package
7561 (name "python-ipaddress")
7562 (version "1.0.18")
7563 (source (origin
7564 (method url-fetch)
7565 (uri (pypi-uri "ipaddress" version))
7566 (sha256
7567 (base32
7568 "1q8klj9d84cmxgz66073x1j35cplr3r77vx1znhxiwl5w74391ax"))))
7569 (build-system python-build-system)
7570 (home-page "https://github.com/phihag/ipaddress")
7571 (synopsis "IP address manipulation library")
7572 (description
7573 "This package provides a fast, lightweight IPv4/IPv6 manipulation library
7574 in Python. This library is used to create, poke at, and manipulate IPv4 and
7575 IPv6 addresses and networks. This is a port of the Python 3.3 ipaddress
7576 module to older versions of Python.")
7577 (license license:psfl)))
7578
7579 (define-public python2-ipaddress
7580 (package-with-python2 python-ipaddress))
7581
7582 (define-public python2-ipaddr
7583 (package
7584 (name "python2-ipaddr")
7585 (version "2.1.11")
7586 (source
7587 (origin
7588 (method url-fetch)
7589 (uri (pypi-uri "ipaddr" version))
7590 (sha256
7591 (base32 "1dwq3ngsapjc93fw61rp17fvzggmab5x1drjzvd4y4q0i255nm8v"))))
7592 (build-system python-build-system)
7593 (arguments
7594 `(#:python ,python-2 ;version 2 only
7595 #:phases
7596 (modify-phases %standard-phases
7597 (replace 'check
7598 (lambda* _
7599 (zero? (system* "python" "ipaddr_test.py")))))))
7600 (home-page "https://github.com/google/ipaddr-py")
7601 (synopsis "IP address manipulation library")
7602 (description
7603 "Ipaddr is a Python@tie{}2 library for creating and manupilating IPv4 and
7604 IPv6 addresses and networks.
7605
7606 For new implementations you may prefer to use the standard module
7607 @code{ipaddress}, which was introduced in Python 3.3 and backported to older
7608 versions of Python.")
7609 (license license:asl2.0)))
7610
7611 (define-public python-idna
7612 (package
7613 (name "python-idna")
7614 (version "2.5")
7615 (source
7616 (origin
7617 (method url-fetch)
7618 (uri (pypi-uri "idna" version))
7619 (sha256
7620 (base32
7621 "1ara12a7k2zc69msa0arrvw00gn61a6i6by01xb3lkkc0h4cxd9w"))))
7622 (build-system python-build-system)
7623 (home-page "https://github.com/kjd/idna")
7624 (synopsis "Internationalized domain names in applications")
7625 (description
7626 "This is a library to support the Internationalised Domain Names in
7627 Applications (IDNA) protocol as specified in RFC 5891. This version of the
7628 protocol is often referred to as “IDNA2008” and can produce different results
7629 from the earlier standard from 2003. The library is also intended to act as a
7630 suitable drop-in replacement for the “encodings.idna” module that comes with
7631 the Python standard library but currently only supports the older 2003
7632 specification.")
7633 (license license:bsd-4)))
7634
7635 (define-public python2-idna
7636 (package-with-python2 python-idna))
7637
7638 (define-public python-pretend
7639 (package
7640 (name "python-pretend")
7641 (version "1.0.8")
7642 (source
7643 (origin
7644 (method url-fetch)
7645 (uri (string-append "https://pypi.python.org/packages/source/p/"
7646 "pretend/pretend-" version ".tar.gz"))
7647 (sha256
7648 (base32
7649 "0r5r7ygz9m6d2bklflbl84cqhjkc2q12xgis8268ygjh30g2q3wk"))))
7650 (build-system python-build-system)
7651 (home-page "https://github.com/alex/pretend")
7652 (synopsis "Library for stubbing in Python")
7653 (description
7654 "Pretend is a library to make stubbing with Python easier. Stubbing is a
7655 technique for writing tests. You may hear the term mixed up with mocks,
7656 fakes, or doubles. Basically, a stub is an object that returns pre-canned
7657 responses, rather than doing any computation.")
7658 (license license:bsd-3)))
7659
7660 (define-public python2-pretend
7661 (package-with-python2 python-pretend))
7662
7663 (define-public python-cryptography-vectors
7664 (package
7665 (name "python-cryptography-vectors")
7666 (version "2.0.2")
7667 (source
7668 (origin
7669 (method url-fetch)
7670 (uri (pypi-uri "cryptography_vectors" version))
7671 (sha256
7672 (base32
7673 "0yvi2cp23rg20bq3hd47ixbvjh0zgxnxrriqx5v17d7vkmliwbsi"))))
7674 (build-system python-build-system)
7675 (home-page "https://github.com/pyca/cryptography")
7676 (synopsis "Test vectors for the cryptography package")
7677 (description
7678 "This package contains test vectors for the cryptography package.")
7679 ;; Distributed under either BSD-3 or ASL2.0
7680 (license (list license:bsd-3 license:asl2.0))))
7681
7682 (define-public python2-cryptography-vectors
7683 (package-with-python2 python-cryptography-vectors))
7684
7685 (define-public python-cryptography
7686 (package
7687 (name "python-cryptography")
7688 (version "2.0.2")
7689 (source
7690 (origin
7691 (method url-fetch)
7692 (uri (pypi-uri "cryptography" version))
7693 (sha256
7694 (base32
7695 "1aq6ilnf2zdqshwqai4w8gmb5y6p7ip34qrjp1yb7sz77rkb501p"))))
7696 (build-system python-build-system)
7697 (inputs
7698 `(("openssl" ,openssl)))
7699 (propagated-inputs
7700 `(("python-asn1crypto" ,python-asn1crypto)
7701 ("python-cffi" ,python-cffi)
7702 ("python-six" ,python-six)
7703 ("python-idna" ,python-idna)
7704 ("python-iso8601" ,python-iso8601)))
7705 (native-inputs
7706 `(("python-cryptography-vectors" ,python-cryptography-vectors)
7707 ("python-hypothesis" ,python-hypothesis)
7708 ("python-pretend" ,python-pretend)
7709 ("python-pytz" ,python-pytz)
7710 ("python-pytest" ,python-pytest-3.0)))
7711 (home-page "https://github.com/pyca/cryptography")
7712 (synopsis "Cryptographic recipes and primitives for Python")
7713 (description
7714 "cryptography is a package which provides cryptographic recipes and
7715 primitives to Python developers. It aims to be the “cryptographic standard
7716 library” for Python. The package includes both high level recipes, and low
7717 level interfaces to common cryptographic algorithms such as symmetric ciphers,
7718 message digests and key derivation functions.")
7719 ;; Distributed under either BSD-3 or ASL2.0
7720 (license (list license:bsd-3 license:asl2.0))
7721 (properties `((python2-variant . ,(delay python2-cryptography))))))
7722
7723 (define-public python2-cryptography
7724 (let ((crypto (package-with-python2
7725 (strip-python2-variant python-cryptography))))
7726 (package (inherit crypto)
7727 (propagated-inputs
7728 `(("python2-ipaddress" ,python2-ipaddress)
7729 ("python2-backport-ssl-match-hostname"
7730 ,python2-backport-ssl-match-hostname)
7731 ("python2-enum34" ,python2-enum34)
7732 ,@(package-propagated-inputs crypto))))))
7733
7734 (define-public python-pyopenssl
7735 (package
7736 (name "python-pyopenssl")
7737 (version "17.2.0")
7738 (source
7739 (origin
7740 (method url-fetch)
7741 (uri (pypi-uri "pyOpenSSL" version))
7742 (sha256
7743 (base32
7744 "0d283g4zi0hr9papd24mjl70mi15gyzq6fx618rizi87dgipqqax"))))
7745 (build-system python-build-system)
7746 (arguments
7747 '(#:phases
7748 (modify-phases %standard-phases
7749 (delete 'check)
7750 (add-after 'install 'check
7751 (lambda* (#:key inputs outputs #:allow-other-keys)
7752 (add-installed-pythonpath inputs outputs)
7753 (zero? (system* "py.test" "-v" "-k"
7754 (string-append
7755 ;; This test tries to look up certificates from
7756 ;; the compiled-in default path in OpenSSL, which
7757 ;; does not exist in the build environment.
7758 "not test_fallback_default_verify_paths "
7759 ;; This test attempts to make a connection to
7760 ;; an external web service.
7761 "and not test_set_default_verify_paths"))))))))
7762 (propagated-inputs
7763 `(("python-cryptography" ,python-cryptography)
7764 ("python-six" ,python-six)))
7765 (inputs
7766 `(("openssl" ,openssl)))
7767 (native-inputs
7768 `(("python-flaky" ,python-flaky)
7769 ("python-pretend" ,python-pretend)
7770 ("python-pytest" ,python-pytest-3.0)))
7771 (home-page "https://github.com/pyca/pyopenssl")
7772 (synopsis "Python wrapper module around the OpenSSL library")
7773 (description
7774 "PyOpenSSL is a high-level wrapper around a subset of the OpenSSL
7775 library.")
7776 (license license:asl2.0)))
7777
7778 (define-public python2-pyopenssl
7779 (package-with-python2 python-pyopenssl))
7780
7781 (define-public python-pip
7782 (package
7783 (name "python-pip")
7784 (version "9.0.1")
7785 (source
7786 (origin
7787 (method url-fetch)
7788 (uri (pypi-uri "pip" version))
7789 (sha256
7790 (base32
7791 "03clr9c1dih5n9c00c592zzvf6r1ffimywkaq9agcqdllzhl7wh9"))))
7792 (build-system python-build-system)
7793 (arguments
7794 '(#:tests? #f)) ; there are no tests in the pypi archive.
7795 (home-page "https://pip.pypa.io/")
7796 (synopsis "Package manager for Python software")
7797 (description
7798 "Pip is a package manager for Python software, that finds packages on the
7799 Python Package Index (PyPI).")
7800 (license license:expat)))
7801
7802 (define-public python2-pip
7803 (package-with-python2 python-pip))
7804
7805 (define-public python-tlsh
7806 (package
7807 (name "python-tlsh")
7808 (version "3.4.4")
7809 (home-page "https://github.com/trendmicro/tlsh")
7810 (source (origin
7811 (method url-fetch)
7812 (uri (string-append "https://github.com/trendmicro/tlsh/archive/v"
7813 version ".tar.gz"))
7814 (sha256
7815 (base32
7816 "00bhzjqrlh7v538kbkbn8lgx976j1138al3sdhklaizqjvpwyk4r"))
7817 (file-name (string-append name "-" version ".tar.gz"))))
7818 (build-system cmake-build-system)
7819 (arguments
7820 '(#:out-of-source? #f
7821 #:phases (modify-phases %standard-phases
7822 (replace
7823 'install
7824 (lambda* (#:key outputs #:allow-other-keys)
7825 ;; Build and install the Python bindings. The underlying
7826 ;; C++ library is apparently not meant to be installed.
7827 (let ((out (assoc-ref outputs "out")))
7828 (with-directory-excursion "py_ext"
7829 (and (system* "python" "setup.py" "build")
7830 (system* "python" "setup.py" "install"
7831 (string-append "--prefix=" out))))))))))
7832 (inputs `(("python" ,python-wrapper))) ;for the bindings
7833 (synopsis "Fuzzy matching library for Python")
7834 (description
7835 "Trend Micro Locality Sensitive Hash (TLSH) is a fuzzy matching library.
7836 Given a byte stream with a minimum length of 256 bytes, TLSH generates a hash
7837 value which can be used for similarity comparisons. Similar objects have
7838 similar hash values, which allows for the detection of similar objects by
7839 comparing their hash values. The byte stream should have a sufficient amount
7840 of complexity; for example, a byte stream of identical bytes will not generate
7841 a hash value.")
7842 (license license:asl2.0)))
7843
7844 (define-public python2-tlsh
7845 (package
7846 (inherit python-tlsh)
7847 (name "python2-tlsh")
7848 (inputs `(("python" ,python-2)))))
7849
7850 (define-public python-termcolor
7851 (package
7852 (name "python-termcolor")
7853 (version "1.1.0")
7854 (source
7855 (origin
7856 (method url-fetch)
7857 (uri (pypi-uri "termcolor" version))
7858 (sha256
7859 (base32
7860 "0fv1vq14rpqwgazxg4981904lfyp84mnammw7y046491cv76jv8x"))))
7861 (build-system python-build-system)
7862 (arguments
7863 ;; There are no tests.
7864 `(#:tests? #f))
7865 (home-page "http://pypi.python.org/pypi/termcolor")
7866 (synopsis "ANSII Color formatting for terminal output")
7867 (description
7868 "This package provides ANSII Color formatting for output in terminals.")
7869 (license license:expat)))
7870
7871 (define-public python2-termcolor
7872 (package-with-python2 python-termcolor))
7873
7874 (define-public python-libarchive-c
7875 (package
7876 (name "python-libarchive-c")
7877 (version "2.2")
7878 (source (origin
7879 (method url-fetch)
7880 (uri (pypi-uri "libarchive-c" version))
7881 (sha256
7882 (base32
7883 "0z4r7v3dhd6b3120mav05ff08srih176r2rg5k8kn7mjd9pslm2x"))))
7884 (build-system python-build-system)
7885 (arguments
7886 '(#:phases (modify-phases %standard-phases
7887 (add-before
7888 'build 'reference-libarchive
7889 (lambda* (#:key inputs #:allow-other-keys)
7890 ;; Retain the absolute file name of libarchive.so.
7891 (let ((libarchive (assoc-ref inputs "libarchive")))
7892 (substitute* "libarchive/ffi.py"
7893 (("find_library\\('archive'\\)")
7894 (string-append "'" libarchive
7895 "/lib/libarchive.so'")))))))))
7896 (inputs
7897 `(("libarchive" ,libarchive)))
7898 (home-page "https://github.com/Changaco/python-libarchive-c")
7899 (synopsis "Python interface to libarchive")
7900 (description
7901 "This package provides Python bindings to libarchive, a C library to
7902 access possibly compressed archives in many different formats. It uses
7903 Python's @code{ctypes} foreign function interface (FFI).")
7904 (license license:lgpl2.0+)))
7905
7906 (define-public python2-libarchive-c
7907 (package-with-python2 python-libarchive-c))
7908
7909 (define-public python-file
7910 (package
7911 (inherit file)
7912 (name "python-file")
7913 (source (origin
7914 (inherit (package-source file))
7915 ;; This patch should not be applied to python2-file.
7916 (patches (search-patches "python-file-double-encoding-bug.patch"))))
7917 (build-system python-build-system)
7918 (arguments
7919 '(#:tests? #f ;no tests
7920 #:configure-flags '("--single-version-externally-managed" "--root=/")
7921 #:phases (modify-phases %standard-phases
7922 (add-before 'build 'change-directory
7923 (lambda _
7924 (chdir "python")
7925 #t))
7926 (add-before 'build 'set-library-file-name
7927 (lambda* (#:key inputs #:allow-other-keys)
7928 (let ((file (assoc-ref inputs "file")))
7929 (substitute* "magic.py"
7930 (("find_library\\('magic'\\)")
7931 (string-append "'" file "/lib/libmagic.so'")))
7932 #t))))))
7933 (inputs `(("file" ,file)))
7934 (self-native-input? #f)
7935 (synopsis "Python bindings to the libmagic file type guesser. Note that
7936 this module and the python-magic module both provide a \"magic.py\" file;
7937 these two modules, which are different and were developed separately, both
7938 serve the same purpose: provide Python bindings for libmagic.")))
7939
7940 (define-public python2-file
7941 (package-with-python2 python-file))
7942
7943 (define-public python-debian
7944 (package
7945 (name "python-debian")
7946 (version "0.1.28")
7947 (source
7948 (origin
7949 (method url-fetch)
7950 (uri (pypi-uri name version))
7951 (sha256
7952 (base32
7953 "0i15f0xzx679sd0ldq2sls9pnnps9fv6vhqvnv9dzf4qhma42i0y"))))
7954 (build-system python-build-system)
7955 (propagated-inputs
7956 `(("python-six" ,python-six)))
7957 (home-page "http://packages.debian.org/sid/python-debian")
7958 (synopsis "Debian package related modules")
7959 (description
7960 ;; XXX: Use @enumerate instead of @itemize to work around
7961 ;; <http://bugs.gnu.org/21772>.
7962 "This package provides Python modules that abstract many formats of
7963 Debian-related files, such as:
7964
7965 @enumerate
7966 @item Debtags information;
7967 @item @file{debian/changelog} files;
7968 @item packages files, pdiffs;
7969 @item control files of single or multiple RFC822-style paragraphs---e.g.
7970 @file{debian/control}, @file{.changes}, @file{.dsc};
7971 @item Raw @file{.deb} and @file{.ar} files, with (read-only) access to
7972 contained files and meta-information.
7973 @end enumerate\n")
7974
7975 ;; Modules are either GPLv2+ or GPLv3+.
7976 (license license:gpl3+)))
7977
7978 (define-public python2-debian
7979 (package-with-python2 python-debian))
7980
7981 (define-public python-nbformat
7982 (package
7983 (name "python-nbformat")
7984 (version "4.1.0")
7985 (source
7986 (origin
7987 (method url-fetch)
7988 (uri (pypi-uri "nbformat" version))
7989 (sha256
7990 (base32
7991 "0mq8iki3d4mnx7wy05phss7x98mds4fqydin8lcagidp1knw1xnv"))))
7992 (build-system python-build-system)
7993 (arguments `(#:tests? #f)) ; no test target
7994 (propagated-inputs
7995 `(("python-ipython-genutils" ,python-ipython-genutils)
7996 ("python-jsonschema" ,python-jsonschema)
7997 ("python-jupyter-core" ,python-jupyter-core)
7998 ("python-traitlets" ,python-traitlets)))
7999 (home-page "http://jupyter.org")
8000 (synopsis "Jupyter Notebook format")
8001 (description "This package provides the reference implementation of the
8002 Jupyter Notebook format and Python APIs for working with notebooks.")
8003 (license license:bsd-3)))
8004
8005 (define-public python2-nbformat
8006 (package-with-python2 python-nbformat))
8007
8008 (define-public python-bleach
8009 (package
8010 (name "python-bleach")
8011 (version "1.4.3")
8012 (source
8013 (origin
8014 (method url-fetch)
8015 (uri (pypi-uri "bleach" version))
8016 (sha256
8017 (base32
8018 "0jvg3jxrvnx7xmm9gj262v60ib452xlnwlb0navyp7jsvcd0d4qj"))))
8019 (build-system python-build-system)
8020 (propagated-inputs
8021 `(("python-html5lib" ,python-html5lib-0.9)
8022 ("python-six" ,python-six)))
8023 (native-inputs
8024 `(("python-nose" ,python-nose)))
8025 (home-page "https://github.com/jsocol/bleach")
8026 (synopsis "Whitelist-based HTML-sanitizing tool")
8027 (description "Bleach is an easy whitelist-based HTML-sanitizing tool.")
8028 (license license:asl2.0)))
8029
8030 (define-public python2-bleach
8031 (package-with-python2 python-bleach))
8032
8033 (define-public python-entrypoints
8034 (package
8035 (name "python-entrypoints")
8036 (version "0.2.2")
8037 (source
8038 (origin
8039 (method url-fetch)
8040 (uri (string-append "https://github.com/takluyver/entrypoints/archive/"
8041 version ".tar.gz"))
8042 (file-name (string-append name "-" version ".tar.gz"))
8043 (sha256
8044 (base32
8045 "0azqlkh3j0za080lsf5crnhaxx3c93k9dpv5ihkhf5cppgw5sjz5"))))
8046 (build-system python-build-system)
8047 ;; The package does not come with a setup.py file, so we have to generate
8048 ;; one ourselves.
8049 (arguments
8050 `(#:tests? #f
8051 #:phases
8052 (modify-phases %standard-phases
8053 (add-after 'unpack 'create-setup.py
8054 (lambda _
8055 (call-with-output-file "setup.py"
8056 (lambda (port)
8057 (format port "\
8058 from setuptools import setup
8059 setup(name='entrypoints', version='~a', py_modules=['entrypoints'])
8060 " ,version))))))))
8061 (home-page "https://github.com/takluyver/entrypoints")
8062 (synopsis "Discover and load entry points from installed Python packages")
8063 (description "Entry points are a way for Python packages to advertise
8064 objects with some common interface. The most common examples are
8065 @code{console_scripts} entry points, which define shell commands by
8066 identifying a Python function to run. The @code{entrypoints} module contains
8067 functions to find and load entry points.")
8068 (license license:expat)))
8069
8070 (define-public python2-entrypoints
8071 (package-with-python2 python-entrypoints))
8072
8073 (define-public python-nbconvert
8074 (package
8075 (name "python-nbconvert")
8076 (version "5.0.0b1")
8077 (source
8078 (origin
8079 (method url-fetch)
8080 (uri (pypi-uri "nbconvert" version))
8081 (sha256
8082 (base32
8083 "0brclbb18l4nmd5qy3dl9wn05rjdh1fz4rmzdlfqacj12rcdvdgp"))))
8084 (build-system python-build-system)
8085 (arguments
8086 `(;; The "bdist_egg" target is disabled by default, causing the installation
8087 ;; to fail.
8088 #:configure-flags (list "bdist_egg")
8089 ;; FIXME: 5 failures, 40 errors.
8090 #:tests? #f))
8091 ;; #:phases
8092 ;; (modify-phases %standard-phases
8093 ;; (replace 'check
8094 ;; (lambda _
8095 ;; (zero? (system* "py.test" "-v")))))
8096 (native-inputs
8097 `(("python-pytest" ,python-pytest)))
8098 (propagated-inputs
8099 `(("python-bleach" ,python-bleach)
8100 ("python-entrypoints" ,python-entrypoints)
8101 ("python-jinja2" ,python-jinja2)
8102 ("python-jupyter-core" ,python-jupyter-core)
8103 ("python-mistune" ,python-mistune)
8104 ("python-nbformat" ,python-nbformat)
8105 ("python-pygments" ,python-pygments)
8106 ("python-traitlets" ,python-traitlets)))
8107 (home-page "http://jupyter.org")
8108 (synopsis "Converting Jupyter Notebooks")
8109 (description "The @code{nbconvert} tool, @{jupyter nbconvert}, converts
8110 notebooks to various other formats via Jinja templates. It allows you to
8111 convert an @code{.ipynb} notebook file into various static formats including:
8112
8113 @enumerate
8114 @item HTML
8115 @item LaTeX
8116 @item PDF
8117 @item Reveal JS
8118 @item Markdown (md)
8119 @item ReStructured Text (rst)
8120 @item executable script
8121 @end enumerate\n")
8122 (license license:bsd-3)))
8123
8124 (define-public python2-nbconvert
8125 (package-with-python2 python-nbconvert))
8126
8127 (define-public python-notebook
8128 (package
8129 (name "python-notebook")
8130 (version "4.2.3")
8131 (source (origin
8132 (method url-fetch)
8133 (uri (pypi-uri "notebook" version))
8134 (sha256
8135 (base32
8136 "0laq5c2f21frq6xcdckgq7raqhznbjb0qs0357g612z87wyn1a9r"))))
8137 (build-system python-build-system)
8138 (arguments
8139 `(#:phases
8140 (modify-phases %standard-phases
8141 (replace 'check
8142 (lambda _
8143 ;; HOME must be set for tests
8144 (setenv "HOME" "/tmp")
8145 (zero? (system* "nosetests")))))))
8146 (propagated-inputs
8147 `(("python-jupyter-core" ,python-jupyter-core)
8148 ("python-nbformat" ,python-nbformat)
8149 ("python-nbconvert" ,python-nbconvert)
8150 ("python-ipython" ,python-ipython)))
8151 (native-inputs
8152 `(("python-nose" ,python-nose)
8153 ("python-sphinx" ,python-sphinx)
8154 ("python-requests" ,python-requests)))
8155 (home-page "http://jupyter.org/")
8156 (synopsis "Web-based notebook environment for interactive computing")
8157 (description
8158 "The Jupyter HTML notebook is a web-based notebook environment for
8159 interactive computing.")
8160 (properties `((python2-variant . ,(delay python2-notebook))))
8161 (license license:bsd-3)))
8162
8163 (define-public python2-notebook
8164 (let ((base (package-with-python2
8165 (strip-python2-variant python-notebook))))
8166 (package (inherit base)
8167 (native-inputs
8168 `(("python2-mock" ,python2-mock)
8169 ,@(package-native-inputs base)))
8170 (arguments
8171 (substitute-keyword-arguments (package-arguments base)
8172 ((#:phases phases)
8173 `(modify-phases ,phases
8174 (add-before 'check 'disable-test-case
8175 ;; The test requires network access to localhost. Curiously it
8176 ;; fails with Python 2 only. Simply make the test-case return
8177 ;; immediately.
8178 (lambda _
8179 (substitute*
8180 "notebook/services/nbconvert/tests/test_nbconvert_api.py"
8181 (("formats = self.nbconvert_api") "return #")))))))))))
8182
8183 (define-public python-widgetsnbextension
8184 (package
8185 (name "python-widgetsnbextension")
8186 (version "1.2.6")
8187 (source
8188 (origin
8189 (method url-fetch)
8190 (uri (pypi-uri "widgetsnbextension" version))
8191 (sha256
8192 (base32
8193 "0lff2mrwrgsa1mxmwx3phl9xvy0jqfpg6khbmxy53jbq56rwy666"))))
8194 (build-system python-build-system)
8195 (propagated-inputs
8196 `(("python-notebook" ,python-notebook)))
8197 (native-inputs
8198 `(("python-certifi" ,python-certifi)
8199 ("python-nose" ,python-nose)))
8200 (home-page "http://ipython.org")
8201 (synopsis "IPython HTML widgets for Jupyter")
8202 (description "This package provides interactive HTML widgets for Jupyter
8203 notebooks.")
8204 (license license:bsd-3)))
8205
8206 (define-public python2-widgetsnbextension
8207 (package-with-python2 python-widgetsnbextension))
8208
8209 (define-public python-ipywidgets
8210 (package
8211 (name "python-ipywidgets")
8212 (version "5.2.2")
8213 (source
8214 (origin
8215 (method url-fetch)
8216 (uri (pypi-uri "ipywidgets" version))
8217 (sha256
8218 (base32
8219 "1lk0qrr5l9a0z7qkkn30hv5832whxwxymf1l576fmmad0n7hkxms"))))
8220 (build-system python-build-system)
8221 ;; FIXME: it's not clear how to run the tests.
8222 (arguments `(#:tests? #f))
8223 (propagated-inputs
8224 `(("python-ipykernel" ,python-ipykernel)
8225 ("python-ipython" ,python-ipython)
8226 ("python-traitlets" ,python-traitlets)
8227 ("python-widgetsnbextension" ,python-widgetsnbextension)))
8228 (home-page "http://ipython.org")
8229 (synopsis "IPython HTML widgets for Jupyter")
8230 (description "Ipywidgets are interactive HTML widgets for Jupyter
8231 notebooks and the IPython kernel. Notebooks come alive when interactive
8232 widgets are used. Users gain control of their data and can visualize changes
8233 in the data.")
8234 (license license:bsd-3)))
8235
8236 (define-public python2-ipywidgets
8237 (package-with-python2 python-ipywidgets))
8238
8239 (define-public python-jupyter-console
8240 (package
8241 (name "python-jupyter-console")
8242 (version "5.0.0")
8243 (source
8244 (origin
8245 (method url-fetch)
8246 (uri (pypi-uri "jupyter_console" version))
8247 (sha256
8248 (base32
8249 "04acmkwsi99rcg3vb54c6n492zv35s92h2ahabc0w6wj976cipvx"))))
8250 (build-system python-build-system)
8251 ;; FIXME: it's not clear how to run the tests.
8252 (arguments `(#:tests? #f))
8253 (propagated-inputs
8254 `(("python-ipykernel" ,python-ipykernel)
8255 ("python-ipython" ,python-ipython)
8256 ("python-jupyter-client" ,python-jupyter-client)
8257 ("python-prompt-toolkit" ,python-prompt-toolkit)
8258 ("python-pygments" ,python-pygments)))
8259 (home-page "https://jupyter.org")
8260 (synopsis "Jupyter terminal console")
8261 (description "This package provides a terminal-based console frontend for
8262 Jupyter kernels. It also allows for console-based interaction with non-Python
8263 Jupyter kernels such as IJulia and IRKernel.")
8264 (license license:bsd-3)))
8265
8266 (define-public python2-jupyter-console
8267 (package-with-python2 python-jupyter-console))
8268
8269 (define-public jupyter
8270 (package
8271 (name "jupyter")
8272 (version "1.0.0")
8273 (source
8274 (origin
8275 (method url-fetch)
8276 (uri (pypi-uri "jupyter" version))
8277 (sha256
8278 (base32
8279 "0pwf3pminkzyzgx5kcplvvbvwrrzd3baa7lmh96f647k30rlpp6r"))))
8280 (build-system python-build-system)
8281 ;; FIXME: it's not clear how to run the tests.
8282 (arguments `(#:tests? #f))
8283 (propagated-inputs
8284 `(("python-ipykernel" ,python-ipykernel)
8285 ("python-ipywidgets" ,python-ipywidgets)
8286 ("python-jupyter-console" ,python-jupyter-console)
8287 ("python-nbconvert" ,python-nbconvert)
8288 ("python-notebook" ,python-notebook)))
8289 (home-page "http://jupyter.org")
8290 (synopsis "Web application for interactive documents")
8291 (description
8292 "The Jupyter Notebook is a web application that allows you to create and
8293 share documents that contain live code, equations, visualizations and
8294 explanatory text. Uses include: data cleaning and transformation, numerical
8295 simulation, statistical modeling, machine learning and much more.")
8296 (license license:bsd-3)))
8297
8298 (define-public python-chardet
8299 (package
8300 (name "python-chardet")
8301 (version "2.3.0")
8302 (source
8303 (origin
8304 (method url-fetch)
8305 (uri (string-append
8306 "https://pypi.python.org/packages/source/c/chardet/chardet-"
8307 version
8308 ".tar.gz"))
8309 (sha256
8310 (base32
8311 "1ak87ikcw34fivcgiz2xvi938dmclh078az65l9x3rmgljrkhgp5"))))
8312 (build-system python-build-system)
8313 (home-page "https://github.com/chardet/chardet")
8314 (synopsis "Universal encoding detector for Python 2 and 3")
8315 (description
8316 "This package provides @code{chardet}, a Python module that can
8317 automatically detect a wide range of file encodings.")
8318 (license license:lgpl2.1+)))
8319
8320 (define-public python2-chardet
8321 (package-with-python2 python-chardet))
8322
8323 (define-public python-docopt
8324 (package
8325 (name "python-docopt")
8326 (version "0.6.2")
8327 (source
8328 (origin
8329 (method url-fetch)
8330 ;; The release on PyPI does not include tests.
8331 (uri (string-append
8332 "https://github.com/docopt/docopt/archive/"
8333 version ".tar.gz"))
8334 (file-name (string-append name "-" version ".tar.gz"))
8335 (sha256
8336 (base32
8337 "16bf890xbdz3m30rsv2qacklh2rdn1zrfspfnwzx9g7vwz8yw4r1"))))
8338 (build-system python-build-system)
8339 (native-inputs
8340 `(("python-pytest" ,python-pytest)))
8341 (arguments
8342 `(#:phases (alist-replace
8343 'check
8344 (lambda _ (zero? (system* "py.test")))
8345 %standard-phases)))
8346 (home-page "http://docopt.org")
8347 (synopsis "Command-line interface description language for Python")
8348 (description "This library allows the user to define a command-line
8349 interface from a program's help message rather than specifying it
8350 programatically with command-line parsers like @code{getopt} and
8351 @code{argparse}.")
8352 (license license:expat)))
8353
8354 (define-public python2-docopt
8355 (package-with-python2 python-docopt))
8356
8357 (define-public python-zope-event
8358 (package
8359 (name "python-zope-event")
8360 (version "4.1.0")
8361 (source
8362 (origin
8363 (method url-fetch)
8364 (uri (string-append "https://pypi.python.org/packages/source/z"
8365 "/zope.event/zope.event-" version ".tar.gz"))
8366 (sha256
8367 (base32
8368 "11p75zpfz3ffhz21nzx9wb23xs993ck5s6hkjcvhswwizni5jynw"))))
8369 (build-system python-build-system)
8370 (home-page "http://pypi.python.org/pypi/zope.event")
8371 (synopsis "Event publishing system for Python")
8372 (description "Zope.event provides an event publishing API, intended for
8373 use by applications which are unaware of any subscribers to their events. It
8374 is a simple event-dispatching system on which more sophisticated event
8375 dispatching systems can be built.")
8376 (license license:zpl2.1)))
8377
8378 (define-public python2-zope-event
8379 (package-with-python2 python-zope-event))
8380
8381 (define-public python-zope-interface
8382 (package
8383 (name "python-zope-interface")
8384 (version "4.1.3")
8385 (source
8386 (origin
8387 (method url-fetch)
8388 (uri (string-append "https://pypi.python.org/packages/source/z"
8389 "/zope.interface/zope.interface-" version ".tar.gz"))
8390 (sha256
8391 (base32
8392 "0ks8h73b2g4bkad821qbv0wzjppdrwys33i7ka45ik3wxjg1l8if"))))
8393 (build-system python-build-system)
8394 (native-inputs
8395 `(("python-zope-event" ,python-zope-event)))
8396 (home-page "https://github.com/zopefoundation/zope.interface")
8397 (synopsis "Python implementation of the \"design by contract\"
8398 methodology")
8399 (description "Zope.interface provides an implementation of \"object
8400 interfaces\" for Python. Interfaces are a mechanism for labeling objects as
8401 conforming to a given API or contract.")
8402 (license license:zpl2.1)))
8403
8404 (define-public python2-zope-interface
8405 (package-with-python2 python-zope-interface))
8406
8407 (define-public python-zope-exceptions
8408 (package
8409 (name "python-zope-exceptions")
8410 (version "4.0.8")
8411 (source
8412 (origin
8413 (method url-fetch)
8414 (uri (string-append "https://pypi.python.org/packages/source/z"
8415 "/zope.exceptions/zope.exceptions-"
8416 version ".tar.gz"))
8417 (sha256
8418 (base32
8419 "0zwxaaa66sqxg5k7zcrvs0fbg9ym1njnxnr28dfmchzhwjvwnfzl"))))
8420 (build-system python-build-system)
8421 (arguments
8422 '(#:tests? #f)) ; circular dependency with zope.testrunner
8423 (propagated-inputs
8424 `(("python-zope-interface" ,python-zope-interface)))
8425 (home-page "http://cheeseshop.python.org/pypi/zope.exceptions")
8426 (synopsis "Zope exceptions")
8427 (description "Zope.exceptions provides general-purpose exception types
8428 that have uses outside of the Zope framework.")
8429 (license license:zpl2.1)))
8430
8431 (define-public python2-zope-exceptions
8432 (package-with-python2 python-zope-exceptions))
8433
8434 (define-public python-zope-testing
8435 (package
8436 (name "python-zope-testing")
8437 (version "4.5.0")
8438 (source
8439 (origin
8440 (method url-fetch)
8441 (uri (string-append "https://pypi.python.org/packages/source/z"
8442 "/zope.testing/zope.testing-" version ".tar.gz"))
8443 (sha256
8444 (base32
8445 "1yvglxhzvhl45mndvn9gskx2ph30zz1bz7rrlyfs62fv2pvih90s"))
8446 (modules '((guix build utils)))
8447 (snippet
8448 '(begin
8449 ;; Remove pre-compiled .pyc files backup files from source.
8450 (for-each delete-file (find-files "." "(\\.pyc|~)$"))
8451 #t))))
8452 (build-system python-build-system)
8453 (native-inputs
8454 `(("python-zope-exceptions" ,python-zope-exceptions)))
8455 (propagated-inputs
8456 `(("python-zope-interface" ,python-zope-interface)))
8457 (home-page "http://pypi.python.org/pypi/zope.testing")
8458 (synopsis "Zope testing helpers")
8459 (description "Zope.testing provides a number of testing utilities for HTML
8460 forms, HTTP servers, regular expressions, and more.")
8461 (license license:zpl2.1)))
8462
8463 (define-public python2-zope-testing
8464 (package-with-python2 python-zope-testing))
8465
8466 (define-public python-zope-testrunner
8467 (package
8468 (name "python-zope-testrunner")
8469 (version "4.4.9")
8470 (source
8471 (origin
8472 (method url-fetch)
8473 (uri (string-append "https://pypi.python.org/packages/source/z"
8474 "/zope.testrunner/zope.testrunner-"
8475 version ".zip"))
8476 (sha256
8477 (base32
8478 "1r7iqknhh55y45f64mz5hghgvzx34h1i11k350s0avx6q8gznja1"))))
8479 (build-system python-build-system)
8480 (arguments
8481 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8482 (native-inputs
8483 `(("python-six" ,python-six)
8484 ;("python-zope-interface" ,python-zope-interface)
8485 ("python-zope-exceptions" ,python-zope-exceptions)
8486 ("python-zope-testing" ,python-zope-testing)
8487 ("unzip" ,unzip)))
8488 (propagated-inputs
8489 `(("python-zope-interface" ,python-zope-interface)))
8490 (home-page "http://pypi.python.org/pypi/zope.testrunner")
8491 (synopsis "Zope testrunner script")
8492 (description "Zope.testrunner provides a script for running Python
8493 tests.")
8494 (license license:zpl2.1)))
8495
8496 (define-public python2-zope-testrunner
8497 (let ((base (package-with-python2 python-zope-testrunner)))
8498 (package
8499 (inherit base)
8500 (native-inputs
8501 (append (package-native-inputs base)
8502 `(("python2-subunit" ,python2-subunit)
8503 ("python2-mimeparse" ,python2-mimeparse)))))))
8504
8505 (define-public python-zope-i18nmessageid
8506 (package
8507 (name "python-zope-i18nmessageid")
8508 (version "4.0.3")
8509 (source
8510 (origin
8511 (method url-fetch)
8512 (uri (string-append
8513 "https://pypi.python.org/packages/source/z"
8514 "/zope.i18nmessageid/zope.i18nmessageid-"
8515 version ".tar.gz"))
8516 (sha256
8517 (base32
8518 "1rslyph0klk58dmjjy4j0jxy21k03azksixc3x2xhqbkv97cmzml"))))
8519 (build-system python-build-system)
8520 (home-page "http://pypi.python.org/pypi/zope.i18nmessageid")
8521 (synopsis "Message identifiers for internationalization")
8522 (description "Zope.i18nmessageid provides facilities for declaring
8523 internationalized messages within program source text.")
8524 (license license:zpl2.1)))
8525
8526 (define-public python2-zope-i18nmessageid
8527 (package-with-python2 python-zope-i18nmessageid))
8528
8529 (define-public python-zope-schema
8530 (package
8531 (name "python-zope-schema")
8532 (version "4.4.2")
8533 (source
8534 (origin
8535 (method url-fetch)
8536 (uri (string-append "https://pypi.python.org/packages/source/z"
8537 "/zope.schema/zope.schema-" version ".tar.gz"))
8538 (sha256
8539 (base32
8540 "1p943jdxb587dh7php4vx04qvn7b2877hr4qs5zyckvp5afhhank"))))
8541 (build-system python-build-system)
8542 (arguments
8543 '(#:tests? #f)) ; FIXME: Tests can't find zope.event.
8544 (propagated-inputs
8545 `(("python-zope-event" ,python-zope-event)
8546 ("python-zope-exceptions", python-zope-exceptions)
8547 ("python-zope-interface" ,python-zope-interface)))
8548 (native-inputs
8549 `(("python-zope-testing" ,python-zope-testing)
8550 ("python-coverage" ,python-coverage)
8551 ("python-nose" ,python-nose)))
8552 (home-page "http://pypi.python.org/pypi/zope.schema")
8553 (synopsis "Zope data schemas")
8554 (description "Zope.scheme provides extensions to zope.interface for
8555 defining data schemas.")
8556 (license license:zpl2.1)))
8557
8558 (define-public python2-zope-schema
8559 (package-with-python2 python-zope-schema))
8560
8561 (define-public python-zope-configuration
8562 (package
8563 (name "python-zope-configuration")
8564 (version "4.0.3")
8565 (source (origin
8566 (method url-fetch)
8567 (uri (string-append "https://pypi.python.org/packages/source/z"
8568 "/zope.configuration/zope.configuration-"
8569 version ".tar.gz"))
8570 (sha256
8571 (base32
8572 "1x9dfqypgympnlm25p9m43xh4qv3p7d75vksv9pzqibrb4cggw5n"))))
8573 (build-system python-build-system)
8574 (arguments
8575 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8576 (propagated-inputs
8577 `(("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
8578 ("python-zope-schema" ,python-zope-schema)))
8579 (home-page "http://pypi.python.org/pypi/zope.configuration")
8580 (synopsis "Zope Configuration Markup Language")
8581 (description "Zope.configuration implements ZCML, the Zope Configuration
8582 Markup Language.")
8583 (license license:zpl2.1)))
8584
8585 (define-public python2-zope-configuration
8586 (package-with-python2 python-zope-configuration))
8587
8588 (define-public python-zope-proxy
8589 (package
8590 (name "python-zope-proxy")
8591 (version "4.1.6")
8592 (source
8593 (origin
8594 (method url-fetch)
8595 (uri (string-append "https://pypi.python.org/packages/source/z"
8596 "/zope.proxy/zope.proxy-" version ".tar.gz"))
8597 (sha256
8598 (base32
8599 "0pqwwmvm1prhwv1ziv9lp8iirz7xkwb6n2kyj36p2h0ppyyhjnm4"))))
8600 (build-system python-build-system)
8601 (arguments
8602 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8603 (propagated-inputs
8604 `(("python-zope-interface" ,python-zope-interface)))
8605 (home-page "http://pypi.python.org/pypi/zope.proxy")
8606 (synopsis "Generic, transparent proxies")
8607 (description "Zope.proxy provides generic, transparent proxies for Python.
8608 Proxies are special objects which serve as mostly-transparent wrappers around
8609 another object, intervening in the apparent behavior of the wrapped object
8610 only when necessary to apply the policy (e.g., access checking, location
8611 brokering, etc.) for which the proxy is responsible.")
8612 (license license:zpl2.1)))
8613
8614 (define-public python2-zope-proxy
8615 (package-with-python2 python-zope-proxy))
8616
8617 (define-public python-zope-location
8618 (package
8619 (name "python-zope-location")
8620 (version "4.0.3")
8621 (source
8622 (origin
8623 (method url-fetch)
8624 (uri (string-append "https://pypi.python.org/packages/source/z"
8625 "/zope.location/zope.location-" version ".tar.gz"))
8626 (sha256
8627 (base32
8628 "1nj9da4ksiyv3h8n2vpzwd0pb03mdsh7zy87hfpx72b6p2zcwg74"))))
8629 (build-system python-build-system)
8630 (arguments
8631 '(#:tests? #f)) ; FIXME: Tests can't find zope.interface.
8632 (propagated-inputs
8633 `(("python-zope-proxy" ,python-zope-proxy)
8634 ("python-zope-schema" ,python-zope-schema)))
8635 (home-page "http://pypi.python.org/pypi/zope.location/")
8636 (synopsis "Zope location library")
8637 (description "Zope.location implements the concept of \"locations\" in
8638 Zope3, which are are special objects that have a structural location.")
8639 (license license:zpl2.1)))
8640
8641 (define-public python2-zope-location
8642 (package-with-python2 python-zope-location))
8643
8644 (define-public python-zope-security
8645 (package
8646 (name "python-zope-security")
8647 (version "4.0.3")
8648 (source
8649 (origin
8650 (method url-fetch)
8651 (uri (string-append "https://pypi.python.org/packages/source/z"
8652 "/zope.security/zope.security-" version ".tar.gz"))
8653 (sha256
8654 (base32
8655 "14zmf684amc0x32kq05yxnhfqd1cmyhafkw05gn81rn90zjv6ssy"))))
8656 (build-system python-build-system)
8657 (arguments
8658 '(#:tests? #f)) ; FIXME: Tests can't find zope.testrunner.
8659 (propagated-inputs
8660 `(("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
8661 ("python-zope-proxy" ,python-zope-proxy)
8662 ("python-zope-schema" ,python-zope-schema)))
8663 (native-inputs
8664 `(("python-six" ,python-six)
8665 ("python-zope-component" ,python-zope-component)
8666 ("python-zope-configuration" ,python-zope-configuration)
8667 ("python-zope-location" ,python-zope-location)
8668 ("python-zope-testrunner" ,python-zope-testrunner)
8669 ("python-zope-testing" ,python-zope-testing)))
8670 (home-page "http://pypi.python.org/pypi/zope.security")
8671 (synopsis "Zope security framework")
8672 (description "Zope.security provides a generic mechanism to implement
8673 security policies on Python objects.")
8674 (license license:zpl2.1)))
8675
8676 (define-public python2-zope-security
8677 (let ((zope-security (package-with-python2 python-zope-security)))
8678 (package (inherit zope-security)
8679 (propagated-inputs
8680 `(("python2-zope-testrunner" ,python2-zope-testrunner)
8681 ,@(alist-delete
8682 "python-zope-testrunner"
8683 (package-propagated-inputs zope-security)))))))
8684
8685 (define-public python-zope-component
8686 (package
8687 (name "python-zope-component")
8688 (version "4.3.0")
8689 (source
8690 (origin
8691 (method url-fetch)
8692 (uri (pypi-uri "zope.component" version))
8693 (sha256
8694 (base32
8695 "1hlvzwj1kcfz1qms1dzhwsshpsf38z9clmyksb1gh41n8k3kchdv"))))
8696 (build-system python-build-system)
8697 (arguments
8698 ;; Skip tests due to circular dependency with python-zope-security.
8699 '(#:tests? #f))
8700 (native-inputs
8701 `(("python-zope-testing" ,python-zope-testing)))
8702 (propagated-inputs
8703 `(("python-zope-event" ,python-zope-event)
8704 ("python-zope-interface" ,python-zope-interface)
8705 ("python-zope-i18nmessageid" ,python-zope-i18nmessageid)
8706 ("python-zope-configuration" ,python-zope-configuration)))
8707 (home-page "https://github.com/zopefoundation/zope.component")
8708 (synopsis "Zope Component Architecture")
8709 (description "Zope.component represents the core of the Zope Component
8710 Architecture. Together with the zope.interface package, it provides
8711 facilities for defining, registering and looking up components.")
8712 (license license:zpl2.1)))
8713
8714 (define-public python2-zope-component
8715 (package-with-python2 python-zope-component))
8716
8717 (define-public python-pythondialog
8718 (package
8719 (name "python-pythondialog")
8720 (version "3.4.0")
8721 (source
8722 (origin
8723 (method url-fetch)
8724 (uri (pypi-uri "pythondialog" version))
8725 (sha256
8726 (base32
8727 "1728ghsran47jczn9bhlnkvk5bvqmmbihabgif5h705b84r1272c"))))
8728 (build-system python-build-system)
8729 (arguments
8730 `(#:phases
8731 (modify-phases %standard-phases
8732 (add-after 'unpack 'patch-path
8733 (lambda* (#:key inputs #:allow-other-keys)
8734 (let* ((dialog (assoc-ref inputs "dialog")))
8735 ;; Since this library really wants to grovel the search path, we
8736 ;; must hardcode dialog's store path into it.
8737 (substitute* "dialog.py"
8738 (("os.getenv\\(\"PATH\", \":/bin:/usr/bin\"\\)")
8739 (string-append "os.getenv(\"PATH\") + \":" dialog "/bin\"")))
8740 #t))))
8741 #:tests? #f)) ; no test suite
8742 (propagated-inputs
8743 `(("dialog" ,dialog)))
8744 (home-page "http://pythondialog.sourceforge.net/")
8745 (synopsis "Python interface to the UNIX dialog utility")
8746 (description "A Python wrapper for the dialog utility. Its purpose is to
8747 provide an easy to use, pythonic and comprehensive Python interface to dialog.
8748 This allows one to make simple text-mode user interfaces on Unix-like systems")
8749 (license license:lgpl2.1)
8750 (properties `((python2-variant . ,(delay python2-pythondialog))))))
8751
8752 (define-public python2-pythondialog
8753 (let ((base (package-with-python2 (strip-python2-variant python-pythondialog))))
8754 (package
8755 (inherit base)
8756 (version (package-version python-pythondialog))
8757 (source (origin
8758 (method url-fetch)
8759 (uri (pypi-uri "python2-pythondialog" version))
8760 (sha256
8761 (base32
8762 "0d8k7lxk50imdyx85lv8j98i4c93a71iwpapnl1506rpkbm9qvd9")))))))
8763
8764 (define-public python-pyrfc3339
8765 (package
8766 (name "python-pyrfc3339")
8767 (version "1.0")
8768 (source
8769 (origin
8770 (method url-fetch)
8771 (uri (pypi-uri "pyRFC3339" version))
8772 (sha256
8773 (base32
8774 "0dgm4l9y8jiax5cp6yxjd2i27cq8h33sh81n1wfbmnmqb32cdywd"))))
8775 (build-system python-build-system)
8776 (propagated-inputs
8777 `(("python-pytz" ,python-pytz)))
8778 (native-inputs
8779 `(("python-nose" ,python-nose)))
8780 (home-page "https://github.com/kurtraschke/pyRFC3339")
8781 (synopsis "Python timestamp library")
8782 (description "Python library for generating and parsing RFC 3339-compliant
8783 timestamps.")
8784 (license license:expat)))
8785
8786 (define-public python2-pyrfc3339
8787 (package-with-python2 python-pyrfc3339))
8788
8789 (define-public python-werkzeug
8790 (package
8791 (name "python-werkzeug")
8792 (version "0.11.15")
8793 (source
8794 (origin
8795 (method url-fetch)
8796 (uri (pypi-uri "Werkzeug" version))
8797 (sha256
8798 (base32
8799 "1h5wycw8yj7q0grqsjnsqflmrlsdagvl2j4dsgdncci6mjc7fpa5"))))
8800 (build-system python-build-system)
8801 (native-inputs
8802 `(("python-pytest" ,python-pytest)))
8803 (home-page "http://werkzeug.pocoo.org/")
8804 (synopsis "Utilities for WSGI applications")
8805 (description "One of the most advanced WSGI utility modules. It includes a
8806 powerful debugger, full-featured request and response objects, HTTP utilities to
8807 handle entity tags, cache control headers, HTTP dates, cookie handling, file
8808 uploads, a powerful URL routing system and a bunch of community-contributed
8809 addon modules.")
8810 (license license:x11)))
8811
8812 (define-public python2-werkzeug
8813 (package-with-python2 python-werkzeug))
8814
8815 (define-public python-configobj
8816 (package
8817 (name "python-configobj")
8818 (version "5.0.6")
8819 (source (origin
8820 (method url-fetch)
8821 (uri (string-append
8822 "https://pypi.python.org/packages/source/c/configobj/"
8823 "configobj-" version ".tar.gz"))
8824 (sha256
8825 (base32
8826 "00h9rcmws03xvdlfni11yb60bz3kxfvsj6dg6nrpzj71f03nbxd2"))
8827 ;; Patch setup.py so it looks for python-setuptools, which is
8828 ;; required to parse the keyword 'install_requires' in setup.py.
8829 (patches (search-patches "python-configobj-setuptools.patch"))))
8830 (build-system python-build-system)
8831 (propagated-inputs
8832 `(("python-six" ,python-six)))
8833 (synopsis "Config file reading, writing and validation")
8834 (description "ConfigObj is a simple but powerful config file reader and
8835 writer: an ini file round tripper. Its main feature is that it is very easy to
8836 use, with a straightforward programmer’s interface and a simple syntax for
8837 config files.")
8838 (home-page "https://github.com/DiffSK/configobj")
8839 (license license:bsd-3)))
8840
8841 (define-public python2-configobj
8842 (package-with-python2 python-configobj))
8843
8844 (define-public python-configargparse
8845 (package
8846 (name "python-configargparse")
8847 (version "0.10.0")
8848 (source (origin
8849 (method url-fetch)
8850 (uri (string-append
8851 "https://pypi.python.org/packages/source/C/ConfigArgParse/"
8852 "ConfigArgParse-" version ".tar.gz"))
8853 (sha256
8854 (base32
8855 "19wh919gbdbzxzpagg52q3lm62yicm95ddlcx77dyjc1slyshl1v"))))
8856 (build-system python-build-system)
8857 (arguments
8858 ;; FIXME: Bug in test suite filed upstream:
8859 ;; https://github.com/bw2/ConfigArgParse/issues/32
8860 '(#:tests? #f))
8861 (synopsis "Replacement for argparse")
8862 (description "A drop-in replacement for argparse that allows options to also
8863 be set via config files and/or environment variables.")
8864 (home-page "https://github.com/bw2/ConfigArgParse")
8865 (license license:expat)))
8866
8867 (define-public python2-configargparse
8868 (package-with-python2 python-configargparse))
8869
8870 (define-public python-ndg-httpsclient
8871 (package
8872 (name "python-ndg-httpsclient")
8873 (version "0.4.2")
8874 (source (origin
8875 (method url-fetch)
8876 (uri (pypi-uri "ndg_httpsclient" version))
8877 (sha256
8878 (base32
8879 "1b5qirv46v4dpnmfqviwq42mdwfcby4dxmz0i41wad2337pqf2aq"))))
8880 (build-system python-build-system)
8881 (arguments
8882 '(;; The tests appear to require networking.
8883 #:tests? #f))
8884 (propagated-inputs
8885 `(("python-pyopenssl" ,python-pyopenssl)))
8886 (synopsis "HTTPS support for Python's httplib and urllib2")
8887 (description "This is a HTTPS client implementation for httplib and urllib2
8888 based on PyOpenSSL. PyOpenSSL provides a more fully featured SSL implementation
8889 over the default provided with Python and importantly enables full verification
8890 of the SSL peer.")
8891 (home-page "https://github.com/cedadev/ndg_httpsclient/")
8892 (license license:bsd-3)))
8893
8894 ;; python2-openssl requires special care, so package-with-python2 is
8895 ;; insufficient.
8896 (define-public python2-ndg-httpsclient
8897 (package (inherit python-ndg-httpsclient)
8898 (name "python2-ndg-httpsclient")
8899 (arguments `(#:python ,python-2))
8900 (propagated-inputs
8901 `(("python2-pyopenssl" ,python2-pyopenssl)))))
8902
8903 (define-public python-contextlib2
8904 (package
8905 (name "python-contextlib2")
8906 (version "0.4.0")
8907 (source
8908 (origin
8909 (method url-fetch)
8910 (uri (pypi-uri "contextlib2" version))
8911 (sha256
8912 (base32
8913 "0cmp131dlh0d0zvw0aza1zd13glvngzk8lb4avks0hm7yxwdr9am"))))
8914 (build-system python-build-system)
8915 (arguments
8916 `(#:phases
8917 (modify-phases %standard-phases
8918 (replace 'check
8919 (lambda _ (zero?
8920 (system*
8921 "python" "test_contextlib2.py" "-v")))))))
8922 (home-page "http://contextlib2.readthedocs.org/")
8923 (synopsis "Tools for decorators and context managers")
8924 (description "This module is primarily a backport of the Python
8925 3.2 contextlib to earlier Python versions. Like contextlib, it
8926 provides utilities for common tasks involving decorators and context
8927 managers. It also contains additional features that are not part of
8928 the standard library.")
8929 (license license:psfl)))
8930
8931 (define-public python2-contextlib2
8932 (package-with-python2 python-contextlib2))
8933
8934 (define-public python-texttable
8935 (package
8936 (name "python-texttable")
8937 (version "0.8.7")
8938 (source
8939 (origin
8940 (method url-fetch)
8941 (uri (pypi-uri "texttable" version))
8942 (sha256
8943 (base32
8944 "1liiiydgkg37i46a418aw19fyf6z3ds51wdwwpyjbs12x0phhf4a"))))
8945 (build-system python-build-system)
8946 (arguments '(#:tests? #f)) ; no tests
8947 (home-page "https://github.com/foutaise/texttable/")
8948 (synopsis "Python module for creating simple ASCII tables")
8949 (description "Texttable is a Python module for creating simple ASCII
8950 tables.")
8951 (license license:lgpl2.1+)))
8952
8953 (define-public python2-texttable
8954 (package-with-python2 python-texttable))
8955
8956 (define-public python-websocket-client
8957 (package
8958 (name "python-websocket-client")
8959 (version "0.37.0")
8960 (source
8961 (origin
8962 (method url-fetch)
8963 (uri (pypi-uri "websocket_client" version))
8964 (sha256
8965 (base32
8966 "0h9glp1jll3z76ly3kg08aqgxqk0a68p4zi9yn50353bh5nj92v7"))))
8967 (build-system python-build-system)
8968 (propagated-inputs
8969 `(("python-six" ,python-six)))
8970 (home-page "https://github.com/liris/websocket-client")
8971 (synopsis "WebSocket client for Python")
8972 (description "The Websocket-client module provides the low level APIs for
8973 WebSocket usage in Python programs.")
8974 (license license:lgpl2.1+)))
8975
8976 (define-public python2-websocket-client
8977 (package-with-python2 python-websocket-client))
8978
8979 (define-public python-atomicwrites
8980 (package
8981 (name "python-atomicwrites")
8982 (version "1.1.5")
8983 (source (origin
8984 (method url-fetch)
8985 (uri (pypi-uri "atomicwrites" version))
8986 (sha256
8987 (base32
8988 "11bm90fwm2avvf4f3ib8g925w7jr4m11vcsinn1bi6ns4bm32214"))))
8989 (build-system python-build-system)
8990 (synopsis "Atomic file writes in Python")
8991 (description "Library for atomic file writes using platform dependent tools
8992 for atomic file system operations.")
8993 (home-page "https://github.com/untitaker/python-atomicwrites")
8994 (license license:expat)))
8995
8996 (define-public python2-atomicwrites
8997 (package-with-python2 python-atomicwrites))
8998
8999 (define-public python-requests-toolbelt
9000 (package
9001 (name "python-requests-toolbelt")
9002 (version "0.6.2")
9003 (source (origin
9004 (method url-fetch)
9005 (uri (string-append
9006 "https://pypi.python.org/packages/"
9007 "e1/a4/a94c037bc72ad70441aff1403d3243510d2542ddca7759faaeffeb11aefe/"
9008 "requests-toolbelt-" version ".tar.gz"))
9009 (sha256
9010 (base32
9011 "15q9nrgp85nqlr4kdz1zvj8z2npafi2sr12y7fqgxbkq28j1aci6"))))
9012 (build-system python-build-system)
9013 (native-inputs
9014 `(("python-betamax" ,python-betamax)
9015 ("python-mock" ,python-mock)
9016 ("python-pytest" ,python-pytest)))
9017 (propagated-inputs
9018 `(("python-requests" ,python-requests)))
9019 (synopsis "Extensions to python-requests")
9020 (description "This is a toolbelt of useful classes and functions to be used
9021 with python-requests.")
9022 (home-page "https://github.com/sigmavirus24/requests-toolbelt")
9023 (license license:asl2.0)))
9024
9025 (define-public python-click-threading
9026 (package
9027 (name "python-click-threading")
9028 (version "0.2.0")
9029 (source (origin
9030 (method url-fetch)
9031 (uri (string-append
9032 "https://pypi.python.org/packages/"
9033 "fe/b7/e7f609d18a2a351cb71616adcf54df1acd82f83cb9b5936935a4d20e2c23/"
9034 "click-threading-" version ".tar.gz"))
9035 (sha256
9036 (base32
9037 "18bcqikxwb3drb8rf60cclxkxw52521b38ax3byah6j8cn8y9p4j"))))
9038 (build-system python-build-system)
9039 (propagated-inputs
9040 `(("python-click" ,python-click)))
9041 (synopsis "Utilities for multithreading in Click")
9042 (description "This package provides utilities for multithreading in Click
9043 applications.")
9044 (home-page "https://github.com/click-contrib/click-threading")
9045 (license license:expat)))
9046
9047 (define-public python-click-log
9048 (package
9049 (name "python-click-log")
9050 (version "0.1.8")
9051 (source (origin
9052 (method url-fetch)
9053 (uri (pypi-uri "click-log" version))
9054 (sha256
9055 (base32
9056 "14ikfjfgnzf21mjniq9lfk2igzykgzfvwwrk85nw2b9fq44109sp"))))
9057 (build-system python-build-system)
9058 (propagated-inputs
9059 `(("python-click" ,python-click)))
9060 (synopsis "Logging for click applications")
9061 (description "This package provides a Python library for logging Click
9062 applications.")
9063 (home-page "https://github.com/click-contrib/click-log")
9064 (license license:expat)))
9065
9066 (define-public python-apipkg
9067 (package
9068 (name "python-apipkg")
9069 (version "1.4")
9070 (source (origin
9071 (method url-fetch)
9072 (uri (pypi-uri "apipkg" version))
9073 (sha256
9074 (base32
9075 "1iks5701qnp3dlr3q1d9qm68y2plp2m029irhpz92a44psfkjf1f"))))
9076 (build-system python-build-system)
9077 (native-inputs
9078 `(("python-pytest" ,python-pytest)))
9079 (synopsis "Namespace control and lazy-import mechanism")
9080 (description "With apipkg you can control the exported namespace of a Python
9081 package and greatly reduce the number of imports for your users. It is a small
9082 pure Python module that works on virtually all Python versions.")
9083 (home-page "https://bitbucket.org/hpk42/apipkg")
9084 (license license:expat)))
9085
9086 (define-public python2-apipkg
9087 (package-with-python2 python-apipkg))
9088
9089 (define-public python-execnet
9090 (package
9091 (name "python-execnet")
9092 (version "1.4.1")
9093 (source (origin
9094 (method url-fetch)
9095 (uri (pypi-uri "execnet" version))
9096 (sha256
9097 (base32
9098 "1rpk1vyclhg911p3hql0m0nrpq7q7mysxnaaw6vs29cpa6kx8vgn"))))
9099 (build-system python-build-system)
9100 (arguments
9101 `(;; 2 failed, 275 passed, 670 skipped, 4 xfailed
9102 ;; The two test failures are caused by the lack of an `ssh` executable.
9103 ;; The test suite can be run with pytest after the 'install' phase.
9104 #:tests? #f))
9105 (native-inputs
9106 `(("python-pytest" ,python-pytest)
9107 ("python-setuptools-scm" ,python-setuptools-scm)))
9108 (propagated-inputs
9109 `(("python-apipkg" ,python-apipkg)))
9110 (synopsis "Rapid multi-Python deployment")
9111 (description "Execnet provides a share-nothing model with
9112 channel-send/receive communication for distributing execution across many
9113 Python interpreters across version, platform and network barriers. It has a
9114 minimal and fast API targeting the following uses:
9115 @enumerate
9116 @item distribute tasks to (many) local or remote CPUs
9117 @item write and deploy hybrid multi-process applications
9118 @item write scripts to administer multiple environments
9119 @end enumerate")
9120 (home-page "http://codespeak.net/execnet/")
9121 (license license:expat)))
9122
9123 (define-public python2-execnet
9124 (package-with-python2 python-execnet))
9125
9126 (define-public python-trollius-redis
9127 (package
9128 (name "python-trollius-redis")
9129 (version "0.1.4")
9130 (source
9131 (origin
9132 (method url-fetch)
9133 (uri (pypi-uri "trollius_redis" version))
9134 (sha256
9135 (base32
9136 "0k3vypszmgmaipgw9xscvgm79h2zd6p6ci8gdp5sxl6g5kbqr9fy"))))
9137 (build-system python-build-system)
9138 ;; TODO: Tests require packaging 'hiredis'.
9139 (arguments '(#:tests? #f))
9140 (home-page "https://github.com/benjolitz/trollius-redis")
9141 (synopsis "Port of asyncio-redis to trollius")
9142 (description "@code{trollius-redis} is a Redis client for Python
9143 trollius. It is an asynchronious IO (PEP 3156) implementation of the
9144 Redis protocol.")
9145 (license license:bsd-2)))
9146
9147 (define-public python2-trollius-redis
9148 (package-with-python2 python-trollius-redis))
9149
9150 ;;; The software provided by this package was integrated into pytest 2.8.
9151 (define-public python-pytest-cache
9152 (package
9153 (name "python-pytest-cache")
9154 (version "1.0")
9155 (source (origin
9156 (method url-fetch)
9157 (uri (pypi-uri "pytest-cache" version))
9158 (sha256
9159 (base32
9160 "1a873fihw4rhshc722j4h6j7g3nj7xpgsna9hhg3zn6ksknnhx5y"))))
9161 (build-system python-build-system)
9162 (propagated-inputs
9163 `(("python-apipkg" ,python-apipkg)
9164 ("python-execnet" ,python-execnet)
9165 ("python-py" ,python-py)
9166 ("python-pytest" ,python-pytest)))
9167 (synopsis "Py.test plugin with mechanisms for caching across test runs")
9168 (description "The pytest-cache plugin provides tools to rerun failures from
9169 the last py.test invocation.")
9170 (home-page "https://bitbucket.org/hpk42/pytest-cache/")
9171 (license license:expat)))
9172
9173 (define-public python2-pytest-cache
9174 (package-with-python2 python-pytest-cache))
9175
9176 (define-public python-pytest-localserver
9177 (package
9178 (name "python-pytest-localserver")
9179 (version "0.3.5")
9180 (source (origin
9181 (method url-fetch)
9182 (uri (pypi-uri "pytest-localserver" version))
9183 (sha256
9184 (base32
9185 "0dvqspjr6va55zwmnnc2mmpqc7mm65kxig9ya44x1z8aadzxpa4p"))))
9186 (build-system python-build-system)
9187 (arguments
9188 `(#:phases (modify-phases %standard-phases
9189 (replace 'check
9190 (lambda _
9191 (zero? (system* "py.test" "--genscript=runtests.py"))
9192 (zero? (system* "py.test")))))))
9193 (native-inputs
9194 `(("python-pytest" ,python-pytest)
9195 ("python-requests" ,python-requests)
9196 ("python-six" ,python-six)))
9197 (propagated-inputs
9198 `(("python-werkzeug" ,python-werkzeug)))
9199 (synopsis "Py.test plugin to test server connections locally")
9200 (description "Pytest-localserver is a plugin for the pytest testing
9201 framework which enables you to test server connections locally.")
9202 (home-page "https://pypi.python.org/pypi/pytest-localserver")
9203 (license license:expat)))
9204
9205 (define-public python-wsgi-intercept
9206 (package
9207 (name "python-wsgi-intercept")
9208 (version "1.2.2")
9209 (source (origin
9210 (method url-fetch)
9211 (uri (string-append
9212 "https://pypi.python.org/packages/"
9213 "38/76/ebcbc24d0cb77db34520a3ca6ed1bd43ace17d182bbd8dd7d976f1c176fb/"
9214 "wsgi_intercept-" version ".tar.gz"))
9215 (sha256
9216 (base32
9217 "0kjj2v2dvmnpdd5h5gk9rzz0f54rhjb0yiz3zg65bmp65slfw65d"))))
9218 (build-system python-build-system)
9219 (propagated-inputs
9220 `(("python-six" ,python-six)))
9221 (native-inputs
9222 `(("python-pytest" ,python-pytest)
9223 ("python-httplib2" ,python-httplib2)
9224 ("python-requests" ,python-requests)
9225 ("python-urllib3" ,python-urllib3)))
9226 (synopsis "Puts a WSGI application in place of a real URI for testing")
9227 (description "Wsgi_intercept installs a WSGI application in place of a real
9228 URI for testing. Testing a WSGI application normally involves starting a
9229 server at a local host and port, then pointing your test code to that address.
9230 Instead, this library lets you intercept calls to any specific host/port
9231 combination and redirect them into a WSGI application importable by your test
9232 program. Thus, you can avoid spawning multiple processes or threads to test
9233 your Web app.")
9234 (home-page "https://github.com/cdent/wsgi-intercept")
9235 (license license:expat)))
9236
9237 (define-public python-pytest-xprocess
9238 (package
9239 (name "python-pytest-xprocess")
9240 (version "0.9.1")
9241 (source (origin
9242 (method url-fetch)
9243 (uri (pypi-uri "pytest-xprocess" version))
9244 (sha256
9245 (base32
9246 "17zlql1xqw3ywcgwwbqmw633aly99lab12hm02asr8awvg5603pp"))))
9247 (build-system python-build-system)
9248 (propagated-inputs
9249 `(("python-pytest" ,python-pytest)
9250 ("python-pytest-cache" ,python-pytest-cache)
9251 ("python-psutil" ,python-psutil)))
9252 (synopsis "Pytest plugin to manage external processes across test runs")
9253 (description "Pytest-xprocess is an experimental py.test plugin for managing
9254 processes across test runs.")
9255 (home-page "https://bitbucket.org/pytest-dev/pytest-xprocess")
9256 (license license:expat)))
9257
9258 (define-public python-icalendar
9259 (package
9260 (name "python-icalendar")
9261 (version "3.11.5")
9262 (source (origin
9263 (method url-fetch)
9264 (uri (pypi-uri "icalendar" version))
9265 (sha256
9266 (base32
9267 "0y6f2js983ag0d138xx4pzyc71gf44hyqmjsdvw6pq2xrkpj8jzk"))))
9268 (build-system python-build-system)
9269 (propagated-inputs
9270 `(("python-dateutil" ,python-dateutil)
9271 ("python-pytz" ,python-pytz)))
9272 (synopsis "Python library for parsing iCalendar files")
9273 (description "The icalendar package is a parser/generator of iCalendar
9274 files for use with Python.")
9275 (home-page "https://github.com/collective/icalendar")
9276 (license license:bsd-2)))
9277
9278 (define-public python-sphinxcontrib-newsfeed
9279 (package
9280 (name "python-sphinxcontrib-newsfeed")
9281 (version "0.1.4")
9282 (source (origin
9283 (method url-fetch)
9284 (uri (pypi-uri "sphinxcontrib-newsfeed" version))
9285 (sha256
9286 (base32
9287 "1d7gam3mn8v4in4p16yn3v10vps7nnaz6ilw99j4klij39dqd37p"))))
9288 (arguments '(#:tests? #f)) ; No tests.
9289 (build-system python-build-system)
9290 (propagated-inputs
9291 `(("python-sphinx" ,python-sphinx)))
9292 (synopsis "News Feed extension for Sphinx")
9293 (description "Sphinxcontrib-newsfeed is an extension for adding a simple
9294 Blog, News or Announcements section to a Sphinx website.")
9295 (home-page "https://bitbucket.org/prometheus/sphinxcontrib-newsfeed")
9296 (license license:bsd-2)))
9297
9298 (define-public python-args
9299 (package
9300 (name "python-args")
9301 (version "0.1.0")
9302 (source (origin
9303 (method url-fetch)
9304 (uri (pypi-uri "args" version))
9305 (sha256
9306 (base32
9307 "057qzi46h5dmxdqknsbrssn78lmqjlnm624iqdhrnpk26zcbi1d7"))))
9308 (build-system python-build-system)
9309 (home-page "https://github.com/kennethreitz/args")
9310 (synopsis "Command-line argument parser")
9311 (description
9312 "This library provides a Python module to parse command-line arguments.")
9313 (license license:bsd-3)))
9314
9315 (define-public python2-args
9316 (package-with-python2 python-args))
9317
9318 (define-public python-clint
9319 (package
9320 (name "python-clint")
9321 (version "0.5.1")
9322 (source (origin
9323 (method url-fetch)
9324 (uri (pypi-uri "clint" version))
9325 (sha256
9326 (base32
9327 "1an5lkkqk1zha47198p42ji3m94xmzx1a03dn7866m87n4r4q8h5"))))
9328 (build-system python-build-system)
9329 (arguments
9330 '(#:phases
9331 (modify-phases %standard-phases
9332 (replace 'check
9333 (lambda _
9334 (zero? (system* "py.test" "-v")))))))
9335 (native-inputs
9336 `(("python-pytest" ,python-pytest)))
9337 (propagated-inputs
9338 `(("python-args" ,python-args)))
9339 (home-page "https://github.com/kennethreitz/clint")
9340 (synopsis "Command-line interface tools")
9341 (description
9342 "Clint is a Python module filled with a set of tools for developing
9343 command-line applications, including tools for colored and indented
9344 output, progress bar display, and pipes.")
9345 (license license:isc)))
9346
9347 (define-public python2-clint
9348 (package-with-python2 python-clint))
9349
9350 (define-public python-astor
9351 (package
9352 (name "python-astor")
9353 (version "0.5")
9354 (source (origin
9355 (method url-fetch)
9356 (uri (pypi-uri "astor" version))
9357 (sha256
9358 (base32
9359 "1fdafq5hkis1fxqlmhw0sn44zp2ar46nxhbc22cvwg7hsd8z5gsa"))))
9360 (build-system python-build-system)
9361 (home-page "https://github.com/berkerpeksag/astor")
9362 (synopsis "Read and write Python ASTs")
9363 (description
9364 "Astor is designed to allow easy manipulation of Python source via the
9365 Abstract Syntax Tree.")
9366 (license license:bsd-3)))
9367
9368 (define-public python2-astor
9369 (package-with-python2 python-astor))
9370
9371 (define-public python-rply
9372 (package
9373 (name "python-rply")
9374 (version "0.7.4")
9375 (source (origin
9376 (method url-fetch)
9377 (uri (pypi-uri "rply" version))
9378 (sha256
9379 (base32
9380 "12rp1d9ba7nvd5rhaxi6xzx1rm67r1k1ylsrkzhpwnphqpb06cvj"))))
9381 (build-system python-build-system)
9382 (propagated-inputs
9383 `(("python-appdirs" ,python-appdirs)))
9384 (home-page "https://github.com/alex/rply")
9385 (synopsis "Parser generator for Python")
9386 (description
9387 "This package provides a pure Python based parser generator, that also
9388 works with RPython. It is a more-or-less direct port of David Bazzley's PLY,
9389 with a new public API, and RPython support.")
9390 (license license:bsd-3)))
9391
9392 (define-public python2-rply
9393 (package-with-python2 python-rply))
9394
9395 (define-public python-hy
9396 (package
9397 (name "python-hy")
9398 (version "0.11.1")
9399 (source (origin
9400 (method url-fetch)
9401 (uri (pypi-uri "hy" version))
9402 (sha256
9403 (base32
9404 "1msqv747iz12r73mz4qvsmlwkddwjvrahlrk7ysrcz07h7dsscxs"))))
9405 (build-system python-build-system)
9406 (arguments
9407 '(#:phases
9408 (modify-phases %standard-phases
9409 (replace 'check
9410 (lambda _
9411 ;; Tests require write access to HOME.
9412 (setenv "HOME" "/tmp")
9413 (zero? (system* "nosetests")))))))
9414 (native-inputs
9415 `(("python-coverage" ,python-coverage)
9416 ("python-nose" ,python-nose)))
9417 (propagated-inputs
9418 `(("python-astor" ,python-astor)
9419 ("python-clint" ,python-clint)
9420 ("python-rply" ,python-rply)))
9421 (home-page "http://hylang.org/")
9422 (synopsis "Lisp frontend to Python")
9423 (description
9424 "Hy is a dialect of Lisp that's embedded in Python. Since Hy transforms
9425 its Lisp code into the Python Abstract Syntax Tree, you have the whole world of
9426 Python at your fingertips, in Lisp form.")
9427 (license license:expat)))
9428
9429 (define-public python2-hy
9430 (package-with-python2 python-hy))
9431
9432 (define-public python-rauth
9433 (package
9434 (name "python-rauth")
9435 (version "0.7.3")
9436 (source
9437 (origin
9438 (method url-fetch)
9439 (uri (pypi-uri "rauth" version))
9440 (sha256
9441 (base32
9442 "02kv8w8l98ky223avyq7vw7x1f2ya9chrm59r77ylq45qb0xnk2j"))))
9443 (build-system python-build-system)
9444 (arguments
9445 `(#:test-target "check"))
9446 (propagated-inputs
9447 `(("python-requests" ,python-requests)))
9448 (home-page "https://github.com/litl/rauth")
9449 (synopsis "Python library for OAuth 1.0/a, 2.0, and Ofly")
9450 (description
9451 "Rauth is a Python library for OAuth 1.0/a, 2.0, and Ofly. It also
9452 provides service wrappers for convenient connection initialization and
9453 authenticated session objects providing things like keep-alive.")
9454 (license license:expat)
9455 (properties `((python2-variant . ,(delay python2-rauth))))))
9456
9457 (define-public python2-rauth
9458 (let ((base (package-with-python2 (strip-python2-variant python-rauth))))
9459 (package
9460 (inherit base)
9461 (native-inputs `(("python2-unittest2" ,python2-unittest2)
9462 ,@(package-native-inputs base))))))
9463
9464 (define-public python2-functools32
9465 (package
9466 (name "python2-functools32")
9467 (version "3.2.3-2")
9468 (source
9469 (origin
9470 (method url-fetch)
9471 (uri (pypi-uri "functools32" version))
9472 (sha256
9473 (base32
9474 "0v8ya0b58x47wp216n1zamimv4iw57cxz3xxhzix52jkw3xks9gn"))))
9475 (build-system python-build-system)
9476 (arguments
9477 `(#:python ,python-2
9478 #:tests? #f)) ; no test target
9479 (home-page "https://github.com/MiCHiLU/python-functools32")
9480 (synopsis
9481 "Backport of the functools module from Python 3.2.3")
9482 (description
9483 "This package is a backport of the @code{functools} module from Python
9484 3.2.3 for use with older versions of Python and PyPy.")
9485 (license license:expat)))
9486
9487 (define-public python2-subprocess32
9488 (package
9489 (name "python2-subprocess32")
9490 (version "3.2.7")
9491 (source (origin
9492 (method url-fetch)
9493 (uri (pypi-uri "subprocess32" version))
9494 (sha256
9495 (base32
9496 "14350dhhlhyz5gqzi3lihn9m6lvskx5mcb20srx1kgsk9i50li8y"))
9497 (patches
9498 (search-patches "python2-subprocess32-disable-input-test.patch"))))
9499 (build-system python-build-system)
9500 (arguments
9501 `(#:python ,python-2
9502 #:phases
9503 (modify-phases %standard-phases
9504 (add-after 'unpack 'patch-/bin/sh
9505 (lambda _
9506 (substitute* '("subprocess32.py"
9507 "test_subprocess32.py")
9508 (("/bin/sh") (which "sh")))
9509 #t))
9510 (delete 'check)
9511 (add-after 'install 'check
9512 (lambda* (#:key inputs outputs #:allow-other-keys)
9513 ;; For some reason this package fails to import
9514 ;; _posixsubprocess.so when PYTHONPATH is set to the build
9515 ;; directory. Running tests after install is easier.
9516 (add-installed-pythonpath inputs outputs)
9517 (zero? (system* "python" "test_subprocess32.py")))))))
9518 (home-page "https://github.com/google/python-subprocess32")
9519 (synopsis "Backport of the subprocess module from Python 3.2")
9520 (description
9521 "This is a backport of the @code{subprocess} standard library module
9522 from Python 3.2 and 3.3 for use on Python 2. It includes bugfixes and some
9523 new features. On POSIX systems it is guaranteed to be reliable when used
9524 in threaded applications. It includes timeout support from Python 3.3 but
9525 otherwise matches 3.2’s API.")
9526 (license license:psfl)))
9527
9528 (define-public python2-futures
9529 (package
9530 (name "python2-futures")
9531 (version "3.0.5")
9532 (source
9533 (origin
9534 (method url-fetch)
9535 (uri (pypi-uri "futures" version))
9536 (sha256
9537 (base32
9538 "1pw1z4329xvlabdpwqa6b7v2fxf7hl64m4cgr22ckbym8m8m4hh5"))))
9539 (build-system python-build-system)
9540 (arguments `(#:python ,python-2))
9541 (home-page "https://github.com/agronholm/pythonfutures")
9542 (synopsis
9543 "Backport of the concurrent.futures package from Python 3.2")
9544 (description
9545 "The concurrent.futures module provides a high-level interface for
9546 asynchronously executing callables. This package backports the
9547 concurrent.futures package from Python 3.2")
9548 (license license:bsd-3)))
9549
9550 (define-public python-promise
9551 (package
9552 (name "python-promise")
9553 (version "0.4.2")
9554 (source
9555 (origin
9556 (method url-fetch)
9557 (uri (pypi-uri "promise" version))
9558 (sha256
9559 (base32
9560 "1k19ms8l3d5jzjh557rgkxb5sg4mqgfc315rn4hx1z3n8qq6lr3h"))))
9561 (build-system python-build-system)
9562 ;; Tests wants python-futures, which is a python2 only program, and
9563 ;; can't be found by python-promise at test time.
9564 (arguments `(#:tests? #f))
9565 (home-page "https://github.com/syrusakbary/promise")
9566 (synopsis "Promises/A+ implementation for Python")
9567 (description
9568 "Promises/A+ implementation for Python")
9569 (properties `((python2-variant . ,(delay python2-promise))))
9570 (license license:expat)))
9571
9572 (define-public python2-promise
9573 (let ((promise (package-with-python2
9574 (strip-python2-variant python-promise))))
9575 (package (inherit promise)
9576 (arguments (substitute-keyword-arguments (package-arguments promise)
9577 ((#:tests? _) #t)))
9578 (native-inputs
9579 `(("python2-futures" ,python2-futures)
9580 ("python2-pytest" ,python2-pytest)
9581 ,@(package-native-inputs promise))))))
9582
9583 (define-public python-urllib3
9584 (package
9585 (name "python-urllib3")
9586 (version "1.18.1")
9587 (source
9588 (origin
9589 (method url-fetch)
9590 (uri (pypi-uri "urllib3" version))
9591 (sha256
9592 (base32
9593 "1wb8aqnq53vzh2amrv8kc66f3h6fx217y0q62y6n30a64p2yqmam"))))
9594 (build-system python-build-system)
9595 (arguments `(#:tests? #f))
9596 (native-inputs
9597 `(;; some packages for tests
9598 ("python-nose" ,python-nose)
9599 ("python-mock" ,python-mock)
9600 ("python-tornado" ,python-tornado)))
9601 (propagated-inputs
9602 `(;; extra packages for https security
9603 ("python-certifi" ,python-certifi)
9604 ("python-ndg-httpsclient" ,python-ndg-httpsclient)
9605 ("python-pyasn1" ,python-pyasn1)
9606 ("python-pyopenssl" ,python-pyopenssl)))
9607 (home-page "https://urllib3.readthedocs.org/")
9608 (synopsis "HTTP library with thread-safe connection pooling")
9609 (description
9610 "Urllib3 supports features left out of urllib and urllib2 libraries. It
9611 can reuse the same socket connection for multiple requests, it can POST files,
9612 supports url redirection and retries, and also gzip and deflate decoding.")
9613 (license license:expat)))
9614
9615 (define-public python2-urllib3
9616 (package-with-python2 python-urllib3))
9617
9618 (define-public python-colorama
9619 (package
9620 (name "python-colorama")
9621 (version "0.3.7")
9622 (source
9623 (origin
9624 (method url-fetch)
9625 (uri (pypi-uri "colorama" version))
9626 (sha256
9627 (base32
9628 "0avqkn6362v7k2kg3afb35g4sfdvixjgy890clip4q174p9whhz0"))))
9629 (build-system python-build-system)
9630 (synopsis "Colored terminal text rendering for Python")
9631 (description "Colorama is a Python library for rendering colored terminal
9632 text.")
9633 (home-page "https://pypi.python.org/pypi/colorama")
9634 (license license:bsd-3)))
9635
9636 (define-public python2-colorama
9637 (package-with-python2 python-colorama))
9638
9639 (define-public python-rsa
9640 (package
9641 (name "python-rsa")
9642 (version "3.4.2")
9643 (source
9644 (origin
9645 (method url-fetch)
9646 (uri (pypi-uri "rsa" version))
9647 (sha256
9648 (base32
9649 "1dcxvszbikgzh99ybdc7jq0zb9wspy2ds8z9mjsqiyv3q884xpr5"))))
9650 (build-system python-build-system)
9651 (propagated-inputs
9652 `(("python-pyasn1" ,python-pyasn1)))
9653 (synopsis "Pure-Python RSA implementation")
9654 (description "Python-RSA is a pure-Python RSA implementation. It supports
9655 encryption and decryption, signing and verifying signatures, and key
9656 generation according to PKCS#1 version 1.5. It can be used as a Python
9657 library as well as on the command line.")
9658 (home-page "http://stuvel.eu/rsa")
9659 (license license:asl2.0)))
9660
9661 (define-public python2-rsa
9662 (package-with-python2 python-rsa))
9663
9664 (define-public python-pluggy
9665 (package
9666 (name "python-pluggy")
9667 (version "0.3.1")
9668 (source
9669 (origin
9670 (method url-fetch)
9671 (uri (pypi-uri "pluggy" version))
9672 (sha256
9673 (base32
9674 "18qfzfm40bgx672lkg8q9x5hdh76n7vax99aank7vh2nw21wg70m"))))
9675 (build-system python-build-system)
9676 (synopsis "Plugin and hook calling mechanism for Python")
9677 (description "Pluggy is an extraction of the plugin manager as used by
9678 Pytest but stripped of Pytest specific details.")
9679 (home-page "https://pypi.python.org/pypi/pluggy")
9680 (license license:expat)))
9681
9682 (define-public python2-pluggy
9683 (package-with-python2 python-pluggy))
9684
9685 (define-public python-tox
9686 (package
9687 (name "python-tox")
9688 (version "2.3.1")
9689 (source
9690 (origin
9691 (method url-fetch)
9692 (uri (pypi-uri "tox" version))
9693 (sha256
9694 (base32
9695 "1vj73ar4rimq3fwy5r2z3jv4g9qbh8rmpmncsc00g0k310acqzxz"))))
9696 (build-system python-build-system)
9697 (arguments
9698 ;; FIXME: Tests require pytest-timeout, which itself requires
9699 ;; pytest>=2.8.0 for installation.
9700 '(#:tests? #f))
9701 (propagated-inputs
9702 `(("python-pluggy" ,python-pluggy) ; >=0.3.0,<0.4.0
9703 ("python-py" ,python-py)
9704 ("python-virtualenv" ,python-virtualenv)))
9705 (native-inputs
9706 `(; FIXME: Missing: ("python-pytest-timeout" ,python-pytest-timeout)
9707 ("python-pytest" ,python-pytest))) ; >= 2.3.5
9708 (home-page "http://tox.testrun.org/")
9709 (synopsis "Virtualenv-based automation of test activities")
9710 (description "Tox is a generic virtualenv management and test command line
9711 tool. It can be used to check that a package installs correctly with
9712 different Python versions and interpreters, or run tests in each type of
9713 supported environment, or act as a frontend to continuous integration
9714 servers.")
9715 (license license:expat)))
9716
9717 (define-public python2-tox
9718 (package-with-python2 python-tox))
9719
9720 (define-public python-jmespath
9721 (package
9722 (name "python-jmespath")
9723 (version "0.9.0")
9724 (source
9725 (origin
9726 (method url-fetch)
9727 (uri (pypi-uri "jmespath" version))
9728 (sha256
9729 (base32
9730 "0g9xvl69y7nr3w7ag4fsp6sm4fqf6vrqjw7504x2hzrrsh3ampq8"))))
9731 (build-system python-build-system)
9732 (native-inputs
9733 `(("python-nose" ,python-nose)))
9734 (synopsis "JSON Matching Expressions")
9735 (description "JMESPath (pronounced “james path”) is a Python library that
9736 allows one to declaratively specify how to extract elements from a JSON
9737 document.")
9738 (home-page "https://github.com/jmespath/jmespath.py")
9739 (license license:expat)))
9740
9741 (define-public python2-jmespath
9742 (package-with-python2 python-jmespath))
9743
9744 (define-public python-botocore
9745 (package
9746 (name "python-botocore")
9747 (version "1.5.26")
9748 (source
9749 (origin
9750 (method url-fetch)
9751 (uri (pypi-uri "botocore" version))
9752 (sha256
9753 (base32
9754 "1b7l48hr88galrrc5q6k21z3sdadzxc87ppzs7k9fz4p1w8bfnvb"))))
9755 (build-system python-build-system)
9756 (arguments
9757 ;; FIXME: Many tests are failing.
9758 '(#:tests? #f))
9759 (propagated-inputs
9760 `(("python-dateutil" ,python-dateutil)
9761 ("python-docutils" ,python-docutils)
9762 ("python-jmespath" ,python-jmespath)))
9763 (native-inputs
9764 `(("python-mock" ,python-mock)
9765 ("python-nose" ,python-nose)
9766 ("behave" ,behave)
9767 ("python-tox" ,python-tox)
9768 ("python-wheel" ,python-wheel)))
9769 (home-page "https://github.com/boto/botocore")
9770 (synopsis "Low-level interface to AWS")
9771 (description "Botocore is a Python library that provides a low-level
9772 interface to the Amazon Web Services (AWS) API.")
9773 (license license:asl2.0)))
9774
9775 (define-public python2-botocore
9776 (package-with-python2 python-botocore))
9777
9778 (define-public awscli
9779 (package
9780 (name "awscli")
9781 (version "1.11.63")
9782 (source
9783 (origin
9784 (method url-fetch)
9785 (uri (pypi-uri name version))
9786 (sha256
9787 (base32
9788 "1r8aqv8w27k76lcsfk83w6qw9lz8gk2ibzwacp5wjhpp2gik911m"))))
9789 (build-system python-build-system)
9790 (propagated-inputs
9791 `(("python-colorama" ,python-colorama)
9792 ("python-botocore" ,python-botocore)
9793 ("python-s3transfer" ,python-s3transfer)
9794 ("python-docutils" ,python-docutils)
9795 ("python-pyyaml" ,python-pyyaml)
9796 ("python-rsa" ,python-rsa)))
9797 (arguments
9798 ;; FIXME: The 'pypi' release does not contain tests.
9799 '(#:tests? #f))
9800 (home-page "https://aws.amazon.com/cli/")
9801 (synopsis "Command line client for AWS")
9802 (description "AWS CLI provides a unified command line interface to the
9803 Amazon Web Services (AWS) API.")
9804 (license license:asl2.0)))
9805
9806 (define-public python-hypothesis
9807 (package
9808 (name "python-hypothesis")
9809 (version "3.1.0")
9810 (source (origin
9811 (method url-fetch)
9812 (uri (pypi-uri "hypothesis" version))
9813 (sha256
9814 (base32
9815 "0qyqq9akm4vshhn8cngjc1qykcvsn7cz6dlm6njfsgpbraqrmbbw"))))
9816 (build-system python-build-system)
9817 (native-inputs
9818 `(("python-flake8" ,python-flake8)
9819 ("python-pytest" ,python-pytest)))
9820 (synopsis "Library for property based testing")
9821 (description "Hypothesis is a library for testing your Python code against a
9822 much larger range of examples than you would ever want to write by hand. It’s
9823 based on the Haskell library, Quickcheck, and is designed to integrate
9824 seamlessly into your existing Python unit testing work flow.")
9825 (home-page "https://github.com/DRMacIver/hypothesis")
9826 (license license:mpl2.0)
9827 (properties `((python2-variant . ,(delay python2-hypothesis))))))
9828
9829 (define-public python2-hypothesis
9830 (let ((hypothesis (package-with-python2
9831 (strip-python2-variant python-hypothesis))))
9832 (package (inherit hypothesis)
9833 (native-inputs
9834 `(("python2-enum34" ,python2-enum34)
9835 ,@(package-native-inputs hypothesis))))))
9836
9837 (define-public python-pytest-subtesthack
9838 (package
9839 (name "python-pytest-subtesthack")
9840 (version "0.1.1")
9841 (source (origin
9842 (method url-fetch)
9843 (uri (pypi-uri "pytest-subtesthack" version))
9844 (sha256
9845 (base32
9846 "15kzcr5pchf3id4ikdvlv752rc0j4d912n589l4rifp8qsj19l1x"))))
9847 (build-system python-build-system)
9848 (propagated-inputs
9849 `(("python-pytest" ,python-pytest)))
9850 (synopsis "Set-up and tear-down fixtures for unit tests")
9851 (description "This plugin allows you to set up and tear down fixtures within
9852 unit test functions that use @code{py.test}. This is useful for using
9853 @command{hypothesis} inside py.test, as @command{hypothesis} will call the test
9854 function multiple times, without setting up or tearing down fixture state as is
9855 normally the case.")
9856 (home-page "https://github.com/untitaker/pytest-subtesthack/")
9857 (license license:unlicense)))
9858
9859 (define-public python2-pytest-subtesthack
9860 (package-with-python2 python-pytest-subtesthack))
9861
9862 (define-public python-xdo
9863 (package
9864 (name "python-xdo")
9865 (version "0.3")
9866 (source (origin
9867 (method url-fetch)
9868 (uri (string-append
9869 "http://http.debian.net/debian/pool/main/p/python-xdo/"
9870 "python-xdo_" version ".orig.tar.gz"))
9871 (sha256
9872 (base32
9873 "1vqh1n5yy5dhnq312kwrl90fnck4v26is3lq3lxdvcn60vv19da0"))))
9874 (build-system python-build-system)
9875 (arguments
9876 '(#:phases
9877 (modify-phases %standard-phases
9878 (add-before 'install 'patch-libxdo-path
9879 ;; Hardcode the path of dynamically loaded libxdo library.
9880 (lambda* (#:key inputs #:allow-other-keys)
9881 (let ((libxdo (string-append
9882 (assoc-ref inputs "xdotool")
9883 "/lib/libxdo.so")))
9884 (substitute* "xdo/_xdo.py"
9885 (("find_library\\(\"xdo\"\\)")
9886 (simple-format #f "\"~a\"" libxdo)))
9887 #t))))
9888 #:tests? #f)) ; no tests provided
9889 (propagated-inputs
9890 `(("python-six" ,python-six)))
9891 (inputs
9892 `(("xdotool" ,xdotool)
9893 ("libX11" ,libx11)))
9894 (home-page "https://tracker.debian.org/pkg/python-xdo")
9895 (synopsis "Python library for simulating X11 keyboard/mouse input")
9896 (description "Provides bindings to libxdo for manipulating X11 via simulated
9897 input. (Note that this is mostly a legacy library; you may wish to look at
9898 python-xdo for newer bindings.)")
9899 (license license:bsd-3)))
9900
9901 (define-public python2-xdo
9902 (package-with-python2 python-xdo))
9903
9904 (define-public python-wtforms
9905 (package
9906 (name "python-wtforms")
9907 (version "2.1")
9908 (source
9909 (origin
9910 (method url-fetch)
9911 (uri (pypi-uri "WTForms" version ".zip"))
9912 (sha256
9913 (base32
9914 "0vyl26y9cg409cfyj8rhqxazsdnd0jipgjw06civhrd53yyi1pzz"))))
9915 (build-system python-build-system)
9916 (arguments
9917 '(#:phases
9918 (modify-phases %standard-phases
9919 (add-after 'unpack 'remove-django-test
9920 ;; Don't fail the tests when the inputs for the optional tests cannot be found.
9921 (lambda _
9922 (substitute*
9923 "tests/runtests.py"
9924 (("'ext_django.tests', 'ext_sqlalchemy', 'ext_dateutil', 'locale_babel'") "")
9925 (("sys.stderr.write(\"### Disabled test '%s', dependency not found\n\" % name)") ""))
9926 #t)))))
9927 (native-inputs
9928 `(("unzip" ,unzip)))
9929 (home-page "http://wtforms.simplecodes.com/")
9930 (synopsis
9931 "Form validation and rendering library for Python web development")
9932 (description
9933 "WTForms is a flexible forms validation and rendering library
9934 for Python web development. It is very similar to the web form API
9935 available in Django, but is a standalone package.")
9936 (license license:bsd-3)))
9937
9938 (define-public python2-wtforms
9939 (package-with-python2 python-wtforms))
9940
9941 (define-public python-mako
9942 (package
9943 (name "python-mako")
9944 (version "1.0.6")
9945 (source
9946 (origin
9947 (method url-fetch)
9948 (uri (pypi-uri "Mako" version))
9949 (sha256
9950 (base32
9951 "03dyxgjknp4ffsv7vwfd28l5bbpzi0ylp20543wpg3iahyyrwma8"))))
9952 (build-system python-build-system)
9953 (propagated-inputs
9954 `(("python-markupsafe" ,python-markupsafe)))
9955 (native-inputs
9956 `(("python-mock" ,python-mock)
9957 ("python-nose" ,python-nose)
9958 ("python-pytest" ,python-pytest)))
9959 (home-page "http://www.makotemplates.org/")
9960 (synopsis "Templating language for Python")
9961 (description "Mako is a templating language for Python that compiles
9962 templates into Python modules.")
9963 (license license:expat)))
9964
9965 (define-public python2-mako
9966 (package-with-python2 python-mako))
9967
9968 (define-public python-waitress
9969 (package
9970 (name "python-waitress")
9971 (version "0.8.10")
9972 (source
9973 (origin
9974 (method url-fetch)
9975 (uri (pypi-uri "waitress" version))
9976 (sha256
9977 (base32
9978 "017n9ra6vvmq9d5sfhdzyzr1mg15x2hj2dhm4pdlw98c1ypw2h3w"))))
9979 (build-system python-build-system)
9980 (home-page "https://github.com/Pylons/waitress")
9981 (synopsis "Waitress WSGI server")
9982 (description "Waitress is meant to be a production-quality pure-Python WSGI
9983 server with very acceptable performance.")
9984 (license license:zpl2.1)))
9985
9986 (define-public python2-waitress
9987 (package-with-python2 python-waitress))
9988
9989 (define-public python-wsgiproxy2
9990 (package
9991 (name "python-wsgiproxy2")
9992 (version "0.4.2")
9993 (source
9994 (origin
9995 (method url-fetch)
9996 (uri (pypi-uri "WSGIProxy2" version ".zip"))
9997 (sha256
9998 (base32
9999 "13kf9bdxrc95y9vriaz0viry3ah11nz4rlrykcfvb8nlqpx3dcm4"))))
10000 (build-system python-build-system)
10001 (arguments
10002 '(;; Wsgiproxy2's test suite requires Restkit, which does not yet fully
10003 ;; support Python 3:
10004 ;; https://github.com/benoitc/restkit/issues/140
10005 #:tests? #f))
10006 (native-inputs
10007 `(("unzip" ,unzip)
10008 ("python-nose" ,python-nose)
10009 ("python-coverage" ,python-coverage)))
10010 (propagated-inputs
10011 `(("python-six" ,python-six)
10012 ("python-webob" ,python-webob)))
10013 (home-page
10014 "https://github.com/gawel/WSGIProxy2/")
10015 (synopsis "WSGI Proxy with various http client backends")
10016 (description "WSGI turns HTTP requests into WSGI function calls.
10017 WSGIProxy turns WSGI function calls into HTTP requests.
10018 It also includes code to sign requests and pass private data,
10019 and to spawn subprocesses to handle requests.")
10020 (license license:expat)))
10021
10022 (define-public python2-wsgiproxy2
10023 (package-with-python2 python-wsgiproxy2))
10024
10025 (define-public python-pastedeploy
10026 (package
10027 (name "python-pastedeploy")
10028 (version "1.5.2")
10029 (source
10030 (origin
10031 (method url-fetch)
10032 (uri (pypi-uri "PasteDeploy" version))
10033 (sha256
10034 (base32
10035 "1jz3m4hq8v6hyhfjz9425nd3nvn52cvbfipdcd72krjmla4qz1fm"))))
10036 (build-system python-build-system)
10037 (native-inputs
10038 `(("python-nose" ,python-nose)))
10039 (home-page "http://pythonpaste.org/deploy/")
10040 (synopsis
10041 "Load, configure, and compose WSGI applications and servers")
10042 (description
10043 "This tool provides code to load WSGI applications and servers from URIs;
10044 these URIs can refer to Python Eggs for INI-style configuration files. Paste
10045 Script provides commands to serve applications based on this configuration
10046 file.")
10047 (license license:expat)))
10048
10049 (define-public python2-pastedeploy
10050 (package-with-python2 python-pastedeploy))
10051
10052 (define-public python-paste
10053 (package
10054 (name "python-paste")
10055 (version "2.0.3")
10056 (source
10057 (origin
10058 (method url-fetch)
10059 (uri (pypi-uri "Paste" version))
10060 (sha256
10061 (base32
10062 "062jk0nlxf6lb2wwj6zc20rlvrwsnikpkh90y0dn8cjch93s6ii3"))
10063 (patches (search-patches "python-paste-remove-website-test.patch"
10064 "python-paste-remove-timing-test.patch"))))
10065 (build-system python-build-system)
10066 (native-inputs
10067 `(("python-nose" ,python-nose)))
10068 (propagated-inputs
10069 `(("python-six" ,python-six)))
10070 (home-page "http://pythonpaste.org")
10071 (synopsis
10072 "Python web development tools, focusing on WSGI")
10073 (description
10074 "Paste provides a variety of web development tools and middleware which
10075 can be nested together to build web applications. Paste's design closely
10076 follows ideas flowing from WSGI (Web Standard Gateway Interface).")
10077 (license license:expat)))
10078
10079 (define-public python2-paste
10080 (package-with-python2 python-paste))
10081
10082 (define-public python-pastescript
10083 (package
10084 (name "python-pastescript")
10085 (version "2.0.2")
10086 (source
10087 (origin
10088 (method url-fetch)
10089 (uri (pypi-uri "PasteScript" version))
10090 (sha256
10091 (base32
10092 "1h3nnhn45kf4pbcv669ik4faw04j58k8vbj1hwrc532k0nc28gy0"))))
10093 (build-system python-build-system)
10094 (native-inputs
10095 `(("python-nose" ,python-nose)))
10096 (propagated-inputs
10097 `(("python-paste" ,python-paste)
10098 ("python-pastedeploy" ,python-pastedeploy)))
10099 (home-page "http://pythonpaste.org/script/")
10100 (arguments
10101 '(;; Unfortunately, this requires the latest unittest2,
10102 ;; but that requires traceback2 which requires linecache2 which requires
10103 ;; unittest2. So we're skipping tests for now.
10104 ;; (Note: Apparently linetest2 only needs unittest2 for its tests,
10105 ;; so in theory we could get around this situation somehow.)
10106 #:tests? #f))
10107 (synopsis
10108 "Pluggable command line tool for serving web applications and more")
10109 (description
10110 "PasteScript is a plugin-friendly command line tool which provides a
10111 variety of features, from launching web applications to bootstrapping project
10112 layouts.")
10113 (license license:expat)))
10114
10115 (define-public python2-pastescript
10116 (package-with-python2 python-pastescript))
10117
10118 (define-public python-pyquery
10119 (package
10120 (name "python-pyquery")
10121 (version "1.2.17")
10122 (source
10123 (origin
10124 (method url-fetch)
10125 (uri (pypi-uri "pyquery" version))
10126 (sha256
10127 (base32
10128 "1xia20wm0vx5dk85kcwgh13bylz8qh47ffjxssd2586r60xi783a"))))
10129 (build-system python-build-system)
10130 (native-inputs
10131 `(("python-webob" ,python-webob)
10132 ("python-webtest" ,python-webtest)))
10133 (propagated-inputs
10134 `(("python-lxml" ,python-lxml)
10135 ("python-cssselect" ,python-cssselect)))
10136 (home-page "https://github.com/gawel/pyquery")
10137 (synopsis "Make jQuery-like queries on xml documents")
10138 (description "pyquery allows you to make jQuery queries on xml documents.
10139 The API is as much as possible the similar to jQuery. pyquery uses lxml for
10140 fast xml and html manipulation.")
10141 (license license:bsd-3)))
10142
10143 (define-public python2-pyquery
10144 (package-with-python2 python-pyquery))
10145
10146 (define-public python-webtest
10147 (package
10148 (name "python-webtest")
10149 (version "2.0.20")
10150 (source
10151 (origin
10152 (method url-fetch)
10153 (uri (pypi-uri "WebTest" version))
10154 (sha256
10155 (base32
10156 "0bv0qhdjakdsdgj4sk21gnpp8xp8bga4x03p6gjb83ihrsb7n4xv"))))
10157 (build-system python-build-system)
10158 (arguments
10159 `(;; Unfortunately we have to disable tests!
10160 ;; This release of WebTest is pinned to python-nose < 1.3,
10161 ;; but older versions of python-nose are plagued with the following
10162 ;; bug(s), which rears its ugly head during test execution:
10163 ;; https://github.com/nose-devs/nose/issues/759
10164 ;; https://github.com/nose-devs/nose/pull/811
10165 #:tests? #f))
10166 ;; Commented out code is no good, but in this case, once tests
10167 ;; are ready to be enabled again, we should put the following
10168 ;; in place:
10169 ;; (native-inputs
10170 ;; `(("python-nose" ,python-nose) ; technially < 1.3,
10171 ;; ; but see above comment
10172 ;; ("python-coverage" ,python-coverage)
10173 ;; ("python-mock" ,python-mock)
10174 ;; ("python-pastedeploy" ,python-pastedeploy)
10175 ;; ("python-wsgiproxy2" ,python-wsgiproxy2)
10176 ;; ("python-pyquery" ,python-pyquery)))
10177 (propagated-inputs
10178 `(("python-waitress" ,python-waitress)
10179 ("python-webob" ,python-webob)
10180 ("python-six" ,python-six)
10181 ("python-beautifulsoup4" ,python-beautifulsoup4)))
10182 (home-page "http://webtest.pythonpaste.org/")
10183 (synopsis "Helper to test WSGI applications")
10184 (description "Webtest allows you to test your Python web applications
10185 without starting an HTTP server. It supports anything that supports the
10186 minimum of WSGI.")
10187 (license license:expat)))
10188
10189 (define-public python2-webtest
10190 (package-with-python2 python-webtest))
10191
10192 (define-public python-anyjson
10193 (package
10194 (name "python-anyjson")
10195 (version "0.3.3")
10196 (source
10197 (origin
10198 (method url-fetch)
10199 (uri (pypi-uri "anyjson" version))
10200 (sha256
10201 (base32
10202 "1fjph4alvcscsl5d4b6qpv1yh31jy05jxi1l0xff7lws7j32v09p"))))
10203 (build-system python-build-system)
10204 (arguments
10205 `(;; We could possibly get tests working, but on Python 3 it's not so easy.
10206 ;; Very strangely, 2to3 is run *during setup.py install* (or bdist, or
10207 ;; whatever) so this transformation needs to be done before the tests
10208 ;; can be run. Maybe we could add a build step to transform beforehand
10209 ;; but it could be annoying/difficult.
10210 ;; We can enable tests for the Python 2 version, though, and do below.
10211 #:tests? #f))
10212 (home-page "http://bitbucket.org/runeh/anyjson/")
10213 (synopsis
10214 "Wraps best available JSON implementation in a common interface")
10215 (description
10216 "Anyjson loads whichever is the fastest JSON module installed
10217 and provides a uniform API regardless of which JSON implementation is used.")
10218 (license license:bsd-3)
10219 (properties `((python2-variant . ,(delay python2-anyjson))))))
10220
10221 (define-public python2-anyjson
10222 (let ((anyjson (package-with-python2
10223 (strip-python2-variant python-anyjson))))
10224 (package
10225 (inherit anyjson)
10226 (arguments `(;; Unlike the python 3 variant, we do run tests. See above!
10227 #:tests? #t
10228 ,@(package-arguments anyjson)))
10229 (native-inputs `(("python2-nose" ,python2-nose))))))
10230
10231 (define-public python-amqp
10232 (package
10233 (name "python-amqp")
10234 (version "1.4.9")
10235 (source
10236 (origin
10237 (method url-fetch)
10238 (uri (pypi-uri "amqp" version))
10239 (sha256
10240 (base32
10241 "06n6q0kxhjnbfz3vn8x9yz09lwmn1xi9d6wxp31h5jbks0b4vsid"))))
10242 (build-system python-build-system)
10243 (native-inputs
10244 `(("python-nose" ,python-nose)
10245 ("python-mock" ,python-mock)))
10246 (home-page "https://github.com/celery/py-amqp")
10247 (synopsis
10248 "Low-level AMQP client for Python (fork of amqplib)")
10249 (description
10250 "This is a fork of amqplib which was originally written by Barry Pederson.
10251 It is maintained by the Celery project, and used by kombu as a pure python
10252 alternative when librabbitmq is not available.")
10253 (license license:lgpl2.1+)
10254 (properties `((python2-variant . ,(delay python2-amqp))))))
10255
10256 (define-public python2-amqp
10257 (let ((amqp (package-with-python2
10258 (strip-python2-variant python-amqp))))
10259 (package
10260 (inherit amqp)
10261 (arguments `(;; Tries to run coverage tests with nose-cover3, which seems
10262 ;; unmaintained. Weirdly, does not do this on the python 3
10263 ;; version?
10264 #:tests? #f
10265 ,@(package-arguments amqp))))))
10266
10267 (define-public python-kombu
10268 (package
10269 (name "python-kombu")
10270 (version "3.0.37")
10271 (source
10272 (origin
10273 (method url-fetch)
10274 (uri (pypi-uri "kombu" version))
10275 (sha256
10276 (base32
10277 "0l16chb314gpq2v7fh94a22c30lcv6w3ylmhsa60bldlcq6a0r70"))))
10278 (build-system python-build-system)
10279 (native-inputs
10280 `(("python-mock" ,python-mock)
10281 ("python-nose" ,python-nose)))
10282 (propagated-inputs
10283 `(("python-anyjson" ,python-anyjson)
10284 ("python-amqp" ,python-amqp)
10285 ("python-redis" ,python-redis)))
10286 (home-page "http://kombu.readthedocs.org")
10287 (synopsis "Message passing library for Python")
10288 (description "The aim of Kombu is to make messaging in Python as easy as
10289 possible by providing an idiomatic high-level interface for the AMQ protocol,
10290 and also provide proven and tested solutions to common messaging problems.
10291 AMQP is the Advanced Message Queuing Protocol, an open standard protocol for
10292 message orientation, queuing, routing, reliability and security, for which the
10293 RabbitMQ messaging server is the most popular implementation.")
10294 (license license:bsd-3)
10295 (properties `((python2-variant . ,(delay python2-kombu))))))
10296
10297 (define-public python2-kombu
10298 (let ((kombu (package-with-python2
10299 (strip-python2-variant python-kombu))))
10300 (package
10301 (inherit kombu)
10302 (arguments `(;; FIXME: 'TestTransport.test_del_sync' fails on python2.
10303 ;; It works fine on the python3 variant.
10304 #:tests? #f
10305 ,@(package-arguments kombu)))
10306 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10307 ,@(package-native-inputs kombu))))))
10308
10309 (define-public python-billiard
10310 (package
10311 (name "python-billiard")
10312 (version "3.3.0.23")
10313 (source
10314 (origin
10315 (method url-fetch)
10316 (uri (pypi-uri "billiard" version))
10317 (sha256
10318 (base32
10319 "02wxsc6bhqvzh8j6w758kvgqbnj14l796mvmrcms8fgfamd2lak9"))))
10320 (build-system python-build-system)
10321 (native-inputs
10322 `(("python-nose" ,python-nose)))
10323 (home-page "https://github.com/celery/billiard")
10324 (synopsis
10325 "Python multiprocessing fork with improvements and bugfixes")
10326 (description
10327 "Billiard is a fork of the Python 2.7 multiprocessing package. The
10328 multiprocessing package itself is a renamed and updated version of R Oudkerk's
10329 pyprocessing package. This standalone variant is intended to be compatible with
10330 Python 2.4 and 2.5, and will draw its fixes/improvements from python-trunk.")
10331 (license license:bsd-3)
10332 (properties `((python2-variant . ,(delay python2-billiard))))))
10333
10334 (define-public python2-billiard
10335 (let ((billiard (package-with-python2
10336 (strip-python2-variant python-billiard))))
10337 (package
10338 (inherit billiard)
10339 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10340 ("python2-mock" ,python2-mock)
10341 ,@(package-native-inputs billiard))))))
10342
10343 (define-public python-celery
10344 (package
10345 (name "python-celery")
10346 (version "3.1.24")
10347 (source
10348 (origin
10349 (method url-fetch)
10350 (uri (pypi-uri "celery" version))
10351 (sha256
10352 (base32
10353 "0yh2prhdnx2dgkb67a5drj12hh2zvzx5f611p7mqqg01ydghif4r"))))
10354 (build-system python-build-system)
10355 (arguments
10356 `(#:phases
10357 (modify-phases %standard-phases
10358 ;; These tests break with Python 3.5:
10359 ;; https://github.com/celery/celery/issues/2897#issuecomment-253066295
10360 (replace 'check
10361 (lambda _
10362 (zero?
10363 (system* "nosetests" "--exclude=^test_safe_to_remove.*")))))))
10364 (native-inputs
10365 `(("python-nose" ,python-nose)))
10366 (propagated-inputs
10367 `(("python-pytz" ,python-pytz)
10368 ("python-billiard" ,python-billiard)
10369 ("python-kombu" ,python-kombu)))
10370 (home-page "http://celeryproject.org")
10371 (synopsis "Distributed Task Queue")
10372 (description "Celery is an asynchronous task queue/job queue based on
10373 distributed message passing. It is focused on real-time operation, but
10374 supports scheduling as well. The execution units, called tasks, are executed
10375 concurrently on a single or more worker servers using multiprocessing,
10376 Eventlet, or gevent. Tasks can execute asynchronously (in the background) or
10377 synchronously (wait until ready).")
10378 (license license:bsd-3)
10379 (properties `((python2-variant . ,(delay python2-celery))))))
10380
10381 (define-public python2-celery
10382 (let ((celery (package-with-python2
10383 (strip-python2-variant python-celery))))
10384 (package
10385 (inherit celery)
10386 (native-inputs `(("python2-unittest2" ,python2-unittest2)
10387 ("python2-mock" ,python2-mock)
10388 ,@(package-native-inputs celery))))))
10389
10390 (define-public python-translitcodec
10391 (package
10392 (name "python-translitcodec")
10393 (version "0.4.0")
10394 (source
10395 (origin
10396 (method url-fetch)
10397 (uri (pypi-uri "translitcodec" version))
10398 (sha256
10399 (base32
10400 "10x6pvblkzky1zhjs8nmx64nb9jdzxad4bxhq4iwv0j4z2aqjnki"))))
10401 (build-system python-build-system)
10402 (arguments
10403 `(#:tests? #f)) ; no tests provided
10404 (home-page
10405 "https://github.com/claudep/translitcodec")
10406 (synopsis
10407 "Unicode to 8-bit charset transliteration codec")
10408 (description
10409 "This package contains codecs for transliterating ISO 10646 texts into
10410 best-effort representations using smaller coded character sets (ASCII,
10411 ISO 8859, etc.).")
10412 (license license:expat)))
10413
10414 (define-public python2-translitcodec
10415 (package-with-python2 python-translitcodec))
10416
10417 (define-public python-editor
10418 (package
10419 (name "python-editor")
10420 (version "0.5")
10421 (source
10422 (origin
10423 (method url-fetch)
10424 (uri (pypi-uri "python-editor" version))
10425 (sha256
10426 (base32
10427 "1ypnpgvzpkbwsg4rdvy4sy51j28b5xq9v8pnkwxncn07vqz06p7n"))))
10428 (build-system python-build-system)
10429 (home-page
10430 "https://github.com/fmoo/python-editor")
10431 (synopsis
10432 "Programmatically open an editor, capture the result")
10433 (description
10434 "python-editor is a library that provides the editor module for
10435 programmatically interfacing with your system's $EDITOR.")
10436 (license license:asl2.0)))
10437
10438 (define-public python2-editor
10439 (package-with-python2 python-editor))
10440
10441 (define-public python-sphinxcontrib-programoutput
10442 (package
10443 (name "python-sphinxcontrib-programoutput")
10444 (version "0.10")
10445 (source (origin
10446 (method url-fetch)
10447 (uri (pypi-uri "sphinxcontrib-programoutput" version))
10448 (sha256
10449 (base32
10450 "153hhnlbx4688zj9wd64819ps5znc2jlyp5crkgzvn5hxgy99vpx"))))
10451 (build-system python-build-system)
10452 (arguments
10453 ;; FIXME: Many tests are failing and the upstream is gone.
10454 '(#:tests? #f))
10455 (propagated-inputs
10456 `(("python-sphinx" ,python-sphinx)))
10457 (synopsis "Sphinx extension to include program output")
10458 (description "A Sphinx extension to literally insert the output of arbitrary
10459 commands into documents, helping you to keep your command examples up to date.")
10460 (home-page "https://github.com/lunaryorn/sphinxcontrib-programoutput")
10461 (license license:bsd-2)))
10462
10463 (define-public python2-sphinxcontrib-programoutput
10464 (package-with-python2 python-sphinxcontrib-programoutput))
10465
10466 (define-public python-sphinx-repoze-autointerface
10467 (package
10468 (name "python-sphinx-repoze-autointerface")
10469 (version "0.8")
10470 (source (origin
10471 (method url-fetch)
10472 (uri (pypi-uri "repoze.sphinx.autointerface" version))
10473 (sha256
10474 (base32
10475 "08ycivzf7bh4a1zcyp31hbyqs1b2c9r26raa3vxjwwmbfqr3iw4f"))))
10476 (build-system python-build-system)
10477 (arguments '(#:tests? #f)) ; No tests.
10478 (propagated-inputs
10479 `(("python-sphinx" ,python-sphinx)
10480 ("python-zope-interface" ,python-zope-interface)))
10481 (synopsis "Auto-generate Sphinx API docs from Zope interfaces")
10482 (description "This package defines an extension for the Sphinx documentation
10483 system. The extension allows generation of API documentation by
10484 introspection of @code{zope.interface} instances in code.")
10485 (home-page "https://github.com/repoze/repoze.sphinx.autointerface")
10486 (license license:repoze)))
10487
10488 (define-public python2-sphinx-repoze-autointerface
10489 (package-with-python2 python-sphinx-repoze-autointerface))
10490
10491 (define-public python-psycopg2
10492 (package
10493 (name "python-psycopg2")
10494 (version "2.6.2")
10495 (source
10496 (origin
10497 (method url-fetch)
10498 (uri (pypi-uri "psycopg2" version))
10499 (sha256
10500 (base32
10501 "0p60z2gwfcal30y2w8gprflchp1kcg9qblc5rn782p4wxl90wjbh"))))
10502 (build-system python-build-system)
10503 (arguments
10504 ;; Tests would require a postgresql database "psycopg2_test"
10505 ;; and a running postgresql database management service.
10506 `(#:tests? #f)) ; TODO re-enable after providing a test-db.
10507 (inputs
10508 `(("postgresql" ,postgresql))) ; libpq
10509 (home-page "http://initd.org/psycopg/")
10510 (synopsis "Python PostgreSQL adapter")
10511 (description
10512 "psycopg2 is a thread-safe PostgreSQL adapter that implements DB-API 2.0. ")
10513 (license license:lgpl3+)))
10514
10515 (define-public python2-psycopg2
10516 (package-with-python2 python-psycopg2))
10517
10518 (define-public python-vobject
10519 (package
10520 (name "python-vobject")
10521 (version "0.9.5")
10522 (source (origin
10523 (method url-fetch)
10524 (uri (pypi-uri "vobject" version))
10525 (sha256
10526 (base32
10527 "0hqjgf3ay1m5w1c0k00g5yfpdz1zni5qnr5rh9b8fg9hjvhwlmhg"))))
10528 (build-system python-build-system)
10529 (arguments
10530 '(;; The test suite relies on some non-portable Windows interfaces.
10531 #:tests? #f))
10532 (propagated-inputs
10533 `(("python-dateutil" ,python-dateutil)
10534 ("python-pyicu" ,python-pyicu)))
10535 (synopsis "Parse and generate vCard and vCalendar files")
10536 (description "Vobject is intended to be a full featured Python package for
10537 parsing and generating vCard and vCalendar files. Currently, iCalendar files
10538 are supported and well tested. vCard 3.0 files are supported, and all data
10539 should be imported, but only a few components are understood in a sophisticated
10540 way.")
10541 (home-page "http://eventable.github.io/vobject/")
10542 (license license:asl2.0)))
10543
10544 (define-public python2-vobject
10545 (package-with-python2 python-vobject))
10546
10547 (define-public python-munkres
10548 (package
10549 (name "python-munkres")
10550 (version "1.0.8")
10551 (source (origin
10552 (method url-fetch)
10553 (uri (pypi-uri "munkres" version))
10554 (sha256
10555 (base32
10556 "0mbspx4zv8id4x6pim6ybsa1xh96qwpbqj7skbqz4c9c9nf1lpqq"))))
10557 (build-system python-build-system)
10558 (arguments
10559 '(#:tests? #f)) ; no test suite
10560 (home-page "http://software.clapper.org/munkres/")
10561 (synopsis "Implementation of the Munkres algorithm")
10562 (description "The Munkres module provides an implementation of the Munkres
10563 algorithm (also called the Hungarian algorithm or the Kuhn-Munkres algorithm),
10564 useful for solving the Assignment Problem.")
10565 (license license:bsd-3)))
10566
10567 (define-public python2-munkres
10568 (package-with-python2 python-munkres))
10569
10570 (define-public python-flask
10571 (package
10572 (name "python-flask")
10573 (version "0.11.1")
10574 (source (origin
10575 (method url-fetch)
10576 (uri (pypi-uri "Flask" version))
10577 (sha256
10578 (base32
10579 "03kbfll4sj3v5z7r31c7bhfpi11r1np076d4p1k2kg4yzcmkywdl"))))
10580 (build-system python-build-system)
10581 (propagated-inputs
10582 `(("python-itsdangerous" ,python-itsdangerous)
10583 ("python-jinja2" ,python-jinja2)
10584 ("python-click" ,python-click)
10585 ("python-werkzeug" ,python-werkzeug)))
10586 (home-page "https://github.com/mitsuhiko/flask/")
10587 (synopsis "Microframework based on Werkzeug, Jinja2 and good intentions")
10588 (description "Flask is a micro web framework based on the Werkzeug toolkit
10589 and Jinja2 template engine. It is called a micro framework because it does not
10590 presume or force a developer to use a particular tool or library.")
10591 (license license:bsd-3)))
10592
10593 (define-public python2-flask
10594 (package-with-python2 python-flask))
10595
10596 (define-public python-flask-wtf
10597 (package
10598 (name "python-flask-wtf")
10599 (version "0.13.1")
10600 (source
10601 (origin
10602 (method url-fetch)
10603 (uri (pypi-uri "Flask-WTF" version))
10604 (sha256
10605 (base32
10606 "04l5743j2dici46038sqlzvf0xzpg8rf7s9ld2x24xv7f4idg990"))))
10607 (build-system python-build-system)
10608 (arguments
10609 '(#:phases
10610 (modify-phases %standard-phases
10611 (add-before 'check 'drop-failing-test
10612 (lambda _
10613 ;; FIXME: This file tries resolving an external server, which
10614 ;; fails. Try to patch out the offending section instead of
10615 ;; deleting the whole thing.
10616 (delete-file "tests/test_recaptcha.py")
10617 #t)))))
10618 (propagated-inputs
10619 `(("python-flask-babel" ,python-flask-babel)
10620 ("python-babel" ,python-babel)
10621 ("python-wtforms" ,python-wtforms)))
10622 (native-inputs
10623 `(("python-nose" ,python-nose)))
10624 (home-page "https://github.com/lepture/flask-wtf")
10625 (synopsis "Simple integration of Flask and WTForms")
10626 (description "Flask-WTF integrates Flask and WTForms, including CSRF, file
10627 upload, and reCAPTCHA.")
10628 (license license:bsd-3)))
10629
10630 (define-public python2-flask-wtf
10631 (package-with-python2 python-flask-wtf))
10632
10633 (define-public python-flask-multistatic
10634 (package
10635 (name "python-flask-multistatic")
10636 (version "1.0")
10637 (source
10638 (origin
10639 (method url-fetch)
10640 (uri (pypi-uri "flask-multistatic" version))
10641 (sha256
10642 (base32
10643 "0p4v50rwv64wcd0zlq7rzl4waprwr4hj19s3cgf1isywa7jcisgm"))))
10644 (build-system python-build-system)
10645 (propagated-inputs
10646 `(("python-flask" ,python-flask)))
10647 (home-page "https://pagure.io/flask-multistatic")
10648 (synopsis "Flask plugin to allow overriding static files")
10649 (description "@code{flask-multistatic} is a flask plugin that adds support
10650 for overriding static files.")
10651 (license license:gpl3+)))
10652
10653 (define-public python2-flask-multistatic
10654 (package-with-python2 python-flask-multistatic))
10655
10656 (define-public python-cookies
10657 (package
10658 (name "python-cookies")
10659 (version "2.2.1")
10660 (source (origin
10661 (method url-fetch)
10662 (uri (pypi-uri "cookies" version))
10663 (sha256
10664 (base32
10665 "13pfndz8vbk4p2a44cfbjsypjarkrall71pgc97glk5fiiw9idnn"))))
10666 (build-system python-build-system)
10667 (arguments
10668 `(;; test are broken: https://gitlab.com/sashahart/cookies/issues/3
10669 #:tests? #f))
10670 (native-inputs
10671 `(("python-pytest" ,python2-pytest)))
10672 (synopsis "HTTP cookie parser and renderer")
10673 (description "A RFC 6265-compliant HTTP cookie parser and renderer in
10674 Python.")
10675 (home-page "https://gitlab.com/sashahart/cookies")
10676 (license license:expat)))
10677
10678 (define-public python2-cookies
10679 (package-with-python2 python-cookies))
10680
10681 (define-public python-responses
10682 (package
10683 (name "python-responses")
10684 (version "0.5.1")
10685 (source (origin
10686 (method url-fetch)
10687 (uri (pypi-uri "responses" version))
10688 (sha256
10689 (base32
10690 "1spcfxixyk9k7pk82jm6zqkwk031s95lh8q0mz7539jrb7269bcc"))))
10691 (build-system python-build-system)
10692 (arguments
10693 `(;; Test suite is not distributed:
10694 ;; https://github.com/getsentry/responses/issues/38
10695 #:tests? #f))
10696 (native-inputs
10697 `(("python-mock" ,python-mock)))
10698 (propagated-inputs
10699 `(("python-requests" ,python-requests)
10700 ("python-cookies" ,python-cookies)
10701 ("python-six" ,python-six)))
10702 (home-page "https://github.com/getsentry/responses")
10703 (synopsis "Utility for mocking out the `requests` Python library")
10704 (description "A utility library for mocking out the `requests` Python
10705 library.")
10706 (license license:asl2.0)))
10707
10708 (define-public python2-responses
10709 (package-with-python2 python-responses))
10710
10711 (define-public python-whoosh
10712 (package
10713 (name "python-whoosh")
10714 (version "2.7.4")
10715 (source
10716 (origin
10717 (method url-fetch)
10718 (uri (pypi-uri "Whoosh" version))
10719 (sha256
10720 (base32
10721 "10qsqdjpbc85fykc1vgcs8xwbgn4l2l52c8d83xf1q59pwyn79bw"))))
10722 (build-system python-build-system)
10723 (native-inputs
10724 `(("python-pytest" ,python-pytest)))
10725 (home-page "http://bitbucket.org/mchaput/whoosh")
10726 (synopsis "Full text indexing, search, and spell checking library")
10727 (description
10728 "Whoosh is a fast, pure-Python full text indexing, search, and spell
10729 checking library.")
10730 (license license:bsd-2)))
10731
10732 (define-public python2-whoosh
10733 (let ((whoosh (package-with-python2 (strip-python2-variant python-whoosh))))
10734 (package (inherit whoosh)
10735 (propagated-inputs
10736 `(("python2-backport-ssl-match-hostname"
10737 ,python2-backport-ssl-match-hostname)
10738 ,@(package-propagated-inputs whoosh))))))
10739
10740 (define-public python-pathlib
10741 (package
10742 (name "python-pathlib")
10743 (version "1.0.1")
10744 (source (origin
10745 (method url-fetch)
10746 (uri (pypi-uri "pathlib" version))
10747 (sha256
10748 (base32
10749 "17zajiw4mjbkkv6ahp3xf025qglkj0805m9s41c45zryzj6p2h39"))))
10750 (build-system python-build-system)
10751 ;; The tests depend on the internal "test" module, which does not provide
10752 ;; a stable interface.
10753 (arguments `(#:tests? #f))
10754 (home-page "https://pathlib.readthedocs.org/")
10755 (synopsis "Object-oriented file system paths")
10756 (description "Pathlib offers a set of classes to handle file system paths.
10757 It offers the following advantages over using string objects:
10758
10759 @enumerate
10760 @item No more cumbersome use of os and os.path functions. Everything can
10761 be done easily through operators, attribute accesses, and method calls.
10762 @item Embodies the semantics of different path types. For example,
10763 comparing Windows paths ignores casing.
10764 @item Well-defined semantics, eliminating any inconsistencies or
10765 ambiguities (forward vs. backward slashes, etc.).
10766 @end enumerate
10767
10768 Note: In Python 3.4, pathlib is now part of the standard library. For other
10769 Python versions please consider python-pathlib2 instead, which tracks the
10770 standard library module. This module (python-pathlib) isn't maintained
10771 anymore.")
10772 (license license:expat)))
10773
10774 (define-public python2-pathlib
10775 (package-with-python2 python-pathlib))
10776
10777 (define-public python2-pathlib2
10778 (package
10779 (name "python2-pathlib2")
10780 (version "2.1.0")
10781 (source (origin
10782 (method url-fetch)
10783 (uri (pypi-uri "pathlib2" version))
10784 (sha256
10785 (base32
10786 "0p050msg5c8d0kadv702jnfshaxrb0il765cpkgnhn6mq5hakcyy"))))
10787 (build-system python-build-system)
10788 ;; We only need the the Python 2 variant, since for Python 3 our minimum
10789 ;; version is 3.4 which already includes this package as part of the
10790 ;; standard library.
10791 (arguments
10792 `(#:python ,python-2))
10793 (native-inputs
10794 `(("python2-six" ,python2-six)))
10795 (home-page "http://pypi.python.org/pypi/pathlib2/")
10796 (synopsis "Object-oriented file system paths - backport of standard
10797 pathlib module")
10798 (description "The goal of pathlib2 is to provide a backport of standard
10799 pathlib module which tracks the standard library module, so all the newest
10800 features of the standard pathlib can be used also on older Python versions.
10801
10802 Pathlib offers a set of classes to handle file system paths. It offers the
10803 following advantages over using string objects:
10804
10805 @enumerate
10806 @item No more cumbersome use of os and os.path functions. Everything can
10807 be done easily through operators, attribute accesses, and method calls.
10808 @item Embodies the semantics of different path types. For example,
10809 comparing Windows paths ignores casing.
10810 @item Well-defined semantics, eliminating any inconsistencies or
10811 ambiguities (forward vs. backward slashes, etc.).
10812 @end enumerate")
10813 (license license:expat)))
10814
10815 (define-public python-jellyfish
10816 (package
10817 (name "python-jellyfish")
10818 (version "0.5.6")
10819 (source (origin
10820 (method url-fetch)
10821 (uri (pypi-uri "jellyfish" version))
10822 (sha256
10823 (base32
10824 "1j9rplb16ba2prjj6mip46z0w9pnhnqpwgiwi0x93vnas14rlyl8"))))
10825 (build-system python-build-system)
10826 (native-inputs
10827 `(("python-pytest" ,python-pytest)))
10828 (home-page "https://github.com/jamesturk/jellyfish")
10829 (synopsis "Approximate and phonetic matching of strings")
10830 (description "Jellyfish uses a variety of string comparison and phonetic
10831 encoding algorithms to do fuzzy string matching.")
10832 (license license:bsd-2)
10833 (properties `((python2-variant . ,(delay python2-jellyfish))))))
10834
10835 (define-public python2-jellyfish
10836 (let ((jellyfish (package-with-python2
10837 (strip-python2-variant python-jellyfish))))
10838 (package (inherit jellyfish)
10839 (native-inputs `(("python2-unicodecsv" ,python2-unicodecsv)
10840 ,@(package-native-inputs jellyfish))))))
10841
10842 (define-public python2-unicodecsv
10843 (package
10844 (name "python2-unicodecsv")
10845 (version "0.14.1")
10846 (source (origin
10847 (method url-fetch)
10848 ;; The test suite is not included in the PyPi release.
10849 ;; https://github.com/jdunck/python-unicodecsv/issues/19
10850 (uri (string-append "https://github.com/jdunck/python-unicodecsv/"
10851 "archive/" version ".tar.gz"))
10852 (file-name (string-append name "-" version ".tar.gz"))
10853 (sha256
10854 (base32
10855 "087nqanfcyp6mlfbbr5lva5f3w6iz1bybls9xlrb8icmc474wh4w"))))
10856 (build-system python-build-system)
10857 (arguments
10858 `(;; It supports Python 3, but Python 3 can already do Unicode CSV.
10859 #:python ,python-2))
10860 (native-inputs
10861 `(("python2-unittest2" ,python2-unittest2)))
10862 (home-page "https://github.com/jdunck/python-unicodecsv")
10863 (synopsis "Unicode CSV module for Python 2")
10864 (description "Unicodecsv is a drop-in replacement for Python 2.7's CSV
10865 module, adding support for Unicode strings.")
10866 (license license:bsd-2)))
10867
10868 (define-public python-rarfile
10869 (package
10870 (name "python-rarfile")
10871 (version "2.8")
10872 (source (origin
10873 (method url-fetch)
10874 (uri (pypi-uri "rarfile" version))
10875 (sha256
10876 (base32
10877 "0qfad483kcbga0bn4qmcz953xjk16r52fahiy46zzn56v80y89ra"))))
10878 (build-system python-build-system)
10879 (arguments
10880 '(#:phases
10881 (modify-phases %standard-phases
10882 (replace 'check
10883 ;; Many tests fail, but the installation proceeds.
10884 (lambda _ (zero? (system* "make" "-C" "test" "test")))))))
10885 (native-inputs
10886 `(("which" ,which))) ; required for tests
10887 (propagated-inputs
10888 `(("libarchive" ,libarchive)))
10889 (home-page "https://github.com/markokr/rarfile")
10890 (synopsis "RAR archive reader for Python")
10891 (description "This is Python module for RAR archive reading. The interface
10892 is made as zipfile like as possible.")
10893 (license license:isc)))
10894
10895 (define-public python2-rarfile
10896 (package-with-python2 python-rarfile))
10897
10898 (define-public python-magic
10899 (package
10900 (name "python-magic")
10901 (version "0.4.3")
10902 (source
10903 (origin
10904 (method url-fetch)
10905 (uri (string-append "https://github.com/ahupp/python-magic/archive/"
10906 version ".tar.gz"))
10907 (sha256
10908 (base32
10909 "17bgy92i7sb021f2s4mw1dcvpm6p1mi9jihridwy1pyn8mzvpjgk"))
10910 (file-name (string-append name "-" version "-checkout"))))
10911 (build-system python-build-system)
10912 (arguments
10913 ;; The tests are unreliable, so don't run them. The tests fail
10914 ;; under Python3 because they were written for Python2 and
10915 ;; contain import statements that do not work in Python3. One of
10916 ;; the tests fails under Python2 because its assertions are
10917 ;; overly stringent; it relies on comparing output strings which
10918 ;; are brittle and can change depending on the version of
10919 ;; libmagic being used and the system on which the test is
10920 ;; running. In my case, under GuixSD 0.10.0, only one test
10921 ;; failed, and it seems to have failed only because the version
10922 ;; of libmagic that is packaged in Guix outputs a slightly
10923 ;; different (but not wrong) string than the one that the test
10924 ;; expected.
10925 '(#:tests? #f
10926 #:phases (modify-phases %standard-phases
10927 ;; Replace a specific method call with a hard-coded
10928 ;; path to the necessary libmagic.so file in the
10929 ;; store. If we don't do this, then the method call
10930 ;; will fail to find the libmagic.so file, which in
10931 ;; turn will cause any application using
10932 ;; python-magic to fail.
10933 (add-before 'build 'hard-code-path-to-libmagic
10934 (lambda* (#:key inputs #:allow-other-keys)
10935 (let ((file (assoc-ref inputs "file")))
10936 (substitute* "magic.py"
10937 (("ctypes.util.find_library\\('magic'\\)")
10938 (string-append "'" file "/lib/libmagic.so'")))
10939 #t)))
10940 (add-before 'install 'disable-egg-compression
10941 (lambda _
10942 (let ((port (open-file "setup.cfg" "a")))
10943 (display "\n[easy_install]\nzip_ok = 0\n"
10944 port)
10945 (close-port port)
10946 #t))))))
10947 (inputs
10948 ;; python-magic needs to be able to find libmagic.so.
10949 `(("file" ,file)))
10950 (home-page "https://github.com/ahupp/python-magic")
10951 (synopsis "File type identification using libmagic")
10952 (description
10953 "This module uses ctypes to access the libmagic file type
10954 identification library. It makes use of the local magic database and
10955 supports both textual and MIME-type output. Note that this module and
10956 the python-file module both provide a \"magic.py\" file; these two
10957 modules, which are different and were developed separately, both serve
10958 the same purpose: to provide Python bindings for libmagic.")
10959 (license license:expat)))
10960
10961 (define-public python2-magic
10962 (package-with-python2 python-magic))
10963
10964 (define-public python2-s3cmd
10965 (package
10966 (name "python2-s3cmd")
10967 (version "1.6.1")
10968 (source
10969 (origin
10970 (method url-fetch)
10971 (uri (string-append "mirror://sourceforge/s3tools/s3cmd/" version "/"
10972 "s3cmd-" version ".tar.gz"))
10973 (sha256
10974 (base32
10975 "0ki1rzhm5icvi9ry5jswi4b22yqwyj0d2wsqsgilwx6qhi7pjxa6"))))
10976 (build-system python-build-system)
10977 (arguments
10978 ;; s3cmd is written for python2 only and contains no tests.
10979 `(#:python ,python-2
10980 #:tests? #f))
10981 (propagated-inputs
10982 `(("python2-dateutil" ,python2-dateutil)
10983 ;; The python-file package also provides a magic.py module.
10984 ;; This is an unfortunate state of affairs; however, s3cmd
10985 ;; fails to install if it cannot find specifically the
10986 ;; python-magic package. Thus we include it, instead of using
10987 ;; python-file. Ironically, s3cmd sometimes works better
10988 ;; without libmagic bindings at all:
10989 ;; https://github.com/s3tools/s3cmd/issues/198
10990 ("python2-magic" ,python2-magic)))
10991 (home-page "http://s3tools.org/s3cmd")
10992 (synopsis "Command line tool for S3-compatible storage services")
10993 (description
10994 "S3cmd is a command line tool for uploading, retrieving and managing data
10995 in storage services that are compatible with the Amazon Simple Storage
10996 Service (S3) protocol, including S3 itself. It supports rsync-like backup,
10997 GnuPG encryption, and more. It also supports management of Amazon's
10998 CloudFront content delivery network.")
10999 (license license:gpl2+)))
11000
11001 (define-public python-pkgconfig
11002 (package
11003 (name "python-pkgconfig")
11004 (version "1.1.0")
11005 (source
11006 (origin
11007 (method url-fetch)
11008 (uri (pypi-uri "pkgconfig" version))
11009 (sha256
11010 (base32
11011 "1pw0kmvc57sjmaxi6c54fqsnihqj6hvhc9y1vaz36axafzqam7bh"))))
11012 (build-system python-build-system)
11013 (native-inputs
11014 `(("python-nose" ,python-nose)))
11015 (inputs
11016 `(("pkg-config" ,pkg-config)))
11017 (arguments
11018 `(;; Tests fail with "ValueError: _type_ 'v' not supported" on Python 3,
11019 ;; and on Python 2 they need the dl module deprecated since Python 2.6.
11020 #:tests? #f
11021 ;; Hard-code the path to pkg-config.
11022 #:phases
11023 (modify-phases %standard-phases
11024 (add-before
11025 'build 'patch
11026 (lambda _
11027 (substitute* "pkgconfig/pkgconfig.py"
11028 (("cmd = 'pkg-config")
11029 (string-append "cmd = '" (which "pkg-config"))))
11030 #t)))))
11031 (home-page "https://github.com/matze/pkgconfig")
11032 (synopsis "Python interface for pkg-config")
11033 (description "This module provides a Python interface to pkg-config. It
11034 can be used to find all pkg-config packages, check if a package exists,
11035 check if a package meets certain version requirements, query CFLAGS and
11036 LDFLAGS and parse the output to build extensions with setup.py.")
11037 (license license:expat)))
11038
11039 (define-public python2-pkgconfig
11040 (package-with-python2 python-pkgconfig))
11041
11042 (define-public python-bz2file
11043 (package
11044 (name "python-bz2file")
11045 (version "0.98")
11046 (source
11047 (origin
11048 (method url-fetch)
11049 (uri (pypi-uri "bz2file" version))
11050 (sha256
11051 (base32
11052 "126s53fkpx04f33a829yqqk8fj4png3qwg4m66cvlmhmwc8zihb4"))))
11053 (build-system python-build-system)
11054 (arguments
11055 `(#:tests? #f)) ; Tests use deprecated python modules.
11056 (home-page "https://github.com/nvawda/bz2file")
11057 (synopsis "Read and write bzip2-compressed files")
11058 (description
11059 "Bz2file is a Python library for reading and writing bzip2-compressed
11060 files. It contains a drop-in replacement for the I/O interface in the
11061 standard library's @code{bz2} module, including features from the latest
11062 development version of CPython that are not available in older releases.")
11063 (license license:asl2.0)
11064 (properties `((python2-variant . ,(delay python2-bz2file))))))
11065
11066 (define-public python2-bz2file
11067 (let ((base (package-with-python2
11068 (strip-python2-variant python-bz2file))))
11069 (package
11070 (inherit base)
11071 (arguments
11072 `(#:python ,python-2
11073 #:phases
11074 (modify-phases %standard-phases
11075 ;; 'python setup.py test' does not work as of 0.98.
11076 ;; There is only the one test file, so we run it directly.
11077 (replace 'check
11078 (lambda _ (zero? (system* "python"
11079 "test_bz2file.py"))))))))))
11080
11081 (define-public python-future
11082 (package
11083 (name "python-future")
11084 (version "0.16.0")
11085 (source
11086 (origin
11087 (method url-fetch)
11088 (uri (pypi-uri "future" version))
11089 (sha256
11090 (base32
11091 "1nzy1k4m9966sikp0qka7lirh8sqrsyainyf8rk97db7nwdfv773"))))
11092 (build-system python-build-system)
11093 ;; Many tests connect to the network or are otherwise flawed.
11094 ;; https://github.com/PythonCharmers/python-future/issues/210
11095 (arguments
11096 `(#:tests? #f))
11097 (home-page "http://python-future.org")
11098 (synopsis "Single-source support for Python 3 and 2")
11099 (description
11100 "@code{python-future} is the missing compatibility layer between Python 2 and
11101 Python 3. It allows you to use a single, clean Python 3.x-compatible codebase
11102 to support both Python 2 and Python 3 with minimal overhead.")
11103 (license license:expat)))
11104
11105 (define-public python2-future
11106 (package-with-python2 python-future))
11107
11108 (define-public python-cysignals
11109 (package
11110 (name "python-cysignals")
11111 (version "1.1.0")
11112 (source
11113 (origin
11114 (method url-fetch)
11115 (uri (pypi-uri "cysignals" version ".tar.bz2"))
11116 (sha256
11117 (base32
11118 "14cbyd9znlz6cxy1s3g6v6dv5jj45hn27pywkidd9b1zanaysqc6"))))
11119 (build-system python-build-system)
11120 (native-inputs
11121 `(("python-cython" ,python-cython)
11122 ("python-sphinx" ,python-sphinx)))
11123 (inputs
11124 `(("pari-gp" ,pari-gp)))
11125 (arguments
11126 `(#:modules ((guix build python-build-system)
11127 ((guix build gnu-build-system) #:prefix gnu:)
11128 (guix build utils))
11129 ;; FIXME: Tests are executed after installation and currently fail
11130 ;; when not installing into standard locations; the author is working
11131 ;; on a fix.
11132 #:tests? #f
11133 #:phases
11134 (modify-phases %standard-phases
11135 (add-before
11136 'build 'configure
11137 (assoc-ref gnu:%standard-phases 'configure)))))
11138 (home-page
11139 "https://github.com/sagemath/cysignals")
11140 (synopsis
11141 "Handling of interrupts and signals for Cython")
11142 (description
11143 "The cysignals package provides mechanisms to handle interrupts (and
11144 other signals and errors) in Cython code, using two related approaches,
11145 for mixed Cython/Python code or external C libraries and pure Cython code,
11146 respectively.")
11147 (license license:lgpl3+)))
11148
11149 (define-public python2-cysignals
11150 (package-with-python2 python-cysignals))
11151
11152 (define-public python2-shedskin
11153 (package
11154 (name "python2-shedskin")
11155 (version "0.9.4")
11156 (source
11157 (origin
11158 (method url-fetch)
11159 (uri (string-append "https://github.com/shedskin/shedskin/"
11160 "releases/download/v" version
11161 "/shedskin-" version ".tgz"))
11162 (sha256
11163 (base32
11164 "0nzwrzgw1ga8rw6f0ryq7zr9kkiavd1cqz5hzxkcbicl1dk7kz41"))))
11165 (build-system python-build-system)
11166 (arguments
11167 `(#:python ,python-2
11168 #:phases (modify-phases %standard-phases
11169 (add-after 'unpack 'fix-resulting-include-libs
11170 (lambda* (#:key inputs #:allow-other-keys)
11171 (let ((libgc (assoc-ref inputs "libgc"))
11172 (pcre (assoc-ref inputs "pcre")))
11173 (substitute* "shedskin/makefile.py"
11174 (("variable == 'CCFLAGS':[ ]*")
11175 (string-append "variable == 'CCFLAGS':\n"
11176 " line += ' -I " pcre "/include"
11177 " -I " libgc "/include'"))
11178 (("variable == 'LFLAGS':[ ]*")
11179 (string-append "variable == 'LFLAGS':\n"
11180 " line += ' -L" pcre "/lib"
11181 " -L " libgc "/lib'")))
11182 #t))))))
11183 (inputs `(("pcre" ,pcre)
11184 ("libgc" ,libgc)))
11185 (home-page "https://shedskin.github.io/")
11186 (synopsis "Experimental Python-2 to C++ Compiler")
11187 (description (string-append "This is an experimental compiler for a subset of
11188 Python. It generates C++ code and a Makefile."))
11189 (license (list license:gpl3 license:bsd-3 license:expat))))
11190
11191 (define-public python2-rope
11192 (package
11193 (name "python2-rope")
11194 (version "0.10.3")
11195 (source
11196 (origin
11197 (method url-fetch)
11198 (uri (pypi-uri "rope" version))
11199 (sha256
11200 (base32
11201 "18k5znhpwvrfck3yp0jmhd5j8r0f0s8bk1zh5yhs2cfgmfhbwigb"))))
11202 (arguments
11203 ;; Rope is currently python-2 only.
11204 ;; https://github.com/python-rope/rope/issues/57
11205 `(#:python ,python-2))
11206 (build-system python-build-system)
11207 (native-inputs
11208 `(("python2-unittest2" ,python2-unittest2)))
11209 (home-page "https://github.com/python-rope/rope")
11210 (synopsis "Refactoring library for Python")
11211 (description "Rope is a refactoring library for Python. It facilitates
11212 the renaming, moving and extracting of attributes, functions, modules, fields
11213 and parameters in Python 2 source code. These refactorings can also be applied
11214 to occurrences in strings and comments.")
11215 (license license:gpl2)))
11216
11217 (define-public python-py3status
11218 (package
11219 (name "python-py3status")
11220 (version "3.1")
11221 (source
11222 (origin
11223 (method url-fetch)
11224 (uri (pypi-uri "py3status" version))
11225 (sha256
11226 (base32
11227 "0i283z1pivmir61z8kbiycigc94l61v33ygzkhczf1ifq7cppyds"))))
11228 (build-system python-build-system)
11229 (arguments
11230 '(#:tests? #f)) ; TODO: Requires many libraries not in Guix.
11231 (home-page "https://github.com/ultrabug/py3status")
11232 (synopsis "Extensible i3status wrapper written in Python")
11233 (description "py3status is an i3status wrapper which extends i3status
11234 functionality in a modular way, allowing you to extend your panel with your
11235 own code, responding to click events and updating clock every second.")
11236 (license license:bsd-3)))
11237
11238 (define-public python-tblib
11239 (package
11240 (name "python-tblib")
11241 (version "1.3.0")
11242 (source (origin
11243 (method url-fetch)
11244 (uri (pypi-uri "tblib" version))
11245 (sha256 (base32
11246 "02iahfkfa927hb4jq2bak36ldihwapzacfiq5lyxg8llwn98a1yi"))))
11247 (build-system python-build-system)
11248 (arguments
11249 `(#:phases
11250 (modify-phases %standard-phases
11251 (replace 'check
11252 (lambda _
11253 ;; Upstream runs tests after installation and the package itself
11254 ;; resides in a subdirectory. Extend PYTHONPATH so it will be
11255 ;; found.
11256 (setenv "PYTHONPATH"
11257 (string-append (getcwd) "/build/lib:"
11258 (getenv "PYTHONPATH")))
11259 (zero? (system* "py.test" "-vv" "tests" "README.rst")))))))
11260 (native-inputs
11261 `(("python-pytest" ,python-pytest)
11262 ("python-six" ,python-six)))
11263 (home-page "https://github.com/ionelmc/python-tblib")
11264 (synopsis "Traceback serialization library")
11265 (description
11266 "Traceback serialization allows you to:
11267
11268 @enumerate
11269 @item Pickle tracebacks and raise exceptions with pickled tracebacks in
11270 different processes. This allows better error handling when running code over
11271 multiple processes (imagine multiprocessing, billiard, futures, celery etc).
11272
11273 @item Parse traceback strings and raise with the parsed tracebacks.
11274 @end enumerate\n")
11275 (license license:bsd-3)))
11276
11277 (define-public python2-tblib
11278 (package-with-python2 python-tblib))
11279
11280 (define-public python-sqlparse
11281 (package
11282 (name "python-sqlparse")
11283 (version "0.1.19")
11284 (source (origin
11285 (method url-fetch)
11286 (uri (pypi-uri "sqlparse" version))
11287 (sha256
11288 (base32
11289 "1s2fvaxgh9kqzrd6iwy5h7i61ckn05plx9np13zby93z3hdbx5nq"))))
11290 (build-system python-build-system)
11291 (arguments
11292 `(#:phases
11293 (modify-phases %standard-phases
11294 (replace 'check
11295 (lambda* _
11296 ;; setup.py-integrated 2to3 only affects the build files, but
11297 ;; py.test is using the source files. So we need to convert them
11298 ;; manually.
11299 (when (zero? (system* "python3"))
11300 (system* "2to3" "--no-diff" "-wn" "sqlparse" "tests"))
11301 (zero? (system* "py.test")))))))
11302 (native-inputs
11303 `(("python-pytest" ,python-pytest)))
11304 (home-page "https://github.com/andialbrecht/sqlparse")
11305 (synopsis "Non-validating SQL parser")
11306 (description "Sqlparse is a non-validating SQL parser for Python. It
11307 provides support for parsing, splitting and formatting SQL statements.")
11308 (license license:bsd-3)))
11309
11310 (define-public python2-sqlparse
11311 (package-with-python2 python-sqlparse))
11312
11313 (define-public python-greenlet
11314 (package
11315 (name "python-greenlet")
11316 (version "0.4.11")
11317 (source (origin
11318 (method url-fetch)
11319 (uri (pypi-uri "greenlet" version))
11320 (sha256
11321 (base32
11322 "1xhik26j4f3kc4qw9xmj0c567rb5h1zryb4ijwqnqwwjvfhbv59h"))))
11323 (build-system python-build-system)
11324 (home-page "https://greenlet.readthedocs.io/")
11325 (synopsis "Lightweight in-process concurrent programming")
11326 (description
11327 "Greenlet package is a spin-off of Stackless, a version of CPython
11328 that supports micro-threads called \"tasklets\". Tasklets run
11329 pseudo-concurrently (typically in a single or a few OS-level threads) and
11330 are synchronized with data exchanges on \"channels\".")
11331 (license (list license:psfl license:expat))))
11332
11333 (define-public python2-greenlet
11334 (package-with-python2 python-greenlet))
11335
11336 (define-public python-gevent
11337 (package
11338 (name "python-gevent")
11339 (version "1.1.1")
11340 (source (origin
11341 (method url-fetch)
11342 (uri (pypi-uri "gevent" version))
11343 (sha256
11344 (base32
11345 "1smf3kvidpdiyi2c81alal74p2zm0clrm6xbyy6y1k9a3f2vkrbf"))
11346 (modules '((guix build utils)))
11347 (snippet
11348 '(begin
11349 ;; unbunding libev and c-ares
11350 (for-each delete-file-recursively '("libev" "c-ares"))
11351 ;; fixing testsuite
11352 (call-with-output-file "greentest/__init__.py" noop)
11353 (substitute* "greentest/testrunner.py"
11354 (("import util") "from . import util")
11355 (("from util import log") "from .util import log"))))))
11356 (build-system python-build-system)
11357 (propagated-inputs
11358 `(("python-greenlet" ,python-greenlet)))
11359 (native-inputs
11360 `(("python-six" ,python-six)))
11361 (inputs
11362 `(("c-ares" ,c-ares)
11363 ("libev" ,libev)))
11364 (home-page "http://www.gevent.org/")
11365 (synopsis "Coroutine-based network library")
11366 (description
11367 "gevent is a coroutine-based Python networking library that uses greenlet
11368 to provide a high-level synchronous API on top of the libev event loop.")
11369 (license license:expat)))
11370
11371 (define-public python2-gevent
11372 (package-with-python2 python-gevent))
11373
11374 (define-public python-geventhttpclient
11375 (package
11376 (name "python-geventhttpclient")
11377 (version "1.3.1")
11378 (source (origin
11379 (method url-fetch)
11380 (uri (pypi-uri "geventhttpclient" version))
11381 (sha256
11382 (base32
11383 "07d0q3wzmml75227r6y6mrl5a0zpf4v9gj0ni5rhbyzmaj4az1xx"))
11384 (modules '((guix build utils)))
11385 (snippet
11386 '(begin
11387 ;; Delete pre-compiled files.
11388 (for-each delete-file (find-files "src/geventhttpclient"
11389 ".*\\.pyc"))
11390 #t))))
11391 (build-system python-build-system)
11392 (arguments
11393 '(#:phases
11394 (modify-phases %standard-phases
11395 (add-after 'unpack 'delete-network-tests
11396 (lambda _
11397 (delete-file "src/geventhttpclient/tests/test_client.py")
11398 #t))
11399 (delete 'check)
11400 (add-after 'install 'check
11401 (lambda* (#:key inputs outputs #:allow-other-keys)
11402 (add-installed-pythonpath inputs outputs)
11403 (zero? (system* "py.test" "src/geventhttpclient/tests" "-v")))))))
11404 (native-inputs
11405 `(("python-pytest" ,python-pytest)))
11406 (propagated-inputs
11407 `(("python-certifi" ,python-certifi)
11408 ("python-gevent" ,python-gevent)
11409 ("python-six" ,python-six)))
11410 (home-page "https://github.com/gwik/geventhttpclient")
11411 (synopsis "HTTP client library for gevent")
11412 (description "@code{python-geventhttpclient} is a high performance,
11413 concurrent HTTP client library for python using @code{gevent}.")
11414 (license license:expat)))
11415
11416 (define-public python2-geventhttpclient
11417 (package-with-python2 python-geventhttpclient))
11418
11419 (define-public python-fastimport
11420 (package
11421 (name "python-fastimport")
11422 (version "0.9.6")
11423 (source
11424 (origin
11425 (method url-fetch)
11426 (uri (pypi-uri "fastimport" version))
11427 (sha256
11428 (base32 "1aqjsin4rmqm7ln4j0p73fzxifws6c6ikgyhav7r137m2ixsxl43"))))
11429 (build-system python-build-system)
11430 (home-page "https://github.com/jelmer/python-fastimport")
11431 (synopsis "VCS fastimport parser and generator in Python")
11432 (description "This package provides a parser for and generator of the Git
11433 @url{https://www.kernel.org/pub/software/scm/git/docs/git-fast-import.html,fastimport}
11434 format.")
11435 (license license:gpl2+)))
11436
11437 (define-public python2-fastimport
11438 (package-with-python2 python-fastimport))
11439
11440 (define-public python-twisted
11441 (package
11442 (name "python-twisted")
11443 (version "16.2.0")
11444 (source (origin
11445 (method url-fetch)
11446 (uri (pypi-uri "Twisted" version ".tar.bz2"))
11447 (sha256
11448 (base32
11449 "0ydxrp9myw1mvsz3qfzx5579y5llmqa82pxvqchgp5syczffi450"))))
11450 (build-system python-build-system)
11451 (arguments
11452 '(#:tests? #f)) ; FIXME: Some tests are failing.
11453 ;; #:phases
11454 ;; (modify-phases %standard-phases
11455 ;; (replace 'check
11456 ;; (lambda _
11457 ;; (zero? (system* "./bin/trial" "twisted")))))
11458 (propagated-inputs
11459 `(("python-zope-interface" ,python-zope-interface)))
11460 (home-page "https://twistedmatrix.com/")
11461 (synopsis "Asynchronous networking framework written in Python")
11462 (description
11463 "Twisted is an extensible framework for Python programming, with special
11464 focus on event-based network programming and multiprotocol integration.")
11465 (license license:expat)))
11466
11467 (define-public python2-twisted
11468 (package-with-python2 python-twisted))
11469
11470 (define-public python-pika
11471 (package
11472 (name "python-pika")
11473 (version "0.10.0")
11474 (source
11475 (origin
11476 (method url-fetch)
11477 (uri (pypi-uri "pika" version))
11478 (sha256
11479 (base32
11480 "0nb4h08di432lv7dy2v9kpwgk0w92f24sqc2hw2s9vwr5b8v8xvj"))))
11481 (build-system python-build-system)
11482 (native-inputs
11483 `(("python-pyev" ,python-pyev)
11484 ("python-tornado" ,python-tornado)
11485 ("python-twisted" ,python-twisted)))
11486 (home-page "https://pika.readthedocs.org")
11487 (synopsis "Pure Python AMQP Client Library")
11488 (description
11489 "Pika is a pure-Python implementation of the AMQP (Advanced Message Queuing
11490 Protocol) 0-9-1 protocol that tries to stay fairly independent of the underlying
11491 network support library.")
11492 (license license:bsd-3)))
11493
11494 (define-public python2-pika
11495 (package-with-python2 python-pika))
11496
11497 (define-public python-ply
11498 (package
11499 (name "python-ply")
11500 (version "3.9")
11501 (source
11502 (origin
11503 (method url-fetch)
11504 (uri (pypi-uri "ply" version))
11505 (sha256
11506 (base32
11507 "0gpl0yli3w03ipyqfrp3w5nf0iawhsq65anf5wwm2wf5p502jzhd"))))
11508 (build-system python-build-system)
11509 (home-page "http://www.dabeaz.com/ply/")
11510 (synopsis "Python Lex & Yacc")
11511 (description "PLY is a @code{lex}/@code{yacc} implemented purely in Python.
11512 It uses LR parsing and does extensive error checking.")
11513 (license license:bsd-3)))
11514
11515 (define-public python2-ply
11516 (package-with-python2 python-ply))
11517
11518 (define-public python-tabulate
11519 (package
11520 (name "python-tabulate")
11521 (version "0.7.7")
11522 (source (origin
11523 (method url-fetch)
11524 (uri (pypi-uri "tabulate" version))
11525 (sha256
11526 (base32
11527 "1inqhspd4frxnp08c32yndr0lc4px1xfkqah184i5w09gkhvi843"))))
11528 (build-system python-build-system)
11529 (arguments
11530 ;; FIXME: The pypi release tarball is missing a 'test/common.py'
11531 ;; and the latest release is not tagged in the upstream repository.
11532 '(#:tests? #f))
11533 (home-page "https://bitbucket.org/astanin/python-tabulate")
11534 (synopsis "Pretty-print tabular data")
11535 (description
11536 "Tabulate is a library and command-line utility to pretty-print tabular
11537 data in Python.")
11538 (license license:expat)))
11539
11540 (define-public python2-tabulate
11541 (package-with-python2 python-tabulate))
11542
11543 (define-public python-kazoo
11544 (package
11545 (name "python-kazoo")
11546 (version "2.2.1")
11547 (source
11548 (origin
11549 (method url-fetch)
11550 (uri (pypi-uri "kazoo" version))
11551 (sha256
11552 (base32
11553 "10pb864if9qi2pq9lfb9m8f7z7ss6rml80gf1d9h64lap5crjnjj"))))
11554 (build-system python-build-system)
11555 (arguments '(#:tests? #f)) ; XXX: needs zookeeper
11556 (propagated-inputs
11557 `(("python-six" ,python-six)))
11558 (home-page "https://kazoo.readthedocs.org")
11559 (synopsis "High-level Zookeeper client library")
11560 (description
11561 "Kazoo is a Python client library for the Apache Zookeeper distributed
11562 application service. It is designed to be easy to use and to avoid common
11563 programming errors.")
11564 (license license:asl2.0)))
11565
11566 (define-public python2-kazoo
11567 (package-with-python2 python-kazoo))
11568
11569 (define-public python-pykafka
11570 (package
11571 (name "python-pykafka")
11572 (version "2.4.0")
11573 (source (origin
11574 (method url-fetch)
11575 (uri (string-append
11576 "https://pypi.python.org/packages/8b/3e/"
11577 "384eeff406b06315738b62483fd2126c6e4f544167116b17cc04ea7d2a59/"
11578 "pykafka-" version ".tar.gz"))
11579 (sha256
11580 (base32
11581 "1id6sr159p6aa13bxcqyr9gln8sqg1l0ddzns5iws8kk5q1p5cfv"))))
11582 (build-system python-build-system)
11583 (arguments '(#:tests? #f)) ; XXX: needs zookeeper, kafka, etc.
11584 (propagated-inputs
11585 `(("python-gevent" ,python-gevent)
11586 ("python-kazoo" ,python-kazoo)
11587 ("python-tabulate" ,python-tabulate)))
11588 (inputs
11589 `(("librdkafka" ,librdkafka)))
11590 (home-page "https://pykafka.readthedocs.io/")
11591 (synopsis "Apache Kafka client for Python")
11592 (description
11593 "PyKafka is a client for the Apache Kafka distributed messaging system.
11594 It includes Python implementations of Kafka producers and consumers, which
11595 are optionally backed by a C extension built on librdkafka.")
11596 (license license:asl2.0)))
11597
11598 (define-public python2-pykafka
11599 (package-with-python2 python-pykafka))
11600
11601 (define-public python-wcwidth
11602 (package
11603 (name "python-wcwidth")
11604 (version "0.1.7")
11605 (source
11606 (origin
11607 (method url-fetch)
11608 (uri (pypi-uri "wcwidth" version))
11609 (sha256
11610 (base32
11611 "0pn6dflzm609m4r3i8ik5ni9ijjbb5fa3vg1n7hn6vkd49r77wrx"))))
11612 (build-system python-build-system)
11613 (home-page "https://github.com/jquast/wcwidth")
11614 (synopsis "Measure number of terminal column cells of wide-character codes")
11615 (description "Wcwidth measures the number of terminal column cells of
11616 wide-character codes. It is useful for those implementing a terminal emulator,
11617 or programs that carefully produce output to be interpreted by one. It is a
11618 Python implementation of the @code{wcwidth} and @code{wcswidth} C functions
11619 specified in POSIX.1-2001 and POSIX.1-2008.")
11620 (license license:expat)))
11621
11622 (define-public python2-wcwidth
11623 (package-with-python2 python-wcwidth))
11624
11625 (define-public python2-jsonrpclib
11626 (package
11627 (name "python2-jsonrpclib")
11628 (version "0.1.7")
11629 (source (origin
11630 (method url-fetch)
11631 (uri (string-append
11632 "https://pypi.python.org/packages/source/j/jsonrpclib/"
11633 "jsonrpclib-" version ".tar.gz"))
11634 (sha256
11635 (base32
11636 "02vgirw2bcgvpcxhv5hf3yvvb4h5wzd1lpjx8na5psdmaffj6l3z"))))
11637 (build-system python-build-system)
11638 (arguments
11639 `(#:tests? #f
11640 #:python ,python-2))
11641 (home-page "https://github.com/joshmarshall/jsonrpclib/")
11642 (synopsis "Implementation of JSON-RPC specification for Python")
11643 (description
11644 "This library is an implementation of the JSON-RPC specification.
11645 It supports both the original 1.0 specification, as well as the
11646 new (proposed) 2.0 spec, which includes batch submission, keyword arguments,
11647 etc.")
11648 (license license:asl2.0)))
11649
11650 (define-public python-chai
11651 (package
11652 (name "python-chai")
11653 (version "1.1.1")
11654 (source (origin
11655 (method url-fetch)
11656 (uri (pypi-uri "chai" version))
11657 (sha256
11658 (base32
11659 "016kf3irrclpkpvcm7q0gmkfibq7jgy30a9v73pp42bq9h9a32bl"))))
11660 (build-system python-build-system)
11661 (home-page "https://github.com/agoragames/chai")
11662 (synopsis "Mocking framework for Python")
11663 (description
11664 "Chai provides an api for mocking, stubbing and spying your python
11665 objects, patterned after the Mocha library for Ruby.")
11666 (license license:bsd-3)))
11667
11668 (define-public python2-chai
11669 (package-with-python2 python-chai))
11670
11671 (define-public python-arrow
11672 (package
11673 (name "python-arrow")
11674 (version "0.8.0")
11675 (source (origin
11676 (method url-fetch)
11677 (uri (pypi-uri "arrow" version))
11678 (sha256
11679 (base32
11680 "1bz7hkdgpqcjs866y58z8jywpy7al0f4rxdr00bh2l5qddyw245j"))))
11681 (build-system python-build-system)
11682 (native-inputs
11683 `(;; For testing
11684 ("python-chai" ,python-chai)
11685 ("python-simplejson" ,python-simplejson)))
11686 (propagated-inputs
11687 `(("python-dateutil" ,python-dateutil)))
11688 (home-page "https://github.com/crsmithdev/arrow/")
11689 (synopsis "Dates and times for Python")
11690 (description
11691 "Arrow is a Python library to creating, manipulating, formatting and
11692 converting dates, times, and timestamps. It implements and updates the
11693 datetime type.")
11694 (license license:asl2.0)))
11695
11696 (define-public python2-arrow
11697 (package-with-python2 python-arrow))
11698
11699 (define-public python-inflection
11700 (package
11701 (name "python-inflection")
11702 (version "0.3.1")
11703 (source
11704 (origin (method url-fetch)
11705 (uri (pypi-uri "inflection" version))
11706 (sha256
11707 (base32
11708 "1jhnxgnw8y3mbzjssixh6qkc7a3afc4fygajhqrqalnilyvpzshq"))))
11709 (build-system python-build-system)
11710 (native-inputs
11711 `(("python-pytest" ,python-pytest)))
11712 (home-page "https://github.com/jpvanhal/inflection")
11713 (synopsis "Python string transformation library")
11714 (description
11715 "Inflection is a string transformation library. It singularizes
11716 and pluralizes English words, and transforms strings from CamelCase to
11717 underscored string.")
11718 (license license:expat)))
11719
11720 (define-public python2-inflection
11721 (package-with-python2 python-inflection))
11722
11723 (define-public python-pylev
11724 (package
11725 (name "python-pylev")
11726 (version "1.3.0")
11727 (source (origin
11728 (method url-fetch)
11729 (uri (pypi-uri "pylev" version))
11730 (sha256
11731 (base32
11732 "1hz1x9blsbxya1y9nnhnwwdnqmakxi9mc0jkwj0rn6b1h44i0f86"))))
11733 (build-system python-build-system)
11734 (home-page "https://github.com/toastdriven/pylev")
11735 (synopsis "Levenshtein distance implementation in Python")
11736 (description "Pure Python Levenshtein implementation, based off the
11737 Wikipedia code samples at
11738 @url{http://en.wikipedia.org/wiki/Levenshtein_distance}.")
11739 (license license:bsd-3)))
11740
11741 (define-public python2-pylev
11742 (package-with-python2 python-pylev))
11743
11744 (define-public python-cleo
11745 (package
11746 (name "python-cleo")
11747 (version "0.4.1")
11748 (source (origin
11749 (method url-fetch)
11750 (uri (pypi-uri "cleo" version))
11751 (sha256
11752 (base32
11753 "1k2dcl6mqpn5bljyl6w42rqyd9mb3y9kh2mg7m2x3kfjwvg0rpva"))))
11754 (build-system python-build-system)
11755 (native-inputs
11756 `(;; For testing
11757 ("python-mock" ,python-mock)
11758 ("python-pytest" ,python-pytest)))
11759 (propagated-inputs
11760 `(("python-psutil" ,python-psutil)
11761 ("python-pylev" ,python-pylev)))
11762 (home-page "https://github.com/sdispater/cleo")
11763 (synopsis "Command-line arguments library for Python")
11764 (description
11765 "Cleo allows you to create command-line commands with signature in
11766 docstring and colored output.")
11767 (license license:expat)))
11768
11769 (define-public python2-cleo
11770 (package-with-python2 python-cleo))
11771
11772 (define-public python-lazy-object-proxy
11773 (package
11774 (name "python-lazy-object-proxy")
11775 (version "1.2.2")
11776 (source (origin
11777 (method url-fetch)
11778 (uri (pypi-uri "lazy-object-proxy" version))
11779 (sha256
11780 (base32
11781 "0s22aqqkdscyh8sjspyyax7qa1aiz8p4midrnyf39717fhfczm6x"))))
11782 (build-system python-build-system)
11783 (home-page "https://github.com/ionelmc/python-lazy-object-proxy")
11784 (synopsis "Lazy object proxy for python")
11785 (description
11786 "Lazy object proxy is an object that wraps a callable but defers the call
11787 until the object is actually required, and caches the result of said call.")
11788 (license license:bsd-2)))
11789
11790 (define-public python2-lazy-object-proxy
11791 (package-with-python2 python-lazy-object-proxy))
11792
11793 (define-public python-dnspython
11794 (package
11795 (name "python-dnspython")
11796 (version "1.15.0")
11797 (source (origin
11798 (method url-fetch)
11799 (uri (string-append "http://www.dnspython.org/kits/"
11800 version "/dnspython-" version ".tar.gz"))
11801 (sha256
11802 (base32
11803 "0jr4v2pd90i6l1xxbss2m05psbjaxvyvvvpq44wycijpfgjqln8i"))))
11804 (build-system python-build-system)
11805 (arguments '(#:tests? #f)) ; XXX: requires internet access
11806 (home-page "http://www.dnspython.org")
11807 (synopsis "DNS toolkit for Python")
11808 (description
11809 "dnspython is a DNS toolkit for Python. It supports almost all record
11810 types. It can be used for queries, zone transfers, and dynamic updates.
11811 It supports TSIG authenticated messages and EDNS0.")
11812 (license license:expat)))
11813
11814 (define-public python2-dnspython
11815 (package-with-python2 python-dnspython))
11816
11817 (define-public python-email-validator
11818 (package
11819 (name "python-email-validator")
11820 (version "1.0.2")
11821 (source
11822 (origin (method url-fetch)
11823 (uri (pypi-uri "email_validator" version))
11824 (sha256
11825 (base32
11826 "1ja9149l9ck5n45a72h3is7v476hjny5ybxbcamx1nw6iplsm7k6"))))
11827 (build-system python-build-system)
11828 (arguments
11829 '(#:phases
11830 (modify-phases %standard-phases
11831 (add-before 'build 'use-dnspython
11832 (lambda _
11833 (substitute* "setup.py"
11834 (("dnspython3") "dnspython"))
11835 #t)))))
11836 (propagated-inputs
11837 `(("python-dnspython" ,python-dnspython)
11838 ("python-idna" ,python-idna)))
11839 (home-page "https://github.com/JoshData/python-email-validator")
11840 (synopsis "Email address validation library for Python")
11841 (description
11842 "This library validates email address syntax and deliverability.")
11843 (license license:cc0)))
11844
11845 (define-public python2-email-validator
11846 (package-with-python2 python-email-validator))
11847
11848 (define-public python-ukpostcodeparser
11849 (package
11850 (name "python-ukpostcodeparser")
11851 (version "1.0.3")
11852 (source (origin
11853 (method url-fetch)
11854 (uri (pypi-uri "UkPostcodeParser" version))
11855 (sha256
11856 (base32
11857 "1jwg9z4rz51mcka1821rwgycsd0mcicyp1kiwjfa2kvg8bm9p2qd"))))
11858 (build-system python-build-system)
11859 (home-page "https://github.com/hamstah/ukpostcodeparser")
11860 (synopsis "UK Postcode parser for Python")
11861 (description
11862 "This library provides the @code{parse_uk_postcode} function for
11863 parsing UK postcodes.")
11864 (license license:expat)))
11865
11866 (define-public python2-ukpostcodeparser
11867 (package-with-python2 python-ukpostcodeparser))
11868
11869 (define-public python-faker
11870 (package
11871 (name "python-faker")
11872 (version "0.7.9")
11873 (source (origin
11874 (method url-fetch)
11875 (uri (pypi-uri "Faker" version))
11876 (sha256
11877 (base32
11878 "1fh2p2yz0fsdr4fqwxgddwbvfb6qn6vp8yx0qwqzra27yq5d1wsm"))
11879 (patches
11880 (search-patches "python-faker-fix-build-32bit.patch"))
11881 (modules '((guix build utils)))
11882 (snippet
11883 '(begin
11884 (for-each delete-file (find-files "." "\\.pyc$"))
11885 #t))))
11886 (build-system python-build-system)
11887 (arguments
11888 '(#:phases
11889 (modify-phases %standard-phases
11890 (replace 'check
11891 (lambda _
11892 (zero? (system* "python" "-m" "unittest" "-v" "tests")))))))
11893 (native-inputs
11894 `(;; For testing
11895 ("python-email-validator" ,python-email-validator)
11896 ("python-mock" ,python-mock)
11897 ("python-ukpostcodeparser" ,python-ukpostcodeparser)))
11898 (propagated-inputs
11899 `(("python-dateutil" ,python-dateutil)
11900 ("python-six" ,python-six)))
11901 (home-page "https://github.com/joke2k/faker")
11902 (synopsis "Python package that generates fake data")
11903 (description
11904 "Faker is a Python package that generates fake data such as names,
11905 addresses, and phone numbers.")
11906 (license license:expat)
11907 (properties `((python2-variant . ,(delay python2-faker))))))
11908
11909 (define-public python2-faker
11910 (let ((base (package-with-python2 (strip-python2-variant
11911 python-faker))))
11912 (package
11913 (inherit base)
11914 (propagated-inputs
11915 `(("python2-ipaddress" ,python2-ipaddress)
11916 ,@(package-propagated-inputs base))))))
11917
11918 (define-public python-pyaml
11919 (package
11920 (name "python-pyaml")
11921 (version "15.8.2")
11922 (source (origin
11923 (method url-fetch)
11924 (uri (pypi-uri "pyaml" version))
11925 (sha256
11926 (base32
11927 "1f5m28vkh4ksq3d80d8mmd2z8wxvc3mgy2pmrv2751dm2xgznm4w"))))
11928 (build-system python-build-system)
11929 (native-inputs
11930 `(("python-unidecode" ,python-unidecode)))
11931 (propagated-inputs
11932 `(("python-pyyaml" ,python-pyyaml)))
11933 (home-page "https://github.com/mk-fg/pretty-yaml")
11934 (synopsis "YAML pretty-print library for Python")
11935 (description
11936 "pyaml is a PyYAML based python module to produce pretty and readable
11937 YAML-serialized data.")
11938 (license (license:non-copyleft "http://www.wtfpl.net/txt/copying/"))))
11939
11940 (define-public python2-pyaml
11941 (package-with-python2 python-pyaml))
11942
11943 (define-public python-flexmock
11944 (package
11945 (name "python-flexmock")
11946 (version "0.10.2")
11947 (source (origin
11948 (method url-fetch)
11949 (uri (pypi-uri "flexmock" version))
11950 (sha256
11951 (base32
11952 "0arc6njvs6i9v9hgvzk5m50296g7zy5m9d7pyb43vdsdgxrci5gy"))))
11953 (build-system python-build-system)
11954 (home-page "https://flexmock.readthedocs.org")
11955 (synopsis "Testing library for Python")
11956 (description
11957 "flexmock is a testing library for Python that makes it easy to create
11958 mocks, stubs and fakes.")
11959 (license license:bsd-3)))
11960
11961 (define-public python2-flexmock
11962 (package-with-python2 python-flexmock))
11963
11964 (define-public python-orator
11965 (package
11966 (name "python-orator")
11967 (version "0.8.2")
11968 (source (origin
11969 (method url-fetch)
11970 (uri (pypi-uri "orator" version))
11971 (sha256
11972 (base32
11973 "1li49irsqha17nrda4nsb48biyy0rarp9pphf0jpqwm5zr8hv569"))))
11974 (build-system python-build-system)
11975 (arguments '(#:tests? #f)) ; no tests
11976 (propagated-inputs
11977 `(("python-arrow" ,python-arrow)
11978 ("python-blinker" ,python-blinker)
11979 ("python-cleo" ,python-cleo)
11980 ("python-faker" ,python-faker)
11981 ("python-inflection" ,python-inflection)
11982 ("python-lazy-object-proxy" ,python-lazy-object-proxy)
11983 ("python-pyaml" ,python-pyaml)
11984 ("python-simplejson" ,python-simplejson)
11985 ("python-wrapt" ,python-wrapt)))
11986 (home-page "https://orator-orm.com/")
11987 (synopsis "ActiveRecord ORM for Python")
11988 (description
11989 "Orator provides a simple ActiveRecord-like Object Relational Mapping
11990 implementation for Python.")
11991 (license license:expat)
11992 (properties `((python2-variant . ,(delay python2-orator))))))
11993
11994 (define-public python2-orator
11995 (let ((base (package-with-python2 (strip-python2-variant python-orator))))
11996 (package
11997 (inherit base)
11998 (propagated-inputs
11999 `(("python2-ipaddress" ,python2-ipaddress)
12000 ,@(package-propagated-inputs base))))))
12001
12002 (define-public python-prompt-toolkit
12003 (package
12004 (name "python-prompt-toolkit")
12005 (version "1.0.9")
12006 (source
12007 (origin
12008 (method url-fetch)
12009 (uri (pypi-uri "prompt_toolkit" version ".tar.gz"))
12010 (sha256
12011 (base32
12012 "172r15k9kwdw2lnajvpz1632dd16nqz1kcal1p0lq5ywdarj6rfd"))))
12013 (build-system python-build-system)
12014 (arguments
12015 '(#:tests? #f)) ; The test suite uses some Windows-specific data types.
12016 (propagated-inputs
12017 `(("python-wcwidth" ,python-wcwidth)
12018 ("python-six" ,python-six)
12019 ("python-pygments" ,python-pygments)))
12020 (home-page "https://github.com/jonathanslenders/python-prompt-toolkit")
12021 (synopsis "Library for building command line interfaces in Python")
12022 (description
12023 "Prompt-Toolkit is a library for building interactive command line
12024 interfaces in Python. It's like GNU Readline but it also features syntax
12025 highlighting while typing, out-of-the-box multi-line input editing, advanced
12026 code completion, incremental search, support for Chinese double-width
12027 characters, mouse support, and auto suggestions.")
12028 (license license:bsd-3)))
12029
12030 (define-public python2-prompt-toolkit
12031 (package-with-python2 python-prompt-toolkit))
12032
12033 (define-public python-jedi
12034 (package
12035 (name "python-jedi")
12036 (version "0.9.0")
12037 (source
12038 (origin
12039 (method url-fetch)
12040 (uri (pypi-uri "jedi" version))
12041 (sha256
12042 (base32
12043 "0c8x962ynpx001fdvp07m2q5jk4igkxbj3rmnydavphvlgxijk1v"))))
12044 (build-system python-build-system)
12045 (arguments
12046 ;; FIXME: One test fails (use "py.test" instead of 'setup.py test').
12047 '(#:tests? #f))
12048 (native-inputs
12049 `(("python-pytest" ,python-pytest)))
12050 (home-page "https://github.com/davidhalter/jedi")
12051 (synopsis
12052 "Autocompletion for Python that can be used for text editors")
12053 (description
12054 "Jedi is an autocompletion tool for Python that can be used for text editors.")
12055 (license license:expat)))
12056
12057 (define-public python2-jedi
12058 (package-with-python2 python-jedi))
12059
12060 (define-public ptpython
12061 (package
12062 (name "ptpython")
12063 (version "0.34")
12064 (source (origin
12065 (method url-fetch)
12066 (uri (pypi-uri "ptpython" version))
12067 (sha256
12068 (base32
12069 "1mmbiyzf0n8hm7z2a562x7w5cbl6jc0zsk6vp40q1z4cyblv1k13"))))
12070 (build-system python-build-system)
12071 (arguments
12072 '(#:tests? #f)) ; FIXME: No tests in pypi tarball.
12073 (propagated-inputs
12074 `(("python-docopt" ,python-docopt)
12075 ("python-jedi" ,python-jedi)
12076 ("python-prompt-toolkit" ,python-prompt-toolkit)
12077 ("python-pygments" ,python-pygments)))
12078 (home-page "https://github.com/jonathanslenders/ptpython")
12079 (synopsis "Python Read-Eval-Print-Loop with nice IDE-like features")
12080 (description
12081 "ptpython is a Python read-eval-print loop with IDE-like features.
12082 It supports syntax highlighting, multiline editing, autocompletion, mouse,
12083 color schemes, bracketed paste, Vi and Emacs keybindings, Chinese characters
12084 etc.")
12085 (license license:bsd-3)
12086 (properties `((python2-variant . ,(delay ptpython-2))))))
12087
12088 (define-public ptpython-2
12089 (let ((base (package-with-python2 (strip-python2-variant ptpython))))
12090 (package
12091 (inherit base)
12092 (name "ptpython2"))))
12093
12094 (define-public python-requests-oauthlib
12095 (package
12096 (name "python-requests-oauthlib")
12097 (version "0.6.2")
12098 (source
12099 (origin
12100 (method url-fetch)
12101 (uri (pypi-uri "requests-oauthlib" version))
12102 (sha256
12103 (base32
12104 "0ykff67sjcl227c23g0rxzfx34rr5bf21kwv0z3zmgk0lfmch7hn"))))
12105 (build-system python-build-system)
12106 (arguments
12107 `(#:phases
12108 (modify-phases %standard-phases
12109 ;; removes tests that require network access
12110 (add-before 'check 'pre-check
12111 (lambda _
12112 (delete-file "tests/test_core.py")
12113 #t)))))
12114 (native-inputs
12115 `(("python-requests-mock" ,python-requests-mock)
12116 ("python-mock" ,python-mock)))
12117 (propagated-inputs
12118 `(("python-oauthlib" ,python-oauthlib)
12119 ("python-requests" ,python-requests)))
12120 (home-page
12121 "https://github.com/requests/requests-oauthlib")
12122 (synopsis
12123 "OAuthlib authentication support for Requests")
12124 (description
12125 "Requests-OAuthlib uses the Python Requests and OAuthlib libraries to
12126 provide an easy-to-use Python interface for building OAuth1 and OAuth2 clients.")
12127 (license license:isc)))
12128
12129 (define-public python2-requests-oauthlib
12130 (package-with-python2 python-requests-oauthlib))
12131
12132 (define-public python-stem
12133 (package
12134 (name "python-stem")
12135 (version "1.5.4")
12136 (source
12137 (origin
12138 (method url-fetch)
12139 (uri (pypi-uri "stem" version))
12140 (sha256
12141 (base32
12142 "1j7pnblrn0yr6jmxvsq6y0ihmxmj5x50jl2n2606w67f6wq16j9n"))))
12143 (build-system python-build-system)
12144 (arguments
12145 `(#:phases
12146 (modify-phases %standard-phases
12147 (replace 'check
12148 (lambda _
12149 (zero? (system* "./run_tests.py" "--unit")))))))
12150 (native-inputs
12151 `(("python-mock" ,python-mock)
12152 ("python-pep8" ,python-pep8)
12153 ("python-pyflakes" ,python-pyflakes)))
12154 (home-page "https://stem.torproject.org/")
12155 (synopsis
12156 "Python controller library that allows applications to interact with Tor")
12157 (description
12158 "Stem is a Python controller library for Tor. With it you can use Tor's
12159 control protocol to script against the Tor process and read descriptor data
12160 relays publish about themselves.")
12161 (license license:lgpl3)))
12162
12163 (define-public python2-stem
12164 (package-with-python2 python-stem))
12165
12166 (define-public python-pyserial
12167 (package
12168 (name "python-pyserial")
12169 (version "3.1.1")
12170 (source
12171 (origin
12172 (method url-fetch)
12173 (uri (pypi-uri "pyserial" version))
12174 (sha256
12175 (base32
12176 "0k1nfdrxxkdlv4zgaqsdv8li0pj3gbh2pyxw8q2bsg6f9490amyn"))))
12177 (build-system python-build-system)
12178 (arguments
12179 '(#:tests? #f)) ; FIXME: 3/49 tests are failing.
12180 ;; #:phases
12181 ;; (modify-phases %standard-phases
12182 ;; (replace 'check
12183 ;; (lambda _
12184 ;; (zero? (system* "python" "test/run_all_tests.py" "loop://")))))))
12185 (home-page
12186 "https://github.com/pyserial/pyserial")
12187 (synopsis "Python Serial Port Bindings")
12188 (description "@code{pyserial} provide serial port bindings for Python. It
12189 supports different byte sizes, stop bits, parity and flow control with RTS/CTS
12190 and/or Xon/Xoff. The port is accessed in RAW mode.")
12191 (license license:bsd-3)))
12192
12193 (define-public python2-pyserial
12194 (package-with-python2 python-pyserial))
12195
12196 (define-public python-kivy
12197 (package
12198 (name "python-kivy")
12199 (version "1.9.1")
12200 (source
12201 (origin
12202 (method url-fetch)
12203 (uri (pypi-uri "kivy" version))
12204 (file-name (string-append name "-" version ".tar.gz"))
12205 (sha256
12206 (base32
12207 "0zk3g1j1z0lzcm9d0k1lprrs95zr8n8k5pdg3p5qlsn26jz4bg19"))))
12208 (build-system python-build-system)
12209 (arguments
12210 `(#:tests? #f ; Tests require many optional packages
12211 #:phases
12212 (modify-phases %standard-phases
12213 (replace 'build (lambda _ (zero? (system* "make" "force"))))
12214 (add-after 'patch-generated-file-shebangs 'set-sdl-paths
12215 (lambda* (#:key inputs #:allow-other-keys)
12216 (setenv "KIVY_SDL2_PATH"
12217 (string-append (assoc-ref inputs "sdl-union")
12218 "/include/SDL2"))
12219 #t)))))
12220 (native-inputs
12221 `(("pkg-config" ,pkg-config)
12222 ("python-cython" ,python-cython)))
12223 (inputs
12224 `(("gstreamer" ,gstreamer)
12225 ("mesa" ,mesa)
12226 ("sdl-union"
12227 ,(sdl-union (list sdl2 sdl2-image sdl2-mixer sdl2-ttf)))))
12228 (home-page "http://kivy.org")
12229 (synopsis
12230 "Multitouch application framework")
12231 (description
12232 "A software library for rapid development of
12233 hardware-accelerated multitouch applications.")
12234 (license license:expat)))
12235
12236 (define-public python2-kivy
12237 (package-with-python2 python-kivy))
12238
12239 (define-public python-kivy-next
12240 (let ((commit "a988c5e7a47da56263ff39514264a3de516ef2fe")
12241 (revision "1"))
12242 (package (inherit python-kivy)
12243 (name "python-kivy-next")
12244 (version (string-append "1.9.1-" revision "."
12245 (string-take commit 7)))
12246 (source
12247 (origin
12248 (method git-fetch)
12249 (uri (git-reference
12250 (url "https://github.com/kivy/kivy")
12251 (commit commit)))
12252 (file-name (string-append name "-" version "-checkout"))
12253 (sha256
12254 (base32
12255 "0jk92b4a8l7blkvkgkjihk171s0dfnq582cckff5srwc8kal5m0p")))))))
12256
12257 (define-public python2-kivy-next
12258 (package-with-python2 python-kivy-next))
12259
12260 (define-public python-binaryornot
12261 (package
12262 (name "python-binaryornot")
12263 (version "0.4.0")
12264 (source (origin
12265 (method url-fetch)
12266 (uri (pypi-uri "binaryornot" version))
12267 (sha256
12268 (base32
12269 "1j4f51dxic39mdwf6alj7gd769wy6mhk916v031wjali51xkh3xb"))))
12270 (build-system python-build-system)
12271 (propagated-inputs
12272 `(("python-chardet" ,python-chardet)
12273 ("python-hypothesis" ,python-hypothesis)))
12274 (home-page "https://github.com/audreyr/binaryornot")
12275 (synopsis "Package to check if a file is binary or text")
12276 (description "Ultra-lightweight pure Python package to check if a file is
12277 binary or text.")
12278 (license license:bsd-3)
12279 (properties `((python2-variant . ,(delay python2-binaryornot))))))
12280
12281 (define-public python2-binaryornot
12282 (let ((base (package-with-python2 (strip-python2-variant python-binaryornot))))
12283 (package (inherit base)
12284 (propagated-inputs
12285 `(("python2-enum34" ,python2-enum34)
12286 ,@(package-propagated-inputs base))))))
12287
12288 (define-public python-nltk
12289 (package
12290 (name "python-nltk")
12291 (version "3.2.1")
12292 (source (origin
12293 (method url-fetch)
12294 (uri (pypi-uri "nltk" version))
12295 (sha256
12296 (base32
12297 "0skxbhnymwlspjkzga0f7x1hg3y50fwpfghs8g8k7fh6f4nknlym"))))
12298 (build-system python-build-system)
12299 (arguments
12300 '(;; The tests require some extra resources to be downloaded.
12301 ;; TODO Try packaging these resources.
12302 #:tests? #f))
12303 (home-page "http://nltk.org/")
12304 (synopsis "Natural Language Toolkit")
12305 (description "It provides interfaces to over 50 corpora and lexical
12306 resources such as WordNet, along with a suite of text processing libraries
12307 for classification, tokenization, stemming, tagging, parsing, and semantic
12308 reasoning, wrappers for natural language processing libraries.")
12309 (license license:asl2.0)))
12310
12311 (define-public python2-nltk
12312 (package-with-python2 python-nltk))
12313
12314 (define-public python-pymongo
12315 (package
12316 (name "python-pymongo")
12317 (version "3.3.0")
12318 (source (origin
12319 (method url-fetch)
12320 (uri (pypi-uri "pymongo" version))
12321 (sha256
12322 (base32
12323 "07mra6w86wjqy4lx5fvimidjhhfzd562gfjn8grsnbv2q8pk0i9x"))))
12324 (build-system python-build-system)
12325 (propagated-inputs
12326 `(("python-certifi" ,python-certifi)))
12327 (home-page "https://github.com/mongodb/mongo-python-driver")
12328 (synopsis "Python driver for MongoDB")
12329 (description "Python driver for MongoDB.")
12330 (license license:asl2.0)))
12331
12332 (define-public python2-pymongo
12333 (package-with-python2 python-pymongo))
12334
12335 (define-public python-sh
12336 (package
12337 (name "python-sh")
12338 (version "1.11")
12339 (source (origin
12340 (method url-fetch)
12341 (uri (pypi-uri "sh" version))
12342 (sha256
12343 (base32
12344 "192r0mpv6dmkysjzhc43ddffiwb5g7c76bgr1mb1z2xz9awbj3sr"))))
12345 (build-system python-build-system)
12346 (arguments
12347 `(#:tests? #f)) ; no tests
12348 (home-page "https://github.com/amoffat/sh")
12349 (synopsis "Python subprocess interface")
12350 (description "Abstracts process invocation by providing a function
12351 interface for programs.")
12352 (license license:expat)))
12353
12354 (define-public python2-sh
12355 (package-with-python2 python-sh))
12356
12357 (define-public python-consul
12358 (package
12359 (name "python-consul")
12360 (version "0.6.1")
12361 (source
12362 (origin
12363 (method url-fetch)
12364 (uri (pypi-uri "python-consul" version))
12365 (sha256
12366 (base32
12367 "0rfyxcy4cr3x848vhx876ifalxd5ghq6l5x813m49h4vq2d4jiq8"))))
12368 (build-system python-build-system)
12369 (native-inputs
12370 `(("python-pytest" ,python-pytest)))
12371 (propagated-inputs
12372 `(("python-requests" ,python-requests)
12373 ("python-six" ,python-six)))
12374 (home-page "https://github.com/cablehead/python-consul")
12375 (synopsis "Python client for Consul")
12376 (description
12377 "Python client for @url{http://www.consul.io/,Consul}, a tool for service
12378 discovery, monitoring and configuration.")
12379 (license license:expat)))
12380
12381 (define-public python2-consul
12382 (package-with-python2 python-consul))
12383
12384 (define-public python-schematics
12385 (package
12386 (name "python-schematics")
12387 (version "1.1.1")
12388 (source
12389 (origin
12390 (method url-fetch)
12391 (uri (string-append
12392 "https://github.com/schematics/schematics/archive/v" version ".tar.gz"))
12393 (file-name (string-append name "-" version ".tar.gz"))
12394 (sha256
12395 (base32
12396 "19v1i69bf3bzarfxmbv0v6ivpcn758x3shvbiy9l2hy0lvqwnp6l"))))
12397 (build-system python-build-system)
12398 (propagated-inputs
12399 `(("python-six" ,python-six)))
12400 (arguments
12401 `(#:tests? #f)) ; requires a bunch of not very nice packages with fixed
12402 ; version requirements (eg python-coveralls)
12403 (home-page "https://github.com/schematics/schematics")
12404 (synopsis "Python Data Structures for Humans")
12405 (description "Python Data Structures for Humans.")
12406 (license license:bsd-3)))
12407
12408 (define-public python2-schematics
12409 (package-with-python2 python-schematics))
12410
12411 (define-public python-publicsuffix
12412 (package
12413 (name "python-publicsuffix")
12414 (version "1.1.0")
12415 (source (origin
12416 (method url-fetch)
12417 (uri (pypi-uri "publicsuffix" version))
12418 (sha256
12419 (base32
12420 "1adx520249z2cy7ykwjr1k190mn2888wqn9jf8qm27ly4qymjxxf"))))
12421 (build-system python-build-system)
12422 (arguments
12423 `(#:tests? #f)) ; tests use the internet
12424 (home-page "https://www.tablix.org/~avian/git/publicsuffix.git")
12425 (synopsis "Get suffix for a domain name")
12426 (description "Get a public suffix for a domain name using the Public Suffix
12427 List.")
12428 (license license:expat)))
12429
12430 (define-public python2-publicsuffix
12431 (package-with-python2 python-publicsuffix))
12432
12433 (define-public python-publicsuffix2
12434 (package
12435 (name "python-publicsuffix2")
12436 (version "2.20160818")
12437 (source
12438 (origin
12439 (method url-fetch)
12440 (uri (pypi-uri "publicsuffix2" version ".tar.bz2"))
12441 (sha256
12442 (base32
12443 "1bb55yka9vkn7i6y1kjzxa516kh6v4gsrxa90w5wdz5p5n968r68"))))
12444 (build-system python-build-system)
12445 (arguments
12446 '(#:tests? #f)) ; The test suite requires network access.
12447 (home-page "https://github.com/pombredanne/python-publicsuffix2")
12448 (synopsis "Get a public suffix for a domain name using the Public Suffix List")
12449 (description "Get a public suffix for a domain name using the Public Suffix
12450 List. Forked from and using the same API as the publicsuffix package.")
12451 (license (list license:expat license:mpl2.0))))
12452
12453 (define-public python2-publicsuffix2
12454 (package-with-python2 python-publicsuffix2))
12455
12456 (define-public python-url
12457 (package
12458 (name "python-url")
12459 (version "0.2.0")
12460 (source (origin
12461 (method url-fetch)
12462 (uri (pypi-uri "url" version))
12463 (sha256
12464 (base32
12465 "0v879yadcz9qxfl41ak6wkga1kimp9cflla9ddz03hjjvgkqy5ki"))))
12466 (build-system python-build-system)
12467 (propagated-inputs
12468 `(("python-publicsuffix" ,python-publicsuffix)))
12469 (native-inputs
12470 `(("python-coverage" ,python-coverage)
12471 ("python-nose" ,python-nose)))
12472 (arguments
12473 `(#:tests? #f)) ; FIXME: tests fail with "ImportError: No module named 'tests'"
12474 (home-page "https://github.com/seomoz/url-py")
12475 (synopsis "URL Parsing")
12476 (description "Library for parsing urls.")
12477 (license license:expat)
12478 (properties `((python2-variant . ,(delay python2-url))))))
12479
12480 (define-public python2-url
12481 (let ((base (package-with-python2 (strip-python2-variant python-url))))
12482 (package (inherit base)
12483 (propagated-inputs
12484 `(("python2-publicsuffix" ,python2-publicsuffix))))))
12485
12486 (define-public python-freezegun
12487 (package
12488 (name "python-freezegun")
12489 (version "0.3.8")
12490 (source
12491 (origin
12492 (method url-fetch)
12493 (uri (pypi-uri "freezegun" version))
12494 (sha256
12495 (base32
12496 "1sf38d3ibv1jhhvr52x7dhrsiyqk1hm165dfv8w8wh0fhmgxg151"))))
12497 (build-system python-build-system)
12498 (native-inputs
12499 `(("python-mock" ,python-mock)
12500 ("python-nose" ,python-nose)
12501 ("python-coverage" ,python-coverage)))
12502 (propagated-inputs
12503 `(("python-six" ,python-six)
12504 ("python-dateutil" ,python-dateutil)))
12505 (arguments
12506 `(#:phases (modify-phases %standard-phases
12507 ;; The tests are normally executed via `make test`, but the PyPi
12508 ;; package does not include the Makefile.
12509 (replace 'check
12510 (lambda _
12511 (zero? (system* "nosetests" "./tests/")))))))
12512 (home-page "https://github.com/spulec/freezegun")
12513 (synopsis "Test utility for mocking the datetime module")
12514 (description
12515 "FreezeGun is a library that allows your python tests to travel through
12516 time by mocking the datetime module.")
12517 (license license:asl2.0)))
12518
12519 (define-public python2-freezegun
12520 (package-with-python2 python-freezegun))
12521
12522
12523 (define-public python-odfpy
12524 (package
12525 (name "python-odfpy")
12526 (version "1.3.3")
12527 (source (origin
12528 (method url-fetch)
12529 (uri (pypi-uri "odfpy" version))
12530 (sha256
12531 (base32
12532 "1a6ms0w9zfhhkqhvrnynwwbxrivw6hgjc0s5k7j06npc7rq0blxw"))))
12533 (arguments
12534 `(#:modules ((srfi srfi-1)
12535 (guix build python-build-system)
12536 (guix build utils))
12537 #:phases
12538 (modify-phases %standard-phases
12539 (replace 'check
12540 ;; The test runner invokes python2 and python3 for test*.py.
12541 ;; To avoid having both in inputs, we replicate it here.
12542 (lambda _
12543 (every (lambda (test-file)
12544 (zero? (system* "python" test-file)))
12545 (find-files "tests" "^test.*\\.py$")))))))
12546 (build-system python-build-system)
12547 (home-page "https://github.com/eea/odfpy")
12548 (synopsis "Python API and tools to manipulate OpenDocument files")
12549 (description "Collection of libraries and utility programs written in
12550 Python to manipulate OpenDocument 1.2 files.")
12551 (license
12552 ;; The software is mainly dual GPL2+ and ASL2.0, but includes a
12553 ;; number of files with other licenses.
12554 (list license:gpl2+ license:asl2.0 license:lgpl2.1+ license:cc-by-sa3.0))))
12555
12556 (define-public python2-odfpy
12557 (package-with-python2 python-odfpy))
12558
12559 (define-public python-cachecontrol
12560 (package
12561 (name "python-cachecontrol")
12562 (version "0.11.6")
12563 (source
12564 (origin
12565 (method url-fetch)
12566 ;; Pypi does not have tests.
12567 (uri (string-append
12568 "https://github.com/ionrock/cachecontrol/archive/v"
12569 version ".tar.gz"))
12570 (file-name (string-append name "-" version ".tar.gz"))
12571 (sha256
12572 (base32
12573 "0yj60d0f69a2l8p7y86k4zhzzm6rnxpq74sfl240pry9l0lfw2vw"))))
12574 (build-system python-build-system)
12575 (arguments
12576 `(#:phases
12577 (modify-phases %standard-phases
12578 (replace 'check
12579 (lambda _
12580 ;; Drop test that requires internet access.
12581 (delete-file "tests/test_regressions.py")
12582 (setenv "PYTHONPATH"
12583 (string-append (getcwd) "/build/lib:"
12584 (getenv "PYTHONPATH")))
12585 (zero? (system* "py.test" "-vv")))))))
12586 (native-inputs
12587 `(("python-pytest" ,python-pytest)
12588 ("python-redis" ,python-redis)
12589 ("python-webtest" ,python-webtest)
12590 ("python-mock" ,python-mock)))
12591 (propagated-inputs
12592 `(("python-requests" ,python-requests)
12593 ("python-lockfile" ,python-lockfile)))
12594 (home-page "https://github.com/ionrock/cachecontrol")
12595 (synopsis "The httplib2 caching algorithms for use with requests")
12596 (description "CacheControl is a port of the caching algorithms in
12597 @code{httplib2} for use with @code{requests} session objects.")
12598 (license license:asl2.0)))
12599
12600 (define-public python2-cachecontrol
12601 (package-with-python2 python-cachecontrol))
12602
12603 (define-public python-lit
12604 (package
12605 (name "python-lit")
12606 (version "0.5.0")
12607 (source
12608 (origin
12609 (method url-fetch)
12610 (uri (pypi-uri "lit" version))
12611 (sha256
12612 (base32
12613 "135m2b9cwih85g66rjggavck328z7lj37srgpq3jxszbg0g2b91y"))))
12614 (build-system python-build-system)
12615 (home-page "http://llvm.org/")
12616 (synopsis "LLVM Software Testing Tool")
12617 (description "@code{lit} is a portable tool for executing LLVM and Clang
12618 style test suites, summarizing their results, and providing indication of
12619 failures.")
12620 (license license:ncsa)))
12621
12622 (define-public python2-lit
12623 (package-with-python2 python-lit))
12624
12625 (define-public python-pytest-pep8
12626 (package
12627 (name "python-pytest-pep8")
12628 (version "1.0.6")
12629 (source (origin
12630 (method url-fetch)
12631 (uri (pypi-uri "pytest-pep8" version))
12632 (sha256
12633 (base32
12634 "06032agzhw1i9d9qlhfblnl3dw5hcyxhagn7b120zhrszbjzfbh3"))))
12635 (build-system python-build-system)
12636 (arguments
12637 `(#:tests? #f)) ; Fails with recent pytest and pep8. See upstream issues #8 and #12.
12638 (native-inputs
12639 `(("python-pytest" ,python-pytest)))
12640 (propagated-inputs
12641 `(("python-pep8" ,python-pep8)))
12642 (home-page "https://bitbucket.org/pytest-dev/pytest-pep8")
12643 (synopsis "Py.test plugin to check PEP8 requirements")
12644 (description "Pytest plugin for checking PEP8 compliance.")
12645 (license license:expat)))
12646
12647 (define-public python2-pytest-pep8
12648 (package-with-python2 python-pytest-pep8))
12649
12650 (define-public python-pytest-flakes
12651 (package
12652 (name "python-pytest-flakes")
12653 (version "1.0.1")
12654 (source (origin
12655 (method url-fetch)
12656 (uri (pypi-uri "pytest-flakes" version))
12657 (sha256
12658 (base32
12659 "0flag3n33kbhyjrhzmq990rvg4yb8hhhl0i48q9hw0ll89jp28lw"))))
12660 (build-system python-build-system)
12661 (arguments
12662 `(#:phases
12663 (modify-phases %standard-phases
12664 (delete 'check)
12665 (add-after 'install 'check
12666 (lambda* (#:key outputs inputs #:allow-other-keys)
12667 ;; It's easier to run tests after install.
12668 ;; Make installed package available for running the tests
12669 (add-installed-pythonpath inputs outputs)
12670 (zero? (system* "py.test" "-vv")))))))
12671 (native-inputs
12672 `(("python-coverage" ,python-coverage)
12673 ("python-pytest" ,python-pytest)
12674 ("python-pytest-cache" ,python-pytest-cache)
12675 ("python-pytest-pep8" ,python-pytest-pep8)))
12676 (propagated-inputs
12677 `(("python-pyflakes" ,python-pyflakes)))
12678 (home-page "https://github.com/fschulze/pytest-flakes")
12679 (synopsis "Py.test plugin to check source code with pyflakes")
12680 (description "Pytest plugin for checking Python source code with pyflakes.")
12681 (license license:expat)))
12682
12683 (define-public python2-pytest-flakes
12684 (package-with-python2 python-pytest-flakes))
12685
12686 (define-public python-natsort
12687 (package
12688 (name "python-natsort")
12689 (version "5.0.2")
12690 (source (origin
12691 (method url-fetch)
12692 (uri (pypi-uri "natsort" version))
12693 (sha256
12694 (base32
12695 "0bh6j0l8iapjnsgg3bs6q075cnzjl6zw1vlgqyv3qrygm2cxypkn"))))
12696 (build-system python-build-system)
12697 (arguments
12698 `(#:phases
12699 (modify-phases %standard-phases
12700 (add-before 'check 'set-cachedir
12701 ;; Tests require write access to $HOME by default
12702 (lambda _ (setenv "PYTHON_EGG_CACHE" "/tmp") #t)))))
12703 (native-inputs
12704 `(("python-hypothesis" ,python-hypothesis)
12705 ("python-pytest-cache" ,python-pytest-cache)
12706 ("python-pytest-cov" ,python-pytest-cov)
12707 ("python-pytest-flakes" ,python-pytest-flakes)
12708 ("python-pytest-pep8" ,python-pytest-pep8)))
12709 (propagated-inputs ; TODO: Add python-fastnumbers.
12710 `(("python-pyicu" ,python-pyicu)))
12711 (home-page "https://github.com/SethMMorton/natsort")
12712 (synopsis "Natural sorting for python and shell")
12713 (description
12714 "Natsort lets you apply natural sorting on lists instead of
12715 lexicographical. If you use the built-in @code{sorted} method in python
12716 on a list such as @code{['a20', 'a9', 'a1', 'a4', 'a10']}, it would be
12717 returned as @code{['a1', 'a10', 'a20', 'a4', 'a9']}. Natsort provides a
12718 function @code{natsorted} that identifies numbers and sorts them separately
12719 from strings. It can also sort version numbers, real numbers, mixed types
12720 and more, and comes with a shell command @command{natsort} that exposes this
12721 functionality in the command line.")
12722 (license license:expat)
12723 (properties `((python2-variant . ,(delay python2-natsort))))))
12724
12725 (define-public python2-natsort
12726 (let ((base (package-with-python2 (strip-python2-variant python-natsort))))
12727 (package (inherit base)
12728 (native-inputs
12729 `(("python2-pathlib" ,python2-pathlib)
12730 ("python2-mock" ,python2-mock)
12731 ("python2-enum34" ,python2-enum34)
12732 ,@(package-native-inputs base))))))
12733
12734 (define-public python-glances
12735 (package
12736 (name "python-glances")
12737 (version "2.7.1")
12738 (source
12739 (origin
12740 (method url-fetch)
12741 (uri (pypi-uri "Glances" version))
12742 (sha256
12743 (base32
12744 "11jbq40g8alsbirnd4kiagznqg270247i0m8qhi48ldf2i5xppxg"))))
12745 (build-system python-build-system)
12746 (propagated-inputs
12747 `(("python-psutil" ,python-psutil)))
12748 (home-page
12749 "https://github.com/nicolargo/glances")
12750 (synopsis
12751 "A cross-platform curses-based monitoring tool")
12752 (description
12753 "Glances is a curses-based monitoring tool for a wide variety of platforms.
12754 Glances uses the PsUtil library to get information from your system. It monitors
12755 CPU, load, memory, network bandwidth, disk I/O, disk use, and more.")
12756 (license license:lgpl3+)))
12757
12758 (define-public python2-glances
12759 (package-with-python2 python-glances))
12760
12761 (define-public python-graphql-core
12762 (package
12763 (name "python-graphql-core")
12764 (version "0.5.3")
12765 (source
12766 (origin
12767 (method url-fetch)
12768 (uri (pypi-uri "graphql-core" version))
12769 (sha256
12770 (base32
12771 "0rsaarx2sj4xnw9966rhh4haiqaapm4lm2mfqm48ywd51j5vh1a0"))))
12772 (build-system python-build-system)
12773 (arguments
12774 `(#:tests? #f ; Tests require the unpackaged pytest-benchmark.
12775 #:phases
12776 (modify-phases %standard-phases
12777 (add-after 'unpack 'patch-hardcoded-version
12778 (lambda _ (substitute*
12779 "setup.py"
12780 (("'gevent==1.1rc1'") "'gevent'"))
12781 #t)))))
12782 (native-inputs
12783 `(("python-gevent" ,python-gevent)
12784 ("python-mock" ,python-mock)
12785 ("python-pytest-mock" ,python-pytest-mock)))
12786 (propagated-inputs
12787 `(("python-promise" ,python-promise)
12788 ("python-six" ,python-six)))
12789 (home-page "https://github.com/graphql-python/graphql-core")
12790 (synopsis "GraphQL implementation for Python")
12791 (description
12792 "GraphQL implementation for Python. GraphQL is a data query language and
12793 runtime designed and used to request and deliver data to mobile and web apps.
12794 This library is a port of @url{https://github.com/graphql/graphql-js,graphql-js}
12795 to Python.")
12796 (license license:expat)))
12797
12798 (define-public python2-graphql-core
12799 (package-with-python2 python-graphql-core))
12800
12801 (define-public python-graphql-relay
12802 (package
12803 (name "python-graphql-relay")
12804 (version "0.4.5")
12805 (source
12806 (origin
12807 (method url-fetch)
12808 (uri (pypi-uri "graphql-relay" version))
12809 (sha256
12810 (base32
12811 "1nv5dxcj59zv31qvl8bd142njmxcmymny2dz3br1l2cpbljbf5i7"))))
12812 (build-system python-build-system)
12813 (native-inputs
12814 `(("python-pytest" ,python-pytest)))
12815 (propagated-inputs
12816 `(("python-graphql-core" ,python-graphql-core)
12817 ("python-promise" ,python-promise)
12818 ("python-six" ,python-six)))
12819 (home-page "https://github.com/graphql-python/graphql-relay-py")
12820 (synopsis "Relay implementation for Python")
12821 (description
12822 "This is a library to allow the easy creation of Relay-compliant servers
12823 using the GraphQL Python reference implementation of a GraphQL server. It
12824 should be noted that the code is a exact port of the original
12825 @url{https://github.com/graphql/graphql-relay-js,graphql-relay js implementation}
12826 from Facebook.")
12827 (license license:expat)))
12828
12829 (define-public python2-graphql-relay
12830 (package-with-python2 python-graphql-relay))
12831
12832 (define-public python-graphene
12833 (package
12834 (name "python-graphene")
12835 (version "0.10.2")
12836 (source
12837 (origin
12838 (method url-fetch)
12839 (uri (pypi-uri "graphene" version))
12840 (sha256
12841 (base32
12842 "09zhac7igh9ixdz0ay6csy35b40l1jwbf2wrbxmgxwfhy51iy06q"))))
12843 (build-system python-build-system)
12844 (native-inputs
12845 `(("python-django-filter" ,python-django-filter)
12846 ("python-mock" ,python-mock)
12847 ("python-psycopg2" ,python-psycopg2)
12848 ("python-pytest-django" ,python-pytest-django)
12849 ("python-sqlalchemy-utils" ,python-sqlalchemy-utils)))
12850 (propagated-inputs
12851 `(("python-graphql-core" ,python-graphql-core)
12852 ("python-graphql-relay" ,python-graphql-relay)
12853 ("python-iso8601" ,python-iso8601)
12854 ("python-promise" ,python-promise)
12855 ("python-six" ,python-six)))
12856 (home-page "http://graphene-python.org/")
12857 (synopsis "GraphQL Framework for Python")
12858 (description
12859 "Graphene is a Python library for building GraphQL schemas/types.
12860 A GraphQL schema describes your data model, and provides a GraphQL server
12861 with an associated set of resolve methods that know how to fetch data.")
12862 (properties `((python2-variant . ,(delay python2-graphene))))
12863 (license license:expat)))
12864
12865 (define-public python2-graphene
12866 (let ((base (package-with-python2
12867 (strip-python2-variant python-graphene))))
12868 (package (inherit base)
12869 (native-inputs
12870 `(("python2-sqlalchemy" ,python2-sqlalchemy)
12871 ,@(package-native-inputs base))))))
12872
12873 (define-public python-nautilus
12874 (package
12875 (name "python-nautilus")
12876 (version "0.4.9")
12877 (source
12878 (origin
12879 (method url-fetch)
12880 (uri (pypi-uri "nautilus" version))
12881 (sha256
12882 (base32
12883 "01hwzjc1zshk4vvxrcghm398fpy4jls66dyz06g07mrwqif8878p"))))
12884 (build-system python-build-system)
12885 (arguments `(#:tests? #f)) ; fails to import test modules
12886 (propagated-inputs
12887 `(("python-bcrypt" ,python-bcrypt)
12888 ("python-click" ,python-click)
12889 ("python-consul" ,python-consul)
12890 ("python-graphene" ,python-graphene)
12891 ("python-jinja2" ,python-jinja2)
12892 ("python-peewee" ,python-peewee)
12893 ("python-pika" ,python-pika)
12894 ("python-tornado" ,python-tornado)
12895 ("python-wtforms" ,python-wtforms)))
12896 (native-inputs
12897 `(("python-nose2" ,python-nose2)))
12898 (home-page "https://github.com/AlecAivazis/nautilus")
12899 (synopsis "Library for creating microservice applications")
12900 (description
12901 "Nautilus is a framework for flux based microservices that looks to
12902 provide extendible implementations of common aspects of a cloud so that you can
12903 focus on building massively scalable web applications.")
12904 (license license:expat)))
12905
12906 (define-public python-snowballstemmer
12907 (package
12908 (name "python-snowballstemmer")
12909 (version "1.2.1")
12910 (source (origin
12911 (method url-fetch)
12912 (uri (pypi-uri "snowballstemmer" version))
12913 (sha256
12914 (base32
12915 "0a0idq4y5frv7qsg2x62jd7rd272749xk4x99misf5rcifk2d7wi"))))
12916 (build-system python-build-system)
12917 (arguments
12918 `(;; No tests exist
12919 #:tests? #f))
12920 (home-page "https://github.com/shibukawa/snowball_py")
12921 (synopsis "Snowball stemming library collection for Python")
12922 (description "This package provides 16 word stemmer algorithms generated
12923 from Snowball algorithms. It includes the 15 original ones plus the Poerter
12924 English stemmer.")
12925 (license license:bsd-3)))
12926
12927 (define-public python2-snowballstemmer
12928 (package-with-python2 python-snowballstemmer))
12929
12930 (define-public python-sphinx-cloud-sptheme
12931 (package
12932 (name "python-sphinx-cloud-sptheme")
12933 (version "1.8.0")
12934 (source (origin
12935 (method url-fetch)
12936 (uri (pypi-uri "cloud_sptheme" version))
12937 (sha256
12938 (base32
12939 "1dniqb6a39yh786f86c4jn666rwnyi1jvzn4616zhcchb7sfdshd"))))
12940 (build-system python-build-system)
12941 ;; FIXME: The 'pypi' release archive does not contain tests.
12942 (arguments '(#:tests? #f))
12943 (native-inputs
12944 `(("python-sphinx" ,python-sphinx)))
12945 (home-page "https://bitbucket.org/ecollins/cloud_sptheme")
12946 (synopsis "'Cloud' theme for Sphinx documenter")
12947 (description "This package contains the \"Cloud\" theme for Sphinx and some
12948 related extensions.")
12949 (license license:bsd-3)))
12950
12951 (define-public python2-sphinx-cloud-sptheme
12952 (package-with-python2 python-sphinx-cloud-sptheme))
12953
12954 (define-public python-sphinx-alabaster-theme
12955 (package
12956 (name "python-sphinx-alabaster-theme")
12957 (version "0.7.9")
12958 (source (origin
12959 (method url-fetch)
12960 (uri (pypi-uri "alabaster" version))
12961 (sha256
12962 (base32
12963 "027anxzcb951gjlcc43y3rbn9qrw36d16vj9wd2smv5410xx9bs7"))))
12964 (build-system python-build-system)
12965 (propagated-inputs
12966 `(("python-pygments" ,python-pygments)))
12967 (home-page "https://alabaster.readthedocs.io/")
12968 (synopsis "Configurable sidebar-enabled Sphinx theme")
12969 (description "Alabaster is a visually (c)lean, responsive, configurable
12970 theme for the Sphinx documentation system. It's the default theme of Sphinx.")
12971 (license license:bsd-3)))
12972
12973 (define-public python2-sphinx-alabaster-theme
12974 (package-with-python2 python-sphinx-alabaster-theme))
12975
12976 (define-public python-betamax
12977 (package
12978 (name "python-betamax")
12979 (version "0.8.0")
12980 (source
12981 (origin
12982 (method url-fetch)
12983 (uri (pypi-uri "betamax" version))
12984 (sha256
12985 (base32
12986 "18f8v5gng3j773jlbbzx4rg1i4y2zw3m2l1zpmbvp8bh5a2q1i42"))))
12987 (build-system python-build-system)
12988 (arguments
12989 '(;; Many tests fail because they require networking.
12990 #:tests? #f))
12991 (propagated-inputs
12992 `(("python-requests" ,python-requests)))
12993 (home-page "https://github.com/sigmavirus24/betamax")
12994 (synopsis "Record HTTP interactions with python-requests")
12995 (description "Betamax will record your test suite's HTTP interactions and
12996 replay them during future tests. It is designed to work with python-requests.")
12997 (license license:expat)))
12998
12999 (define-public python2-betamax
13000 (package-with-python2 python-betamax))
13001
13002 (define-public python-s3transfer
13003 (package
13004 (name "python-s3transfer")
13005 (version "0.1.10")
13006 (source (origin
13007 (method url-fetch)
13008 (uri (pypi-uri "s3transfer" version))
13009 (sha256
13010 (base32
13011 "1h8g9bknvxflxkpbnxyfxmk8pvgykbbk9ljdvhqh6z4vjc2926ms"))))
13012 (build-system python-build-system)
13013 (arguments
13014 `(#:phases
13015 (modify-phases %standard-phases
13016 (replace 'check
13017 (lambda _
13018 ;; 7 of the 'integration' tests require network access or login
13019 ;; credentials.
13020 (zero? (system* "nosetests" "--exclude=integration")))))))
13021 (native-inputs
13022 `(("python-docutils" ,python-docutils)
13023 ("python-mock" ,python-mock)
13024 ("python-nose" ,python-nose)))
13025 (propagated-inputs
13026 `(("python-botocore" ,python-botocore)))
13027 (synopsis "Amazon S3 Transfer Manager")
13028 (description "S3transfer is a Python library for managing Amazon S3
13029 transfers.")
13030 (home-page "https://github.com/boto/s3transfer")
13031 (license license:asl2.0)
13032 (properties `((python2-variant . ,(delay python2-s3transfer))))))
13033
13034 (define-public python2-s3transfer
13035 (let ((base (package-with-python2 (strip-python2-variant python-s3transfer))))
13036 (package
13037 (inherit base)
13038 (native-inputs
13039 `(("python2-futures" ,python2-futures)
13040 ,@(package-native-inputs base))))))
13041
13042 (define-public python-setproctitle
13043 (package
13044 (name "python-setproctitle")
13045 (version "1.1.10")
13046 (source
13047 (origin
13048 (method url-fetch)
13049 (uri (pypi-uri "setproctitle" version))
13050 (sha256
13051 (base32
13052 "163kplw9dcrw0lffq1bvli5yws3rngpnvrxrzdw89pbphjjvg0v2"))))
13053 (build-system python-build-system)
13054 (arguments
13055 '(#:phases
13056 (modify-phases %standard-phases
13057 (add-before 'check 'patch-Makefile
13058 ;; Stricly this is only required for the python2 variant.
13059 ;; But adding a phase in an inherited package seems to be
13060 ;; cumbersum. So we patch even for python3.
13061 (lambda _
13062 (let ((nose (assoc-ref %build-inputs "python2-nose")))
13063 (when nose
13064 (substitute* "Makefile"
13065 (("\\$\\(PYTHON\\) [^ ]which nosetests[^ ] ")
13066 (string-append nose "/bin/nosetests "))))
13067 #t)))
13068 (replace 'check
13069 (lambda _
13070 (setenv "PYTHON" (or (which "python3") (which "python")))
13071 (setenv "PYCONFIG" (or (which "python3-config")
13072 (which "python-config")))
13073 (setenv "CC" "gcc")
13074 ;; No need to extend PYTHONPATH to find the built package, since
13075 ;; the Makefile will build anyway
13076 (zero? (system* "make" "check")))))))
13077 (native-inputs
13078 `(("procps" ,procps))) ; required for tests
13079 (home-page
13080 "https://github.com/dvarrazzo/py-setproctitle")
13081 (synopsis
13082 "Setproctitle implementation for Python to customize the process title")
13083 (description "The library allows a process to change its title (as displayed
13084 by system tools such as ps and top).
13085
13086 Changing the title is mostly useful in multi-process systems, for
13087 example when a master process is forked: changing the children's title
13088 allows to identify the task each process is busy with. The technique
13089 is used by PostgreSQL and the OpenSSH Server for example.")
13090 (license license:bsd-3)
13091 (properties `((python2-variant . ,(delay python2-setproctitle))))))
13092
13093 (define-public python2-setproctitle
13094 (let ((base (package-with-python2
13095 (strip-python2-variant python-setproctitle))))
13096 (package
13097 (inherit base)
13098 (native-inputs `(("python2-nose" ,python2-nose)
13099 ,@(package-native-inputs base))))))
13100
13101 (define-public python-validictory
13102 (package
13103 (name "python-validictory")
13104 (version "1.0.1")
13105 (source
13106 (origin
13107 (method url-fetch)
13108 (uri (pypi-uri "validictory" version))
13109 (sha256
13110 (base32
13111 "1zf1g9sw47xzp5f80bd94pb42j9yqv82lcrgcvdwr6nkaphfi37q"))))
13112 (build-system python-build-system)
13113 (arguments
13114 '(#:phases
13115 (modify-phases %standard-phases
13116 (add-after 'unpack 'bootstrap
13117 ;; Move the tests out of the package directory to avoid
13118 ;; packaging them.
13119 (lambda* _
13120 (rename-file "validictory/tests" "tests")
13121 (delete-file "tests/__init__.py")))
13122 (replace 'check
13123 (lambda _
13124 ;; Extend PYTHONPATH so the built package will be found.
13125 (setenv "PYTHONPATH"
13126 (string-append (getcwd) "/build/lib:"
13127 (getenv "PYTHONPATH")))
13128 (zero? (system* "py.test" "-vv" )))))))
13129 (native-inputs
13130 `(("python-pytest" ,python-pytest)))
13131 (home-page
13132 "https://github.com/jamesturk/validictory")
13133 (synopsis "General purpose Python data validator")
13134 (description "It allows validation of arbitrary Python data structures.
13135
13136 The schema format is based on the JSON Schema
13137 proposal (http://json-schema.org), so combined with json the library is also
13138 useful as a validator for JSON data.")
13139 (license license:expat)))
13140
13141 (define-public python2-validictory
13142 (package-with-python2 python-validictory))
13143
13144 (define-public python-aniso8601
13145 (package
13146 (name "python-aniso8601")
13147 (version "1.1.0")
13148 (source
13149 (origin
13150 (method url-fetch)
13151 (uri (pypi-uri "aniso8601" version))
13152 (sha256
13153 (base32
13154 "1k5mjg9iqbjfslb5prrsfz7dhlvi6s35p1jxq8dm87w1b7dn5i2g"))))
13155 (build-system python-build-system)
13156 (propagated-inputs
13157 `(("python-dateutil" ,python-dateutil)))
13158 (home-page
13159 "https://bitbucket.org/nielsenb/aniso8601")
13160 (synopsis
13161 "Python library for parsing ISO 8601 strings")
13162 (description
13163 "This package contains a library for parsing ISO 8601 datetime strings.")
13164 (license license:bsd-3)))
13165
13166 (define-public python-flask-restful
13167 (package
13168 (name "python-flask-restful")
13169 (version "0.3.5")
13170 (source
13171 (origin
13172 (method url-fetch)
13173 (uri (pypi-uri "Flask-RESTful" version))
13174 (sha256
13175 (base32
13176 "0hjcmdb56b7z4bkw848lxfkyrpnkwzmqn2dgnlv12mwvjpzsxr6c"))))
13177 (build-system python-build-system)
13178 (propagated-inputs
13179 `(("python-aniso8601" ,python-aniso8601)
13180 ("python-flask" ,python-flask)
13181 ("python-pycrypto" ,python-pycrypto)
13182 ("python-pytz" ,python-pytz)))
13183 (native-inputs
13184 `(;; Optional dependency of Flask. Tests need it.
13185 ("python-blinker" ,python-blinker)
13186 ("python-mock" ,python-mock) ; For tests
13187 ("python-nose" ,python-nose) ; For tests
13188 ("python-sphinx" ,python-sphinx)))
13189 (home-page
13190 "https://www.github.com/flask-restful/flask-restful/")
13191 (synopsis
13192 "Flask module for creating REST APIs")
13193 (description
13194 "This package contains a Flask module for creating REST APIs.")
13195 (license license:bsd-3)))
13196
13197 (define-public python-flask-basicauth
13198 (package
13199 (name "python-flask-basicauth")
13200 (version "0.2.0")
13201 (source
13202 (origin
13203 (method url-fetch)
13204 (uri (pypi-uri "Flask-BasicAuth" version))
13205 (sha256
13206 (base32
13207 "1zq1spkjr4sjdnalpp8wl242kdqyk6fhbnhr8hi4r4f0km4bspnz"))))
13208 (build-system python-build-system)
13209 (propagated-inputs
13210 `(("python-flask" ,python-flask)))
13211 (home-page
13212 "https://github.com/jpvanhal/flask-basicauth")
13213 (synopsis
13214 "HTTP basic access authentication for Flask")
13215 (description
13216 "This package provides HTTP basic access authentication for Flask.")
13217 (license license:bsd-3)))
13218
13219 (define-public python-flask-sqlalchemy
13220 (package
13221 (name "python-flask-sqlalchemy")
13222 (version "2.1")
13223 (source
13224 (origin
13225 (method url-fetch)
13226 (uri (pypi-uri "Flask-SQLAlchemy" version))
13227 (sha256
13228 (base32
13229 "1i9ps5d5snih9xlqhrvmi3qfiygkmqzxh92n25kj4pf89kj4s965"))))
13230 (build-system python-build-system)
13231 (propagated-inputs
13232 `(("python-flask" ,python-flask)
13233 ("python-sqlalchemy" ,python-sqlalchemy)))
13234 (home-page
13235 "https://github.com/mitsuhiko/flask-sqlalchemy")
13236 (synopsis
13237 "Module adding SQLAlchemy support to your Flask application")
13238 (description
13239 "This package adds SQLAlchemy support to your Flask application.")
13240 (license license:bsd-3)))
13241
13242 (define-public python-pyev
13243 (package
13244 (name "python-pyev")
13245 (version "0.9.0")
13246 (source
13247 (origin
13248 (method url-fetch)
13249 (uri (pypi-uri "pyev" version))
13250 (sha256
13251 (base32
13252 "0rf603lc0s6zpa1nb25vhd8g4y337wg2wyz56i0agsdh7jchl0sx"))))
13253 (build-system python-build-system)
13254 (arguments
13255 `(#:tests? #f ; no test suite
13256 #:phases
13257 (modify-phases %standard-phases
13258 (add-after 'unpack 'patch
13259 (lambda* (#:key inputs #:allow-other-keys)
13260 (let ((libev (string-append (assoc-ref inputs "libev")
13261 "/lib/libev.so.4")))
13262 (substitute* "setup.py"
13263 (("libev_dll_name = find_library\\(\\\"ev\\\"\\)")
13264 (string-append "libev_dll_name = \"" libev "\"")))))))))
13265 (inputs
13266 `(("libev" ,libev)))
13267 (home-page "http://pythonhosted.org/pyev/")
13268 (synopsis "Python libev interface")
13269 (description "Pyev provides a Python interface to libev.")
13270 (license license:gpl3)))
13271
13272 (define-public python2-pyev
13273 (package-with-python2 python-pyev))
13274
13275 (define-public python-imagesize
13276 (package
13277 (name "python-imagesize")
13278 (version "0.7.1")
13279 (source
13280 (origin
13281 (method url-fetch)
13282 (uri (pypi-uri "imagesize" version))
13283 (sha256
13284 (base32
13285 "0qk07k0z4241lkzzjji7z4da04pcvg7bfc4xz1934zlqhwmwdcha"))))
13286 (build-system python-build-system)
13287 (arguments
13288 '(;; Test files are not distributed on PyPi:
13289 ;; https://github.com/shibukawa/imagesize_py/issues/7
13290 #:tests? #f))
13291 (home-page "https://github.com/shibukawa/imagesize_py")
13292 (synopsis "Gets image size of files in variaous formats in Python")
13293 (description
13294 "This package allows determination of image size from
13295 PNG, JPEG, JPEG2000 and GIF files in pure Python.")
13296 (license license:expat)))
13297
13298 (define-public python2-imagesize
13299 (package-with-python2 python-imagesize))
13300
13301 (define-public python-axolotl-curve25519
13302 (package
13303 (name "python-axolotl-curve25519")
13304 (version "0.1")
13305 (source
13306 (origin
13307 (method git-fetch)
13308 (uri (git-reference
13309 (url "git://github.com/tgalal/python-axolotl-curve25519")
13310 (commit "e4a9c4de0eae27223200579c58d1f8f6d20637e2")))
13311 (file-name (string-append name "-" version "-checkout"))
13312 (sha256
13313 (base32
13314 "0agap5q0hmvf6cwzjqc05kw53pjgf6942pcivpazksmg1vk400ra"))))
13315 (build-system python-build-system)
13316 (arguments
13317 `(;; Prevent creation of the egg. This works around
13318 ;; https://debbugs.gnu.org/cgi/bugreport.cgi?bug=20765
13319 #:configure-flags '("--root=/")))
13320 (home-page "https://github.com/tgalal/python-axolotl-curve25519")
13321 (synopsis "Python wrapper for curve25519 library")
13322 (description "This is a python wrapper for the curve25519 library
13323 with ed25519 signatures. The C code was pulled from
13324 libaxolotl-android. At the moment this wrapper is meant for use by
13325 python-axolotl.")
13326 (license (list license:gpl3 ; Most files
13327 license:bsd-3)))) ; curve/curve25519-donna.c
13328
13329 (define-public python2-axolotl-curve25519
13330 (package-with-python2 python-axolotl-curve25519))
13331
13332 (define-public python-axolotl
13333 (package
13334 (name "python-axolotl")
13335 (version "0.1.35")
13336 (source
13337 (origin
13338 (method url-fetch)
13339 (uri (string-append
13340 "https://github.com/tgalal/python-axolotl/archive/"
13341 version ".tar.gz"))
13342 (file-name (string-append name "-" version ".tar.gz"))
13343 (sha256
13344 (base32 "1z8d89p7v40p4bwywjm9h4z28fdvra79ddw06azlkrfjbl7dxmz8"))))
13345 (build-system python-build-system)
13346 (arguments
13347 `(#:phases
13348 (modify-phases %standard-phases
13349 ;; Don't install tests
13350 (add-before 'install 'remove-tests
13351 (lambda _
13352 (for-each delete-file-recursively
13353 '("axolotl/tests" "build/lib/axolotl/tests"))
13354 #t)))))
13355 (propagated-inputs
13356 `(("python-axolotl-curve25519" ,python-axolotl-curve25519)
13357 ("python-dateutil" ,python-dateutil)
13358 ("python-protobuf" ,python-protobuf)
13359 ("python-pycrypto" ,python-pycrypto)))
13360 (home-page "https://github.com/tgalal/python-axolotl")
13361 (synopsis "Python port of libaxolotl-android")
13362 (description "This is a python port of libaxolotl-android. This
13363 is a ratcheting forward secrecy protocol that works in synchronous and
13364 asynchronous messaging environments.")
13365 (license license:gpl3)))
13366
13367 (define-public python2-axolotl
13368 (package-with-python2 python-axolotl))
13369
13370 (define-public python-termstyle
13371 (package
13372 (name "python-termstyle")
13373 (version "0.1.11")
13374 (source
13375 (origin
13376 (method url-fetch)
13377 (uri (pypi-uri "termstyle" version))
13378 (sha256
13379 (base32
13380 "17wzkkcqy5zc0g68xlad3kcv66iw14d2pwqc0h9420gak0vbhx7g"))))
13381 (build-system python-build-system)
13382 (arguments
13383 '(#:phases
13384 (modify-phases %standard-phases
13385 (replace 'check
13386 (lambda _
13387 (zero? (system* "python" "test3.py")))))))
13388 (home-page "https://github.com/gfxmonk/termstyle")
13389 (synopsis "Console text coloring for Python")
13390 (description "This package provides console text coloring for Python.")
13391 (license license:bsd-3)))
13392
13393 (define-public python-rednose
13394 (package
13395 (name "python-rednose")
13396 (version "1.2.1")
13397 (source
13398 (origin
13399 (method url-fetch)
13400 (uri (pypi-uri "rednose" version))
13401 (sha256
13402 (base32
13403 "0b0bsna217lr1nykyhl5fgjly15zhdvqd4prg4wy1zrgfv7al6m0"))))
13404 (build-system python-build-system)
13405 (arguments
13406 `(#:phases
13407 (modify-phases %standard-phases
13408 (add-after 'unpack 'fix-deps
13409 (lambda _
13410 ;; See <https://github.com/JBKahn/rednose/issues/12>
13411 (substitute* "setup.py"
13412 (("python-termstyle") "termstyle"))
13413 #t)))))
13414 (propagated-inputs
13415 `(("python-colorama" ,python-colorama)
13416 ("python-termstyle" ,python-termstyle)))
13417 (native-inputs
13418 `(("python-six" ,python-six)
13419 ("python-nose" ,python-nose)))
13420 (home-page "https://github.com/JBKahn/rednose")
13421 (synopsis "Colored output for Python nosetests")
13422 (description "This package provides colored output for the
13423 @command{nosetests} command of the Python Nose unit test framework.")
13424 (license license:bsd-3)))
13425
13426 (define-public python2-rednose
13427 (package-with-python2 python-rednose))
13428
13429 (define-public python-flask-restplus
13430 (package
13431 (name "python-flask-restplus")
13432 (version "0.9.2")
13433 (source
13434 (origin
13435 (method url-fetch)
13436 (uri (pypi-uri "flask-restplus" version))
13437 (sha256
13438 (base32
13439 "11his6ii5brpkhld0d5bwzjjw4q3vmplpd6fmgzjrvvklsbk0cf4"))))
13440 (build-system python-build-system)
13441 (arguments
13442 '(#:tests? #f)) ; FIXME: 35/882 tests failing.
13443 ;; #:phases
13444 ;; (modify-phases %standard-phases
13445 ;; (replace 'check
13446 ;; (lambda _
13447 ;; (zero? (system* "nosetests")))))))
13448 (propagated-inputs
13449 `(("python-aniso8601" ,python-aniso8601)
13450 ("python-flask" ,python-flask)
13451 ("python-jsonschema" ,python-jsonschema)
13452 ("python-pytz" ,python-pytz)
13453 ("python-six" ,python-six)))
13454 (native-inputs
13455 `(("python-tzlocal" ,python-tzlocal)
13456 ("python-blinker" ,python-blinker)
13457 ("python-nose" ,python-nose)
13458 ("python-rednose" ,python-rednose)))
13459 (home-page "https://github.com/noirbizarre/flask-restplus")
13460 (synopsis "Framework for documented API development with Flask")
13461 (description "This package provides a framework for API development with
13462 the Flask web framework in Python. It is similar to package
13463 @code{python-flask-restful} but supports the @code{python-swagger}
13464 documentation builder.")
13465 (license license:expat)))
13466
13467 (define-public python-sadisplay
13468 (package
13469 (name "python-sadisplay")
13470 (version "0.4.6")
13471 (source
13472 (origin
13473 (method url-fetch)
13474 (uri (pypi-uri "sadisplay" version))
13475 (sha256
13476 (base32
13477 "0zqad2fl7q26p090qmqgmxbm6iwgf9zij1w8da1g3wdgjj72ql05"))))
13478 (build-system python-build-system)
13479 (propagated-inputs
13480 `(("python-sqlalchemy" ,python-sqlalchemy)))
13481 (native-inputs
13482 `(("python-nose" ,python-nose)))
13483 (home-page "https://bitbucket.org/estin/sadisplay")
13484 (synopsis "SQLAlchemy schema displayer")
13485 (description "This package provides a program to build Entity
13486 Relationship diagrams from a SQLAlchemy model (or directly from the
13487 database).")
13488 (license license:bsd-3)))
13489
13490 (define-public python2-sadisplay
13491 (package-with-python2 python-sadisplay))
13492
13493 (define-public python-flask-restful-swagger
13494 (package
13495 (name "python-flask-restful-swagger")
13496 (version "0.19")
13497 (source
13498 (origin
13499 (method url-fetch)
13500 (uri (pypi-uri "flask-restful-swagger" version))
13501 (sha256
13502 (base32
13503 "16msl8hd5xjmj833bpy264v98cpl5hkw5bgl5gf5vgndxbv3rm6v"))))
13504 (build-system python-build-system)
13505 (propagated-inputs
13506 `(("python-flask-restful" ,python-flask-restful)))
13507 (home-page "https://github.com/rantav/flask-restful-swagger")
13508 (synopsis "Extract Swagger specs from Flask-Restful projects")
13509 (description "This package lets you extract Swagger API documentation
13510 specs from your Flask-Restful projects.")
13511 (license license:expat)))
13512
13513 (define-public python2-flask-restful-swagger
13514 (package-with-python2 python-flask-restful-swagger))
13515
13516 (define-public python-argcomplete
13517 (package
13518 (name "python-argcomplete")
13519 (version "1.7.0")
13520 (source
13521 (origin
13522 (method url-fetch)
13523 (uri (pypi-uri "argcomplete" version))
13524 (sha256
13525 (base32
13526 "11bwiw6j0nilgz81xnw6f1npyga3prp8asjqrm87cdr3ria5l03x"))))
13527 (build-system python-build-system)
13528 (native-inputs
13529 `(("python-pexpect" ,python-pexpect)
13530 ("tcsh" ,tcsh)))
13531 (home-page "https://github.com/kislyuk/argcomplete")
13532 (synopsis "Shell tab completion for Python argparse")
13533 (description "argcomplete provides extensible command line tab completion
13534 of arguments and options for Python scripts using @code{argparse}. It's
13535 particularly useful for programs with many options or sub-parsers that can
13536 dynamically suggest completions; for example, when browsing resources over the
13537 network.")
13538 (license license:asl2.0)))
13539
13540 (define-public python2-argcomplete
13541 (package-with-python2 python-argcomplete))
13542
13543 (define-public python-xopen
13544 (package
13545 (name "python-xopen")
13546 (version "0.1.1")
13547 (source
13548 (origin
13549 (method url-fetch)
13550 (uri (pypi-uri "xopen" version))
13551 (sha256
13552 (base32
13553 "1wx6mylzcsyhjl19ycb83qq6iqpmr927lz62njfsar6ldsj0qcni"))
13554 (file-name (string-append name "-" version ".tar.gz"))))
13555 (build-system python-build-system)
13556 (home-page "https://github.com/marcelm/xopen/")
13557 (synopsis "Open compressed files transparently")
13558 (description "This module provides an @code{xopen} function that works like
13559 Python's built-in @code{open} function, but can also deal with compressed files.
13560 Supported compression formats are gzip, bzip2 and, xz, and are automatically
13561 recognized by their file extensions. The focus is on being as efficient as
13562 possible on all supported Python versions.")
13563 (license license:expat)))
13564
13565 (define-public python2-xopen
13566 (package-with-python2 python-xopen))
13567
13568 (define-public python2-cheetah
13569 (package
13570 (name "python2-cheetah")
13571 (version "2.4.4")
13572 (source
13573 (origin
13574 (method url-fetch)
13575 (uri (pypi-uri "Cheetah" version))
13576 (sha256
13577 (base32
13578 "0l5mm4lnysjkzpjr95q5ydm9xc8bv43fxmr79ypybrf1y0lq4c5y"))))
13579 (build-system python-build-system)
13580 (arguments
13581 `(#:python ,python-2))
13582 (propagated-inputs
13583 `(("python2-markdown" ,python2-markdown)))
13584 (home-page "https://pythonhosted.org/Cheetah/")
13585 (synopsis "Template engine")
13586 (description "Cheetah is a text-based template engine and Python code
13587 generator.
13588
13589 Cheetah can be used as a standalone templating utility or referenced as
13590 a library from other Python applications. It has many potential uses,
13591 but web developers looking for a viable alternative to ASP, JSP, PHP and
13592 PSP are expected to be its principle user group.
13593
13594 Features:
13595 @enumerate
13596 @item Generates HTML, SGML, XML, SQL, Postscript, form email, LaTeX, or any other
13597 text-based format.
13598 @item Cleanly separates content, graphic design, and program code.
13599 @item Blends the power and flexibility of Python with a simple template language
13600 that non-programmers can understand.
13601 @item Gives template writers full access to any Python data structure, module,
13602 function, object, or method in their templates.
13603 @item Makes code reuse easy by providing an object-orientated interface to
13604 templates that is accessible from Python code or other Cheetah templates.
13605 One template can subclass another and selectively reimplement sections of it.
13606 @item Provides a simple, yet powerful, caching mechanism that can dramatically
13607 improve the performance of a dynamic website.
13608 @item Compiles templates into optimized, yet readable, Python code.
13609 @end enumerate")
13610 (license (license:x11-style "file://LICENSE"))))
13611
13612 (define-public python-dulwich
13613 (package
13614 (name "python-dulwich")
13615 (version "0.16.3")
13616 (source
13617 (origin
13618 (method url-fetch)
13619 (uri (list (string-append "https://www.dulwich.io/releases/"
13620 "dulwich-" version ".tar.gz")
13621 (pypi-uri "dulwich" version)))
13622 (sha256
13623 (base32 "0fl47vzfgc3w3rmhn8naii905cjqcp0vc68iyvymxp7567hh6als"))))
13624 (build-system python-build-system)
13625 (arguments
13626 `(#:phases
13627 (modify-phases %standard-phases
13628 (add-before 'check 'fix-tests
13629 (lambda* (#:key inputs #:allow-other-keys)
13630 ;; The tests use Popen with a custom environment which doesn't
13631 ;; include PATH.
13632 (substitute* "dulwich/tests/compat/utils.py"
13633 (("'git'") (string-append "'"
13634 (which "git")
13635 "'")))
13636 (substitute* '("dulwich/tests/test_repository.py"
13637 "dulwich/tests/test_hooks.py")
13638 (("#!/bin/sh") (string-append "#!" (which "sh"))))
13639 (setenv "TEST_RUNNER" "unittest")
13640 (setenv "PYTHONHASHSEED" "random")
13641 #t)))))
13642 (propagated-inputs
13643 `(("python-fastimport" ,python-fastimport)))
13644 (native-inputs
13645 `(("python-mock" ,python-mock)
13646 ("python-geventhttpclient" ,python-geventhttpclient)
13647 ("git" ,git)))
13648 (home-page "https://www.dulwich.io/")
13649 (synopsis "Git implementation in Python")
13650 (description "Dulwich is an implementation of the Git file formats and
13651 protocols written in pure Python.")
13652 ;; Can be used with either license.
13653 (license (list license:asl2.0 license:gpl2+))))
13654
13655 (define-public python2-dulwich
13656 (package-with-python2 python-dulwich))
13657
13658 (define-public python-pbkdf2
13659 (package
13660 (name "python-pbkdf2")
13661 (version "1.3")
13662 (source
13663 (origin
13664 (method url-fetch)
13665 (uri (pypi-uri "pbkdf2" version))
13666 (sha256
13667 (base32
13668 "0yb99rl2mbsaamj571s1mf6vgniqh23v98k4632150hjkwv9fqxc"))))
13669 (build-system python-build-system)
13670 (arguments
13671 '(#:phases
13672 (modify-phases %standard-phases
13673 (replace 'check
13674 (lambda _
13675 (setenv "PYTHONPATH"
13676 (string-append (getcwd) "/build/lib:"
13677 (getenv "PYTHONPATH")))
13678 (zero? (system* "python" "test/test_pbkdf2.py")))))))
13679 (propagated-inputs
13680 `(("python-pycrypto" ,python-pycrypto))) ; optional
13681 (home-page "http://www.dlitz.net/software/python-pbkdf2/")
13682 (synopsis "Password-based key derivation")
13683 (description "This module implements the password-based key derivation
13684 function, PBKDF2, specified in RSA PKCS#5 v2.0.
13685
13686 PKCS#5 v2.0 Password-Based Key Derivation is a key derivation function which
13687 is part of the RSA Public Key Cryptography Standards series. The provided
13688 implementation takes a password or a passphrase and a salt value (and
13689 optionally a iteration count, a digest module, and a MAC module) and provides
13690 a file-like object from which an arbitrarly-sized key can be read.")
13691 (license license:expat)))
13692
13693 (define-public python2-pbkdf2
13694 (package-with-python2 python-pbkdf2))
13695
13696 (define-public python-qrcode
13697 (package
13698 (name "python-qrcode")
13699 (version "5.3")
13700 (source
13701 (origin
13702 (method url-fetch)
13703 (uri (pypi-uri "qrcode" version))
13704 (sha256
13705 (base32
13706 "0kljfrfq0c2rmxf8am57333ia41kd0snbm2rnqbdy816hgpcq5a1"))))
13707 (build-system python-build-system)
13708 (arguments
13709 ;; FIXME: Tests require packaging 'pymaging'.
13710 '(#:tests? #f))
13711 (propagated-inputs
13712 `(("python-lxml" ,python-lxml) ; for SVG output
13713 ("python-pillow" ,python-pillow) ; for PNG output
13714 ("python-six" ,python-six)))
13715 (home-page "https://github.com/lincolnloop/python-qrcode")
13716 (synopsis "QR Code image generator")
13717 (description "This package provides a pure Python QR Code generator
13718 module. It uses the Python Imaging Library (PIL) to allow for the generation
13719 of QR Codes.
13720
13721 In addition this package provides a command line tool to generate QR codes and
13722 either write these QR codes to a file or do the output as ascii art at the
13723 console.")
13724 (license license:bsd-3)))
13725
13726 (define-public python2-qrcode
13727 (package-with-python2 python-qrcode))
13728
13729 ;; SlowAES isn't compatible with Python 3.
13730 (define-public python2-slowaes
13731 (package
13732 (name "python2-slowaes")
13733 (version "0.1a1")
13734 (source
13735 (origin
13736 (method url-fetch)
13737 (uri (pypi-uri "slowaes" version))
13738 (sha256
13739 (base32
13740 "02dzajm83a7lqgxf6r3hgj64wfmcxz8gs4nvgxpvj5n19kjqlrc3"))))
13741 (build-system python-build-system)
13742 (arguments `(#:python ,python-2))
13743 (home-page "http://code.google.com/p/slowaes/")
13744 (synopsis "Implementation of AES in Python")
13745 (description "This package contains an implementation of AES in Python.
13746 This implementation is slow (hence the project name) but still useful when
13747 faster ones are not available.")
13748 (license license:asl2.0)))
13749
13750 (define-public python-rst2ansi
13751 (package
13752 (name "python-rst2ansi")
13753 (version "0.1.5")
13754 (source
13755 (origin
13756 (method url-fetch)
13757 (uri (pypi-uri "rst2ansi" version))
13758 (sha256
13759 (base32
13760 "0vzy6gd60l79ff750scl0sz48r1laalkl6md6dwzah4dcadgn5qv"))))
13761 (build-system python-build-system)
13762 (propagated-inputs
13763 `(("python-docutils" ,python-docutils)))
13764 (home-page "https://github.com/Snaipe/python-rst-to-ansi")
13765 (synopsis "Convert RST to ANSI-decorated console output")
13766 (description
13767 "Python module dedicated to rendering RST (reStructuredText) documents
13768 to ansi-escaped strings suitable for display in a terminal.")
13769 (license license:expat)))
13770
13771 (define-public python-ansi2html
13772 (package
13773 (name "python-ansi2html")
13774 (version "1.2.0")
13775 (source
13776 (origin
13777 (method url-fetch)
13778 (uri (pypi-uri "ansi2html" version))
13779 (sha256
13780 (base32
13781 "1wa00zffprb78w1mqq90dk47czz1knanys2a40zbw2vyapd5lp9y"))))
13782 (build-system python-build-system)
13783 (native-inputs
13784 `(("python-mock" ,python-mock)
13785 ("python-nose" ,python-nose)))
13786 (propagated-inputs
13787 `(("python-six" ,python-six)))
13788 (home-page "http://github.com/ralphbean/ansi2html")
13789 (synopsis "Convert ANSI-decorated console output to HTML")
13790 (description
13791 "@command{ansi2html} is a Python library and command line utility for
13792 convering text with ANSI color codes to HTML or LaTeX.")
13793 (license license:gpl3+)))
13794
13795 (define-public python2-ansi2html
13796 (package-with-python2 python-ansi2html))
13797
13798 (define-public python-ddt
13799 (package
13800 (name "python-ddt")
13801 (version "1.1.1")
13802 (source
13803 (origin
13804 (method url-fetch)
13805 (uri (pypi-uri "ddt" version))
13806 (sha256
13807 (base32
13808 "1c00ikkxr7lha97c81k938bzhgd4pbwamkjn0h4nkhr3xk00zp6n"))))
13809 (build-system python-build-system)
13810 (native-inputs
13811 `(("python-mock" ,python-mock)
13812 ("python-nose" ,python-nose)))
13813 (propagated-inputs
13814 `(("python-six" ,python-six)
13815 ("python-pyyaml" ,python-pyyaml)))
13816 (home-page "https://github.com/txels/ddt")
13817 (synopsis "Data-Driven Tests")
13818 (description
13819 "DDT (Data-Driven Tests) allows you to multiply one test case by running
13820 it with different test data, and make it appear as multiple test cases.")
13821 (license license:expat)))
13822
13823 (define-public python2-ddt
13824 (package-with-python2 python-ddt))
13825
13826 (define-public python-pycosat
13827 (package
13828 (name "python-pycosat")
13829 (version "0.6.1")
13830 (source
13831 (origin
13832 (method url-fetch)
13833 (uri (pypi-uri "pycosat" version))
13834 (sha256
13835 (base32
13836 "1kl3wh1f47rc712n4bmwplbx3fqz3x9i1b587jrbpmvdva4c8f6l"))))
13837 ;; TODO: Unundle picosat. http://fmv.jku.at/picosat/
13838 (build-system python-build-system)
13839 (home-page "https://github.com/ContinuumIO/pycosat")
13840 (synopsis "Bindings to picosat (a SAT solver)")
13841 (description
13842 "This package provides efficient Python bindings to @code{picosat} on
13843 the C level. When importing pycosat, the @code{picosat} solver becomes part
13844 of the Python process itself. @code{picosat} is a @dfn{Boolean Satisfiability
13845 Problem} (SAT) solver.")
13846 (license license:expat)))
13847
13848 (define-public python2-pycosat
13849 (package-with-python2 python-pycosat))
13850
13851 (define-public python2-ruamel.ordereddict
13852 (package
13853 (name "python2-ruamel.ordereddict")
13854 (version "0.4.9")
13855 (source
13856 (origin
13857 (method url-fetch)
13858 (uri (pypi-uri "ruamel.ordereddict" version))
13859 (sha256
13860 (base32
13861 "1xmkl8v9l9inm2pyxgc1fm5005yxm7fkd5gv74q7lj1iy5qc8n3h"))))
13862 (build-system python-build-system)
13863 (arguments
13864 `(#:python ,python-2
13865 #:phases
13866 (modify-phases %standard-phases
13867 (delete 'check)
13868 (add-after 'install 'check
13869 (lambda* (#:key inputs outputs #:allow-other-keys)
13870 (add-installed-pythonpath inputs outputs)
13871 (zero? (system* "python" "test/testordereddict.py")))))))
13872 (home-page "https://bitbucket.org/ruamel/ordereddict")
13873 (synopsis "Version of dict that keeps keys in insertion order")
13874 (description
13875 "This is an implementation of an ordered dictionary with @dfn{Key
13876 Insertion Order} (KIO: updates of values do not affect the position of the
13877 key), @dfn{Key Value Insertion Order} (KVIO, an existing key's position is
13878 removed and put at the back). The standard library module @code{OrderedDict},
13879 implemented later, implements a subset of @code{ordereddict} functionality.
13880 Sorted dictionaries are also provided. Currently only with @dfn{Key Sorted
13881 Order} (KSO, no sorting function can be specified, but a transform can be
13882 specified to apply on the key before comparison (e.g. @code{string.lower})).")
13883 (license license:expat)))
13884
13885 (define-public python-pypeg2
13886 (package
13887 (name "python-pypeg2")
13888 (version "2.15.2")
13889 (source
13890 (origin
13891 (method url-fetch)
13892 (uri (pypi-uri "pyPEG2" version))
13893 (sha256
13894 (base32
13895 "0v8ziaam2r637v94ra4dbjw6jzxz99gs5x4i585kgag1v204yb9b"))))
13896 (build-system python-build-system)
13897 (propagated-inputs `(("python-lxml" ,python-lxml)))
13898 (arguments
13899 ;;https://bitbucket.org/fdik/pypeg/issues/36/test-failures-on-py35
13900 '(#:tests? #f))
13901 (home-page "https://fdik.org/pyPEG/")
13902 (synopsis "Parsering Expression Grammars in Python")
13903 (description "PyPEG is an intrinsic parser interpreter framework for
13904 Python. It is based on Parsing Expression Grammars, PEG. With pyPEG you can
13905 parse many formal languages.")
13906 (license license:gpl2)))
13907
13908 (define-public python2-cliapp
13909 (package
13910 (name "python2-cliapp")
13911 (version "1.20160724")
13912 (source
13913 (origin
13914 (method url-fetch)
13915 (uri (string-append
13916 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/cliapp/snapshot/cliapp-"
13917 version ".tar.gz"))
13918 (sha256
13919 (base32
13920 "025cyi75vxyghbm4hav8dz4fzwksshddavy9g9fwr440awcvw74f"))))
13921 (build-system python-build-system)
13922 (arguments
13923 `(#:python ,python-2))
13924 (propagated-inputs
13925 `(("python2-pyaml" ,python2-pyaml)))
13926 (home-page "https://liw.fi/cliapp/")
13927 (synopsis "Python framework for command line programs")
13928 (description "@code{python2-cliapp} is a python framework for
13929 command line programs. It contains the typical stuff such programs
13930 need to do, such as parsing the command line for options, and
13931 iterating over input files.")
13932 (license license:gpl2+)))
13933
13934 (define-public python2-ttystatus
13935 (package
13936 (name "python2-ttystatus")
13937 (version "0.32")
13938 (source
13939 (origin
13940 (method url-fetch)
13941 (uri (string-append
13942 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/ttystatus/snapshot/ttystatus-"
13943 version ".tar.gz"))
13944 (sha256
13945 (base32
13946 "0b5g889jj23r2w1hi300cdldx6jvspanp0ybf5n1qvdvl150aamf"))))
13947 (build-system python-build-system)
13948 (arguments
13949 `(#:python ,python-2))
13950 (home-page "https://liw.fi/ttystatus/")
13951 (synopsis "Python library for showing progress reporting and
13952 status updates on terminals")
13953 (description "@code{python2-ttystatus} is a python library for
13954 showing progress reporting and status updates on terminals, for
13955 command line programs. Output is automatically adapted to the width
13956 of the terminal: truncated if it does not fit, and resized if the
13957 terminal size changes.")
13958 (license license:gpl3+)))
13959
13960 (define-public python2-tracing
13961 (package
13962 (name "python2-tracing")
13963 (version "0.10")
13964 (source
13965 (origin
13966 (method url-fetch)
13967 (uri (string-append
13968 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/python-tracing/snapshot/tracing-"
13969 version ".tar.gz"))
13970 (sha256
13971 (base32
13972 "06cw4zg42fsvqy372vi2whj26w56vzg5axhzwdjc2bgwf03garbw"))))
13973 (build-system python-build-system)
13974 (arguments
13975 `(#:python ,python-2))
13976 (home-page "https://liw.fi/tracing/")
13977 (synopsis "Python debug logging helper")
13978 (description "@code{python2-tracing} is a python library for
13979 logging debug messages. It provides a way to turn debugging messages
13980 on and off, based on the filename they occur in. It is much faster
13981 than using @code{logging.Filter} to accomplish the same thing, which
13982 matters when code is run in production mode. The actual logging still
13983 happens using the @code{logging} library.")
13984 (license license:gpl3+)))
13985
13986 (define-public python2-larch
13987 (package
13988 (name "python2-larch")
13989 (version "1.20151025")
13990 (source
13991 (origin
13992 (method url-fetch)
13993 (uri (string-append
13994 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/larch/snapshot/larch-"
13995 version ".tar.gz"))
13996 (sha256
13997 (base32
13998 "1p4knkkavlqymgciz2wbcnfrdgdbafhg14maplnk4vbw0q8xs663"))))
13999 (build-system python-build-system)
14000 (arguments
14001 `(#:python ,python-2))
14002 (propagated-inputs
14003 `(("python2-tracing" ,python2-tracing)))
14004 (home-page "https://liw.fi/larch/")
14005 (synopsis "Python copy-on-write B-tree library")
14006 (description "@code{python2-larch} is an implementation of
14007 particular kind of B-tree, based on research by Ohad Rodeh. See
14008 @url{http://liw.fi/larch/ohad-btrees-shadowing-clones.pdf} for details
14009 on the data structure.
14010
14011 The distinctive feature of this B-tree is that a node is never
14012 (conceptually) modified. Instead, all updates are done by
14013 copy-on-write. This makes it easy to clone a tree, and modify only the
14014 clone, while other processes access the original tree.")
14015 (license license:gpl3+)))
14016
14017 (define-public python-htmlmin
14018 (package
14019 (name "python-htmlmin")
14020 (version "0.1.10")
14021 (source
14022 (origin
14023 (method url-fetch)
14024 (uri (pypi-uri "htmlmin" version))
14025 (sha256
14026 (base32
14027 "0qxa93j3p1ak32qh8d9kshqv8v3z0hkc13dwbhp5cn7sn3xmsp6a"))))
14028 (arguments
14029 `(#:tests? #f)) ;htmlmin has no tests
14030 (build-system python-build-system)
14031 (home-page "https://htmlmin.readthedocs.org/en/latest/")
14032 (synopsis "HTML minifier")
14033 (description "@code{htmlmin} is an HTML minifier that just works.
14034 It comes with safe defaults and easily configurable options.")
14035 (license license:bsd-3)))
14036
14037 (define-public python2-htmlmin
14038 (package-with-python2 python-htmlmin))
14039
14040 (define-public python-flask-htmlmin
14041 (package
14042 (name "python-flask-htmlmin")
14043 (version "1.2")
14044 (source
14045 (origin
14046 (method url-fetch)
14047 (uri (pypi-uri "Flask-HTMLmin" version))
14048 (sha256
14049 (base32
14050 "1n6zlq72kakkw0z2jpq6nh74lfsmxybm4g053pwhc14fbr809348"))))
14051 (propagated-inputs
14052 `(("python-flask" ,python-flask)
14053 ("python-htmlmin" ,python-htmlmin)))
14054 (build-system python-build-system)
14055 (home-page "https://github.com/hamidfzm/Flask-HTMLmin")
14056 (synopsis "HTML response minifier for Flask")
14057 (description
14058 "Minify @code{text/html} MIME type responses when using @code{Flask}.")
14059 (license license:bsd-3)))
14060
14061 (define-public python2-flask-htmlmin
14062 (package-with-python2 python-flask-htmlmin))
14063
14064 (define-public python-flask-login
14065 (package
14066 (name "python-flask-login")
14067 (version "0.4.0")
14068 (source
14069 (origin
14070 (method url-fetch)
14071 (uri (string-append "https://github.com/maxcountryman/flask-login/archive/"
14072 version ".tar.gz"))
14073 (file-name (string-append name "-" version ".tar.gz"))
14074 (sha256
14075 (base32
14076 "1pdqp7a2gyb7k06xda004x0fi2w66s6kn2i0ndkqndmg12d83f9w"))))
14077 (arguments
14078 ;; Tests fail PEP8 compliance. See:
14079 ;; https://github.com/maxcountryman/flask-login/issues/340
14080 `(#:tests? #f))
14081 (build-system python-build-system)
14082 (home-page "https://github.com/maxcountryman/flask-login")
14083 (synopsis "User session management for Flask")
14084 (description
14085 "@code{Flask-Login} provides user session management for Flask. It
14086 handles the common tasks of logging in, logging out, and remembering your
14087 users' sessions over extended periods of time.")
14088 (license license:expat)))
14089
14090 (define-public python2-flask-login
14091 (package-with-python2 python-flask-login))
14092
14093 (define-public python-astroid
14094 (package
14095 (name "python-astroid")
14096 (version "1.5.3")
14097 (source
14098 (origin
14099 (method url-fetch)
14100 (uri (string-append
14101 "https://github.com/PyCQA/astroid/archive/astroid-"
14102 version ".tar.gz"))
14103 (sha256
14104 (base32
14105 "0isn5p7f9n48hmksgbrj7dkm9dyglnayzn5jngk37qywg8a74ngn"))))
14106 (build-system python-build-system)
14107 (propagated-inputs
14108 `(("python-lazy-object-proxy" ,python-lazy-object-proxy)
14109 ("python-six" ,python-six)
14110 ("python-wrapt" ,python-wrapt)))
14111 (arguments
14112 `(#:phases
14113 (modify-phases %standard-phases
14114 (replace 'check
14115 (lambda _
14116 (zero? (system* "python" "-m" "unittest" "discover"
14117 "-p" "unittest*.py")))))))
14118 (home-page "https://github.com/PyCQA/astroid")
14119 (synopsis "Common base representation of python source code for pylint and
14120 other projects")
14121 (description "@code{python-astroid} provides a common base representation
14122 of python source code for projects such as pychecker, pyreverse, pylint, etc.
14123
14124 It provides a compatible representation which comes from the _ast module. It
14125 rebuilds the tree generated by the builtin _ast module by recursively walking
14126 down the AST and building an extended ast. The new node classes have
14127 additional methods and attributes for different usages. They include some
14128 support for static inference and local name scopes. Furthermore, astroid
14129 builds partial trees by inspecting living objects.")
14130 (license license:lgpl2.1+)
14131 (properties `((python2-variant . ,(delay python2-astroid))))))
14132
14133 (define-public python2-astroid
14134 (let ((base (package-with-python2
14135 (strip-python2-variant python-astroid))))
14136 (package (inherit base)
14137 (propagated-inputs
14138 `(("python2-backports-functools-lru-cache"
14139 ,python2-backports-functools-lru-cache)
14140 ("python2-enum34" ,python2-enum34)
14141 ("python2-singledispatch" ,python2-singledispatch)
14142 ,@(package-propagated-inputs base))))))
14143
14144 (define-public python-isort
14145 (package
14146 (name "python-isort")
14147 (version "4.2.5")
14148 (source
14149 (origin
14150 (method url-fetch)
14151 (uri (string-append
14152 "https://github.com/timothycrosley/isort/archive/"
14153 version ".tar.gz"))
14154 (file-name (string-append name "-" version ".tar.gz"))
14155 (sha256
14156 (base32
14157 "0zsrgkb0krn5476yncy5dd56k7dk34zqb4bnlvwy44ixgilyjmfh"))))
14158 (build-system python-build-system)
14159 (native-inputs
14160 `(("python-mock" ,python-mock)
14161 ("python-pytest" ,python-pytest)))
14162 (home-page "https://github.com/timothycrosley/isort")
14163 (synopsis "Python utility/library to sort python imports")
14164 (description "@code{python-isort} is a python utility/library to sort
14165 imports alphabetically, and automatically separated into sections. It
14166 provides a command line utility, a python library and plugins for various
14167 editors.")
14168 (license license:expat)))
14169
14170 (define-public python2-isort
14171 (package-with-python2 python-isort))
14172
14173 (define-public python2-backports-functools-lru-cache
14174 (package
14175 (name "python2-backports-functools-lru-cache")
14176 (version "1.3")
14177 (source
14178 (origin
14179 (method url-fetch)
14180 ;; only the pypi tarballs contain the necessary metadata
14181 (uri (pypi-uri "backports.functools_lru_cache" version))
14182 (sha256
14183 (base32
14184 "158ysf2hb0q4p4695abfiym9x1ywg0dgh8a3apd7gqaaxjy22jj4"))))
14185 (build-system python-build-system)
14186 (native-inputs
14187 `(("python2-setuptools-scm" ,python2-setuptools-scm)))
14188 (arguments
14189 `(#:python ,python-2))
14190 (home-page "https://github.com/jaraco/backports.functools_lru_cache")
14191 (synopsis "Backport of functools.lru_cache from Python 3.3")
14192 (description "@code{python2-backports-functools-lru-cache} is a backport
14193 of @code{functools.lru_cache} from python 3.3.")
14194 (license license:expat)))
14195
14196 (define-public python-configparser
14197 (package
14198 (name "python-configparser")
14199 (version "3.5.0")
14200 (source
14201 (origin
14202 (method url-fetch)
14203 (uri (string-append
14204 "https://bitbucket.org/ambv/configparser/get/"
14205 version ".tar.bz2"))
14206 (file-name (string-append name "-" version ".tar.gz"))
14207 (sha256
14208 (base32
14209 "0waq40as14abwzbb321hfz4vr1fi363nscy32ga14qvfygrg96wa"))))
14210 (build-system python-build-system)
14211 (home-page "http://docs.python.org/py3k/library/configparser.html")
14212 (synopsis "Backport of configparser from python 3.5")
14213 (description "@code{python-configparser} is a backport of
14214 @code{configparser} from Python 3.5 so that it can be used directly
14215 in other versions.")
14216 (license license:expat)))
14217
14218 (define-public python2-configparser
14219 (package-with-python2 python-configparser))
14220
14221 (define-public python2-coverage-test-runner
14222 (package
14223 (name "python2-coverage-test-runner")
14224 (version "1.11")
14225 (source
14226 (origin
14227 (method url-fetch)
14228 (uri (string-append
14229 "http://git.liw.fi/cgi-bin/cgit/cgit.cgi/"
14230 "coverage-test-runner/snapshot/coverage-test-runner-"
14231 version ".tar.gz"))
14232 (sha256
14233 (base32
14234 "0y1m7z3dl63kmhcmydl1mwg0hacnf6ghrx9dah17j9iasssfa3g7"))))
14235 (build-system python-build-system)
14236 (arguments
14237 `(#:python ,python-2
14238 #:phases
14239 (modify-phases %standard-phases
14240 (replace 'check
14241 (lambda _
14242 (zero? (system* "./testrun")))))))
14243 (propagated-inputs
14244 `(("python2-coverage" ,python2-coverage)))
14245 (home-page "https://liw.fi/coverage-test-runner/")
14246 (synopsis "Python module for running unit tests")
14247 (description "@code{CoverageTestRunner} is a python module for running
14248 unit tests and failing them if the unit test module does not exercise all
14249 statements in the module it tests.")
14250 (license license:gpl3+)))
14251
14252 (define-public python-pylint
14253 (package
14254 (name "python-pylint")
14255 (version "1.7.2")
14256 (source
14257 (origin
14258 (method url-fetch)
14259 (uri (string-append
14260 "https://github.com/PyCQA/pylint/archive/pylint-"
14261 version ".tar.gz"))
14262 (sha256
14263 (base32
14264 "0mzn1czhf1mgr2wiqfihb274sja02h899b85kywdpivppa9nwrmp"))))
14265 (build-system python-build-system)
14266 (native-inputs
14267 `(("python-pytest" ,python-pytest)
14268 ("python-pytest-runner" ,python-pytest-runner)
14269 ("python-tox" ,python-tox)))
14270 (propagated-inputs
14271 `(("python-astroid" ,python-astroid)
14272 ("python-isort" ,python-isort)
14273 ("python-mccabe" ,python-mccabe)
14274 ("python-six" ,python-six)))
14275 (arguments
14276 `(#:phases
14277 (modify-phases %standard-phases
14278 (replace 'check
14279 (lambda _
14280 ;; Somehow, tests for python2-pylint
14281 ;; fail if run from the build directory
14282 (let ((work "/tmp/work"))
14283 (mkdir-p work)
14284 (setenv "PYTHONPATH"
14285 (string-append (getenv "PYTHONPATH") ":" work))
14286 (copy-recursively "." work)
14287 (with-directory-excursion "/tmp"
14288 (zero? (system* "python" "-m" "unittest" "discover"
14289 "-s" (string-append work "/pylint/test")
14290 "-p" "*test_*.py")))))))))
14291 (home-page "https://github.com/PyCQA/pylint")
14292 (synopsis "Python source code analyzer which looks for coding standard
14293 errors")
14294 (description "Pylint is a Python source code analyzer which looks
14295 for programming errors, helps enforcing a coding standard and sniffs
14296 for some code smells (as defined in Martin Fowler's Refactoring book).
14297
14298 Pylint has many rules enabled by default, way too much to silence them
14299 all on a minimally sized program. It's highly configurable and handle
14300 pragmas to control it from within your code. Additionally, it is
14301 possible to write plugins to add your own checks.")
14302 (license license:gpl2+)))
14303
14304 (define-public python2-pylint
14305 (let ((pylint (package-with-python2 python-pylint)))
14306 (package (inherit pylint)
14307 (propagated-inputs
14308 `(("python2-backports-functools-lru-cache"
14309 ,python2-backports-functools-lru-cache)
14310 ("python2-configparser" ,python2-configparser)
14311 ,@(package-propagated-inputs pylint))))))
14312
14313 (define-public python-paramunittest
14314 (package
14315 (name "python-paramunittest")
14316 (version "0.2")
14317 (source
14318 (origin
14319 (method url-fetch)
14320 (uri (pypi-uri "ParamUnittest" version))
14321 (sha256
14322 (base32
14323 "0kp793hws5xv1wvycxq7jw2pwy36f35k39jg8hx5qikij5a0jid1"))))
14324 (build-system python-build-system)
14325 (home-page
14326 "https://github.com/rik0/ParamUnittest")
14327 (synopsis
14328 "Simple extension to have parametrized unit tests")
14329 (description
14330 "This package allows to create parametrized unit-tests that work with the standard
14331 unittest package. A parametrized test case is automatically converted to multiple test
14332 cases. Since they are TestCase subclasses, they work with other test suites that
14333 recognize TestCases.")
14334 (license license:bsd-2)))
14335
14336 (define-public python2-python-paramunittest
14337 (package-with-python2 python-paramunittest))
14338
14339 (define-public python-mando
14340 (package
14341 (name "python-mando")
14342 (version "0.5")
14343 (source
14344 (origin
14345 (method url-fetch)
14346 (uri (pypi-uri "mando" version))
14347 (sha256
14348 (base32
14349 "0q05h66439gqdmlk4jqm6xrwrzfdgs4mwk70barxhr2y83qbbdc0"))))
14350 (build-system python-build-system)
14351 (propagated-inputs
14352 `(("python-rst2ansi" ,python-rst2ansi)))
14353 (native-inputs
14354 `(("python-sphinx" ,python-sphinx-1.5.3)
14355 ("python-paramunittest" ,python-paramunittest)))
14356 (home-page "https://mando.readthedocs.org/")
14357 (synopsis
14358 "Wrapper around argparse, allowing creation of complete CLI applications")
14359 (description
14360 "This package is a wrapper around argparse, allowing you to write complete CLI
14361 applications in seconds while maintaining all the flexibility.")
14362 (license license:expat)))
14363
14364 (define-public python2-mando
14365 (package-with-python2 python-mando))
14366
14367 (define-public python-mando-0.3.1
14368 ;; python-radon (version 1.5.0) has a requirement
14369 ;; for mando<0.4,>=0.3
14370 (package
14371 (inherit python-mando)
14372 (name "python-mando")
14373 (version "0.3.1")
14374 (source
14375 (origin
14376 (method url-fetch)
14377 (uri (string-append "https://github.com/rubik/mando/archive/v"
14378 version
14379 ".tar.gz"))
14380 (sha256
14381 (base32
14382 "17jlkdpqw22z1nyml5ybslilqkzmnk0dxxjml8bfghav1l5hbwd2"))))))
14383
14384 (define-public python-fudge
14385 (package
14386 (name "python-fudge")
14387 ;; 0.9.6 is the latest version suitable for testing the "fabric" Python 2
14388 ;; package, which is currently the only use of this package.
14389 (version "0.9.6")
14390 (source
14391 (origin
14392 (method url-fetch)
14393 (uri (pypi-uri "fudge" version))
14394 (sha256
14395 (base32
14396 "185ia3vr3qk4f2s1a9hdxb8ci4qc0x0xidrad96pywg8j930qs9l"))))
14397 (build-system python-build-system)
14398 (arguments
14399 `(#:tests? #f)) ;XXX: Tests require the NoseJS Python package.
14400 (home-page "https://github.com/fudge-py/fudge")
14401 (synopsis "Replace real objects with fakes/mocks/stubs while testing")
14402 (description
14403 "Fudge is a Python module for using fake objects (mocks and stubs) to
14404 test real ones.
14405
14406 In readable Python code, you declare the methods available on your fake object
14407 and how they should be called. Then you inject that into your application and
14408 start testing. This declarative approach means you don’t have to record and
14409 playback actions and you don’t have to inspect your fakes after running code.
14410 If the fake object was used incorrectly then you’ll see an informative
14411 exception message with a traceback that points to the culprit.")
14412 (license license:expat)))
14413
14414 (define-public python2-fudge
14415 (package-with-python2 python-fudge))
14416
14417 (define-public python-oauth2client
14418 (package
14419 (name "python-oauth2client")
14420 (version "4.0.0")
14421 (source
14422 (origin
14423 (method url-fetch)
14424 (uri (pypi-uri "oauth2client" version))
14425 (sha256
14426 (base32
14427 "1irqqap2zibysf8dba8sklfqikia579srd0phm5n754ni0h59gl0"))))
14428 (build-system python-build-system)
14429 (arguments
14430 `(#:tests? #f))
14431 (propagated-inputs
14432 `(("python-httplib2" ,python-httplib2)
14433 ("python-pyasn1" ,python-pyasn1)
14434 ("python-pyasn1-modules" ,python-pyasn1-modules)
14435 ("python-rsa" ,python-rsa)
14436 ("python-six" ,python-six)))
14437 (home-page "http://github.com/google/oauth2client/")
14438 (synopsis "OAuth 2.0 client library")
14439 (description "@code{python-oauth2client} provides an OAuth 2.0 client
14440 library for Python")
14441 (license license:asl2.0)))
14442
14443 (define-public python-flask-oidc
14444 (package
14445 (name "python-flask-oidc")
14446 (version "1.1.1")
14447 (source
14448 (origin
14449 (method url-fetch)
14450 (uri (pypi-uri "flask-oidc" version))
14451 (sha256
14452 (base32
14453 "1ay5j0mf174bix7i67hclr95gv16z81fpx0dijvi0gydvdj3ddy2"))))
14454 (build-system python-build-system)
14455 (propagated-inputs
14456 `(("python-flask" ,python-flask)
14457 ("python-itsdangerous" ,python-itsdangerous)
14458 ("python-oauth2client" ,python-oauth2client)
14459 ("python-six" ,python-six)))
14460 (native-inputs
14461 `(("python-nose" ,python-nose)
14462 ("python-mock" ,python-mock)))
14463 (home-page "https://github.com/puiterwijk/flask-oidc")
14464 (synopsis "OpenID Connect extension for Flask")
14465 (description "@code{python-flask-oidc} provides an OpenID Connect extension
14466 for Flask.")
14467 (license license:bsd-2)))
14468
14469 (define-public python-mwclient
14470 (package
14471 (name "python-mwclient")
14472 (version "0.8.4")
14473 (source
14474 (origin
14475 (method url-fetch)
14476 ;; The PyPI version wouldn't contain tests.
14477 (uri (string-append "https://github.com/mwclient/mwclient/archive/"
14478 "v" version ".tar.gz"))
14479 (sha256
14480 (base32
14481 "1jj0yhilkjir00719fc7w133x7hdyhkxhk6xblla4asig45klsfv"))))
14482 (build-system python-build-system)
14483 (propagated-inputs
14484 `(("python-requests" ,python-requests)
14485 ("python-requests-oauthlib"
14486 ,python-requests-oauthlib)
14487 ("python-six" ,python-six)))
14488 (native-inputs
14489 `(("python-mock" ,python-mock)
14490 ("python-pytest" ,python-pytest)
14491 ("python-pytest-pep8" ,python-pytest-pep8)
14492 ("python-pytest-cache" ,python-pytest-cache)
14493 ("python-pytest-cov" ,python-pytest-cov)
14494 ("python-responses" ,python-responses)))
14495 (home-page "https://github.com/btongminh/mwclient")
14496 (synopsis "MediaWiki API client")
14497 (description "This package provides a MediaWiki API client.")
14498 (license license:expat)))
14499
14500 (define-public python2-mwclient
14501 (package-with-python2 python-mwclient))
14502
14503 (define-public python-pytest-warnings
14504 (package
14505 (name "python-pytest-warnings")
14506 (version "0.2.0")
14507 (source
14508 (origin
14509 (method url-fetch)
14510 (uri (pypi-uri "pytest-warnings" version))
14511 (sha256
14512 (base32
14513 "0gf2dpahpl5igb7jh1sr9acj3z3gp7zahqdqb69nk6wx01c8kc1g"))))
14514 (build-system python-build-system)
14515 (propagated-inputs
14516 `(("pytest" ,python-pytest-3.0)))
14517 (home-page "https://github.com/fschulze/pytest-warnings")
14518 (synopsis "Pytest plugin to list Python warnings in pytest report")
14519 (description
14520 "Python-pytest-warnings is a pytest plugin to list Python warnings in
14521 pytest report.")
14522 (license license:expat)))
14523
14524 (define-public python2-pytest-warnings
14525 (package-with-python2 python-pytest-warnings))
14526
14527 (define-public python-pytest-capturelog
14528 (package
14529 (name "python-pytest-capturelog")
14530 (version "0.7")
14531 (source
14532 (origin
14533 (method url-fetch)
14534 (uri (pypi-uri "pytest-capturelog" version ".tar.gz"))
14535 (sha256
14536 (base32
14537 "038049nyjl7di59ycnxvc9nydivc5m8np3hqq84j2iirkccdbs5n"))))
14538 (build-system python-build-system)
14539 (propagated-inputs
14540 `(("pytest" ,python-pytest-3.0)))
14541 (home-page "http://bitbucket.org/memedough/pytest-capturelog/overview")
14542 (synopsis "Pytest plugin to catch log messages")
14543 (description
14544 "Python-pytest-catchlog is a pytest plugin to catch log messages.")
14545 (license license:expat)))
14546
14547 (define-public python2-pytest-capturelog
14548 (package-with-python2 python-pytest-capturelog))
14549
14550 (define-public python-pytest-catchlog
14551 (package
14552 (name "python-pytest-catchlog")
14553 (version "1.2.2")
14554 (source
14555 (origin
14556 (method url-fetch)
14557 (uri (pypi-uri "pytest-catchlog" version ".zip"))
14558 (sha256
14559 (base32
14560 "1w7wxh27sbqwm4jgwrjr9c2gy384aca5jzw9c0wzhl0pmk2mvqab"))))
14561 (build-system python-build-system)
14562 (native-inputs
14563 `(("unzip" ,unzip)))
14564 (propagated-inputs
14565 `(("pytest" ,python-pytest-3.0)))
14566 (home-page "https://github.com/eisensheng/pytest-catchlog")
14567 (synopsis "Pytest plugin to catch log messages")
14568 (description
14569 "Python-pytest-catchlog is a pytest plugin to catch log messages. This is
14570 a fork of pytest-capturelog.")
14571 (license license:expat)))
14572
14573 (define-public python2-pytest-catchlog
14574 (package-with-python2 python-pytest-catchlog))
14575
14576 (define-public python-utils
14577 (package
14578 (name "python-utils")
14579 (version "2.1.0")
14580 (source (origin
14581 (method url-fetch)
14582 (uri (pypi-uri "python-utils" version))
14583 (sha256
14584 (base32
14585 "1mcsy6q5am4ya72rgkpb6kax6vv7c93cfkkas89xnpa4sj9zf28p"))))
14586 (build-system python-build-system)
14587 (native-inputs
14588 `(("pytest-runner" ,python-pytest-runner)
14589 ("pytest" ,python-pytest)
14590 ("six" ,python-six)))
14591 (home-page "https://github.com/WoLpH/python-utils")
14592 (synopsis "Convenient utilities not included with the standard Python install")
14593 (description
14594 "Python Utils is a collection of small Python functions and classes which
14595 make common patterns shorter and easier.")
14596 (license license:bsd-2)))
14597
14598 (define-public python2-utils
14599 (package-with-python2 python-utils))
14600
14601 (define-public python-webassets
14602 (package
14603 (name "python-webassets")
14604 (version "0.12.1")
14605 (source
14606 (origin
14607 (method url-fetch)
14608 (uri (pypi-uri "webassets" version))
14609 (sha256
14610 (base32
14611 "1nrqkpb7z46h2b77xafxihqv3322cwqv6293ngaky4j3ff4cing7"))))
14612 (build-system python-build-system)
14613 (native-inputs
14614 `(("python-jinja2" ,python-jinja2)
14615 ("python-mock" ,python-mock)
14616 ("python-nose" ,python-nose)
14617 ("python-pytest" ,python-pytest)))
14618 (home-page "https://github.com/miracle2k/webassets")
14619 (synopsis "Media asset management")
14620 (description "Merges, minifies and compresses Javascript and CSS files,
14621 supporting a variety of different filters, including YUI, jsmin, jspacker or
14622 CSS tidy. Also supports URL rewriting in CSS files.")
14623 (license license:bsd-2)))
14624
14625 (define-public python-sphinx-me
14626 (package
14627 (name "python-sphinx-me")
14628 (version "0.3")
14629 (source
14630 (origin
14631 (method url-fetch)
14632 (uri (pypi-uri "sphinx-me" version))
14633 (sha256
14634 (base32
14635 "06jzgp213zihnvpcy2y5jy3ykid3apc2ncp2pg6a2g05lhiziglq"))))
14636 (build-system python-build-system)
14637 (home-page "https://github.com/stephenmcd/sphinx-me")
14638 (synopsis "Create a Sphinx documentation shell")
14639 (description
14640 "Create a Sphinx documentation shell for your project and include the
14641 README file as the documentation index. It handles extracting the required
14642 meta data such as the project name, author and version from your project for
14643 use in your Sphinx docs.")
14644 (license license:bsd-2)))
14645
14646 (define-public python2-sphinx-me
14647 (package-with-python2 python-sphinx-me))
14648
14649 (define-public python-cssmin
14650 (package
14651 (name "python-cssmin")
14652 (version "0.2.0")
14653 (source
14654 (origin
14655 (method url-fetch)
14656 (uri (pypi-uri "cssmin" version))
14657 (sha256
14658 (base32
14659 "1dk723nfm2yf8cp4pj785giqlwv42l0kj8rk40kczvq1hk6g04p0"))))
14660 (build-system python-build-system)
14661 (home-page "https://github.com/zacharyvoase/cssmin")
14662 (synopsis "Python port of the YUI CSS Compressor")
14663 (description "Python port of the YUI CSS Compressor.")
14664 (license (list license:expat license:bsd-3))))
14665
14666 (define-public python2-cssmin
14667 (package-with-python2 python-cssmin))
14668
14669 (define-public python-diff-match-patch
14670 (package
14671 (name "python-diff-match-patch")
14672 (version "20121119")
14673 (source
14674 (origin
14675 (method url-fetch)
14676 (uri (pypi-uri "diff-match-patch" version))
14677 (sha256
14678 (base32
14679 "0k1f3v8nbidcmmrk65m7h8v41jqi37653za9fcs96y7jzc8mdflx"))))
14680 (build-system python-build-system)
14681 (home-page "https://code.google.com/p/google-diff-match-patch")
14682 (synopsis "Synchronize plain text")
14683 (description "Diff Match and Patch libraries offer robust algorithms to
14684 perform the operations required for synchronizing plain text.")
14685 (license license:asl2.0)))
14686
14687 (define-public python2-diff-match-patch
14688 (package-with-python2 python-diff-match-patch))
14689
14690 (define-public python-dirsync
14691 (package
14692 (name "python-dirsync")
14693 (version "2.2.2")
14694 (source
14695 (origin
14696 (method url-fetch)
14697 (uri (pypi-uri "dirsync" version ".zip"))
14698 (sha256
14699 (base32
14700 "1hcdvmkwd5512zbxpin0k7bx5bkgzy3swjx7d0kj1y45af6r75v2"))))
14701 (build-system python-build-system)
14702 (native-inputs
14703 `(("unzip" ,unzip)))
14704 (propagated-inputs
14705 `(("six" ,python-six)))
14706 (home-page "https://bitbucket.org/tkhyn/dirsync")
14707 (synopsis "Advanced directory tree synchronisation tool")
14708 (description "Advanced directory tree synchronisation tool.")
14709 (license license:expat)))
14710
14711 (define-public python2-dirsync
14712 (package-with-python2 python-dirsync))
14713
14714 (define-public python-nosexcover
14715 (package
14716 (name "python-nosexcover")
14717 (version "1.0.11")
14718 (source (origin
14719 (method url-fetch)
14720 (uri (pypi-uri "nosexcover" version))
14721 (sha256
14722 (base32
14723 "10xqr12qv62k2flxwqhh8cr00cjhn7sfjrm6p35gd1x5bmjkr319"))))
14724 (build-system python-build-system)
14725 (propagated-inputs
14726 `(("python-coverage" ,python-coverage)
14727 ("python-nose" ,python-nose)))
14728 (home-page "http://github.com/cmheisel/nose-xcover")
14729 (synopsis "Extends nose.plugins.cover to add Cobertura-style XML reports")
14730 (description "Nose-xcover is a companion to the built-in
14731 @code{nose.plugins.cover}. This plugin will write out an XML coverage report
14732 to a file named coverage.xml.
14733
14734 It will honor all the options you pass to the Nose coverage plugin,
14735 especially -cover-package.")
14736 (license license:expat)))
14737
14738 (define-public python2-nosexcover
14739 (package-with-python2 python-nosexcover))
14740
14741 (define-public python-elasticsearch
14742 (package
14743 (name "python-elasticsearch")
14744 (version "1.0.0")
14745 (source
14746 (origin
14747 (method url-fetch)
14748 (uri (pypi-uri "elasticsearch" version))
14749 (sha256
14750 (base32
14751 "1sdw1r05cw7ihnmng8ra9v968fj7bq6sji8i1dikymsnkcpgc69g"))))
14752 (build-system python-build-system)
14753 (native-inputs
14754 `(("python-mock" ,python-mock)
14755 ("python-nosexcover" ,python-nosexcover)
14756 ("python-pyaml" ,python-pyaml)
14757 ("python-requests" ,python-requests)))
14758 (propagated-inputs
14759 `(("urllib3" ,python-urllib3)))
14760 (arguments
14761 ;; tests require the test_elasticsearch module but it is not distributed.
14762 `(#:tests? #f))
14763 (home-page "https://github.com/elastic/elasticsearch-py")
14764 (synopsis "Low-level client for Elasticsearch")
14765 (description "Official low-level client for Elasticsearch. Its goal is to
14766 provide common ground for all Elasticsearch-related code in Python; because of
14767 this it tries to be opinion-free and very extendable.")
14768 (license license:expat)))
14769
14770 (define-public python2-elasticsearch
14771 (package-with-python2 python-elasticsearch))
14772
14773 (define-public python-levenshtein
14774 (package
14775 (name "python-levenshtein")
14776 (version "0.12.0")
14777 (source
14778 (origin
14779 (method url-fetch)
14780 (uri (pypi-uri "python-Levenshtein" version))
14781 (sha256
14782 (base32
14783 "1c9ybqcja31nghfcc8xxbbz9h60s9qi12b9hr4jyl69xbvg12fh3"))))
14784 (build-system python-build-system)
14785 (home-page "https://github.com/ztane/python-Levenshtein")
14786 (synopsis "Fast computation of Levenshtein distance and string similarity")
14787 (description
14788 "The Levenshtein Python C extension module contains functions for fast computation of
14789 @enumerate
14790 @item Levenshtein (edit) distance, and edit operations
14791 @item string similarity
14792 @item approximate median strings, and generally string averaging
14793 @item string sequence and set similarity
14794 @end enumerate
14795 It supports both normal and Unicode strings.")
14796 (license license:gpl2+)))
14797
14798 (define-public python2-levenshtein
14799 (package-with-python2 python-levenshtein))
14800
14801 (define-public python-scandir
14802 (package
14803 (name "python-scandir")
14804 (version "1.4")
14805 (source
14806 (origin
14807 (method url-fetch)
14808 (uri (pypi-uri "scandir" version))
14809 (sha256
14810 (base32 "0yjrgp0mxp3d8bjkq2m1ac2ys8n76wykksvgyjrnil9gr3fx7a5d"))))
14811 (build-system python-build-system)
14812 (home-page "https://github.com/benhoyt/scandir")
14813 (synopsis "Directory iteration function")
14814 (description
14815 "Directory iteration function like os.listdir(), except that instead of
14816 returning a list of bare filenames, it yields DirEntry objects that include
14817 file type and stat information along with the name. Using scandir() increases
14818 the speed of os.walk() by 2-20 times (depending on the platform and file
14819 system) by avoiding unnecessary calls to os.stat() in most cases.")
14820 (license license:bsd-3)))
14821
14822 (define-public python2-scandir
14823 (package-with-python2 python-scandir))
14824
14825 (define-public python2-stemming
14826 (package
14827 (name "python2-stemming")
14828 (version "1.0.1")
14829 (source
14830 (origin
14831 (method url-fetch)
14832 (uri (pypi-uri "stemming" version))
14833 (sha256
14834 (base32 "0ldwa24gnnxhniv0fhygkpc2mwgd93q10ag8rvzayv6hw418frsr"))))
14835 (build-system python-build-system)
14836 (arguments
14837 `(#:python ,python-2))
14838 (home-page "https://bitbucket.org/mchaput/stemming/overview")
14839 (synopsis "Python implementations of various stemming algorithms")
14840 (description
14841 "Python implementations of the Porter, Porter2, Paice-Husk, and Lovins
14842 stemming algorithms for English. These implementations are straightforward and
14843 efficient, unlike some Python versions of the same algorithms available on the
14844 Web. This package is an extraction of the stemming code included in the Whoosh
14845 search engine.")
14846 (license license:public-domain)))
14847
14848 (define-public python-factory-boy
14849 (package
14850 (name "python-factory-boy")
14851 (version "2.8.1")
14852 (source
14853 (origin
14854 (method url-fetch)
14855 (uri (pypi-uri "factory_boy" version))
14856 (sha256
14857 (base32 "1fvin6san5xsjh2c4y18caj2lnmwxlylyqm8mh1yc6rp38wlwr56"))))
14858 (build-system python-build-system)
14859 (arguments
14860 ;; Tests are not included in the tarball.
14861 `(#:tests? #f))
14862 (propagated-inputs
14863 `(("faker" ,python-faker)))
14864 (home-page "https://github.com/benhoyt/scandir")
14865 (synopsis "Versatile test fixtures replacement")
14866 (description
14867 "Factory_boy is a fixtures replacement based on thoughtbot’s factory_girl.
14868
14869 As a fixtures replacement tool, it aims to replace static, hard to maintain
14870 fixtures with easy-to-use factories for complex object.
14871
14872 Instead of building an exhaustive test setup with every possible combination
14873 of corner cases, factory_boy allows you to use objects customized for the
14874 current test, while only declaring the test-specific fields")
14875 (license license:expat)))
14876
14877 (define-public python2-factory-boy
14878 (package-with-python2 python-factory-boy))
14879
14880 (define-public python-translate-toolkit
14881 (package
14882 (name "python-translate-toolkit")
14883 (version "2.1.0")
14884 (source
14885 (origin
14886 (method url-fetch)
14887 (uri (pypi-uri "translate-toolkit" version ".tar.bz2"))
14888 (sha256
14889 (base32 "1vlkwrg83vb17jc36pmwh2b7jphwf390lz0jw8hakcg16qhwypvq"))))
14890 (build-system python-build-system)
14891 (native-inputs
14892 `(("python-pytest" ,python-pytest)
14893 ("python-sphinx" ,python-sphinx)))
14894 (propagated-inputs
14895 `(("python-babel" ,python-babel)
14896 ("python-beautifulsoup4" ,python-beautifulsoup4)
14897 ("python-chardet" ,python-chardet)
14898 ("python-diff-match-patch" ,python-diff-match-patch)
14899 ("python-levenshtein" ,python-levenshtein)
14900 ("python-lxml" ,python-lxml)
14901 ("python-six" ,python-six)
14902 ("python-vobject" ,python-vobject)
14903 ("python-pyyaml" ,python-pyyaml)))
14904 (arguments
14905 ;; TODO: tests are not run, because they end with
14906 ;; TypeError: parse() missing 2 required positional arguments: 'tree' and
14907 ;; 'parse_funcs'
14908 ;; during test setup.
14909 `(#:tests? #f))
14910 (home-page "http://toolkit.translatehouse.org")
14911 (synopsis "Tools and API for translation and localization engineering")
14912 (description
14913 "Tools and API for translation and localization engineering. It contains
14914 several utilities, as well as an API for building localization tools.")
14915 (license license:gpl2+)))
14916
14917 (define-public python2-translate-toolkit
14918 (package-with-python2 python-translate-toolkit))
14919
14920 (define-public python-mysqlclient
14921 (package
14922 (name "python-mysqlclient")
14923 (version "1.3.10")
14924 (source
14925 (origin
14926 (method url-fetch)
14927 (uri (pypi-uri "mysqlclient" version))
14928 (sha256
14929 (base32
14930 "0qkj570x4rbsblji6frvsvp2v1ap32dqzj1lq62zp9515ffsyaj5"))))
14931 (build-system python-build-system)
14932 (native-inputs
14933 `(("mariadb" ,mariadb)
14934 ("nose" ,python-nose)
14935 ("mock" ,python-mock)
14936 ("py.test" ,python-pytest)))
14937 (inputs
14938 `(("mysql" ,mysql)
14939 ("libz" ,zlib)
14940 ("openssl" ,openssl)))
14941 (home-page "https://github.com/PyMySQL/mysqlclient-python")
14942 (synopsis "MySQLdb is an interface to the popular MySQL database server for Python")
14943 (description "MySQLdb is an interface to the popular MySQL database server
14944 for Python. The design goals are:
14945 @enumerate
14946 @item Compliance with Python database API version 2.0 [PEP-0249],
14947 @item Thread-safety,
14948 @item Thread-friendliness (threads will not block each other).
14949 @end enumerate")
14950 (license license:gpl2)))
14951
14952 (define-public python2-mysqlclient
14953 (package-with-python2 python-mysqlclient))
14954
14955 (define-public python-hiredis
14956 (package
14957 (name "python-hiredis")
14958 (version "0.2.0")
14959 (source
14960 (origin
14961 (method url-fetch)
14962 (uri (pypi-uri "hiredis" version))
14963 (sha256
14964 (base32
14965 "1dfm2k9l9zar9nw9fwmm74zrgraxdxs04vx9li56fjcf289qx5fa"))))
14966 (build-system python-build-system)
14967 (arguments
14968 ;; no tests
14969 `(#:tests? #f))
14970 (home-page "https://github.com/redis/hiredis-py")
14971 (synopsis "Python extension that wraps protocol parsing code in hiredis")
14972 (description "Python-hiredis is a python extension that wraps protocol
14973 parsing code in hiredis. It primarily speeds up parsing of multi bulk replies.")
14974 (license license:bsd-3)))
14975
14976 (define-public python2-hiredis
14977 (package-with-python2 python-hiredis))
14978
14979 (define-public python-fakeredis
14980 (package
14981 (name "python-fakeredis")
14982 (version "0.8.2")
14983 (source
14984 (origin
14985 (method url-fetch)
14986 (uri (pypi-uri "fakeredis" version))
14987 (sha256
14988 (base32
14989 "0zncahj3byyasyfx9i7k991ph0n0lq8v3a21pqri5qxn9564bk9r"))))
14990 (build-system python-build-system)
14991 (arguments
14992 ;; no tests
14993 `(#:tests? #f))
14994 (home-page "https://github.com/jamesls/fakeredis")
14995 (synopsis "Fake implementation of redis API for testing purposes")
14996 (description "Fakeredis is a pure python implementation of the redis-py
14997 python client that simulates talking to a redis server. This was created for a
14998 single purpose: to write unittests. Setting up redis is not hard, but many time
14999 you want to write unittests that do not talk to an external server (such as
15000 redis). This module now allows tests to simply use this module as a reasonable
15001 substitute for redis.")
15002 (license license:bsd-3)))
15003
15004 (define-public python2-fakeredis
15005 (package-with-python2 python-fakeredis))
15006
15007 (define-public python-behave-web-api
15008 (package
15009 (name "python-behave-web-api")
15010 (version "1.0.6")
15011 (source
15012 (origin
15013 (method url-fetch)
15014 (uri (pypi-uri "behave-web-api" version))
15015 (sha256
15016 (base32
15017 "03kpq2xsy1gab3jy0dccbxlsg7vwfy4lagss0qldwmx3xz6b3i19"))))
15018 (build-system python-build-system)
15019 (arguments
15020 `(#:phases
15021 (modify-phases %standard-phases
15022 (add-after 'unpack 'fix-dependencies
15023 (lambda _
15024 (substitute* "setup.py"
15025 (("'wheel'") "") ; We don't use it.
15026 (("'ordereddict==1.1'") ""))))))) ; Python >= 2.7 has it built-in.
15027 (propagated-inputs
15028 `(("behave" ,behave)
15029 ("python-requests" ,python-requests)))
15030 (home-page "https://github.com/jefersondaniel/behave-web-api")
15031 (synopsis "Provides testing for JSON APIs with Behave for Python")
15032 (description "This package provides testing utility modules for testing
15033 JSON APIs with Behave.")
15034 (license license:expat)))
15035
15036 (define-public python2-behave-web-api
15037 (package-with-python2 python-behave-web-api))
15038
15039 (define-public python-flask-script
15040 (package
15041 (name "python-flask-script")
15042 (version "2.0.5")
15043 (source
15044 (origin
15045 (method url-fetch)
15046 (uri (pypi-uri "Flask-Script" version))
15047 (sha256
15048 (base32
15049 "0zqh2yq8zk7m9b4xw1ryqmrljkdigfb3hk5155a3b5hkfnn6xxyf"))))
15050 (build-system python-build-system)
15051 (propagated-inputs
15052 `(("python-flask" ,python-flask)
15053 ("python-argcomplete" ,python-argcomplete)
15054 ("python-werkzeug" ,python-werkzeug)))
15055 (native-inputs
15056 `(("python-pytest" ,python-pytest)))
15057 (home-page
15058 "http://github.com/smurfix/flask-script")
15059 (synopsis "Scripting support for Flask")
15060 (description "The Flask-Script extension provides support for writing
15061 external scripts in Flask. This includes running a development server,
15062 a customised Python shell, scripts to set up your database, cronjobs,
15063 and other command-line tasks that belong outside the web application
15064 itself.")
15065 (license license:bsd-3)))
15066
15067 (define-public python2-flask-script
15068 (package-with-python2 python-flask-script))
15069
15070 (define-public python-flask-migrate
15071 (package
15072 (name "python-flask-migrate")
15073 (version "2.0.3")
15074 (source
15075 (origin
15076 (method url-fetch)
15077 (uri (pypi-uri "Flask-Migrate" version))
15078 (sha256
15079 (base32
15080 "107x78lkqsnbg92dld3dkagg07jvchp3ib3y0sivc4ipz6n1y7rk"))))
15081 (build-system python-build-system)
15082 (propagated-inputs
15083 `(("python-flask" ,python-flask)
15084 ("python-alembic" ,python-alembic)
15085 ("python-sqlalchemy" ,python-sqlalchemy)
15086 ("python-flask-script" ,python-flask-script)
15087 ("python-flask-sqlalchemy" ,python-flask-sqlalchemy)))
15088 (home-page "http://github.com/miguelgrinberg/flask-migrate/")
15089 (synopsis "SQLAlchemy database migrations for Flask programs using
15090 Alembic")
15091 (description "This package contains SQLAlchemy database migration tools
15092 for Flask programs that are using @code{python-alembic}.")
15093 (license license:expat)))
15094
15095 (define-public python2-flask-migrate
15096 (package-with-python2 python-flask-migrate))
15097
15098 (define-public python-packaging
15099 (package
15100 (name "python-packaging")
15101 (version "16.8")
15102 (source
15103 (origin
15104 (method url-fetch)
15105 (uri (pypi-uri "packaging" version))
15106 (sha256
15107 (base32
15108 "17k1xbjshackwvbsnxqixbph8rbqhz4bf4g3al5xyzhavxgq6l2x"))))
15109 (build-system python-build-system)
15110 (native-inputs
15111 `(("python-pretend" ,python-pretend)
15112 ("python-pytest" ,python-pytest)))
15113 (propagated-inputs
15114 `(("python-pyparsing" ,python-pyparsing)
15115 ("python-six" ,python-six)))
15116 (home-page "https://github.com/pypa/packaging")
15117 (synopsis "Core utilities for Python packages")
15118 (description "Packaging is a Python module for dealing with Python packages.
15119 It offers an interface for working with package versions, names, and dependency
15120 information.")
15121 ;; From 'LICENSE': This software is made available under the terms of
15122 ;; *either* of the licenses found in LICENSE.APACHE or LICENSE.BSD.
15123 ;; Contributions to this software is made under the terms of *both* these
15124 ;; licenses.
15125 (license (list license:asl2.0 license:bsd-2))))
15126
15127 (define-public python2-packaging
15128 (package-with-python2 python-packaging))
15129
15130 (define-public python-sql
15131 (package
15132 (name "python-sql")
15133 (version "0.9")
15134 (source
15135 (origin
15136 (method url-fetch)
15137 (uri (pypi-uri "python-sql" version))
15138 (sha256
15139 (base32
15140 "0p6kaqj02vz0habmdx37zjk6hjxdfm8aw737zs059vvpr70ird87"))))
15141 (build-system python-build-system)
15142 (home-page "https://python-sql.tryton.org/")
15143 (synopsis "Library to write SQL queries in a pythonic way")
15144 (description "@code{python-sql} is a library to write SQL queries, that
15145 transforms idiomatic python function calls to well-formed SQL queries.")
15146 (license license:bsd-3)))
15147
15148 (define-public python2-sql
15149 (package-with-python2 python-sql))
15150
15151 (define-public python-genshi
15152 (package
15153 (name "python-genshi")
15154 (version "0.7")
15155 (source
15156 (origin
15157 (method url-fetch)
15158 (uri (string-append
15159 "https://ftp.edgewall.org/pub/genshi/Genshi-"
15160 version ".tar.gz"))
15161 (patches
15162 (search-patches
15163 ;; The first 4 patches are in the master branch upstream.
15164 ;; See this as a reference https://genshi.edgewall.org/ticket/582
15165 ;; The last 2 are NOT in any branch.
15166 ;; They were sent as attachments to a ticket opened at
15167 ;; https://genshi.edgewall.org/ticket/602#no1
15168 "python-genshi-stripping-of-unsafe-script-tags.patch"
15169 "python-genshi-disable-speedups-on-python-3.3.patch"
15170 "python-genshi-isstring-helper.patch"
15171 "python-genshi-add-support-for-python-3.4-AST.patch"
15172 "python-genshi-fix-tests-on-python-3.5.patch"
15173 "python-genshi-buildable-on-python-2.7.patch"))
15174 (sha256
15175 (base32
15176 "0lkkbp6fbwzv0zda5iqc21rr7rdldkwh3hfabfjl9i4bwq14858x"))))
15177 (build-system python-build-system)
15178 (home-page "https://genshi.edgewall.org/")
15179 (synopsis "Toolkit for generation of output for the web")
15180 (description "Genshi is a Python library that provides an integrated set
15181 of components for parsing, generating, and processing HTML, XML or other
15182 textual content for output generation on the web.")
15183 (license license:bsd-3)))
15184
15185 ;; The linter here claims that patch file names should start with the package
15186 ;; name. But, in this case the patches are inherited from python-genshi with
15187 ;; the "python-genshi-" prefix instead of "python2-genshi-".
15188 (define-public python2-genshi
15189 (package-with-python2 python-genshi))
15190
15191 (define-public python-relatorio
15192 (package
15193 (name "python-relatorio")
15194 (version "0.6.4")
15195 (source
15196 (origin
15197 (method url-fetch)
15198 (uri (pypi-uri "relatorio" version))
15199 (sha256
15200 (base32
15201 "0lincq79mzgazwd9gh41dybjh9c3n87r83pl8nk3j79aihyfk84z"))))
15202 (build-system python-build-system)
15203 (propagated-inputs
15204 `(("python-lxml" ,python-lxml)
15205 ("python-genshi" ,python-genshi)))
15206 (home-page "https://relatorio.tryton.org/")
15207 (synopsis "Templating library able to output ODT and PDF files")
15208 (description "Relatorio is a templating library which provides a way to
15209 easily output ODT, ODS, PNG, SVG and several other kinds of files. Support
15210 for more filetypes can be easily added by creating plugins for them.")
15211 (license license:gpl3+)))
15212
15213 (define-public python2-relatorio
15214 (package-with-python2 python-relatorio))
15215
15216 (define-public python-radon
15217 (package
15218 (name "python-radon")
15219 (version "1.5.0")
15220 (source
15221 (origin
15222 (method url-fetch)
15223 (uri (pypi-uri "radon" version))
15224 (sha256
15225 (base32
15226 "1h6jv36am0i827182a04ki6291lyx4kp957xfr5njgprj4nd0qsl"))))
15227 (build-system python-build-system)
15228 (propagated-inputs
15229 `(("python-colorama" ,python-colorama)
15230 ("python-flake8-polyfill" ,python-flake8-polyfill)
15231 ("python-mando" ,python-mando-0.3.1)))
15232 (native-inputs
15233 `(("python-flake8" ,python-flake8)
15234 ("python-tox" ,python-tox)
15235 ("python-pytest" ,python-pytest)
15236 ("python-paramunittest" ,python-paramunittest)))
15237 (home-page "https://radon.readthedocs.org/")
15238 (synopsis "Code Metrics in Python")
15239 (description "Radon is a Python tool which computes various code metrics.
15240 Supported metrics are:
15241 @itemize @bullet
15242 @item raw metrics: SLOC, comment lines, blank lines, &c.
15243 @item Cyclomatic Complexity (i.e. McCabe’s Complexity)
15244 @item Halstead metrics (all of them)
15245 @item the Maintainability Index (a Visual Studio metric)
15246 @end itemize")
15247 (license license:expat)))
15248
15249 (define-public python2-radon
15250 (package-with-python2 python-radon))
15251
15252 (define-public python-sure
15253 (package
15254 (name "python-sure")
15255 (version "1.4.6")
15256 (source
15257 (origin
15258 (method url-fetch)
15259 (uri (pypi-uri "sure" version))
15260 (sha256
15261 (base32
15262 "1iyqsy2d6radi88g1qf0lziy5b39h5cpb3g5jiqyb4xi46ig3x1z"))))
15263 (build-system python-build-system)
15264 (propagated-inputs
15265 `(("python-mock" ,python-mock)
15266 ("python-six" ,python-six)))
15267 (native-inputs
15268 `(("python-nose" ,python-nose)))
15269 (home-page "https://github.com/gabrielfalcao/sure")
15270 (synopsis "Automated testing library in python for python")
15271 (description
15272 "Sure is a python library that leverages a DSL for writing assertions.
15273 Sure is heavily inspired by @code{RSpec Expectations} and @code{should.js}.")
15274 (license license:gpl3+)))
15275
15276 (define-public python2-sure
15277 (package-with-python2 python-sure))
15278
15279 (define-public python2-couleur
15280 ;; This package does not seem to support python3 at all, hence,
15281 ;; only the python2 variant definition is provided.
15282 (package
15283 (name "python2-couleur")
15284 (version "0.6.2")
15285 (source
15286 (origin
15287 (method url-fetch)
15288 (uri (pypi-uri "couleur" version))
15289 (sha256
15290 (base32
15291 "1qqaxyqz74wvid0cr119dhcwz0h0if5b5by44zl49pd5z65v58k1"))))
15292 (build-system python-build-system)
15293 (arguments
15294 `(#:python ,python-2))
15295 (home-page "https://github.com/gabrielfalcao/couleur")
15296 (synopsis
15297 "ANSI terminal tool for python, colored shell and other handy fancy features")
15298 (description
15299 "@code{Couleur} provides python programs a way to use the ANSI features in a unix
15300 terminal such as coloured output in the shell, overwriting output, indentation, etc.")
15301 ;; README.md says ASL2.0, but all source code headers are LGPL3+.
15302 ;; https://github.com/gabrielfalcao/couleur/issues/11
15303 (license license:lgpl3+)))
15304
15305 (define-public python-misaka
15306 (package
15307 (name "python-misaka")
15308 (version "2.1.0")
15309 (source
15310 (origin
15311 (method url-fetch)
15312 (uri (pypi-uri "misaka" version))
15313 (sha256
15314 (base32
15315 "1yqrq3a5rracirmvk52n28nn6ckdaz897gnigv89a9gmyn87sqw7"))))
15316 (build-system python-build-system)
15317 (arguments
15318 `(;; Line 37 of setup.py calls self.run_command('develop')
15319 ;; in the 'check' phase. This command seems to be trying
15320 ;; to write to
15321 ;; /gnu/store/...-python-<version>/lib/python<version>/site-packages/
15322 ;; for which it does not have the permission to write.
15323 #:tests? #f))
15324 (propagated-inputs
15325 `(("python-cffi" ,python-cffi)))
15326 (home-page "https://github.com/FSX/misaka")
15327 (synopsis "Python binding for Hoedown")
15328 (description
15329 "@code{Misaka} is a CFFI-based binding for @code{Hoedown}, a fast markdown processing
15330 library written in C. It features a fast HTML renderer and functionality to make custom
15331 renderers (e.g. man pages or LaTeX).")
15332 (license license:expat)))
15333
15334 (define-public python2-misaka
15335 (package-with-python2 python-misaka))
15336
15337 (define-public python2-steadymark
15338 ;; This is forced into being a python2 only variant
15339 ;; due to its dependence on couleur that has no support
15340 ;; for python3
15341 (package
15342 (name "python2-steadymark")
15343 (version "0.7.3")
15344 (source
15345 (origin
15346 (method url-fetch)
15347 (uri (pypi-uri "steadymark" version))
15348 (sha256
15349 (base32
15350 "1640i9g8dycql3cc8j0bky0jkzj0q39blfbp4lsgpkprkfgcdk8v"))))
15351 (build-system python-build-system)
15352 (native-inputs
15353 `(("python-couleur" ,python2-couleur)
15354 ("python-sure" ,python2-sure)
15355 ("python-misaka" ,python2-misaka)))
15356 (arguments
15357 `(#:python ,python-2
15358 #:phases
15359 (modify-phases %standard-phases
15360 (add-before 'build 'patch-setup-py
15361 (lambda _
15362 ;; Update requirements from dependency==version
15363 ;; to dependency>=version
15364 (substitute* "setup.py"
15365 (("==") ">="))
15366 #t)))))
15367 (home-page "https://github.com/gabrielfalcao/steadymark")
15368 (synopsis "Markdown-based test runner for python")
15369 (description
15370 "@code{Steadymark} allows documentation to be written in github-flavoured
15371 markdown. The documentation may contain snippets of code surrounded by python
15372 code blocks and @code{Steadymark} will find these snippets and run them, making
15373 sure that there are no old malfunctional examples in the documentation examples.")
15374 (license license:expat)))
15375
15376 (define-public python-nose-randomly
15377 (package
15378 (name "python-nose-randomly")
15379 (version "1.2.5")
15380 (source
15381 (origin
15382 (method url-fetch)
15383 (uri (pypi-uri "nose-randomly" version))
15384 (sha256
15385 (base32
15386 "1cw9dlr1zh3w4i438kin7z0rm8092ki52hayisyc43h9pcplq7rn"))))
15387 (build-system python-build-system)
15388 (native-inputs
15389 `(("python-nose" ,python-nose)
15390 ("python-numpy" ,python-numpy)))
15391 (home-page "https://github.com/adamchainz/nose-randomly")
15392 (synopsis
15393 "Nose plugin to randomly order tests and control random.seed")
15394 (description
15395 "This is a @code{Nose} plugin to randomly order tests which can be quite
15396 powerful in discovering hidden flaws in the tests themselves, while helping to
15397 reduce inter-test dependencies. It also helps in controlling @code{random.seed},
15398 by resetting it to a repeatable number for each test, enabling the tests to
15399 create data based on random numbers and yet remain repeatable.")
15400 (license license:bsd-3)))
15401
15402 (define-public python2-nose-randomly
15403 (package-with-python2 python-nose-randomly))
15404
15405 (define-public python-jsonpointer
15406 (package
15407 (name "python-jsonpointer")
15408 (version "1.10")
15409 (source
15410 (origin
15411 (method url-fetch)
15412 (uri (pypi-uri "jsonpointer" version))
15413 (sha256
15414 (base32
15415 "1cg0gvgqjysydv6p45v4jywg1jb3v48c7m3cbpi57zgf6nndr9cz"))))
15416 (build-system python-build-system)
15417 (home-page "https://github.com/stefankoegl/python-json-pointer")
15418 (synopsis "Identify specific nodes in a JSON document")
15419 (description "@code{jsonpointer} allows you to access specific nodes
15420 by path in a JSON document (see RFC 6901).")
15421 (license license:bsd-3)))
15422
15423 (define-public python2-jsonpointer
15424 (package-with-python2 python-jsonpointer))
15425
15426 (define-public python-jsonpatch
15427 (package
15428 (name "python-jsonpatch")
15429 (version "1.16")
15430 (source
15431 (origin
15432 (method url-fetch)
15433 ;; pypi version lacks tests.js
15434 (uri (string-append "https://github.com/stefankoegl/python-json-patch/"
15435 "archive/v" version ".tar.gz"))
15436 (file-name (string-append name "-" version ".tar.gz"))
15437 (sha256
15438 (base32
15439 "085ykisl8v7mv9h7hvhdy3l2fjzs4214gx32r5k6nx4f76hbv6y5"))))
15440 (build-system python-build-system)
15441 (native-inputs
15442 `(("python-jsonpointer" ,python-jsonpointer)))
15443 (home-page "https://github.com/stefankoegl/python-json-patch")
15444 (synopsis "Applying JSON Patches in Python 2.6+ and 3.x")
15445 (description "@code{jsonpatch} is a library and program that allows
15446 applying JSON Patches according to RFC 6902.")
15447 (license license:bsd-3)))
15448
15449 (define-public python2-jsonpatch
15450 (package-with-python2 python-jsonpatch))
15451
15452 (define-public python-jsonpatch-0.4
15453 (package (inherit python-jsonpatch)
15454 (name "python-jsonpatch")
15455 (version "0.4")
15456 (source
15457 (origin
15458 (method url-fetch)
15459 (uri (string-append "https://github.com/stefankoegl/python-json-patch/"
15460 "archive/v" version ".tar.gz"))
15461 (file-name (string-append name "-" version ".tar.gz"))
15462 (sha256
15463 (base32
15464 "0j0cd9z9zyp8kppp464jxrfgrnbgkzl1yi10i5gsv8yz6d95929d"))))))
15465
15466 (define-public python2-jsonpatch-0.4
15467 (package-with-python2 python-jsonpatch-0.4))
15468
15469 (define-public python-rfc3987
15470 (package
15471 (name "python-rfc3987")
15472 (version "1.3.7")
15473 (source
15474 (origin
15475 (method url-fetch)
15476 (uri (pypi-uri "rfc3987" version))
15477 (sha256
15478 (base32
15479 "192pclzs2y0yaywqkrlvd0x73740q310kvqvm6jldhi619mq59wi"))))
15480 (build-system python-build-system)
15481 (home-page "http://pypi.python.org/pypi/rfc3987")
15482 (synopsis "Parsing and validation of URIs (RFC 3986) and IRIs (RFC 3987)")
15483 (description "@code{rfc3987} provides routines for parsing and
15484 validation of URIs (see RFC 3986) and IRIs (see RFC 3987).")
15485 (license license:gpl3+)))
15486
15487 (define-public python2-rfc3987
15488 (package-with-python2 python-rfc3987))
15489
15490 (define-public python-validate-email
15491 (package
15492 (name "python-validate-email")
15493 (version "1.3")
15494 (source
15495 (origin
15496 (method url-fetch)
15497 (uri (pypi-uri "validate_email" version))
15498 (sha256
15499 (base32
15500 "1bxffaf5yz2cph8ki55vdvdypbwkvn2xr1firlcy62vqbzf1jivq"))))
15501 (build-system python-build-system)
15502 (home-page "http://github.com/syrusakbary/validate_email")
15503 (synopsis "Verifies if an email address is valid and really exists")
15504 (description "@code{validate_email} can be used to verify if an email
15505 address is valid and really exists.")
15506 (license license:lgpl3+)))
15507
15508 (define-public python2-validate-email
15509 (package-with-python2 python-validate-email))
15510
15511 (define-public python-flex
15512 (package
15513 (name "python-flex")
15514 (version "6.10.0")
15515 (source
15516 (origin
15517 (method url-fetch)
15518 (uri (pypi-uri "flex" version))
15519 (sha256
15520 (base32
15521 "00pamnwla3khk8nyla7y28dq9jnh69swd7f4jfsl7sn1izs8n8zk"))))
15522 (build-system python-build-system)
15523 (propagated-inputs
15524 `(("python-click" ,python-click)
15525 ("python-iso8601" ,python-iso8601)
15526 ("python-jsonpointer" ,python-jsonpointer)
15527 ("python-pyyaml" ,python-pyyaml)
15528 ("python-requests" ,python-requests)
15529 ("python-rfc3987" ,python-rfc3987)
15530 ("python-six" ,python-six)
15531 ("python-validate-email" ,python-validate-email)))
15532 (home-page "https://github.com/pipermerriam/flex")
15533 (synopsis "Validates Swagger schemata")
15534 (description "@code{flex} can be used to validate Swagger schemata.")
15535 (license license:bsd-3)))
15536
15537 (define-public python2-flex
15538 (package-with-python2 python-flex))
15539
15540 (define-public python-marshmallow
15541 (package
15542 (name "python-marshmallow")
15543 (version "3.0.0b2")
15544 (source
15545 (origin
15546 (method url-fetch)
15547 (uri (pypi-uri "marshmallow" version))
15548 (sha256
15549 (base32
15550 "11bnpvfdbczr74177p295zbkdrax2cahvbj5bqhhlprgz2xxi5d9"))))
15551 (build-system python-build-system)
15552 (propagated-inputs
15553 `(("python-dateutil" ,python-dateutil)
15554 ("python-simplejson" ,python-simplejson)))
15555 (native-inputs
15556 `(("python-pytest-3.0" ,python-pytest-3.0)
15557 ("python-pytz" ,python-pytz)))
15558 (home-page "https://github.com/marshmallow-code/marshmallow")
15559 (synopsis "Convert complex datatypes to and from native
15560 Python datatypes.")
15561 (description "@code{marshmallow} provides a library for converting
15562 complex datatypes to and from native Python datatypes.")
15563 (license license:expat)))
15564
15565 (define-public python2-marshmallow
15566 (package-with-python2 python-marshmallow))
15567
15568 (define-public python-bottle
15569 (package
15570 (name "python-bottle")
15571 (version "0.12.13")
15572 (source
15573 (origin
15574 (method url-fetch)
15575 (uri (pypi-uri "bottle" version))
15576 (sha256
15577 (base32
15578 "0m9k2a7yxvggc4kw8fsvj381vgsvfcdshg5nzy6vwrxiw2p53drr"))))
15579 (build-system python-build-system)
15580 (home-page "http://bottlepy.org/")
15581 (synopsis "WSGI framework for small web-applications.")
15582 (description "@code{python-bottle} is a WSGI framework for small web-applications.")
15583 (license license:expat)))
15584
15585 (define-public python2-bottle
15586 (package-with-python2 python-bottle))
15587
15588 (define-public python-apispec
15589 (package
15590 (name "python-apispec")
15591 (version "0.22.0")
15592 (source
15593 (origin
15594 (method url-fetch)
15595 (uri (pypi-uri "apispec" version))
15596 (sha256
15597 (base32
15598 "0y3jxmgp2d24am3hxl40f5rw9abb0r8037sagax3dv64h4n1azwq"))))
15599 (build-system python-build-system)
15600 (propagated-inputs
15601 `(("python-pyyaml" ,python-pyyaml)))
15602 (native-inputs
15603 `(("python-pytest-3.0" ,python-pytest-3.0)
15604 ("python-flask" ,python-flask)
15605 ("python-marshmallow" ,python-marshmallow)
15606 ("python-tornado" ,python-tornado)
15607 ("python-bottle" ,python-bottle)
15608 ("python-mock" ,python-mock)))
15609 (home-page "https://github.com/marshmallow-code/apispec")
15610 (synopsis "Swagger 2.0 API specification generator")
15611 (description "@code{python-apispec} is a pluggable API specification
15612 generator. Currently supports the OpenAPI specification (f.k.a.
15613 Swagger 2.0).")
15614 (license license:expat)))
15615
15616 (define-public python2-apispec
15617 (package-with-python2 python-apispec))
15618
15619 (define-public python-flasgger
15620 (package
15621 (name "python-flasgger")
15622 (version "0.6.3")
15623 (source
15624 (origin
15625 (method url-fetch)
15626 (uri (string-append "https://github.com/rochacbruno/flasgger/archive/"
15627 version ".tar.gz"))
15628 (file-name (string-append name "-" version ".tar.gz"))
15629 (sha256
15630 (base32
15631 "1gqzlm0rb55fdpsy5ipkganlx9cnpi454fqyycr03jm22zql14ay"))))
15632 (build-system python-build-system)
15633 (arguments
15634 `(#:phases
15635 (modify-phases %standard-phases
15636 (replace 'check
15637 (lambda* (#:key inputs outputs #:allow-other-keys)
15638 (substitute* "Makefile"
15639 (("flake8 flasgger --ignore=F403")
15640 "flake8 flasgger --ignore=E731,F403"))
15641 (setenv "PYTHONPATH" (string-append (getcwd)
15642 ":"
15643 (getenv "PYTHONPATH")))
15644 (zero? (system* "py.test")))))))
15645 (propagated-inputs
15646 `(("python-flask" ,python-flask)
15647 ("python-pyyaml" ,python-pyyaml)
15648 ("python-jsonschema" ,python-jsonschema)
15649 ("python-mistune" ,python-mistune)
15650 ("python-six" ,python-six)))
15651 (native-inputs
15652 `(("python-decorator" ,python-decorator)
15653 ("python-flake8" ,python-flake8)
15654 ("python-flask-restful" ,python-flask-restful)
15655 ("python-flex" ,python-flex)
15656 ("python-pytest-3.0" ,python-pytest-3.0)
15657 ("python-pytest-cov" ,python-pytest-cov)
15658 ("python-marshmallow" ,python-marshmallow)
15659 ("python-apispec" ,python-apispec)))
15660 (home-page "https://github.com/rochacbruno/flasgger/")
15661 (synopsis "Extract Swagger specs from your Flask project")
15662 (description "@code{python-flasgger} allows extracting Swagger specs
15663 from your Flask project. It is a fork of Flask-Swagger.")
15664 (license license:expat)))
15665
15666 (define-public python2-flasgger
15667 (package-with-python2 python-flasgger))
15668
15669 (define-public python-swagger-spec-validator
15670 (package
15671 (name "python-swagger-spec-validator")
15672 (version "2.1.0")
15673 (source
15674 (origin
15675 (method url-fetch)
15676 (uri (pypi-uri "swagger-spec-validator" version))
15677 (sha256
15678 (base32
15679 "13hkpn2lycwr0468yqhjb3kwszqf7hjwlq61w7vdxq1caz31k4nw"))))
15680 (build-system python-build-system)
15681 (propagated-inputs
15682 `(("python-jsonschema" ,python-jsonschema)
15683 ("python-six" ,python-six)))
15684 (home-page
15685 "http://github.com/Yelp/swagger_spec_validator")
15686 (synopsis "Validation of Swagger specifications")
15687 (description "@code{swagger_spec_validator} provides a library for
15688 validating Swagger API specifications.")
15689 (license license:asl2.0)))
15690
15691 (define-public python2-swagger-spec-validator
15692 (package-with-python2 python-swagger-spec-validator))
15693
15694 (define-public python-apache-libcloud
15695 (package
15696 (name "python-apache-libcloud")
15697 (version "2.0.0")
15698 (source
15699 (origin
15700 (method url-fetch)
15701 (uri (pypi-uri "apache-libcloud" version))
15702 (sha256
15703 (base32
15704 "1a71z02ckcxld72k4qgmdnkjan52c4wczncs3p2mp5yafh7dsan7"))))
15705 (build-system python-build-system)
15706 (arguments
15707 `(#:phases
15708 (modify-phases %standard-phases
15709 (add-after 'unpack 'patch-ssh
15710 (lambda* (#:key inputs #:allow-other-keys)
15711 (substitute* "libcloud/compute/ssh.py"
15712 (("'ssh'") (string-append "'" (assoc-ref inputs "openssh")
15713 "/bin/ssh" "'")))
15714 #t))
15715 (add-after 'unpack 'patch-tests
15716 (lambda _
15717 (substitute* "./libcloud/test/test_file_fixtures.py"
15718 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-923>.
15719 (("def _ascii") "def _raw_data(self, method, url, body, headers):
15720 return (httplib.OK,
15721 \"1234abcd\",
15722 {\"test\": \"value\"},
15723 httplib.responses[httplib.OK])
15724 def _ascii"))
15725 (substitute* "libcloud/test/compute/test_ssh_client.py"
15726 (("class ShellOutSSHClientTests")
15727 "@unittest.skip(\"Guix container doesn't have ssh service\")
15728 class ShellOutSSHClientTests")
15729 ;; See <https://issues.apache.org/jira/browse/LIBCLOUD-924>.
15730 (("'.xf0.x90.x8d.x88'") "b'\\xF0\\x90\\x8D\\x88'")
15731 (("'.xF0', '.x90', '.x8D', '.x88'")
15732 "b'\\xF0', b'\\x90', b'\\x8D', b'\\x88'"))
15733 #t)))))
15734 (inputs
15735 `(("openssh" ,openssh)))
15736 (propagated-inputs
15737 `(("python-paramiko" ,python-paramiko)
15738 ("python-requests" ,python-requests)))
15739 (native-inputs
15740 `(("python-lockfile" ,python-lockfile)
15741 ("python-mock" ,python-mock)
15742 ("python-requests-mock" ,python-requests-mock)))
15743 (home-page "https://libcloud.apache.org/")
15744 (synopsis "Unified Cloud API")
15745 (description "@code{libcloud} is a Python library for interacting with
15746 many of the popular cloud service providers using a unified API.")
15747 (license license:asl2.0)))
15748
15749 (define-public python2-apache-libcloud
15750 (package-with-python2 python-apache-libcloud))
15751
15752 (define-public python-smmap2
15753 (package
15754 (name "python-smmap2")
15755 (version "2.0.3")
15756 (source
15757 (origin
15758 (method url-fetch)
15759 (uri (pypi-uri "smmap2" version))
15760 (sha256
15761 (base32
15762 "1hvn28p3zvxa98sbi9lrqvv2ps4q284j4jq9a619zw0m7yv0sly7"))))
15763 (build-system python-build-system)
15764 (native-inputs
15765 `(("python-nosexcover" ,python-nosexcover)))
15766 (home-page "https://github.com/Byron/smmap")
15767 (synopsis "Python sliding window memory map manager")
15768 (description "@code{smmap2} is a pure Python implementation of a sliding
15769 window memory map manager.")
15770 (license license:bsd-3)))
15771
15772 (define-public python2-smmap2
15773 (package-with-python2 python-smmap2))
15774
15775 (define-public python-regex
15776 (package
15777 (name "python-regex")
15778 (version "2017.06.07")
15779 (source (origin
15780 (method url-fetch)
15781 (uri (pypi-uri "regex" version))
15782 (sha256
15783 (base32
15784 "06r6b7yigikbj3a72whl85r2b64pj1r0ypmw9yalmkm0wnxq8mz4"))))
15785 (build-system python-build-system)
15786 (home-page "https://bitbucket.org/mrabarnett/mrab-regex")
15787 (synopsis "Alternative regular expression module")
15788 (description "This regular expression implementation is backwards-
15789 compatible with the standard @code{re} module, but offers additional
15790 functionality like full case-folding for case-insensitive matches in Unicode.")
15791 (license license:psfl)))
15792
15793 (define-public python2-regex
15794 (package-with-python2 python-regex))
15795
15796 (define-public python2-pyopengl
15797 (package
15798 (name "python2-pyopengl")
15799 (version "3.1.0")
15800 (source
15801 (origin
15802 (method url-fetch)
15803 (uri (pypi-uri "PyOpenGL" version))
15804 (sha256
15805 (base32
15806 "1byxjj6a8rwzhxhjqlc588zdad2qwxdd7vlam2653ylll31waiwv"))))
15807 (arguments
15808 `(#:python ,python-2))
15809 (build-system python-build-system)
15810 (home-page "http://pyopengl.sourceforge.net")
15811 (synopsis "Standard OpenGL bindings for Python")
15812 (description
15813 "PyOpenGL is the most common cross platform Python binding to OpenGL and
15814 related APIs. The binding is created using the standard @code{ctypes}
15815 library.")
15816 (license license:bsd-3)))
15817
15818 (define-public python-rencode
15819 (package
15820 (name "python-rencode")
15821 (version "1.0.3")
15822 (source
15823 (origin
15824 (method url-fetch)
15825 (uri (pypi-uri "rencode" version))
15826 (sha256
15827 (base32
15828 "08if5yax1xn5yfp8p3765ccjmfcv9di7i4m5jckgnwvdsgznwkbj"))))
15829 (build-system python-build-system)
15830 (native-inputs `(("pkg-config" ,pkg-config)
15831 ("python-cython", python-cython)))
15832 (home-page "https://github.com/aresch/rencode")
15833 (synopsis "Serialization of heterogeneous data structures")
15834 (description
15835 "The @code{rencode} module is a data structure serialization library,
15836 similar to @code{bencode} from the BitTorrent project. For complex,
15837 heterogeneous data structures with many small elements, r-encoding stake up
15838 significantly less space than b-encodings. This version of rencode is a
15839 complete rewrite in Cython to attempt to increase the performance over the
15840 pure Python module.")
15841 (license license:bsd-3)))
15842
15843 (define-public python2-rencode
15844 (package-with-python2 python-rencode))
15845
15846 (define-public python-flask-principal
15847 (package
15848 (name "python-flask-principal")
15849 (version "0.4.0")
15850 (source
15851 (origin
15852 (method url-fetch)
15853 (uri (pypi-uri "Flask-Principal" version))
15854 (sha256
15855 (base32
15856 "0lwlr5smz8vfm5h9a9i7da3q1c24xqc6vm9jdywdpgxfbi5i7mpm"))))
15857 (build-system python-build-system)
15858 (propagated-inputs
15859 `(("python-blinker" ,python-blinker)))
15860 (native-inputs
15861 `(("python-flask" ,python-flask)
15862 ("python-nose" ,python-nose)))
15863 (home-page "http://packages.python.org/Flask-Principal/")
15864 (synopsis "Identity management for Flask")
15865 (description "@code{flask_principal} is a identity management library for
15866 Flask. It supports managing both authentication and authorization data in a
15867 thread-local variable.")
15868 (license license:expat)))
15869
15870 (define-public python2-flask-principal
15871 (package-with-python2 python-flask-principal))
15872
15873 (define-public python-flask-httpauth
15874 (package
15875 (name "python-flask-httpauth")
15876 (version "3.2.3")
15877 (source
15878 (origin
15879 (method url-fetch)
15880 (uri (pypi-uri "Flask-HTTPAuth" version))
15881 (sha256
15882 (base32
15883 "13gff5w1mqpzm5nccyg02v3ifb9ifqh5k866cssjhghhg6msfjsz"))))
15884 (build-system python-build-system)
15885 (native-inputs
15886 `(("python-flask" ,python-flask)))
15887 (home-page "http://github.com/miguelgrinberg/flask-httpauth/")
15888 (synopsis "Basic and Digest HTTP authentication for Flask routes")
15889 (description "@code{flask_httpauth} provides Basic and Digest HTTP
15890 authentication for Flask routes.")
15891 (license license:expat)))
15892
15893 (define-public python2-flask-httpauth
15894 (package-with-python2 python-flask-httpauth))