2018-01-31 15:09:24 +01:00
|
|
|
{ lowPrio, newScope, stdenv, targetPlatform, cmake, libstdcxxHook
|
|
|
|
, libxml2, python2, isl, fetchurl, overrideCC, wrapCC, ccWrapperFun
|
|
|
|
, darwin
|
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
|
|
|
callPackage = newScope (self // { inherit stdenv cmake libxml2 python2 isl release_version version fetch; });
|
|
|
|
|
2018-01-31 15:09:43 +01:00
|
|
|
release_version = "6.0.0";
|
2018-02-26 20:58:03 +01:00
|
|
|
version = "6.0.0rc3"; # differentiating these is important for rc's
|
2018-01-31 15:09:24 +01:00
|
|
|
|
|
|
|
fetch = name: sha256: fetchurl {
|
2018-02-26 20:58:03 +01:00
|
|
|
url = "http://prereleases.llvm.org/${release_version}/rc3/${name}-${version}.src.tar.xz";
|
2018-01-31 15:09:24 +01:00
|
|
|
inherit sha256;
|
|
|
|
};
|
|
|
|
|
2018-02-26 20:58:03 +01:00
|
|
|
compiler-rt_src = fetch "compiler-rt" "1lv5xawwn0spisa7jknq247pdndh4mlj22z1s0d7a5gqy9y0rlwv";
|
|
|
|
clang-tools-extra_src = fetch "clang-tools-extra" "0qv7rl8cpsj0l2xl5iym6ymxi3906mb2yx95mcf5ihlwjcms5klf";
|
2018-01-31 15:09:24 +01:00
|
|
|
|
|
|
|
# Add man output without introducing extra dependencies.
|
|
|
|
overrideManOutput = drv:
|
|
|
|
let drv-manpages = drv.override { enableManpages = true; }; in
|
|
|
|
drv // { man = drv-manpages.out; /*outputs = drv.outputs ++ ["man"];*/ };
|
|
|
|
|
|
|
|
llvm = callPackage ./llvm.nix {
|
|
|
|
inherit compiler-rt_src stdenv;
|
|
|
|
};
|
|
|
|
|
|
|
|
clang-unwrapped = callPackage ./clang {
|
|
|
|
inherit clang-tools-extra_src stdenv;
|
|
|
|
};
|
|
|
|
|
|
|
|
self = {
|
|
|
|
llvm = overrideManOutput llvm;
|
|
|
|
clang-unwrapped = overrideManOutput clang-unwrapped;
|
|
|
|
|
|
|
|
libclang = self.clang-unwrapped.lib;
|
|
|
|
llvm-manpages = lowPrio self.llvm.man;
|
|
|
|
clang-manpages = lowPrio self.clang-unwrapped.man;
|
|
|
|
|
|
|
|
clang = if stdenv.cc.isGNU then self.libstdcxxClang else self.libcxxClang;
|
|
|
|
|
|
|
|
libstdcxxClang = ccWrapperFun {
|
|
|
|
cc = self.clang-unwrapped;
|
|
|
|
/* FIXME is this right? */
|
|
|
|
inherit (stdenv.cc) bintools libc nativeTools nativeLibc;
|
|
|
|
extraPackages = [ libstdcxxHook ];
|
|
|
|
};
|
|
|
|
|
|
|
|
libcxxClang = ccWrapperFun {
|
|
|
|
cc = self.clang-unwrapped;
|
|
|
|
/* FIXME is this right? */
|
|
|
|
inherit (stdenv.cc) bintools libc nativeTools nativeLibc;
|
|
|
|
extraPackages = [ self.libcxx self.libcxxabi ];
|
|
|
|
};
|
|
|
|
|
|
|
|
stdenv = stdenv.override (drv: {
|
|
|
|
allowedRequisites = null;
|
|
|
|
cc = self.clang;
|
|
|
|
});
|
|
|
|
|
|
|
|
libcxxStdenv = stdenv.override (drv: {
|
|
|
|
allowedRequisites = null;
|
|
|
|
cc = self.libcxxClang;
|
|
|
|
});
|
|
|
|
|
|
|
|
lld = callPackage ./lld.nix {};
|
|
|
|
|
|
|
|
lldb = callPackage ./lldb.nix {};
|
|
|
|
|
|
|
|
libcxx = callPackage ./libc++ {};
|
|
|
|
|
|
|
|
libcxxabi = callPackage ./libc++abi.nix {};
|
|
|
|
|
|
|
|
openmp = callPackage ./openmp.nix {};
|
|
|
|
};
|
|
|
|
|
|
|
|
in self
|