2022-07-14 12:49:19 +00:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, fetchFromGitHub
|
|
|
|
, autoreconfHook
|
|
|
|
, check
|
|
|
|
, flex
|
|
|
|
, pkg-config
|
|
|
|
, which
|
|
|
|
, elfutils
|
|
|
|
, libelf
|
2023-02-02 18:25:31 +00:00
|
|
|
, libffi
|
2022-07-14 12:49:19 +00:00
|
|
|
, llvm
|
|
|
|
, zlib
|
|
|
|
}:
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
|
|
|
pname = "nvc";
|
2023-02-22 10:55:15 +00:00
|
|
|
version = "1.8.2";
|
2022-07-14 12:49:19 +00:00
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "nickg";
|
|
|
|
repo = pname;
|
|
|
|
rev = "r${version}";
|
2023-02-22 10:55:15 +00:00
|
|
|
hash = "sha256-s7QgufD3sQ6sZh2H78E8x0dMidHRKHUm8tASXoKK3xk=";
|
2022-07-14 12:49:19 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
nativeBuildInputs = [
|
|
|
|
autoreconfHook
|
|
|
|
check
|
|
|
|
flex
|
|
|
|
pkg-config
|
|
|
|
which
|
|
|
|
];
|
|
|
|
|
|
|
|
buildInputs = [
|
2023-02-02 18:25:31 +00:00
|
|
|
libffi
|
2022-07-14 12:49:19 +00:00
|
|
|
llvm
|
|
|
|
zlib
|
|
|
|
] ++ [
|
|
|
|
(if stdenv.isLinux then elfutils else libelf)
|
|
|
|
];
|
|
|
|
|
2022-08-21 13:32:41 +00:00
|
|
|
# TODO: recheck me on next release
|
|
|
|
postPatch = lib.optionalString stdenv.isLinux ''
|
|
|
|
sed -i "/vhpi4/d" test/regress/testlist.txt
|
2022-07-14 12:49:19 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
preConfigure = ''
|
|
|
|
mkdir build
|
|
|
|
cd build
|
|
|
|
'';
|
|
|
|
|
|
|
|
configureScript = "../configure";
|
|
|
|
|
|
|
|
configureFlags = [
|
|
|
|
"--enable-vhpi"
|
|
|
|
"--disable-lto"
|
|
|
|
];
|
|
|
|
|
|
|
|
doCheck = true;
|
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
description = "VHDL compiler and simulator";
|
|
|
|
homepage = "https://www.nickg.me.uk/nvc/";
|
|
|
|
license = licenses.gpl3Plus;
|
|
|
|
platforms = platforms.unix;
|
|
|
|
maintainers = with maintainers; [ wegank ];
|
|
|
|
};
|
|
|
|
}
|