From 3e6abb633c17e82977b5ef7a0c122b666c9e3fc2 Mon Sep 17 00:00:00 2001 From: Austin Seipp Date: Fri, 14 Dec 2018 09:41:51 -0600 Subject: ber_metaocaml: cleanup, tweaks This puts MetaOCaml on more equal footing with the normal OCaml packages, which have a few passthru's and expect to have more 'meta' information available (such as 'platforms'). With these changes, you can use the ber_metaocaml package along with ocaml-ng.mkOcamlPackages in order to create a full package set with Native MetaOCaml support, though this currently isn't implemented (you have to do this yourself). There are also other light cleanups, for example this also removes the old MIPS support and restricts the platforms to x86 Linux/Darwin, for now. Other platforms can be added on a case-by-case basis. Signed-off-by: Austin Seipp --- pkgs/development/compilers/ocaml/ber-metaocaml.nix | 67 +++++++++++++--------- 1 file changed, 40 insertions(+), 27 deletions(-) (limited to 'pkgs/development/compilers/ocaml/ber-metaocaml.nix') diff --git a/pkgs/development/compilers/ocaml/ber-metaocaml.nix b/pkgs/development/compilers/ocaml/ber-metaocaml.nix index 2eeb6ad8408..999b2ebd6f6 100644 --- a/pkgs/development/compilers/ocaml/ber-metaocaml.nix +++ b/pkgs/development/compilers/ocaml/ber-metaocaml.nix @@ -1,17 +1,24 @@ -{ stdenv, fetchurl, ncurses, libX11, xproto, buildEnv }: +{ stdenv, fetchurl +, ncurses +, libX11, xproto, buildEnv +}: let useX11 = stdenv.isi686 || stdenv.isx86_64; + x11deps = [ libX11 xproto ]; inherit (stdenv.lib) optionals; + + baseOcamlBranch = "4.07"; + baseOcamlVersion = "${baseOcamlBranch}.1"; + metaocamlPatch = "107"; in stdenv.mkDerivation rec { - name = "ber-metaocaml-${version}"; - version = "107"; + version = metaocamlPatch; src = fetchurl { - url = "https://caml.inria.fr/pub/distrib/ocaml-4.07/ocaml-4.07.1.tar.gz"; + url = "https://caml.inria.fr/pub/distrib/ocaml-${baseOcamlBranch}/ocaml-${baseOcamlVersion}.tar.gz"; sha256 = "1x4sln131mcspisr22qc304590rvg720rbl7g2i4xiymgvhkpm1a"; }; @@ -20,21 +27,19 @@ stdenv.mkDerivation rec { sha256 = "0xy6n0yj1f53pk612zfmn49pn04bd75qa40xgmr0w0lzx6dqsfmm"; }; - # Needed to avoid a SIGBUS on the final executable on mips - NIX_CFLAGS_COMPILE = if stdenv.isMips then "-fPIC" else ""; - - x11env = buildEnv { name = "x11env"; paths = [libX11 xproto];}; - x11lib = x11env + "/lib"; - x11inc = x11env + "/include"; + x11env = buildEnv { name = "x11env"; paths = x11deps; }; + x11lib = "${x11env}/lib"; + x11inc = "${x11env}/include"; prefixKey = "-prefix "; - configureFlags = optionals useX11 [ "-x11lib" x11lib - "-x11include" x11inc ]; + configureFlags = optionals useX11 + [ "-x11lib" x11lib + "-x11include" x11inc + "-flambda" + ]; dontStrip = true; - buildInputs = [ncurses] ++ optionals useX11 [ libX11 xproto ]; - installFlags = "-i"; - installTargets = "install"; # + optionalString useNativeCompilers " installopt"; + buildInputs = [ ncurses ] ++ optionals useX11 x11deps; postConfigure = '' tar -xvzf $metaocaml @@ -42,6 +47,7 @@ stdenv.mkDerivation rec { make patch cd .. ''; + buildPhase = '' make world make -i install @@ -53,13 +59,13 @@ stdenv.mkDerivation rec { ln -sv $out/lib/ocaml/caml $out/include/caml cd ${name} make all + ''; + + installPhase = '' make install make install.opt - cd .. - ''; - installPhase = ""; - postBuild = '' ''; + checkPhase = '' cd ${name} make test @@ -68,16 +74,23 @@ stdenv.mkDerivation rec { cd .. ''; + passthru = { + nativeCompilers = true; + }; + meta = with stdenv.lib; { - homepage = "http://okmij.org/ftp/ML/index.html#ber-metaocaml"; - license = with licenses; [ - qpl /* compiler */ - lgpl2 /* library */ - ]; - description = "Conservative extension of OCaml"; + description = "Multi-Stage Programming extension for OCaml"; + homepage = http://okmij.org/ftp/ML/MetaOCaml.html; + license = with licenses; [ /* compiler */ qpl /* library */ lgpl2 ]; + maintainers = with maintainers; [ thoughtpolice ]; + + branch = baseOcamlBranch; + platforms = with platforms; linux ++ darwin; + broken = stdenv.isAarch64 || stdenv.isMips; + longDescription = '' - A conservative extension of OCaml with the primitive type of code values, - and three basic multi-stage expression forms: Brackets, Escape, and Run + A simple extension of OCaml with the primitive type of code values, and + three basic multi-stage expression forms: Brackets, Escape, and Run. ''; }; } -- cgit 1.4.1