nixpkgs/pkgs/development/python-modules/coffea/default.nix

111 lines
1.8 KiB
Nix

{
lib,
buildPythonPackage,
pythonOlder,
fetchFromGitHub,
# build-system
hatchling,
hatch-vcs,
# dependencies
aiohttp,
awkward,
cachetools,
cloudpickle,
correctionlib,
dask,
dask-awkward,
dask-histogram,
fsspec-xrootd,
hist,
lz4,
matplotlib,
mplhep,
numba,
numpy,
packaging,
pandas,
pyarrow,
requests,
scipy,
toml,
tqdm,
uproot,
# checks
distributed,
pyinstrument,
pytestCheckHook,
}:
buildPythonPackage rec {
pname = "coffea";
version = "2024.6.1";
pyproject = true;
disabled = pythonOlder "3.8";
src = fetchFromGitHub {
owner = "CoffeaTeam";
repo = "coffea";
rev = "refs/tags/v${version}";
hash = "sha256-Z6c8R8B8IrDkXVDx89XVtg3eRgORuHPfUyAPRGwAlrg=";
};
build-system = [
hatchling
hatch-vcs
];
dependencies = [
aiohttp
awkward
cachetools
cloudpickle
correctionlib
dask
dask-awkward
dask-histogram
fsspec-xrootd
hist
lz4
matplotlib
mplhep
numba
numpy
packaging
pandas
pyarrow
requests
scipy
toml
tqdm
uproot
] ++ dask.optional-dependencies.array;
nativeCheckInputs = [
distributed
pyinstrument
pytestCheckHook
];
pythonImportsCheck = [ "coffea" ];
disabledTests = [
# Requires internet access
# https://github.com/CoffeaTeam/coffea/issues/1094
"test_lumimask"
];
__darwinAllowLocalNetworking = true;
meta = {
description = "Basic tools and wrappers for enabling not-too-alien syntax when running columnar Collider HEP analysis";
homepage = "https://github.com/CoffeaTeam/coffea";
changelog = "https://github.com/CoffeaTeam/coffea/releases/tag/v${version}";
license = with lib.licenses; [ bsd3 ];
maintainers = with lib.maintainers; [ veprbl ];
};
}