c9baba9212
(My OCD kicked in today...) Remove repeated package names, capitalize first word, remove trailing periods and move overlong descriptions to longDescription. I also simplified some descriptions as well, when they were particularly long or technical, often based on Arch Linux' package descriptions. I've tried to stay away from generated expressions (and I think I succeeded). Some specifics worth mentioning: * cron, has "Vixie Cron" in its description. The "Vixie" part is not mentioned anywhere else. I kept it in a parenthesis at the end of the description. * ctags description started with "Exuberant Ctags ...", and the "exuberant" part is not mentioned elsewhere. Kept it in a parenthesis at the end of description. * nix has the description "The Nix Deployment System". Since that doesn't really say much what it is/does (especially after removing the package name!), I changed that to "Powerful package manager that makes package management reliable and reproducible" (borrowed from nixos.org). * Tons of "GNU Foo, Foo is a [the important bits]" descriptions is changed to just [the important bits]. If the package name doesn't contain GNU I don't think it's needed to say it in the description either.
81 lines
2.8 KiB
Nix
81 lines
2.8 KiB
Nix
{ stdenv, fetchurl, adns, curl, gettext, gmp, gnutls, libextractor
|
|
, libgcrypt, libgnurl, libidn, libmicrohttpd, libtool, libunistring
|
|
, makeWrapper, ncurses, pkgconfig, libxml2, sqlite, zlib }:
|
|
|
|
stdenv.mkDerivation rec {
|
|
name = "gnunet-0.10.1";
|
|
|
|
src = fetchurl {
|
|
url = "mirror://gnu/gnunet/${name}.tar.gz";
|
|
sha256 = "04wxzm3wkgqbn42b8ksr4cx6m5cckyig5cls1adh0nwdczwvnp7n";
|
|
};
|
|
|
|
buildInputs = [
|
|
adns curl gettext gmp gnutls libextractor libgcrypt libgnurl libidn
|
|
libmicrohttpd libtool libunistring libxml2 makeWrapper ncurses
|
|
pkgconfig sqlite zlib
|
|
];
|
|
|
|
preConfigure = ''
|
|
# Brute force: since nix-worker chroots don't provide
|
|
# /etc/{resolv.conf,hosts}, replace all references to `localhost'
|
|
# by their IPv4 equivalent.
|
|
for i in $(find . \( -name \*.c -or -name \*.conf \) \
|
|
-exec grep -l '\<localhost\>' {} \;)
|
|
do
|
|
echo "$i: substituting \`127.0.0.1' to \`localhost'..."
|
|
sed -i "$i" -e's/\<localhost\>/127.0.0.1/g'
|
|
done
|
|
|
|
# Make sure the tests don't rely on `/tmp', for the sake of chroot
|
|
# builds.
|
|
for i in $(find . \( -iname \*test\*.c -or -name \*.conf \) \
|
|
-exec grep -l /tmp {} \;)
|
|
do
|
|
echo "$i: replacing references to \`/tmp' by \`$TMPDIR'..."
|
|
substituteInPlace "$i" --replace "/tmp" "$TMPDIR"
|
|
done
|
|
|
|
# Ensure NSS installation works fine
|
|
configureFlags="$configureFlags --with-nssdir=$out/lib"
|
|
patchShebangs src/gns/nss/install-nss-plugin.sh
|
|
'';
|
|
|
|
doCheck = false;
|
|
|
|
/* FIXME: Tests must be run this way, but there are still a couple of
|
|
failures.
|
|
|
|
postInstall =
|
|
'' export GNUNET_PREFIX="$out"
|
|
export PATH="$out/bin:$PATH"
|
|
make -k check
|
|
'';
|
|
*/
|
|
|
|
meta = {
|
|
description = "GNU's decentralized anonymous and censorship-resistant P2P framework";
|
|
|
|
longDescription = ''
|
|
GNUnet is a framework for secure peer-to-peer networking that
|
|
does not use any centralized or otherwise trusted services. A
|
|
first service implemented on top of the networking layer
|
|
allows anonymous censorship-resistant file-sharing. Anonymity
|
|
is provided by making messages originating from a peer
|
|
indistinguishable from messages that the peer is routing. All
|
|
peers act as routers and use link-encrypted connections with
|
|
stable bandwidth utilization to communicate with each other.
|
|
GNUnet uses a simple, excess-based economic model to allocate
|
|
resources. Peers in GNUnet monitor each others behavior with
|
|
respect to resource usage; peers that contribute to the
|
|
network are rewarded with better service.
|
|
'';
|
|
|
|
homepage = http://gnunet.org/;
|
|
|
|
license = stdenv.lib.licenses.gpl2Plus;
|
|
|
|
maintainers = with stdenv.lib.maintainers; [ ludo viric ];
|
|
platforms = stdenv.lib.platforms.gnu;
|
|
};
|
|
}
|