diff options
Diffstat (limited to 'nixpkgs/pkgs/development/libraries/nettle')
-rw-r--r-- | nixpkgs/pkgs/development/libraries/nettle/cygwin.patch | 12 | ||||
-rw-r--r-- | nixpkgs/pkgs/development/libraries/nettle/default.nix | 10 | ||||
-rw-r--r-- | nixpkgs/pkgs/development/libraries/nettle/generic.nix | 70 |
3 files changed, 92 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/development/libraries/nettle/cygwin.patch b/nixpkgs/pkgs/development/libraries/nettle/cygwin.patch new file mode 100644 index 000000000000..d5036237c8d5 --- /dev/null +++ b/nixpkgs/pkgs/development/libraries/nettle/cygwin.patch @@ -0,0 +1,12 @@ +Cygwin sucks. Patch suggested by Niel Möller. + +--- nettle-2.0/examples/setup-env 2009-06-08 20:27:12.000000000 +0200 ++++ nettle-2.0/examples/setup-env 2009-09-18 16:58:03.000000000 +0200 +@@ -3,5 +3,5 @@ + set -e + + if [ -x rsa-keygen ] ; then +- ./rsa-keygen -r rsa-decrypt -o testkey || exit 1 ++ ./rsa-keygen -r rsa-decrypt.exe -o testkey || exit 1 + fi + diff --git a/nixpkgs/pkgs/development/libraries/nettle/default.nix b/nixpkgs/pkgs/development/libraries/nettle/default.nix new file mode 100644 index 000000000000..36c9f0e6ac75 --- /dev/null +++ b/nixpkgs/pkgs/development/libraries/nettle/default.nix @@ -0,0 +1,10 @@ +{ callPackage, fetchurl, ... } @ args: + +callPackage ./generic.nix (args // rec { + version = "3.5.1"; + + src = fetchurl { + url = "mirror://gnu/nettle/nettle-${version}.tar.gz"; + sha256 = "06clvkdfxhlbagn4afssylmn5vrak59dlmnvy8b2xc31hycs3k3m"; + }; +}) diff --git a/nixpkgs/pkgs/development/libraries/nettle/generic.nix b/nixpkgs/pkgs/development/libraries/nettle/generic.nix new file mode 100644 index 000000000000..9939cbf60679 --- /dev/null +++ b/nixpkgs/pkgs/development/libraries/nettle/generic.nix @@ -0,0 +1,70 @@ +{ stdenv, buildPackages, gmp, gnum4 + +# Version specific args +, version, src +, ...}: + +stdenv.mkDerivation ({ + name = "nettle-${version}"; + + inherit src; + + outputs = [ "out" "dev" ]; + outputBin = "dev"; + + depsBuildBuild = [ buildPackages.stdenv.cc ]; + nativeBuildInputs = [ gnum4 ]; + propagatedBuildInputs = [ gmp ]; + + configureFlags = [ "--enable-fat" ]; # runtime selection of HW-accelerated code + + doCheck = (stdenv.hostPlatform.system != "i686-cygwin" && !stdenv.isDarwin); + + enableParallelBuilding = true; + + patches = stdenv.lib.optional (stdenv.hostPlatform.system == "i686-cygwin") + ./cygwin.patch; + + meta = with stdenv.lib; { + description = "Cryptographic library"; + + longDescription = '' + Nettle is a cryptographic library that is designed to fit + easily in more or less any context: In crypto toolkits for + object-oriented languages (C++, Python, Pike, ...), in + applications like LSH or GNUPG, or even in kernel space. In + most contexts, you need more than the basic cryptographic + algorithms, you also need some way to keep track of available + algorithms, their properties and variants. You often have + some algorithm selection process, often dictated by a protocol + you want to implement. + + And as the requirements of applications differ in subtle and + not so subtle ways, an API that fits one application well can + be a pain to use in a different context. And that is why + there are so many different cryptographic libraries around. + + Nettle tries to avoid this problem by doing one thing, the + low-level crypto stuff, and providing a simple but general + interface to it. In particular, Nettle doesn't do algorithm + selection. It doesn't do memory allocation. It doesn't do any + I/O. + ''; + + license = licenses.gpl2Plus; + + homepage = http://www.lysator.liu.se/~nisse/nettle/; + + platforms = platforms.all; + }; +} + +// + +stdenv.lib.optionalAttrs stdenv.isSunOS { + # Make sure the right <gmp.h> is found, and not the incompatible + # /usr/include/mp.h from OpenSolaris. See + # <https://lists.gnu.org/archive/html/hydra-users/2012-08/msg00000.html> + # for details. + configureFlags = [ "--with-include-path=${gmp.dev}/include" ]; +}) |