2021-01-23 13:15:07 +00:00
|
|
|
{ lib, stdenv
|
2021-03-25 11:00:51 +00:00
|
|
|
, python3
|
2020-11-19 19:29:02 +00:00
|
|
|
, libffi
|
|
|
|
, git
|
|
|
|
, cmake
|
|
|
|
, zlib
|
|
|
|
, fetchgit
|
|
|
|
, makeWrapper
|
|
|
|
, runCommand
|
|
|
|
, llvmPackages_5
|
|
|
|
, glibc
|
2021-05-08 23:58:11 +01:00
|
|
|
, ncurses
|
2020-11-19 19:29:02 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
|
|
|
unwrapped = stdenv.mkDerivation rec {
|
|
|
|
pname = "cling-unwrapped";
|
|
|
|
version = "0.7";
|
|
|
|
|
|
|
|
src = fetchgit {
|
|
|
|
url = "http://root.cern/git/clang.git";
|
|
|
|
# This commit has the tag cling-0.7 so we use it, even though cpt.py
|
|
|
|
# tries to use refs/tags/cling-patches-rrelease_50
|
|
|
|
rev = "354b25b5d915ff3b1946479ad07f3f2768ea1621";
|
|
|
|
branchName = "cling-patches";
|
|
|
|
sha256 = "0q8q2nnvjx3v59ng0q3qqqhzmzf4pmfqqiy3rz1f3drx5w3lgyjg";
|
|
|
|
};
|
|
|
|
|
|
|
|
clingSrc = fetchgit {
|
|
|
|
url = "http://root.cern/git/cling.git";
|
|
|
|
rev = "70163975eee5a76b45a1ca4016bfafebc9b57e07";
|
|
|
|
sha256 = "1mv2fhk857kp5rq714bq49iv7gy9fgdwibydj5wy1kq2m3sf3ysi";
|
|
|
|
};
|
|
|
|
|
|
|
|
preConfigure = ''
|
|
|
|
echo "add_llvm_external_project(cling)" >> tools/CMakeLists.txt
|
|
|
|
cp -r $clingSrc ./tools/cling
|
|
|
|
chmod -R a+w ./tools/cling
|
|
|
|
'';
|
|
|
|
|
2021-05-08 23:58:11 +01:00
|
|
|
nativeBuildInputs = [ python3 git cmake llvmPackages_5.llvm.dev ];
|
|
|
|
buildInputs = [ libffi llvmPackages_5.llvm zlib ncurses ];
|
2020-11-19 19:29:02 +00:00
|
|
|
|
2021-03-25 11:00:51 +00:00
|
|
|
strictDeps = true;
|
|
|
|
|
2020-11-19 19:29:02 +00:00
|
|
|
cmakeFlags = [
|
|
|
|
"-DLLVM_TARGETS_TO_BUILD=host;NVPTX"
|
|
|
|
"-DLLVM_ENABLE_RTTI=ON"
|
|
|
|
|
|
|
|
# Setting -DCLING_INCLUDE_TESTS=ON causes the cling/tools targets to be built;
|
|
|
|
# see cling/tools/CMakeLists.txt
|
|
|
|
"-DCLING_INCLUDE_TESTS=ON"
|
|
|
|
];
|
|
|
|
|
2021-01-23 13:15:07 +00:00
|
|
|
meta = with lib; {
|
2020-11-19 19:29:02 +00:00
|
|
|
description = "The Interactive C++ Interpreter";
|
|
|
|
homepage = "https://root.cern/cling/";
|
|
|
|
license = with licenses; [ lgpl21 ncsa ];
|
|
|
|
maintainers = with maintainers; [ thomasjm ];
|
|
|
|
platforms = platforms.unix;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# The flags passed to the wrapped cling should
|
|
|
|
# a) prevent it from searching for system include files and libs, and
|
|
|
|
# b) provide it with the include files and libs it needs (C and C++ standard library)
|
|
|
|
|
|
|
|
# These are also exposed as cling.flags/cling.compilerIncludeFlags because it's handy to be
|
|
|
|
# able to pass them to tools that wrap Cling, particularly Jupyter kernels such as xeus-cling
|
|
|
|
# and the built-in jupyter-cling-kernel. Both of these use Cling as a library by linking against
|
|
|
|
# libclingJupyter.so, so the makeWrapper approach to wrapping the binary doesn't work.
|
|
|
|
# Thus, if you're packaging a Jupyter kernel, you either need to pass these flags as extra
|
|
|
|
# args to xcpp (for xeus-cling) or put them in the environment variable CLING_OPTS
|
|
|
|
# (for jupyter-cling-kernel)
|
|
|
|
flags = [
|
|
|
|
"-nostdinc"
|
|
|
|
"-nostdinc++"
|
2021-01-23 13:15:07 +00:00
|
|
|
"-isystem" "${lib.getDev stdenv.cc.libc}/include"
|
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 09:23:57 +01:00
|
|
|
"-I" "${lib.getDev unwrapped}/include"
|
|
|
|
"-I" "${lib.getLib unwrapped}/lib/clang/5.0.2/include"
|
2020-11-19 19:29:02 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
# Autodetect the include paths for the compiler used to build Cling, in the same way Cling does at
|
|
|
|
# https://github.com/root-project/cling/blob/v0.7/lib/Interpreter/CIFactory.cpp#L107:L111
|
|
|
|
# Note: it would be nice to just put the compiler in Cling's PATH and let it do this by itself, but
|
|
|
|
# unfortunately passing -nostdinc/-nostdinc++ disables Cling's autodetection logic.
|
2021-08-15 16:12:23 +01:00
|
|
|
compilerIncludeFlags = runCommand "compiler-include-flags.txt" {} ''
|
2020-11-19 19:29:02 +00:00
|
|
|
export LC_ALL=C
|
|
|
|
${stdenv.cc}/bin/c++ -xc++ -E -v /dev/null 2>&1 | sed -n -e '/^.include/,''${' -e '/^ \/.*++/p' -e '}' > tmp
|
|
|
|
sed -e 's/^/-isystem /' -i tmp
|
|
|
|
tr '\n' ' ' < tmp > $out
|
|
|
|
'';
|
|
|
|
|
|
|
|
in
|
|
|
|
|
|
|
|
runCommand "cling-${unwrapped.version}" {
|
|
|
|
buildInputs = [ makeWrapper ];
|
|
|
|
inherit unwrapped flags compilerIncludeFlags;
|
|
|
|
inherit (unwrapped) meta;
|
|
|
|
} ''
|
|
|
|
makeWrapper $unwrapped/bin/cling $out/bin/cling \
|
|
|
|
--add-flags "$(cat "$compilerIncludeFlags")" \
|
|
|
|
--add-flags "$flags"
|
|
|
|
''
|