2024-06-05 15:53:02 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
buildPythonPackage,
|
|
|
|
fetchPypi,
|
|
|
|
pythonOlder,
|
|
|
|
jinja2,
|
|
|
|
ply,
|
|
|
|
verilog,
|
|
|
|
pytestCheckHook,
|
2021-08-05 21:33:18 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
pname = "pyverilog";
|
|
|
|
version = "1.3.0";
|
2024-01-02 11:29:13 +00:00
|
|
|
format = "setuptools";
|
2021-08-05 21:33:18 +00:00
|
|
|
|
|
|
|
src = fetchPypi {
|
|
|
|
inherit pname version;
|
|
|
|
sha256 = "1a74k8r21swmfwvgv4c014y6nbcyl229fspxw89ygsgb0j83xnar";
|
|
|
|
};
|
|
|
|
|
|
|
|
disabled = pythonOlder "3.7";
|
|
|
|
|
|
|
|
patchPhase = ''
|
|
|
|
# The path to Icarus can still be overridden via an environment variable at runtime.
|
|
|
|
substituteInPlace pyverilog/vparser/preprocessor.py \
|
|
|
|
--replace "iverilog = 'iverilog'" "iverilog = '${verilog}/bin/iverilog'"
|
|
|
|
'';
|
|
|
|
|
|
|
|
propagatedBuildInputs = [
|
|
|
|
jinja2
|
|
|
|
ply
|
|
|
|
verilog
|
|
|
|
];
|
|
|
|
|
2022-04-15 01:41:22 +00:00
|
|
|
preCheck = ''
|
|
|
|
substituteInPlace pytest.ini \
|
|
|
|
--replace "python_paths" "pythonpath"
|
|
|
|
'';
|
|
|
|
|
2024-06-05 15:53:02 +00:00
|
|
|
nativeCheckInputs = [ pytestCheckHook ];
|
2021-08-05 21:33:18 +00:00
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
homepage = "https://github.com/PyHDI/Pyverilog";
|
|
|
|
description = "Python-based Hardware Design Processing Toolkit for Verilog HDL";
|
|
|
|
license = licenses.asl20;
|
|
|
|
maintainers = with maintainers; [ trepetti ];
|
|
|
|
};
|
|
|
|
}
|