2024-07-27 06:49:29 +00:00
|
|
|
{
|
|
|
|
lib,
|
|
|
|
stdenv,
|
|
|
|
buildPythonPackage,
|
|
|
|
rustPlatform,
|
|
|
|
fetchFromGitHub,
|
|
|
|
darwin,
|
|
|
|
libiconv,
|
|
|
|
pkg-config,
|
|
|
|
protobuf,
|
|
|
|
attrs,
|
|
|
|
cachetools,
|
|
|
|
deprecation,
|
|
|
|
overrides,
|
|
|
|
packaging,
|
|
|
|
pydantic,
|
|
|
|
pylance,
|
|
|
|
requests,
|
|
|
|
retry,
|
|
|
|
tqdm,
|
|
|
|
aiohttp,
|
|
|
|
pandas,
|
|
|
|
polars,
|
|
|
|
pytest-asyncio,
|
|
|
|
pytestCheckHook,
|
2024-09-19 14:19:46 +00:00
|
|
|
nix-update-script,
|
2024-07-27 06:49:29 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
buildPythonPackage rec {
|
|
|
|
pname = "lancedb";
|
2024-09-19 14:19:46 +00:00
|
|
|
version = "0.13.0";
|
2024-07-27 06:49:29 +00:00
|
|
|
pyproject = true;
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "lancedb";
|
|
|
|
repo = "lancedb";
|
|
|
|
rev = "refs/tags/python-v${version}";
|
2024-09-19 14:19:46 +00:00
|
|
|
hash = "sha256-6E20WgyoEALdxmiOfgq89dCkqovvIMzc/wy+kvjDWwU=";
|
2024-07-27 06:49:29 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
buildAndTestSubdir = "python";
|
|
|
|
|
|
|
|
cargoDeps = rustPlatform.importCargoLock { lockFile = ./Cargo.lock; };
|
|
|
|
|
|
|
|
postPatch = ''
|
|
|
|
ln -s ${./Cargo.lock} Cargo.lock
|
|
|
|
'';
|
|
|
|
|
|
|
|
build-system = [ rustPlatform.maturinBuildHook ];
|
|
|
|
|
|
|
|
nativeBuildInputs = [
|
|
|
|
pkg-config
|
|
|
|
rustPlatform.cargoSetupHook
|
|
|
|
];
|
|
|
|
|
|
|
|
buildInputs =
|
|
|
|
[
|
|
|
|
libiconv
|
|
|
|
protobuf
|
|
|
|
]
|
2024-09-26 11:04:55 +00:00
|
|
|
++ lib.optionals stdenv.hostPlatform.isDarwin (
|
2024-07-27 06:49:29 +00:00
|
|
|
with darwin.apple_sdk.frameworks;
|
|
|
|
[
|
|
|
|
IOKit
|
|
|
|
Security
|
|
|
|
SystemConfiguration
|
|
|
|
]
|
|
|
|
);
|
|
|
|
|
|
|
|
dependencies = [
|
|
|
|
attrs
|
|
|
|
cachetools
|
|
|
|
deprecation
|
|
|
|
overrides
|
|
|
|
packaging
|
|
|
|
pydantic
|
|
|
|
pylance
|
|
|
|
requests
|
|
|
|
retry
|
|
|
|
tqdm
|
|
|
|
];
|
|
|
|
|
|
|
|
pythonImportsCheck = [ "lancedb" ];
|
|
|
|
|
|
|
|
nativeCheckInputs = [
|
|
|
|
aiohttp
|
|
|
|
pandas
|
|
|
|
polars
|
|
|
|
pytest-asyncio
|
|
|
|
pytestCheckHook
|
|
|
|
];
|
|
|
|
|
|
|
|
preCheck = ''
|
|
|
|
cd python/python/tests
|
|
|
|
'';
|
|
|
|
|
|
|
|
pytestFlagsArray = [ "-m 'not slow'" ];
|
|
|
|
|
|
|
|
disabledTests = [
|
|
|
|
# require tantivy which is not packaged in nixpkgs
|
|
|
|
"test_basic"
|
2024-09-19 14:19:46 +00:00
|
|
|
|
|
|
|
# polars.exceptions.ComputeError: TypeError: _scan_pyarrow_dataset_impl() got multiple values for argument 'batch_size'
|
|
|
|
# https://github.com/lancedb/lancedb/issues/1539
|
|
|
|
"test_polars"
|
2024-07-27 06:49:29 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
disabledTestPaths = [
|
|
|
|
# touch the network
|
|
|
|
"test_s3.py"
|
|
|
|
];
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
passthru.updateScript = nix-update-script {
|
|
|
|
extraArgs = [
|
|
|
|
"--version-regex"
|
|
|
|
"python-v(.*)"
|
|
|
|
"--generate-lockfile"
|
|
|
|
"--lockfile-metadata-path"
|
|
|
|
"python"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2024-07-27 06:49:29 +00:00
|
|
|
meta = {
|
|
|
|
description = "Developer-friendly, serverless vector database for AI applications";
|
|
|
|
homepage = "https://github.com/lancedb/lancedb";
|
2024-09-19 14:19:46 +00:00
|
|
|
changelog = "https://github.com/lancedb/lancedb/releases/tag/python-v${version}";
|
2024-07-27 06:49:29 +00:00
|
|
|
license = lib.licenses.asl20;
|
|
|
|
maintainers = with lib.maintainers; [ natsukium ];
|
|
|
|
};
|
|
|
|
}
|