pkgsStatic: Inline more of static overlay

This commit is contained in:
John Ericson 2021-08-19 17:56:53 +00:00
parent a17fc03375
commit 904625852d
5 changed files with 41 additions and 51 deletions

View File

@ -189,6 +189,8 @@ stdenv.mkDerivation {
configureScript = "./bootstrap.sh"; configureScript = "./bootstrap.sh";
configurePlatforms = []; configurePlatforms = [];
dontDisableStatic = true;
dontAddStaticConfigureFlags = true;
configureFlags = [ configureFlags = [
"--includedir=$(dev)/include" "--includedir=$(dev)/include"
"--libdir=$(out)/lib" "--libdir=$(out)/lib"

View File

@ -57,11 +57,13 @@ stdenv.mkDerivation (rec {
# and giving nothing builds both. # and giving nothing builds both.
# So we have 3 possible ways to build both: # So we have 3 possible ways to build both:
# `--static --shared`, `--shared` and giving nothing. # `--static --shared`, `--shared` and giving nothing.
# Of these, we choose `--shared`, only because that's # Of these, we choose `--static --shared`, for clarity and simpler
# what we did in the past and we can avoid mass rebuilds this way. # conditions.
# As a result, we pass `--static` only when we want just static. configureFlags = lib.optional static "--static"
configureFlags = lib.optional (static && !shared) "--static"
++ lib.optional shared "--shared"; ++ lib.optional shared "--shared";
# We do the right thing manually, above, so don't need these.
dontDisableStatic = true;
dontAddStaticConfigureFlags = true;
# Note we don't need to set `dontDisableStatic`, because static-disabling # Note we don't need to set `dontDisableStatic`, because static-disabling
# works by grepping for `enable-static` in the `./configure` script # works by grepping for `enable-static` in the `./configure` script

View File

@ -90,6 +90,24 @@ rec {
}); });
}); });
# Best effort static binaries. Will still be linked to libSystem,
# but more portable than Nix store binaries.
makeStaticDarwin = stdenv: stdenv.override (old: {
# extraBuildInputs are dropped in cross.nix, but darwin still needs them
extraBuildInputs = [ pkgs.buildPackages.darwin.CF ];
mkDerivationFromStdenv = extendMkDerivationArgs old (args: {
NIX_CFLAGS_LINK = toString (args.NIX_CFLAGS_LINK or "")
+ lib.optionalString (stdenv.cc.isGNU or false) " -static-libgcc";
nativeBuildInputs = (args.nativeBuildInputs or []) ++ [
(pkgs.buildPackages.makeSetupHook {
substitutions = {
libsystem = "${stdenv.cc.libc}/lib/libSystem.B.dylib";
};
} ./darwin/portable-libsystem.sh)
];
});
});
/* Modify a stdenv so that all buildInputs are implicitly propagated to /* Modify a stdenv so that all buildInputs are implicitly propagated to
consuming derivations consuming derivations

View File

@ -9,6 +9,7 @@
, scpSupport ? zlibSupport && !stdenv.isSunOS && !stdenv.isCygwin, libssh2 ? null , scpSupport ? zlibSupport && !stdenv.isSunOS && !stdenv.isCygwin, libssh2 ? null
, gssSupport ? with stdenv.hostPlatform; ( , gssSupport ? with stdenv.hostPlatform; (
!isWindows && !isWindows &&
# disable gss becuase of: undefined reference to `k5_bcmp'
# a very sad story re static: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=439039 # a very sad story re static: https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=439039
!isStatic && !isStatic &&
# the "mig" tool does not configure its compiler correctly. This could be # the "mig" tool does not configure its compiler correctly. This could be
@ -95,15 +96,15 @@ stdenv.mkDerivation rec {
"--without-ca-bundle" "--without-ca-bundle"
"--without-ca-path" "--without-ca-path"
# The build fails when using wolfssl with --with-ca-fallback # The build fails when using wolfssl with --with-ca-fallback
( if wolfsslSupport then "--without-ca-fallback" else "--with-ca-fallback") (lib.withFeature wolfsslSupport "ca-fallback")
"--disable-manual" "--disable-manual"
( if sslSupport then "--with-ssl=${openssl.dev}" else "--without-ssl" ) (lib.withFeatureAs sslSupport "ssl" openssl.dev)
( if gnutlsSupport then "--with-gnutls=${gnutls.dev}" else "--without-gnutls" ) (lib.withFeatureAs gnutlsSupport "gnutls" gnutls.dev)
( if scpSupport then "--with-libssh2=${libssh2.dev}" else "--without-libssh2" ) (lib.withFeatureAs scpSupport "libssh2" libssh2.dev)
( if ldapSupport then "--enable-ldap" else "--disable-ldap" ) (lib.enableFeature ldapSupport "ldap")
( if ldapSupport then "--enable-ldaps" else "--disable-ldaps" ) (lib.enableFeature ldapSupport "ldaps")
( if idnSupport then "--with-libidn=${libidn.dev}" else "--without-libidn" ) (lib.withFeatureAs idnSupport "libidn" libidn.dev)
( if brotliSupport then "--with-brotli" else "--without-brotli" ) (lib.withFeature brotliSupport "brotli")
] ]
++ lib.optional wolfsslSupport "--with-wolfssl=${wolfssl.dev}" ++ lib.optional wolfsslSupport "--with-wolfssl=${wolfssl.dev}"
++ lib.optional c-aresSupport "--enable-ares=${c-ares}" ++ lib.optional c-aresSupport "--enable-ares=${c-ares}"

View File

@ -13,26 +13,9 @@
self: super: let self: super: let
inherit (super.stdenvAdapters) makeStaticBinaries inherit (super.stdenvAdapters) makeStaticBinaries
makeStaticLibraries makeStaticLibraries
propagateBuildInputs; propagateBuildInputs
inherit (super.lib) foldl optional flip id composeExtensions optionalAttrs optionalString; makeStaticDarwin;
inherit (super) makeSetupHook; inherit (super.lib) foldl optional flip id composeExtensions;
# Best effort static binaries. Will still be linked to libSystem,
# but more portable than Nix store binaries.
makeStaticDarwin = stdenv_: let stdenv = stdenv_.override {
# extraBuildInputs are dropped in cross.nix, but darwin still needs them
extraBuildInputs = [ self.buildPackages.darwin.CF ];
}; in stdenv // {
mkDerivation = args: stdenv.mkDerivation (args // {
NIX_CFLAGS_LINK = toString (args.NIX_CFLAGS_LINK or "")
+ optionalString (stdenv_.cc.isGNU or false) " -static-libgcc";
nativeBuildInputs = (args.nativeBuildInputs or []) ++ [ (makeSetupHook {
substitutions = {
libsystem = "${stdenv.cc.libc}/lib/libSystem.B.dylib";
};
} ../stdenv/darwin/portable-libsystem.sh) ];
});
};
staticAdapters = staticAdapters =
optional super.stdenv.hostPlatform.isDarwin makeStaticDarwin optional super.stdenv.hostPlatform.isDarwin makeStaticDarwin
@ -48,24 +31,8 @@ self: super: let
; ;
in { in {
# Do not add new packages here! Instead use `stdenv.hostPlatform.isStatic` to
# write conditional code in the original package.
stdenv = foldl (flip id) super.stdenv staticAdapters; stdenv = foldl (flip id) super.stdenv staticAdapters;
boost = super.boost.override {
# Dont use new stdenv for boost because it doesnt like the
# --disable-shared flag
stdenv = super.stdenv;
};
curl = super.curl.override {
# brotli doesn't build static (Mar. 2021)
brotliSupport = false;
# disable gss becuase of: undefined reference to `k5_bcmp'
gssSupport = false;
};
zlib = super.zlib.override {
# Dont use new stdenv zlib because
# it doesnt like the --disable-shared flag
stdenv = super.stdenv;
};
} }