9bb3fccb5b
continuation of #109595 pkgconfig was aliased in 2018, however, it remained in all-packages.nix due to its wide usage. This cleans up the remaining references to pkgs.pkgsconfig and moves the entry to aliases.nix. python3Packages.pkgconfig remained unchanged because it's the canonical name of the upstream package on pypi.
82 lines
2.7 KiB
Nix
82 lines
2.7 KiB
Nix
{ lib, stdenv, fetchurl, pkg-config
|
|
, libgcrypt, libgpgerror, libtasn1
|
|
|
|
# Optional Dependencies
|
|
, pam ? null, libidn ? null, gnutls ? null
|
|
}:
|
|
|
|
let
|
|
mkFlag = trueStr: falseStr: cond: name: val: "--"
|
|
+ (if cond then trueStr else falseStr)
|
|
+ name
|
|
+ lib.optionalString (val != null && cond != false) "=${val}";
|
|
mkEnable = mkFlag "enable-" "disable-";
|
|
mkWith = mkFlag "with-" "without-";
|
|
mkOther = mkFlag "" "" true;
|
|
|
|
shouldUsePkg = pkg: if pkg != null && lib.any (lib.meta.platformMatch stdenv.hostPlatform) pkg.meta.platforms then pkg else null;
|
|
|
|
optPam = shouldUsePkg pam;
|
|
optLibidn = shouldUsePkg libidn;
|
|
optGnutls = shouldUsePkg gnutls;
|
|
in
|
|
with lib;
|
|
stdenv.mkDerivation rec {
|
|
name = "shishi-1.0.2";
|
|
|
|
src = fetchurl {
|
|
url = "mirror://gnu/shishi/${name}.tar.gz";
|
|
sha256 = "032qf72cpjdfffq1yq54gz3ahgqf2ijca4vl31sfabmjzq9q370d";
|
|
};
|
|
|
|
# Fixes support for gcrypt 1.6+
|
|
patches = [ ./gcrypt-fix.patch ./freebsd-unistd.patch ];
|
|
|
|
nativeBuildInputs = [ pkg-config ];
|
|
buildInputs = [ libgcrypt libgpgerror libtasn1 optPam optLibidn optGnutls ];
|
|
|
|
configureFlags = [
|
|
(mkOther "sysconfdir" "/etc")
|
|
(mkOther "localstatedir" "/var")
|
|
(mkEnable true "libgcrypt" null)
|
|
(mkEnable (optPam != null) "pam" null)
|
|
(mkEnable true "ipv6" null)
|
|
(mkWith (optLibidn != null) "stringprep" null)
|
|
(mkEnable (optGnutls != null) "starttls" null)
|
|
(mkEnable true "des" null)
|
|
(mkEnable true "3des" null)
|
|
(mkEnable true "aes" null)
|
|
(mkEnable true "md" null)
|
|
(mkEnable false "null" null)
|
|
(mkEnable true "arcfour" null)
|
|
];
|
|
|
|
NIX_CFLAGS_COMPILE
|
|
= optionalString stdenv.isDarwin "-DBIND_8_COMPAT";
|
|
|
|
doCheck = true;
|
|
|
|
installFlags = [ "sysconfdir=\${out}/etc" ];
|
|
|
|
# Fix *.la files
|
|
postInstall = ''
|
|
sed -i $out/lib/libshi{sa,shi}.la \
|
|
'' + optionalString (optLibidn != null) ''
|
|
-e 's,\(-lidn\),-L${optLibidn.out}/lib \1,' \
|
|
'' + optionalString (optGnutls != null) ''
|
|
-e 's,\(-lgnutls\),-L${optGnutls.out}/lib \1,' \
|
|
'' + ''
|
|
-e 's,\(-lgcrypt\),-L${libgcrypt.out}/lib \1,' \
|
|
-e 's,\(-lgpg-error\),-L${libgpgerror.out}/lib \1,' \
|
|
-e 's,\(-ltasn1\),-L${libtasn1.out}/lib \1,'
|
|
'';
|
|
|
|
meta = {
|
|
homepage = "https://www.gnu.org/software/shishi/";
|
|
description = "An implementation of the Kerberos 5 network security system";
|
|
license = licenses.gpl3Plus;
|
|
maintainers = with maintainers; [ bjg lovek323 ];
|
|
platforms = platforms.linux;
|
|
};
|
|
}
|