Files
nixpkgs/pkgs/development/python-modules/pyorc/default.nix
2025-10-06 12:35:12 +00:00

81 lines
1.6 KiB
Nix

{
lib,
buildPythonPackage,
fetchFromGitHub,
pybind11,
setuptools,
pytestCheckHook,
tzdata,
python,
pkgs,
}:
buildPythonPackage rec {
pname = "pyorc";
version = "0.10.0";
pyproject = true;
src = fetchFromGitHub {
owner = "noirello";
repo = "pyorc";
tag = "v${version}";
hash = "sha256-2w3Qh6g+Yg+D10kTow9YR6B6FhQ+z2DvgDy5GtYxH4g=";
};
postPatch = ''
substituteInPlace pyproject.toml \
--replace-fail \
'"pybind11>2.6.0,<3.0"' \
'"pybind11>2.6.0"'
'';
build-system = [
pybind11
setuptools
];
env = {
PYORC_SKIP_ORC_BUILD = "true";
};
buildInputs = [
pkgs.lz4
pkgs.protobuf_31
pkgs.snappy
pkgs.zlib
pkgs.zstd
pkgs.apache-orc
];
preCheck = ''
# provide timezone data, works only on linux
export TZDIR=${tzdata}/${python.sitePackages}/tzdata/zoneinfo
substituteInPlace "tests/compare/test_writer_cmp.py" \
--replace-fail "deps/bin/orc-contents" "orc-contents"
substituteInPlace "tests/compare/test_reader_cmp.py" \
--replace-fail "deps/bin/orc-metadata" "orc-metadata"
mkdir -p deps
ln -s "${pkgs.apache-orc.src}/examples" "deps/"
'';
pythonImportsCheck = [
"pyorc"
];
nativeCheckInputs = [
pytestCheckHook
pkgs.apache-orc
];
meta = {
changelog = "https://github.com/noirello/pyorc/blob/${version}/CHANGELOG.rst";
description = "Python module for Apache ORC file format";
homepage = "https://github.com/noirello/pyorc";
license = lib.licenses.asl20;
maintainers = [ ];
};
}