Martin Weinelt ae4a1a485a
treewide: add explicit format attribute for Python packages
If a Python package does not come with either `format` or `pyproject` we
consider it a setuptools build, that calls `setup.py` directly, which is
deprecated.

This change, as a first step, migrates a large chunk of these packages to
set setuptools as their explicit format

This is so we can unify the problem space for the next step of the
migration.
2025-07-02 05:56:47 +02:00

51 lines
1.4 KiB
Nix

{
lib,
lammps,
stdenv,
buildPythonPackage,
}:
let
LAMMPS_SHARED_LIB = "${lib.getLib lammps}/lib/liblammps${stdenv.hostPlatform.extensions.library}";
in
buildPythonPackage {
format = "setuptools";
inherit (lammps) pname version src;
env = {
# Needed for tests
inherit LAMMPS_SHARED_LIB;
};
# Don't perform checks if GPU is enabled - because libcuda.so cannot be opened in the sandbox
doCheck = if lammps.passthru.packages ? GPU then !lammps.passthru.packages.GPU else true;
preConfigure = ''
cd python
# Upstream assumes that the shared library is located in the same directory
# as the core.py file. We want to separate the shared library (built by
# cmake) and the Python library, so we perform this substitution:
substituteInPlace lammps/core.py \
--replace-fail \
"from inspect import getsourcefile" \
"getsourcefile = lambda f: \"${LAMMPS_SHARED_LIB}\""
'';
pythonImportsCheck = [
"lammps"
"lammps.pylammps"
];
# We could potentially run other examples, but some of them are so old that
# they don't run with nowadays' LAMMPS. This one is simple enough and recent
# enough and it works.
checkPhase = ''
python examples/mc.py examples/in.mc
'';
meta = {
description = "Python Bindings for LAMMPS";
homepage = "https://docs.lammps.org/Python_head.html";
inherit (lammps.meta) license;
maintainers = with lib.maintainers; [ doronbehar ];
};
}