forked from gentoo/gentoo
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
dev-ml/llvm-ocaml: Add 19.0.0_pre20240712 snapshot
Signed-off-by: Michał Górny <[email protected]>
- Loading branch information
Showing
2 changed files
with
108 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
# Copyright 1999-2024 Gentoo Authors | ||
# Distributed under the terms of the GNU General Public License v2 | ||
|
||
EAPI=8 | ||
|
||
PYTHON_COMPAT=( python3_{10..13} ) | ||
inherit cmake llvm.org llvm-utils python-any-r1 | ||
|
||
DESCRIPTION="OCaml bindings for LLVM" | ||
HOMEPAGE="https://llvm.org/" | ||
|
||
LICENSE="Apache-2.0-with-LLVM-exceptions UoI-NCSA" | ||
SLOT="0/${PV}" | ||
IUSE="+debug test" | ||
RESTRICT="!test? ( test )" | ||
|
||
RDEPEND=" | ||
>=dev-lang/ocaml-4.00.0:0= | ||
dev-ml/ocaml-ctypes:= | ||
~sys-devel/llvm-${PV}:=[debug?] | ||
!sys-devel/llvm[ocaml(-)] | ||
" | ||
|
||
DEPEND=" | ||
${RDEPEND} | ||
" | ||
BDEPEND=" | ||
${PYTHON_DEPS} | ||
dev-lang/perl | ||
dev-ml/findlib | ||
" | ||
|
||
LLVM_COMPONENTS=( llvm cmake third-party ) | ||
LLVM_USE_TARGETS=llvm | ||
llvm.org_set_globals | ||
|
||
src_configure() { | ||
llvm_prepend_path "${LLVM_MAJOR}" | ||
|
||
local libdir=$(get_libdir) | ||
local mycmakeargs=( | ||
-DLLVM_LIBDIR_SUFFIX=${libdir#lib} | ||
|
||
-DBUILD_SHARED_LIBS=OFF | ||
-DLLVM_BUILD_LLVM_DYLIB=ON | ||
-DLLVM_LINK_LLVM_DYLIB=ON | ||
-DLLVM_OCAML_OUT_OF_TREE=ON | ||
|
||
# cheap hack: LLVM combines both anyway, and the only difference | ||
# is that the former list is explicitly verified at cmake time | ||
-DLLVM_TARGETS_TO_BUILD="" | ||
-DLLVM_EXPERIMENTAL_TARGETS_TO_BUILD="${LLVM_TARGETS// /;}" | ||
-DLLVM_BUILD_TESTS=$(usex test) | ||
|
||
# disable various irrelevant deps and settings | ||
-DLLVM_ENABLE_FFI=OFF | ||
-DLLVM_ENABLE_TERMINFO=OFF | ||
-DHAVE_HISTEDIT_H=NO | ||
-DLLVM_ENABLE_ASSERTIONS=$(usex debug) | ||
-DLLVM_ENABLE_EH=ON | ||
-DLLVM_ENABLE_RTTI=ON | ||
|
||
-DLLVM_HOST_TRIPLE="${CHOST}" | ||
|
||
-DPython3_EXECUTABLE="${PYTHON}" | ||
|
||
# TODO: ocamldoc | ||
) | ||
|
||
use test && mycmakeargs+=( | ||
-DLLVM_LIT_ARGS="$(get_lit_flags)" | ||
) | ||
|
||
# LLVM_ENABLE_ASSERTIONS=NO does not guarantee this for us, #614844 | ||
# also: custom rules for OCaml do not work for CPPFLAGS | ||
use debug || local -x CFLAGS="${CFLAGS} -DNDEBUG" | ||
cmake_src_configure | ||
|
||
local llvm_libdir=$(llvm-config --libdir) | ||
# an ugly hack; TODO: figure out a way to pass -L to ocaml... | ||
cd "${BUILD_DIR}/${libdir}" || die | ||
ln -s "${llvm_libdir}"/*.so . || die | ||
|
||
if use test; then | ||
local llvm_bindir=$(llvm-config --bindir) | ||
# Force using system-installed tools. | ||
sed -i -e "/llvm_tools_dir/s@\".*\"@\"${llvm_bindir}\"@" \ | ||
"${BUILD_DIR}"/test/lit.site.cfg.py || die | ||
fi | ||
} | ||
|
||
src_compile() { | ||
cmake_build ocaml_all | ||
} | ||
|
||
src_test() { | ||
# respect TMPDIR! | ||
local -x LIT_PRESERVES_TMP=1 | ||
cmake_build check-llvm-bindings-ocaml | ||
} | ||
|
||
src_install() { | ||
DESTDIR="${D}" \ | ||
cmake -P "${BUILD_DIR}"/bindings/ocaml/cmake_install.cmake || die | ||
|
||
dodoc bindings/ocaml/README.txt | ||
} |