libgcrypt: Revert to old style

This commit is contained in:
Eelco Dolstra 2015-06-04 11:14:24 +02:00
parent c47e78bbec
commit 330d198be1
3 changed files with 20 additions and 59 deletions

View File

@ -1,20 +1,7 @@
{ stdenv, fetchurl { lib, stdenv, fetchurl, libgpgerror, enableCapabilities ? false, libcap }:
, libgpgerror
# Optional Dependencies assert enableCapabilities -> stdenv.isLinux;
, libcap ? null
}:
let
mkFlag = trueStr: falseStr: cond: name: val:
if cond == null then null else
"--${if cond != false then trueStr else falseStr}${name}${if val != null && cond != false then "=${val}" else ""}";
mkWith = mkFlag "with-" "without-";
shouldUsePkg = pkg: if pkg != null && stdenv.lib.any (x: x == stdenv.system) pkg.meta.platforms then pkg else null;
optLibcap = shouldUsePkg libcap;
in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
name = "libgcrypt-1.5.4"; name = "libgcrypt-1.5.4";
@ -23,18 +10,16 @@ stdenv.mkDerivation rec {
sha256 = "0czvqxkzd5y872ipy6s010ifwdwv29sqbnqc4pf56sd486gqvy6m"; sha256 = "0czvqxkzd5y872ipy6s010ifwdwv29sqbnqc4pf56sd486gqvy6m";
}; };
buildInputs = [ libgpgerror optLibcap ]; buildInputs =
[ libgpgerror ]
configureFlags = [ ++ lib.optional enableCapabilities libcap;
(mkWith (optLibcap != null) "capabilities" null)
];
# Make sure libraries are correct for .pc and .la files # Make sure libraries are correct for .pc and .la files
# Also make sure includes are fixed for callers who don't use libgpgcrypt-config # Also make sure includes are fixed for callers who don't use libgpgcrypt-config
postInstall = '' postInstall = ''
sed -i 's,#include <gpg-error.h>,#include "${libgpgerror}/include/gpg-error.h",g' $out/include/gcrypt.h sed -i 's,#include <gpg-error.h>,#include "${libgpgerror}/include/gpg-error.h",g' $out/include/gcrypt.h
'' + stdenv.lib.optionalString (!stdenv.isDarwin && optLibcap != null) '' '' + stdenv.lib.optionalString enableCapabilities ''
sed -i 's,\(-lcap\),-L${optLibcap}/lib \1,' $out/lib/libgcrypt.la sed -i 's,\(-lcap\),-L${libcap}/lib \1,' $out/lib/libgcrypt.la
''; '';
doCheck = true; doCheck = true;

View File

@ -1,24 +1,7 @@
{ stdenv, fetchurl { lib, stdenv, fetchurl, libgpgerror, enableCapabilities ? false, libcap }:
, libgpgerror
# Optional Dependencies assert enableCapabilities -> stdenv.isLinux;
, libcap ? null, pth ? null
}:
let
mkFlag = trueStr: falseStr: cond: name: val:
if cond == null then null else
"--${if cond != false then trueStr else falseStr}${name}${if val != null && cond != false then "=${val}" else ""}";
mkEnable = mkFlag "enable-" "disable-";
mkWith = mkFlag "with-" "without-";
mkOther = mkFlag "" "" true;
shouldUsePkg = pkg: if pkg != null && stdenv.lib.any (x: x == stdenv.system) pkg.meta.platforms then pkg else null;
optLibcap = shouldUsePkg libcap;
#optPth = shouldUsePkg pth;
optPth = null; # Broken as of 1.6.3
in
stdenv.mkDerivation rec { stdenv.mkDerivation rec {
name = "libgcrypt-1.6.3"; name = "libgcrypt-1.6.3";
@ -27,29 +10,26 @@ stdenv.mkDerivation rec {
sha256 = "0pq2nwfqgggrsh8rk84659d80vfnlkbphwqjwahccd5fjdxr3d21"; sha256 = "0pq2nwfqgggrsh8rk84659d80vfnlkbphwqjwahccd5fjdxr3d21";
}; };
buildInputs = [ libgpgerror optLibcap optPth ]; buildInputs =
[ libgpgerror ]
configureFlags = [ ++ lib.optional enableCapabilities libcap;
(mkWith (optLibcap != null) "capabilities" null)
(mkEnable (optPth != null) "random-daemon" null)
];
# Make sure libraries are correct for .pc and .la files # Make sure libraries are correct for .pc and .la files
# Also make sure includes are fixed for callers who don't use libgpgcrypt-config # Also make sure includes are fixed for callers who don't use libgpgcrypt-config
postInstall = '' postInstall = ''
sed -i 's,#include <gpg-error.h>,#include "${libgpgerror}/include/gpg-error.h",g' $out/include/gcrypt.h sed -i 's,#include <gpg-error.h>,#include "${libgpgerror}/include/gpg-error.h",g' $out/include/gcrypt.h
'' + stdenv.lib.optionalString (!stdenv.isDarwin && optLibcap != null) '' '' + stdenv.lib.optionalString enableCapabilities ''
sed -i 's,\(-lcap\),-L${optLibcap}/lib \1,' $out/lib/libgcrypt.la sed -i 's,\(-lcap\),-L${libcap}/lib \1,' $out/lib/libgcrypt.la
''; '';
doCheck = true; doCheck = true;
meta = with stdenv.lib; { meta = {
homepage = https://www.gnu.org/software/libgcrypt/; homepage = https://www.gnu.org/software/libgcrypt/;
description = "General-pupose cryptographic library"; description = "General-pupose cryptographic library";
license = licenses.lgpl2Plus; license = lib.licenses.lgpl2Plus;
platforms = platforms.all; platforms = lib.platforms.all;
maintainers = with maintainers; [ wkennington ]; maintainers = [ lib.maintainers.wkennington ];
repositories.git = git://git.gnupg.org/libgcrypt.git; repositories.git = git://git.gnupg.org/libgcrypt.git;
}; };
} }

View File

@ -6787,13 +6787,9 @@ let
libftdi1 = callPackage ../development/libraries/libftdi/1.x.nix { }; libftdi1 = callPackage ../development/libraries/libftdi/1.x.nix { };
libgcrypt = callPackage ../development/libraries/libgcrypt { libgcrypt = callPackage ../development/libraries/libgcrypt { };
# Breaks packages that expect to have elevated privileges
# Ex. Lightdm, cryptsetup
libcap = null;
};
libgcrypt_1_5 = lowPrio (callPackage ../development/libraries/libgcrypt/1.5.nix { }); libgcrypt_1_5 = callPackage ../development/libraries/libgcrypt/1.5.nix { };
libgdiplus = callPackage ../development/libraries/libgdiplus { }; libgdiplus = callPackage ../development/libraries/libgdiplus { };