gnu: libretro-lowresnx: Update to 1.2.
[jackhill/guix/guix.git] / gnu / packages / wireservice.scm
CommitLineData
451742bc
PL
1;;; GNU Guix --- Functional package management for GNU
2;;; Copyright © 2019 Pierre Langlois <pierre.langlois@gmx.com>
ef617ded 3;;; Copyright © 2020 Tobias Geerinckx-Rice <me@tobias.gr>
43d8faf8 4;;; Copyright © 2020 Tanguy Le Carrour <tanguy@bioneland.org>
451742bc
PL
5;;;
6;;; This file is part of GNU Guix.
7;;;
8;;; GNU Guix is free software; you can redistribute it and/or modify it
9;;; under the terms of the GNU General Public License as published by
10;;; the Free Software Foundation; either version 3 of the License, or (at
11;;; your option) any later version.
12;;;
13;;; GNU Guix is distributed in the hope that it will be useful, but
14;;; WITHOUT ANY WARRANTY; without even the implied warranty of
15;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16;;; GNU General Public License for more details.
17;;;
18;;; You should have received a copy of the GNU General Public License
19;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
20
21(define-module (gnu packages wireservice)
22 #:use-module ((guix licenses) #:prefix license:)
23 #:use-module (guix build-system python)
bf187d92 24 #:use-module (guix download)
451742bc
PL
25 #:use-module (guix git-download)
26 #:use-module (guix packages)
27 #:use-module (gnu packages)
28 #:use-module (gnu packages check)
9b2850c8 29 #:use-module (gnu packages databases)
451742bc
PL
30 #:use-module (gnu packages python-web)
31 #:use-module (gnu packages python-xyz)
dc835e75 32 #:use-module (gnu packages sphinx)
55e1475c
MB
33 #:use-module (gnu packages time)
34 #:use-module (gnu packages xml))
451742bc 35
b9a1d74d
PL
36;; Common package definition for packages from https://github.com/wireservice.
37(define-syntax-rule (wireservice-package extra-fields ...)
451742bc 38 (package
451742bc 39 (build-system python-build-system)
451742bc
PL
40 (arguments
41 `(#:phases
42 (modify-phases %standard-phases
43 (replace 'check
44 (lambda _
45 (invoke "nosetests" "tests")))
46 (add-after 'install 'install-docs
47 (lambda* (#:key outputs #:allow-other-keys)
48 (let* ((out (assoc-ref outputs "out"))
49 (doc (string-append out "/share/doc/"
50 ,(package-name this-package)
51 "-"
52 ,(package-version this-package))))
53 (with-directory-excursion "docs"
54 (for-each
55 (lambda (target)
56 (invoke "make" target)
57 (copy-recursively (string-append "_build/" target)
58 (string-append doc "/" target)))
59 '("html" "dirhtml" "singlehtml" "text")))
60 #t))))))
b9a1d74d
PL
61 (license license:expat)
62 extra-fields ...))
451742bc
PL
63
64(define-public python-leather
b9a1d74d
PL
65 (wireservice-package
66 (name "python-leather")
67 (version "0.3.3")
68 (source (origin
69 (method git-fetch)
70 (uri (git-reference
b0e7b699 71 (url "https://github.com/wireservice/leather")
b9a1d74d
PL
72 (commit version)))
73 (file-name (git-file-name name version))
74 (sha256
75 (base32
76 "1ck3dplni99sv4s117cbm07ydwwjsrxkhdy19rnk0iglia1d4s5i"))))
77 (native-inputs
78 `(("python-nose" ,python-nose)
79 ("python-sphinx" ,python-sphinx)
80 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)
81 ("python-csselect" ,python-cssselect)
82 ("python-lxml" ,python-lxml)))
83 (propagated-inputs
84 `(("python-six" ,python-six)))
85 (home-page "https://leather.rtfd.org")
86 (synopsis "Python charting for 80% of humans")
87 (description "Leather is a Python charting library for those who need
451742bc 88charts now and don't care if they're perfect.")))
dc835e75
PL
89
90(define-public python-agate
b9a1d74d
PL
91 (wireservice-package
92 (name "python-agate")
93 (version "1.6.1")
94 (source (origin
95 (method git-fetch)
96 (uri (git-reference
b0e7b699 97 (url "https://github.com/wireservice/agate")
b9a1d74d
PL
98 (commit version)))
99 (file-name (git-file-name name version))
100 (sha256
101 (base32
102 "077zj8xad8hsa3nqywvf7ircirmx3krxdipl8wr3dynv3l3khcpl"))))
103 (native-inputs
104 `(("python-nose" ,python-nose)
105 ("python-sphinx" ,python-sphinx)
106 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)
107 ("python-csselect" ,python-cssselect)
108 ("python-lxml" ,python-lxml)))
109 (propagated-inputs
110 `(("python-babel" ,python-babel)
111 ("python-isodate" ,python-isodate)
112 ("python-leather" ,python-leather)
113 ("python-parsedatetime" ,python-parsedatetime)
114 ("python-pytimeparse" ,python-pytimeparse)
115 ("python-six" ,python-six)
116 ("python-slugify" ,python-slugify)))
117 (home-page "https://agate.rtfd.org")
118 (synopsis "Data analysis library")
119 (description "Agate is a Python data analysis library. It is an
dc835e75
PL
120alternative to numpy and pandas that solves real-world problems with readable
121code. Agate was previously known as journalism.")))
9b2850c8
PL
122
123(define-public python-agate-sql
b9a1d74d
PL
124 (wireservice-package
125 (name "python-agate-sql")
126 (version "0.5.4")
127 (source (origin
128 (method git-fetch)
129 (uri (git-reference
b0e7b699 130 (url "https://github.com/wireservice/agate-sql")
b9a1d74d
PL
131 (commit version)))
132 (file-name (git-file-name name version))
133 (sha256
134 (base32
135 "16q0b211n5b1qmhzkfl2jr56lda0rvyh5j1wzw26h2n4pm4wxlx2"))))
136 (native-inputs
137 `(("python-nose" ,python-nose)
138 ("python-sphinx" ,python-sphinx)
139 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)))
140 (propagated-inputs
141 `(("python-agate" ,python-agate)
142 ("python-crate" ,python-crate)
143 ("python-sqlalchemy" ,python-sqlalchemy)))
144 (home-page "https://agate-sql.rtfd.org")
145 (synopsis "SQL read/write support to agate")
146 (description "@code{agatesql} uses a monkey patching pattern to add SQL
9b2850c8 147support to all @code{agate.Table} instances.")))
f1122a2c
PL
148
149(define-public python-agate-dbf
b9a1d74d
PL
150 (wireservice-package
151 (name "python-agate-dbf")
152 (version "0.2.1")
153 (source (origin
154 (method git-fetch)
155 (uri (git-reference
b0e7b699 156 (url "https://github.com/wireservice/agate-dbf")
b9a1d74d
PL
157 (commit version)))
158 (file-name (git-file-name name version))
159 (sha256
160 (base32
161 "1y49fi6pmm7gzhajvqmfpcca2sqnwj24fqnsvzwk7r1hg2iaa2gi"))))
162 (native-inputs
163 `(("python-nose" ,python-nose)
164 ("python-sphinx" ,python-sphinx)
165 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)))
166 (propagated-inputs
167 `(("python-agate" ,python-agate)
168 ("python-dbfread" ,python-dbfread)))
169 (home-page "https://agate-dbf.rtfd.org")
170 (synopsis "Add read support for dbf files to agate")
171 (description "@code{agatedbf} uses a monkey patching pattern to add read
f1122a2c 172for dbf files support to all @code{agate.Table} instances.")))
213b05f0
PL
173
174(define-public python-agate-excel
b9a1d74d
PL
175 (wireservice-package
176 (name "python-agate-excel")
177 (version "0.2.3")
178 (source (origin
179 (method git-fetch)
180 (uri (git-reference
b0e7b699 181 (url "https://github.com/wireservice/agate-excel")
b9a1d74d
PL
182 (commit version)))
183 (file-name (git-file-name name version))
184 (sha256
185 (base32
186 "1k5lv21k19s7kgbj5srd1xgrkqvxqqs49qwj33zncs9l7851afy7"))))
187 (native-inputs
188 `(("python-nose" ,python-nose)
189 ("python-sphinx" ,python-sphinx)
190 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)))
191 (propagated-inputs
192 `(("python-agate" ,python-agate)
193 ("python-openpyxl" ,python-openpyxl)
194 ("python-xlrd" ,python-xlrd)))
195 (home-page "https://agate-excel.rtfd.org")
196 (synopsis "Add read support for Excel files (xls and xlsx) to agate")
197 (description "@code{agateexcel} uses a monkey patching pattern to add read
213b05f0 198for xls and xlsx files support to all @code{agate.Table} instances.")))
bf187d92
PL
199
200(define-public csvkit
201 (package
202 (name "csvkit")
ef617ded 203 (version "1.0.5")
bf187d92
PL
204 (source (origin
205 (method url-fetch)
206 (uri (pypi-uri "csvkit" version))
207 (sha256
208 (base32
ef617ded 209 "1ffmbzk4rxnl1yhqfl58v7kvl5m9cbvjm8v7xp4mvr00sgs91lvv"))))
bf187d92
PL
210 (build-system python-build-system)
211 (native-inputs
ef617ded 212 `(("python-psycopg2" ,python-psycopg2) ; to test PostgreSQL support
bf187d92
PL
213 ("python-sphinx" ,python-sphinx)
214 ("python-sphinx-rtd-theme" ,python-sphinx-rtd-theme)))
215 (inputs
216 `(("python-agate-dbf" ,python-agate-dbf)
217 ("python-agate-excel" ,python-agate-excel)
218 ("python-agate-sql" ,python-agate-sql)
43d8faf8
TLC
219 ("python-six" ,python-six)
220 ("python-text-unidecode" ,python-text-unidecode)))
bf187d92
PL
221 (arguments
222 `(#:phases
223 (modify-phases %standard-phases
224 (add-after 'install 'install-docs
225 (lambda* (#:key outputs #:allow-other-keys)
226 (let* ((out (assoc-ref outputs "out"))
227 (man1 (string-append out "/share/man/man1")))
228 (with-directory-excursion "docs"
229 (invoke "make" "man")
230 (copy-recursively "_build/man" man1))
231 #t))))))
232 (home-page "https://csvkit.rtfd.org")
233 (synopsis "Command-line tools for working with CSV")
234 (description "csvkit is a suite of command-line tools for converting to
235and working with CSV. It provides the following commands:
236@itemize
237@item Input:
238 @itemize
239 @item @command{in2csv}: Convert various formats to CSV.
240 @item @command{sql2csv}: Execute SQL commands on a database and return the
241data as CSV.
242 @end itemize
243@item Processing:
244 @itemize
245 @item @command{csvclean}: Remove common syntax errors.
246 @item @command{csvcut}: Filter and truncate CSV files.
247 @item @command{csvgrep}: Filter tabular data to only those rows where
248certain columns contain a given value or match a regular expression.
249 @item @command{csvjoin}: Merges two or more CSV tables together using a
250method analogous to SQL JOIN operation.
251 @item @command{csvsort}: Sort CSV files.
252 @item @command{csvstack}: Stack up the rows from multiple CSV files,
253optionally adding a grouping value to each row.
254 @end itemize
255@item Output and analysis:
256 @itemize
257 @item @command{csvformat}: Convert a CSV file to a custom output format.
258 @item @command{csvjson}: Converts a CSV file into JSON or GeoJSON.
259 @item @command{csvlook}: Renders a CSV to the command line in a
260Markdown-compatible, fixed-width format.
261 @item @command{csvpy}: Loads a CSV file into a @code{agate.csv.Reader}
262object and then drops into a Python shell so the user can inspect the data
263however they see fit.
264 @item @command{csvsql}: Generate SQL statements for a CSV file or execute
265those statements directly on a database.
266 @item @command{csvstat}: Prints descriptive statistics for all columns in a
267CSV file.
268 @end itemize
269@end itemize")
270 (license license:expat)))