3
0
Fork 0
forked from mirrors/nixpkgs
nixpkgs/pkgs/development/compilers/manticore/default.nix

56 lines
1.4 KiB
Nix
Raw Normal View History

{ stdenv, fetchFromGitHub, coreutils, autoreconfHook, smlnj }:
let
2019-09-24 12:21:38 +01:00
rev= "4528ccacdfd53d36f5959c005b27cd7ab6175b83";
2019-08-13 22:52:01 +01:00
in stdenv.mkDerivation {
pname = "manticore";
2019-09-24 12:21:38 +01:00
version = "2019.09.20";
src = fetchFromGitHub {
owner = "ManticoreProject";
repo = "manticore";
2019-09-24 12:21:38 +01:00
sha256 = "1xz7msiq5x2c56zjxydbxlj6r001mm5zszcda6f6v5qfmmd1bakz";
inherit rev;
};
enableParallelBuilding = false;
nativeBuildInputs = [ autoreconfHook ];
buildInputs = [ coreutils smlnj ];
autoreconfFlags = "-Iconfig -vfi";
unpackPhase = ''
mkdir -p $out
cd $out
unpackFile $src
mv source repo_checkout
cd repo_checkout
chmod u+w . -R
'';
postPatch = ''
patchShebangs .
substituteInPlace configure.ac --replace 'MANTICORE_ROOT=`pwd`' 'MANTICORE_ROOT=$out/repo_checkout'
'';
preInstall = "mkdir -p $out/bin";
meta = {
description = "A parallel, pure variant of Standard ML";
longDescription = ''
Manticore is a high-level parallel programming language aimed at
general-purpose applications running on multi-core
processors. Manticore supports parallelism at multiple levels:
explicit concurrency and coarse-grain parallelism via CML-style
constructs and fine-grain parallelism via various light-weight
notations, such as parallel tuple expressions and NESL/Nepal-style
parallel array comprehensions.
'';
homepage = http://manticore.cs.uchicago.edu/;
};
}