libgcrypt: Revert to old style
This commit is contained in:
parent
c47e78bbec
commit
330d198be1
@ -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;
|
||||||
|
@ -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;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -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 { };
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user