From: Marius Bakke <mbakke@fastmail.com>
To: Tobias Geerinckx-Rice <me@tobias.gr>, 29618@debbugs.gnu.org
Subject: [bug#29618] [PATCH] gnu: Add uthash.
Date: Tue, 12 Dec 2017 01:15:42 +0100 [thread overview]
Message-ID: <87zi6ox0lt.fsf@fastmail.com> (raw)
In-Reply-To: <20171208184540.26410-1-me@tobias.gr>
[-- Attachment #1: Type: text/plain, Size: 3506 bytes --]
Tobias Geerinckx-Rice <me@tobias.gr> writes:
> * gnu/packages/datastructures.scm (uthash): New public variable.
> ---
> gnu/packages/datastructures.scm | 54 +++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 54 insertions(+)
>
> diff --git a/gnu/packages/datastructures.scm b/gnu/packages/datastructures.scm
> index 36318ee04..7db2fc82a 100644
> --- a/gnu/packages/datastructures.scm
> +++ b/gnu/packages/datastructures.scm
> @@ -116,3 +116,57 @@ with the number of cores. liburcu-cds provides efficient data structures
> based on RCU and lock-free algorithms. These structures include hash tables,
> queues, stacks, and doubly-linked lists.")
> (license license:lgpl2.1+)))
> +
> +(define-public uthash
> + (package
> + (name "uthash")
> + (version "2.0.2")
> + (source
> + (origin
> + (method url-fetch)
> + (file-name (string-append name "-" version ".tar.gz"))
> + (uri (string-append "https://github.com/troydhanson/uthash/archive/v"
> + version ".tar.gz"))
> + (sha256
> + (base32
> + "1la82gdlyl7m8ahdjirigwfh7zjgkc24cvydrqcri0vsvm8iv8rl"))))
> + (build-system gnu-build-system)
> + (native-inputs
> + `(("perl" ,perl)))
> + (arguments
> + `(#:make-flags (list "CC=gcc")
> + #:phases
> + (modify-phases %standard-phases
> + (delete 'configure) ; nothing to configure
> + (delete 'build) ; nothing to build
> + (replace 'check
> + (lambda* (#:key make-flags #:allow-other-keys)
> + (with-directory-excursion "tests"
> + (zero? (apply system* "make"
> + make-flags)))))
> + (replace 'install
> + ;; There is no top-level Makefile to do this for us.
> + (lambda* (#:key outputs #:allow-other-keys)
> + (let* ((out (assoc-ref outputs "out"))
> + (doc (string-append out "/share/doc/" ,name))
> + (include (string-append out "/include")))
> + ;; Don't install HTML files: they are generated from these .txt
> + ;; files, could be stale, and updating them requires ‘asciidoc‘.
> + (for-each (λ (file) (install-file file doc))
> + (append (list "LICENSE")
> + (find-files "doc" "\\.txt$")))
Just FYI: In 'core-updates', there is now a phase that installs license
files automatically.
> + (for-each (λ (file) (install-file file include))
> + (find-files "src" "\\.h$"))))))))
Return #t here. LGTM!
> + (home-page "https://troydhanson.github.io/uthash/")
> + (synopsis
> + "Hash tables, lists, and other data structures implemented as C macros")
> + (description
> + "uthash implements a hash table and a few other basic data structures
> +as C preprocessor macros. It aims to be minimalistic and efficient: it's
> +around 1,000 lines of code which, being macros, inline automatically.
> +
> +Unlike function calls with fixed prototypes, macros operate on untyped
> +arguments. Thus, they are able to work with any type of structure or key.
> +Any C structure can be stored in a hash table by adding @code{UT_hash_handle}
> +to the structure and choosing one or more fields to act as the key.")
> + (license license:bsd-2)))
> --
> 2.15.0
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]
next prev parent reply other threads:[~2017-12-12 0:16 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-12-08 18:45 [bug#29618] [PATCH] gnu: Add uthash Tobias Geerinckx-Rice
2017-12-11 13:27 ` Ludovic Courtès
2017-12-12 0:15 ` Marius Bakke [this message]
2017-12-12 4:18 ` bug#29618: " Tobias Geerinckx-Rice
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87zi6ox0lt.fsf@fastmail.com \
--to=mbakke@fastmail.com \
--cc=29618@debbugs.gnu.org \
--cc=me@tobias.gr \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/guix.git
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.