nixpkgs/pkgs/tools/package-management/nix/default.nix

161 lines
5.4 KiB
Nix
Raw Normal View History

{ lib, stdenv, fetchurl, fetchFromGitHub, perl, curl, bzip2, sqlite, openssl ? null, xz
, pkgconfig, boehmgc, perlPackages, libsodium, aws-sdk-cpp, brotli, readline
, autoreconfHook, autoconf-archive, bison, flex, libxml2, libxslt, docbook5, docbook5_xsl
, storeDir ? "/nix/store"
, stateDir ? "/nix/var"
2017-05-03 15:04:52 +02:00
, confDir ? "/etc"
}:
let
2017-04-09 03:15:21 +02:00
common = { name, suffix ? "", src, patchPhase ? "", fromGit ? false }: stdenv.mkDerivation rec {
2017-04-08 22:54:16 +02:00
inherit name src patchPhase;
version = lib.getVersion name;
VERSION_SUFFIX = lib.optionalString fromGit suffix;
2014-12-14 05:29:24 +01:00
outputs = [ "out" "dev" "man" "doc" ];
nativeBuildInputs =
2017-04-11 15:36:51 +02:00
[ pkgconfig ]
++ lib.optionals (!lib.versionAtLeast version "1.12pre") [ perl ]
++ lib.optionals fromGit [ autoreconfHook autoconf-archive bison flex libxml2 libxslt docbook5 docbook5_xsl ];
buildInputs = [ curl openssl sqlite xz ]
++ lib.optional (stdenv.isLinux || stdenv.isDarwin) libsodium
++ lib.optionals fromGit [ brotli readline ] # Since 1.12
2017-03-05 13:39:23 +01:00
++ lib.optional ((stdenv.isLinux || stdenv.isDarwin) && lib.versionAtLeast version "1.12pre")
(aws-sdk-cpp.override {
apis = ["s3"];
customMemoryManagement = false;
});
propagatedBuildInputs = [ boehmgc ];
# Note: bzip2 is not passed as a build input, because the unpack phase
# would end up using the wrong bzip2 when cross-compiling.
# XXX: The right thing would be to reinstate `--with-bzip2' in Nix.
postUnpack =
'' export CPATH="${bzip2.dev}/include"
export LIBRARY_PATH="${bzip2.out}/lib"
export CXXFLAGS="-Wno-error=reserved-user-defined-literal"
'';
configureFlags =
[ "--with-store-dir=${storeDir}"
"--localstatedir=${stateDir}"
2017-05-03 15:04:52 +02:00
"--sysconfdir=${confDir}"
"--disable-init-state"
"--enable-gc"
]
2017-04-11 15:36:51 +02:00
++ lib.optionals (!lib.versionAtLeast version "1.12pre") [
"--with-dbi=${perlPackages.DBI}/${perl.libPrefix}"
"--with-dbd-sqlite=${perlPackages.DBDSQLite}/${perl.libPrefix}"
"--with-www-curl=${perlPackages.WWWCurl}/${perl.libPrefix}"
];
2012-12-07 13:45:47 +01:00
makeFlags = "profiledir=$(out)/etc/profile.d";
installFlags = "sysconfdir=$(out)/etc";
2012-12-07 13:45:47 +01:00
doInstallCheck = true;
separateDebugInfo = stdenv.isLinux;
crossAttrs = {
postUnpack =
'' export CPATH="${bzip2.crossDrv}/include"
export NIX_CROSS_LDFLAGS="-L${bzip2.crossDrv}/lib -rpath-link ${bzip2.crossDrv}/lib $NIX_CROSS_LDFLAGS"
'';
configureFlags =
''
--with-store-dir=${storeDir} --localstatedir=${stateDir}
--with-dbi=${perlPackages.DBI}/${perl.libPrefix}
--with-dbd-sqlite=${perlPackages.DBDSQLite}/${perl.libPrefix}
--with-www-curl=${perlPackages.WWWCurl}/${perl.libPrefix}
--disable-init-state
--enable-gc
'' + stdenv.lib.optionalString (
stdenv.cross ? nix && stdenv.cross.nix ? system
) ''--with-system=${stdenv.cross.nix.system}'';
doInstallCheck = false;
};
enableParallelBuilding = true;
meta = {
description = "Powerful package manager that makes package management reliable and reproducible";
longDescription = ''
Nix is a powerful package manager for Linux and other Unix systems that
makes package management reliable and reproducible. It provides atomic
upgrades and rollbacks, side-by-side installation of multiple versions of
a package, multi-user package management and easy setup of build
environments.
'';
homepage = http://nixos.org/;
license = stdenv.lib.licenses.lgpl2Plus;
maintainers = [ stdenv.lib.maintainers.eelco ];
platforms = stdenv.lib.platforms.all;
};
2017-04-11 15:36:51 +02:00
passthru = { inherit fromGit; };
};
perl-bindings = { nix }: stdenv.mkDerivation {
name = "nix-perl-" + nix.version;
inherit (nix) src;
postUnpack = "sourceRoot=$sourceRoot/perl";
nativeBuildInputs =
[ perl pkgconfig curl nix libsodium ]
++ lib.optionals nix.fromGit [ autoreconfHook autoconf-archive ];
configureFlags =
[ "--with-dbi=${perlPackages.DBI}/${perl.libPrefix}"
"--with-dbd-sqlite=${perlPackages.DBDSQLite}/${perl.libPrefix}"
];
2017-04-26 02:36:04 +02:00
preConfigure = "export NIX_STATE_DIR=$TMPDIR";
2017-04-26 02:36:04 +02:00
preBuild = "unset NIX_INDENT_MAKE";
};
in rec {
2016-02-12 16:10:18 +01:00
nix = nixStable;
2017-04-11 15:36:51 +02:00
nixStable = (common rec {
2017-04-25 17:19:10 +02:00
name = "nix-1.11.9";
2016-02-12 16:10:18 +01:00
src = fetchurl {
url = "http://nixos.org/releases/nix/${name}/${name}.tar.xz";
2017-04-25 17:19:10 +02:00
sha256 = "0e943e277f37843f9196b0293cc31d828613ad7a328ee77cd5be01935dc6e7e1";
2016-02-12 16:10:18 +01:00
};
2017-04-08 22:54:16 +02:00
# Until 1.11.9 is released, we do this :)
2017-04-08 22:54:16 +02:00
patchPhase = ''
substituteInPlace src/libexpr/json-to-value.cc \
--replace 'std::less<Symbol>, gc_allocator<Value *>' \
'std::less<Symbol>, gc_allocator<std::pair<const Symbol, Value *> >'
sed -i '/if (settings.readOnlyMode) {/a curSchema = getSchema();' src/libstore/local-store.cc
2017-04-08 22:54:16 +02:00
'';
2017-04-11 15:36:51 +02:00
}) // { perl-bindings = nixStable; };
2016-02-12 16:10:18 +01:00
2017-04-11 15:36:51 +02:00
nixUnstable = (lib.lowPrio (common rec {
name = "nix-1.12${suffix}";
suffix = "pre5350_7689181e";
src = fetchFromGitHub {
owner = "NixOS";
repo = "nix";
rev = "7689181e4f5921d3356736996079ec0310e834c6";
sha256 = "08daxcpj18dffsbqs3fckahq06gzs8kl6xr4b4jgijwdl5vqwiri";
2016-02-12 16:10:18 +01:00
};
fromGit = true;
2017-04-11 15:36:51 +02:00
})) // { perl-bindings = perl-bindings { nix = nixUnstable; }; };
}