{ lib, buildPythonPackage, fetchFromGitHub, # build-system hatchling, # optional-dependencies # cudf, dask, # modin, pandas, polars, pyarrow, pyspark, sqlframe, # tests duckdb, hypothesis, pytest-env, pytestCheckHook, }: buildPythonPackage rec { pname = "narwhals"; version = "1.37.0"; pyproject = true; src = fetchFromGitHub { owner = "narwhals-dev"; repo = "narwhals"; tag = "v${version}"; hash = "sha256-AYgpHJwQVP+F2kr5YJtjnLNYedc81RvRcX1Cfh7c0xw="; }; build-system = [ hatchling ]; optional-dependencies = { # cudf = [ cudf ]; dask = [ dask ] ++ dask.optional-dependencies.dataframe; # modin = [ modin ]; pandas = [ pandas ]; polars = [ polars ]; pyarrow = [ pyarrow ]; pyspark = [ pyspark ]; sqlframe = [ sqlframe ]; }; nativeCheckInputs = [ duckdb hypothesis pytest-env pytestCheckHook ] ++ lib.flatten (builtins.attrValues optional-dependencies); pythonImportsCheck = [ "narwhals" ]; pytestFlagsArray = [ "-W" "ignore::DeprecationWarning" ]; meta = { description = "Lightweight and extensible compatibility layer between dataframe libraries"; homepage = "https://github.com/narwhals-dev/narwhals"; changelog = "https://github.com/narwhals-dev/narwhals/releases/tag/${src.tag}"; license = lib.licenses.mit; maintainers = with lib.maintainers; [ fab ]; }; }