{ lib , buildPythonPackage , duckdb , fsspec , google-cloud-storage , numpy , openssl , pandas , psutil , pybind11 , setuptools-scm , pytestCheckHook }: buildPythonPackage rec { inherit (duckdb) pname version src; format = "setuptools"; # 1. let nix control build cores # 2. default to extension autoload & autoinstall disabled # 3. unconstrain setuptools_scm version patches = (duckdb.patches or []) ++ [ ./setup.patch ]; postPatch = (duckdb.postPatch or "") + '' # we can't use sourceRoot otherwise patches don't apply, because the patches apply to the C++ library cd tools/pythonpkg substituteInPlace setup.py --subst-var NIX_BUILD_CORES # avoid dependency on mypy rm tests/stubs/test_stubs.py ''; BUILD_HTTPFS = 1; nativeBuildInputs = [ pybind11 setuptools-scm ]; buildInputs = [ openssl ]; propagatedBuildInputs = [ numpy pandas ]; nativeCheckInputs = [ fsspec google-cloud-storage psutil pytestCheckHook ]; disabledTests = [ # tries to make http request "test_install_non_existent_extension" # test is racy and interrupt can be delivered before or after target point "test_connection_interrupt" ]; preCheck = '' export HOME="$(mktemp -d)" ''; setupPyBuildFlags = [ "--inplace" ]; pythonImportsCheck = [ "duckdb" ]; meta = with lib; { description = "Python binding for DuckDB"; homepage = "https://duckdb.org/"; license = licenses.mit; maintainers = with maintainers; [ cpcloud ]; }; }