forked from mirrors/nixpkgs
nghttp2: 1.8.0 -> 1.9.2, unify with libnghttp2, and use multiple outputs
Note: I ignored the C++ libraries, but it appears we're not currently using them. Once we do, we'll probably want to put them in a separate output as well (to prevent non-C++ users from depending on Boost).
This commit is contained in:
parent
21a2f2ba3b
commit
b4bf432709
|
@ -124,7 +124,7 @@ in
|
|||
${pkgs.xz.out}/lib/liblzma*.so* mr,
|
||||
${pkgs.libgcrypt.out}/lib/libgcrypt*.so* mr,
|
||||
${pkgs.libgpgerror.out}/lib/libgpg-error*.so* mr,
|
||||
${pkgs.libnghttp2.out}/lib/libnghttp2*.so* mr,
|
||||
${pkgs.nghttp2.lib}/lib/libnghttp2*.so* mr,
|
||||
${pkgs.c-ares.out}/lib/libcares*.so* mr,
|
||||
${pkgs.libcap.out}/lib/libcap*.so* mr,
|
||||
${pkgs.attr.out}/lib/libattr*.so* mr,
|
||||
|
|
|
@ -1,77 +1,36 @@
|
|||
{ stdenv, fetchurl, pkgconfig
|
||||
|
||||
# Optinal Dependencies
|
||||
# Optional Dependencies
|
||||
, openssl ? null, libev ? null, zlib ? null, jansson ? null, boost ? null
|
||||
, libxml2 ? null, jemalloc ? null
|
||||
|
||||
# Extra argument
|
||||
, prefix ? ""
|
||||
}:
|
||||
|
||||
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;
|
||||
|
||||
isLib = prefix == "lib";
|
||||
|
||||
optOpenssl = if isLib then null else shouldUsePkg openssl;
|
||||
optLibev = if isLib then null else shouldUsePkg libev;
|
||||
optZlib = if isLib then null else shouldUsePkg zlib;
|
||||
|
||||
hasApp = optOpenssl != null && optLibev != null && optZlib != null;
|
||||
|
||||
optJansson = if isLib then null else shouldUsePkg jansson;
|
||||
#optBoost = if isLib then null else shouldUsePkg boost;
|
||||
optBoost = null; # Currently detection is broken
|
||||
optLibxml2 = if !hasApp then null else shouldUsePkg libxml2;
|
||||
optJemalloc = if !hasApp then null else shouldUsePkg jemalloc;
|
||||
in
|
||||
stdenv.mkDerivation rec {
|
||||
name = "${prefix}nghttp2-${version}";
|
||||
version = "1.8.0";
|
||||
name = "nghttp2-${version}";
|
||||
version = "1.9.2";
|
||||
|
||||
# Don't use fetchFromGitHub since this needs a bootstrap curl
|
||||
src = fetchurl {
|
||||
url = "https://github.com/nghttp2/nghttp2/releases/download/v${version}/nghttp2-${version}.tar.bz2";
|
||||
sha256 = "10xz3s624w208pr9xgm4ammc8bc5mi17vy4357hjfd5vmmp5m8b0";
|
||||
sha256 = "1jnms0mmf73cwdqvbzpdyi974f8xq7p8bxgba2ippw70pz8y0ac0";
|
||||
};
|
||||
|
||||
# Configure script searches for a symbol which does not exist in jemalloc on Darwin
|
||||
# Reported upstream in https://github.com/tatsuhiro-t/nghttp2/issues/233
|
||||
postPatch = if (stdenv.isDarwin && optJemalloc != null) then ''
|
||||
postPatch = if stdenv.isDarwin && jemalloc != null then ''
|
||||
substituteInPlace configure --replace "malloc_stats_print" "je_malloc_stats_print"
|
||||
'' else null;
|
||||
|
||||
nativeBuildInputs = [ pkgconfig ];
|
||||
buildInputs = [ optJansson optBoost optLibxml2 optJemalloc ]
|
||||
++ stdenv.lib.optionals hasApp [ optOpenssl optLibev optZlib ];
|
||||
outputs = [ "dev" "out" "lib" ];
|
||||
|
||||
configureFlags = [
|
||||
(mkEnable false "werror" null)
|
||||
(mkEnable false "debug" null)
|
||||
(mkEnable true "threads" null)
|
||||
(mkEnable hasApp "app" null)
|
||||
(mkEnable (optJansson != null) "hpack-tools" null)
|
||||
(mkEnable (optBoost != null) "asio-lib" null)
|
||||
(mkEnable false "examples" null)
|
||||
(mkEnable false "python-bindings" null)
|
||||
(mkEnable false "failmalloc" null)
|
||||
(mkWith (optLibxml2 != null) "libxml2" null)
|
||||
(mkWith (optJemalloc != null) "jemalloc" null)
|
||||
(mkWith false "spdylay" null)
|
||||
(mkWith false "cython" null)
|
||||
(mkWith false "mruby" null)
|
||||
];
|
||||
nativeBuildInputs = [ pkgconfig ];
|
||||
buildInputs = [ openssl libev zlib ];
|
||||
|
||||
enableParallelBuilding = true;
|
||||
|
||||
meta = with stdenv.lib; {
|
||||
homepage = http://nghttp2.org/;
|
||||
description = "an implementation of HTTP/2 in C";
|
||||
description = "A C implementation of HTTP/2";
|
||||
license = licenses.mit;
|
||||
platforms = platforms.all;
|
||||
maintainers = with maintainers; [ wkennington ];
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
{ stdenv, fetchurl, perl, zlib, apr, aprutil, pcre, libiconv
|
||||
, proxySupport ? true
|
||||
, sslSupport ? true, openssl
|
||||
, http2Support ? true, libnghttp2
|
||||
, http2Support ? true, nghttp2
|
||||
, ldapSupport ? true, openldap
|
||||
, libxml2Support ? true, libxml2
|
||||
, luaSupport ? false, lua5
|
||||
|
@ -13,7 +13,7 @@ in
|
|||
|
||||
assert sslSupport -> aprutil.sslSupport && openssl != null;
|
||||
assert ldapSupport -> aprutil.ldapSupport && openldap != null;
|
||||
assert http2Support -> libnghttp2 != null;
|
||||
assert http2Support -> nghttp2 != null;
|
||||
|
||||
stdenv.mkDerivation rec {
|
||||
version = "2.4.18";
|
||||
|
@ -32,7 +32,7 @@ stdenv.mkDerivation rec {
|
|||
optional sslSupport openssl ++
|
||||
optional ldapSupport openldap ++ # there is no --with-ldap flag
|
||||
optional libxml2Support libxml2 ++
|
||||
optional http2Support libnghttp2 ++
|
||||
optional http2Support nghttp2 ++
|
||||
optional stdenv.isDarwin libiconv;
|
||||
|
||||
patchPhase = ''
|
||||
|
@ -59,7 +59,7 @@ stdenv.mkDerivation rec {
|
|||
--enable-cgi
|
||||
${optionalString proxySupport "--enable-proxy"}
|
||||
${optionalString sslSupport "--enable-ssl"}
|
||||
${optionalString http2Support "--enable-http2 --with-nghttp2=${libnghttp2}"}
|
||||
${optionalString http2Support "--enable-http2 --with-nghttp2"}
|
||||
${optionalString luaSupport "--enable-lua --with-lua=${lua5}"}
|
||||
${optionalString libxml2Support "--with-libxml2=${libxml2.dev}/include/libxml2"}
|
||||
--docdir=$(doc)/share/doc
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
{ stdenv, fetchurl, pkgconfig, perl
|
||||
, http2Support ? true, libnghttp2
|
||||
, http2Support ? true, nghttp2
|
||||
, idnSupport ? false, libidn ? null
|
||||
, ldapSupport ? false, openldap ? null
|
||||
, zlibSupport ? false, zlib ? null
|
||||
|
@ -9,7 +9,7 @@
|
|||
, c-aresSupport ? false, c-ares ? null
|
||||
}:
|
||||
|
||||
assert http2Support -> libnghttp2 != null;
|
||||
assert http2Support -> nghttp2 != null;
|
||||
assert idnSupport -> libidn != null;
|
||||
assert ldapSupport -> openldap != null;
|
||||
assert zlibSupport -> zlib != null;
|
||||
|
@ -33,7 +33,7 @@ stdenv.mkDerivation rec {
|
|||
# "-lz -lssl", which aren't necessary direct build inputs of
|
||||
# applications that use Curl.
|
||||
propagatedBuildInputs = with stdenv.lib;
|
||||
optional http2Support libnghttp2 ++
|
||||
optional http2Support nghttp2 ++
|
||||
optional idnSupport libidn ++
|
||||
optional ldapSupport openldap ++
|
||||
optional zlibSupport zlib ++
|
||||
|
@ -51,7 +51,6 @@ stdenv.mkDerivation rec {
|
|||
configureFlags = [
|
||||
"--with-ca-bundle=/etc/ssl/certs/ca-certificates.crt"
|
||||
"--disable-manual"
|
||||
( if http2Support then "--with-nghttp2=${libnghttp2}" else "--without-nghttp2" )
|
||||
( if sslSupport then "--with-ssl=${openssl}" else "--without-ssl" )
|
||||
( if scpSupport then "--with-libssh2=${libssh2}" else "--without-libssh2" )
|
||||
( if ldapSupport then "--enable-ldap" else "--disable-ldap" )
|
||||
|
|
|
@ -7536,7 +7536,9 @@ in
|
|||
|
||||
libechonest = callPackage ../development/libraries/libechonest { };
|
||||
|
||||
libev = callPackage ../development/libraries/libev { };
|
||||
libev = callPackage ../development/libraries/libev {
|
||||
fetchurl = fetchurlBoot;
|
||||
};
|
||||
|
||||
libevent = callPackage ../development/libraries/libevent { };
|
||||
|
||||
|
@ -8276,11 +8278,10 @@ in
|
|||
|
||||
newt = callPackage ../development/libraries/newt { };
|
||||
|
||||
nghttp2 = callPackage ../development/libraries/nghttp2 { };
|
||||
libnghttp2 = self.nghttp2.override {
|
||||
prefix = "lib";
|
||||
nghttp2 = callPackage ../development/libraries/nghttp2 {
|
||||
fetchurl = fetchurlBoot;
|
||||
};
|
||||
libnghttp2 = nghttp2.lib;
|
||||
|
||||
nix-plugins = callPackage ../development/libraries/nix-plugins {
|
||||
nix = pkgs.nixUnstable;
|
||||
|
|
Loading…
Reference in a new issue