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 <aseipp@pobox.com>
wip/yesman
Austin Seipp 6 years ago
parent 8dd2fb2ffb
commit 3e6abb633c
  1. 67
      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.
'';
};
}

Loading…
Cancel
Save