2021-05-11 21:12:04 +00:00
|
|
|
{ lib, stdenv, llvm_meta, cmake, fetch, libcxx, libunwind, llvm, version
|
2021-11-15 15:07:31 +00:00
|
|
|
, enableShared ? !stdenv.hostPlatform.isStatic
|
2021-04-19 13:02:40 +00:00
|
|
|
, standalone ? stdenv.hostPlatform.useLLVM or false
|
|
|
|
, withLibunwind ? !stdenv.isDarwin && !stdenv.isFreeBSD && !stdenv.hostPlatform.isWasm
|
2020-12-20 06:11:26 +00:00
|
|
|
}:
|
2020-08-25 17:29:57 +00:00
|
|
|
|
|
|
|
stdenv.mkDerivation {
|
2021-05-11 19:43:21 +00:00
|
|
|
pname = "libcxxabi";
|
2020-08-25 17:29:57 +00:00
|
|
|
inherit version;
|
|
|
|
|
2021-02-17 20:39:09 +00:00
|
|
|
src = fetch "libcxxabi" "1azcf31mxw59hb1x17xncnm3dyw90ylh8rqx462lvypqh3nr6c8l";
|
2020-08-25 17:29:57 +00:00
|
|
|
|
llvmPackages: Multuple outputs for everythting
Also begin to start work on cross compilation, though that will have to
be finished later.
The patches are based on the first version of
https://reviews.llvm.org/D99484. It's very annoying to do the
back-porting but the review has uncovered nothing super major so I'm
fine sticking with what I've got.
Beyond making the outputs work, I also strove to re-sync the packages,
as they have been drifting pointlessly apart for some time.
----
Other misc notes, highly incomplete
- lvm-config-native and llvm-config are put in `dev` because they are
tools just for build time.
- Clang no longer has an lld dep. That was introduced in
db29857eb391ed002046090851a44c452b80bdbd, but if clang needs help
finding lld when it is used we should just pass it flags / put in the
resource dir. Providing it at build time increases critical path
length for no good reason.
----
A note on `nativeCC`:
`stdenv` takes tools from the previous stage, so:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.stdenv.cc`: `(?0, ?1, x)`
while:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.targetPackages`: `(x, x, ?2)`
3. `pkgsBuildBuild.targetPackages.stdenv.cc`: `(?1, x, x)`
2020-10-15 08:23:57 +00:00
|
|
|
outputs = [ "out" "dev" ];
|
2020-08-25 17:29:57 +00:00
|
|
|
|
|
|
|
postUnpack = ''
|
|
|
|
unpackFile ${libcxx.src}
|
2020-10-07 21:29:47 +00:00
|
|
|
mv libcxx-* libcxx
|
2020-08-25 17:29:57 +00:00
|
|
|
unpackFile ${llvm.src}
|
2020-10-07 21:29:47 +00:00
|
|
|
mv llvm-* llvm
|
2021-01-22 11:25:31 +00:00
|
|
|
'' + lib.optionalString stdenv.isDarwin ''
|
2020-08-25 17:29:57 +00:00
|
|
|
export TRIPLE=x86_64-apple-darwin
|
2021-01-22 11:25:31 +00:00
|
|
|
'' + lib.optionalString stdenv.hostPlatform.isMusl ''
|
2021-04-15 10:15:07 +00:00
|
|
|
patch -p1 -d libcxx -i ${../../libcxx-0001-musl-hacks.patch}
|
2021-01-22 11:25:31 +00:00
|
|
|
'' + lib.optionalString stdenv.hostPlatform.isWasm ''
|
2021-03-24 01:40:33 +00:00
|
|
|
patch -p1 -d llvm -i ${./wasm.patch}
|
2020-08-25 17:29:57 +00:00
|
|
|
'';
|
|
|
|
|
llvmPackages: Multuple outputs for everythting
Also begin to start work on cross compilation, though that will have to
be finished later.
The patches are based on the first version of
https://reviews.llvm.org/D99484. It's very annoying to do the
back-porting but the review has uncovered nothing super major so I'm
fine sticking with what I've got.
Beyond making the outputs work, I also strove to re-sync the packages,
as they have been drifting pointlessly apart for some time.
----
Other misc notes, highly incomplete
- lvm-config-native and llvm-config are put in `dev` because they are
tools just for build time.
- Clang no longer has an lld dep. That was introduced in
db29857eb391ed002046090851a44c452b80bdbd, but if clang needs help
finding lld when it is used we should just pass it flags / put in the
resource dir. Providing it at build time increases critical path
length for no good reason.
----
A note on `nativeCC`:
`stdenv` takes tools from the previous stage, so:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.stdenv.cc`: `(?0, ?1, x)`
while:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.targetPackages`: `(x, x, ?2)`
3. `pkgsBuildBuild.targetPackages.stdenv.cc`: `(?1, x, x)`
2020-10-15 08:23:57 +00:00
|
|
|
patches = [
|
|
|
|
./no-threads.patch
|
|
|
|
./gnu-install-dirs.patch
|
|
|
|
];
|
|
|
|
|
|
|
|
nativeBuildInputs = [ cmake ];
|
2021-04-19 13:02:40 +00:00
|
|
|
buildInputs = lib.optional withLibunwind libunwind;
|
llvmPackages: Multuple outputs for everythting
Also begin to start work on cross compilation, though that will have to
be finished later.
The patches are based on the first version of
https://reviews.llvm.org/D99484. It's very annoying to do the
back-porting but the review has uncovered nothing super major so I'm
fine sticking with what I've got.
Beyond making the outputs work, I also strove to re-sync the packages,
as they have been drifting pointlessly apart for some time.
----
Other misc notes, highly incomplete
- lvm-config-native and llvm-config are put in `dev` because they are
tools just for build time.
- Clang no longer has an lld dep. That was introduced in
db29857eb391ed002046090851a44c452b80bdbd, but if clang needs help
finding lld when it is used we should just pass it flags / put in the
resource dir. Providing it at build time increases critical path
length for no good reason.
----
A note on `nativeCC`:
`stdenv` takes tools from the previous stage, so:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.stdenv.cc`: `(?0, ?1, x)`
while:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.targetPackages`: `(x, x, ?2)`
3. `pkgsBuildBuild.targetPackages.stdenv.cc`: `(?1, x, x)`
2020-10-15 08:23:57 +00:00
|
|
|
|
2021-07-06 22:34:59 +00:00
|
|
|
cmakeFlags = lib.optionals standalone [
|
llvmPackages: Multuple outputs for everythting
Also begin to start work on cross compilation, though that will have to
be finished later.
The patches are based on the first version of
https://reviews.llvm.org/D99484. It's very annoying to do the
back-porting but the review has uncovered nothing super major so I'm
fine sticking with what I've got.
Beyond making the outputs work, I also strove to re-sync the packages,
as they have been drifting pointlessly apart for some time.
----
Other misc notes, highly incomplete
- lvm-config-native and llvm-config are put in `dev` because they are
tools just for build time.
- Clang no longer has an lld dep. That was introduced in
db29857eb391ed002046090851a44c452b80bdbd, but if clang needs help
finding lld when it is used we should just pass it flags / put in the
resource dir. Providing it at build time increases critical path
length for no good reason.
----
A note on `nativeCC`:
`stdenv` takes tools from the previous stage, so:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.stdenv.cc`: `(?0, ?1, x)`
while:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.targetPackages`: `(x, x, ?2)`
3. `pkgsBuildBuild.targetPackages.stdenv.cc`: `(?1, x, x)`
2020-10-15 08:23:57 +00:00
|
|
|
"-DLLVM_ENABLE_LIBCXX=ON"
|
2021-11-15 15:07:31 +00:00
|
|
|
] ++ lib.optionals (standalone && withLibunwind) [
|
llvmPackages: Multuple outputs for everythting
Also begin to start work on cross compilation, though that will have to
be finished later.
The patches are based on the first version of
https://reviews.llvm.org/D99484. It's very annoying to do the
back-porting but the review has uncovered nothing super major so I'm
fine sticking with what I've got.
Beyond making the outputs work, I also strove to re-sync the packages,
as they have been drifting pointlessly apart for some time.
----
Other misc notes, highly incomplete
- lvm-config-native and llvm-config are put in `dev` because they are
tools just for build time.
- Clang no longer has an lld dep. That was introduced in
db29857eb391ed002046090851a44c452b80bdbd, but if clang needs help
finding lld when it is used we should just pass it flags / put in the
resource dir. Providing it at build time increases critical path
length for no good reason.
----
A note on `nativeCC`:
`stdenv` takes tools from the previous stage, so:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.stdenv.cc`: `(?0, ?1, x)`
while:
1. `pkgsBuildBuild`: `(?1, x, x)`
2. `pkgsBuildBuild.targetPackages`: `(x, x, ?2)`
3. `pkgsBuildBuild.targetPackages.stdenv.cc`: `(?1, x, x)`
2020-10-15 08:23:57 +00:00
|
|
|
"-DLIBCXXABI_USE_LLVM_UNWINDER=ON"
|
|
|
|
] ++ lib.optionals stdenv.hostPlatform.isWasm [
|
|
|
|
"-DLIBCXXABI_ENABLE_THREADS=OFF"
|
|
|
|
"-DLIBCXXABI_ENABLE_EXCEPTIONS=OFF"
|
|
|
|
] ++ lib.optionals (!enableShared) [
|
|
|
|
"-DLIBCXXABI_ENABLE_SHARED=OFF"
|
|
|
|
];
|
|
|
|
|
2020-08-25 17:29:57 +00:00
|
|
|
installPhase = if stdenv.isDarwin
|
|
|
|
then ''
|
|
|
|
for file in lib/*.dylib; do
|
|
|
|
# this should be done in CMake, but having trouble figuring out
|
|
|
|
# the magic combination of necessary CMake variables
|
|
|
|
# if you fancy a try, take a look at
|
|
|
|
# https://gitlab.kitware.com/cmake/community/-/wikis/doc/cmake/RPATH-handling
|
2021-05-16 04:24:52 +00:00
|
|
|
${stdenv.cc.targetPrefix}install_name_tool -id $out/$file $file
|
2020-08-25 17:29:57 +00:00
|
|
|
done
|
|
|
|
make install
|
|
|
|
install -d 755 $out/include
|
|
|
|
install -m 644 ../include/*.h $out/include
|
|
|
|
''
|
|
|
|
else ''
|
|
|
|
install -d -m 755 $out/include $out/lib
|
|
|
|
install -m 644 lib/libc++abi.a $out/lib
|
|
|
|
install -m 644 ../include/cxxabi.h $out/include
|
2021-01-22 11:25:31 +00:00
|
|
|
'' + lib.optionalString enableShared ''
|
2020-08-25 17:29:57 +00:00
|
|
|
install -m 644 lib/libc++abi.so.1.0 $out/lib
|
|
|
|
ln -s libc++abi.so.1.0 $out/lib/libc++abi.so
|
|
|
|
ln -s libc++abi.so.1.0 $out/lib/libc++abi.so.1
|
|
|
|
'';
|
|
|
|
|
2021-05-11 21:12:04 +00:00
|
|
|
meta = llvm_meta // {
|
2020-08-25 17:29:57 +00:00
|
|
|
homepage = "https://libcxxabi.llvm.org/";
|
2021-05-11 21:12:04 +00:00
|
|
|
description = "Provides C++ standard library support";
|
|
|
|
longDescription = ''
|
|
|
|
libc++abi is a new implementation of low level support for a standard C++ library.
|
|
|
|
'';
|
|
|
|
# "All of the code in libc++abi is dual licensed under the MIT license and
|
|
|
|
# the UIUC License (a BSD-like license)":
|
|
|
|
license = with lib.licenses; [ mit ncsa ];
|
|
|
|
maintainers = llvm_meta.maintainers ++ [ lib.maintainers.vlstill ];
|
2020-08-25 17:29:57 +00:00
|
|
|
};
|
|
|
|
}
|