lamindb 0.70.0__py3-none-any.whl → 0.70.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
lamindb/__init__.py CHANGED
@@ -40,7 +40,7 @@ Modules & settings:
40
40
 
41
41
  """
42
42
 
43
- __version__ = "0.70.0" # denote a release candidate for 0.1.0 with 0.1rc1
43
+ __version__ = "0.70.1" # denote a release candidate for 0.1.0 with 0.1rc1
44
44
 
45
45
  import os as _os
46
46
 
lamindb/_artifact.py CHANGED
@@ -37,7 +37,7 @@ from lamindb.core.storage import (
37
37
  size_adata,
38
38
  write_to_file,
39
39
  )
40
- from lamindb.core.storage.file import (
40
+ from lamindb.core.storage.paths import (
41
41
  auto_storage_key_from_artifact,
42
42
  auto_storage_key_from_artifact_uid,
43
43
  filepath_from_artifact,
@@ -50,8 +50,8 @@ from .core._data import (
50
50
  save_feature_set_links,
51
51
  save_feature_sets,
52
52
  )
53
- from .core.storage.file import AUTO_KEY_PREFIX
54
- from .core.storage.object import _mudata_is_installed
53
+ from .core.storage.objects import _mudata_is_installed
54
+ from .core.storage.paths import AUTO_KEY_PREFIX
55
55
 
56
56
  if TYPE_CHECKING:
57
57
  from lamindb_setup.core.types import UPathStr
@@ -167,7 +167,7 @@ def process_data(
167
167
  # Alex: I don't understand the line below
168
168
  if path.suffixes == []:
169
169
  path = path.with_suffix(suffix)
170
- if suffix not in {".zarr", ".zrad"}:
170
+ if suffix != ".zarr":
171
171
  write_to_file(data, path)
172
172
  use_existing_storage_key = False
173
173
  else:
@@ -188,11 +188,7 @@ def get_stat_or_artifact(
188
188
  n_objects = None
189
189
  if settings.upon_file_create_skip_size_hash:
190
190
  return None, None, None, n_objects
191
- if (
192
- suffix in {".zarr", ".zrad"}
193
- and memory_rep is not None
194
- and isinstance(memory_rep, AnnData)
195
- ):
191
+ if suffix == ".zarr" and memory_rep is not None and isinstance(memory_rep, AnnData):
196
192
  size = size_adata(memory_rep)
197
193
  return size, None, None, n_objects
198
194
  stat = path.stat() # one network request
@@ -450,7 +446,12 @@ def data_is_anndata(data: AnnData | UPathStr):
450
446
  if isinstance(data, AnnData):
451
447
  return True
452
448
  if isinstance(data, (str, Path, UPath)):
453
- return Path(data).suffix in {".h5ad", ".zrad"}
449
+ if Path(data).suffix == ".h5ad":
450
+ return True
451
+ elif Path(data).suffix == ".zarr":
452
+ raise NotImplementedError(
453
+ "auto-detecting AnnData from Zarr is not yet supported"
454
+ )
454
455
  return False
455
456
 
456
457
 
@@ -832,7 +833,7 @@ def replace(
832
833
 
833
834
  # docstring handled through attach_func_to_class_method
834
835
  def backed(self, is_run_input: bool | None = None) -> AnnDataAccessor | BackedAccessor:
835
- suffixes = (".h5", ".hdf5", ".h5ad", ".zrad", ".zarr")
836
+ suffixes = (".h5", ".hdf5", ".h5ad", ".zarr")
836
837
  if self.suffix not in suffixes:
837
838
  raise ValueError(
838
839
  "Artifact should have a zarr or h5 object as the underlying data, please"
lamindb/_can_validate.py CHANGED
@@ -30,6 +30,7 @@ def inspect(
30
30
  *,
31
31
  mute: bool = False,
32
32
  organism: str | Registry | None = None,
33
+ public_source: Registry | None = None,
33
34
  ) -> InspectResult:
34
35
  """{}."""
35
36
  return _inspect(
@@ -38,6 +39,7 @@ def inspect(
38
39
  field=field,
39
40
  mute=mute,
40
41
  organism=organism,
42
+ public_source=public_source,
41
43
  )
42
44
 
43
45
 
@@ -63,6 +65,7 @@ def _inspect(
63
65
  mute: bool = False,
64
66
  using_key: str | None = None,
65
67
  organism: str | Registry | None = None,
68
+ public_source: Registry | None = None,
66
69
  ) -> pd.DataFrame | dict[str, list[str]]:
67
70
  """{}."""
68
71
  from lamin_utils._inspect import inspect
@@ -86,9 +89,9 @@ def _inspect(
86
89
 
87
90
  if len(nonval) > 0 and orm.__get_schema_name__() == "bionty":
88
91
  try:
89
- bionty_result = orm.public(organism=organism).inspect(
90
- values=nonval, field=field, mute=True
91
- )
92
+ bionty_result = orm.public(
93
+ organism=organism, public_source=public_source
94
+ ).inspect(values=nonval, field=field, mute=True)
92
95
  bionty_validated = bionty_result.validated
93
96
  bionty_mapper = bionty_result.synonyms_mapper
94
97
  hint = False
lamindb/_collection.py CHANGED
@@ -234,7 +234,7 @@ def mapped(
234
234
  ) -> MappedCollection:
235
235
  path_list = []
236
236
  for artifact in self.artifacts.all():
237
- if artifact.suffix not in {".h5ad", ".zrad", ".zarr"}:
237
+ if artifact.suffix not in {".h5ad", ".zarr"}:
238
238
  logger.warning(f"Ignoring artifact with suffix {artifact.suffix}")
239
239
  continue
240
240
  elif not stream:
lamindb/_from_values.py CHANGED
@@ -21,6 +21,7 @@ def get_or_create_records(
21
21
  from_public: bool = False,
22
22
  organism: Registry | str | None = None,
23
23
  public_source: Registry | None = None,
24
+ mute: bool = False,
24
25
  ) -> list[Registry]:
25
26
  """Get or create records from iterables."""
26
27
  upon_create_search_names = settings.upon_create_search_names
@@ -38,14 +39,18 @@ def get_or_create_records(
38
39
 
39
40
  # returns existing records & non-existing values
40
41
  records, nonexist_values, msg = get_existing_records(
41
- iterable_idx=iterable_idx, field=field, **kwargs
42
+ iterable_idx=iterable_idx, field=field, mute=mute, **kwargs
42
43
  )
43
44
 
44
45
  # new records to be created based on new values
45
46
  if len(nonexist_values) > 0:
46
47
  if from_public:
47
48
  records_bionty, unmapped_values = create_records_from_public(
48
- iterable_idx=nonexist_values, field=field, msg=msg, **kwargs
49
+ iterable_idx=nonexist_values,
50
+ field=field,
51
+ msg=msg,
52
+ mute=mute,
53
+ **kwargs,
49
54
  )
50
55
  if len(records_bionty) > 0:
51
56
  msg = ""
@@ -56,16 +61,17 @@ def get_or_create_records(
56
61
  unmapped_values = nonexist_values
57
62
  # unmapped new_ids will NOT create records
58
63
  if len(unmapped_values) > 0:
59
- if len(msg) > 0:
64
+ if len(msg) > 0 and not mute:
60
65
  logger.success(msg)
61
66
  s = "" if len(unmapped_values) == 1 else "s"
62
67
  print_values = colors.yellow(_print_values(unmapped_values))
63
68
  name = Registry.__name__
64
69
  n_nonval = colors.yellow(f"{len(unmapped_values)} non-validated")
65
- logger.warning(
66
- f"{colors.red('did not create')} {name} record{s} for "
67
- f"{n_nonval} {colors.italic(f'{field.field.name}{s}')}: {print_values}"
68
- )
70
+ if not mute:
71
+ logger.warning(
72
+ f"{colors.red('did not create')} {name} record{s} for "
73
+ f"{n_nonval} {colors.italic(f'{field.field.name}{s}')}: {print_values}"
74
+ )
69
75
  if Registry.__module__.startswith("lnschema_bionty.") or Registry == ULabel:
70
76
  if isinstance(iterable, pd.Series):
71
77
  feature = iterable.name
@@ -85,6 +91,7 @@ def get_or_create_records(
85
91
  def get_existing_records(
86
92
  iterable_idx: pd.Index,
87
93
  field: StrField,
94
+ mute: bool = False,
88
95
  **kwargs,
89
96
  ):
90
97
  model = field.field.model
@@ -96,7 +103,11 @@ def get_existing_records(
96
103
  # standardize based on the DB reference
97
104
  # log synonyms mapped terms
98
105
  result = model.inspect(
99
- iterable_idx, field=field, organism=kwargs.get("organism"), mute=True
106
+ iterable_idx,
107
+ field=field,
108
+ organism=kwargs.get("organism"),
109
+ public_source=kwargs.get("public_source"),
110
+ mute=True,
100
111
  )
101
112
  syn_mapper = result.synonyms_mapper
102
113
 
@@ -146,9 +157,10 @@ def get_existing_records(
146
157
  # no logging if all values are validated
147
158
  # logs if there are synonyms
148
159
  if len(syn_msg) > 0:
149
- if len(msg) > 0:
160
+ if len(msg) > 0 and not mute:
150
161
  logger.success(msg)
151
- logger.success(syn_msg)
162
+ if not mute:
163
+ logger.success(syn_msg)
152
164
  msg = ""
153
165
 
154
166
  existing_values = iterable_idx.intersection(
@@ -163,6 +175,7 @@ def create_records_from_public(
163
175
  iterable_idx: pd.Index,
164
176
  field: StrField,
165
177
  msg: str = "",
178
+ mute: bool = False,
166
179
  **kwargs,
167
180
  ):
168
181
  model = field.field.model
@@ -219,19 +232,20 @@ def create_records_from_public(
219
232
  s = "" if len(validated) == 1 else "s"
220
233
  print_values = colors.purple(_print_values(validated))
221
234
  # this is the success msg for existing records in the DB
222
- if len(msg) > 0:
235
+ if len(msg) > 0 and not mute:
223
236
  logger.success(msg)
224
- logger.success(
225
- "created"
226
- f" {colors.purple(f'{len(validated)} {model.__name__} record{s} from Bionty')}"
227
- f" matching {colors.italic(f'{field.field.name}')}: {print_values}"
228
- )
237
+ if not mute:
238
+ logger.success(
239
+ "created"
240
+ f" {colors.purple(f'{len(validated)} {model.__name__} record{s} from Bionty')}"
241
+ f" matching {colors.italic(f'{field.field.name}')}: {print_values}"
242
+ )
229
243
 
230
244
  # make sure that synonyms logging appears after the field logging
231
- if len(msg_syn) > 0:
245
+ if len(msg_syn) > 0 and not mute:
232
246
  logger.success(msg_syn)
233
247
  # warning about multi matches
234
- if len(multi_msg) > 0:
248
+ if len(multi_msg) > 0 and not mute:
235
249
  logger.warning(multi_msg)
236
250
 
237
251
  # return the values that are not found in the bionty reference
lamindb/_registry.py CHANGED
@@ -134,6 +134,7 @@ def from_values(
134
134
  field: StrField | None = None,
135
135
  organism: Registry | str | None = None,
136
136
  public_source: Registry | None = None,
137
+ mute: bool = False,
137
138
  ) -> list[Registry]:
138
139
  """{}."""
139
140
  from_public = True if cls.__module__.startswith("lnschema_bionty.") else False
@@ -144,6 +145,7 @@ def from_values(
144
145
  from_public=from_public,
145
146
  organism=organism,
146
147
  public_source=public_source,
148
+ mute=mute,
147
149
  )
148
150
 
149
151
 
lamindb/_save.py CHANGED
@@ -16,11 +16,11 @@ from lamindb_setup.core.upath import UPath, print_hook
16
16
  from lnschema_core.models import Artifact, Registry
17
17
 
18
18
  from lamindb.core._settings import settings
19
- from lamindb.core.storage.file import (
19
+ from lamindb.core.storage.paths import (
20
20
  attempt_accessing_path,
21
21
  auto_storage_key_from_artifact,
22
22
  delete_storage_using_key,
23
- store_artifact,
23
+ store_file_or_folder,
24
24
  )
25
25
 
26
26
  try:
@@ -286,7 +286,7 @@ def upload_artifact(
286
286
  )
287
287
  msg = f"storing artifact '{artifact.uid}' at '{storage_path}'"
288
288
  if (
289
- artifact.suffix in {".zarr", ".zrad"}
289
+ artifact.suffix == ".zarr"
290
290
  and hasattr(artifact, "_memory_rep")
291
291
  and artifact._memory_rep is not None
292
292
  ):
@@ -295,6 +295,5 @@ def upload_artifact(
295
295
  write_adata_zarr(artifact._memory_rep, storage_path, callback=print_progress)
296
296
  elif hasattr(artifact, "_to_store") and artifact._to_store:
297
297
  logger.save(msg)
298
- store_artifact(artifact._local_filepath, storage_path)
299
-
298
+ store_file_or_folder(artifact._local_filepath, storage_path)
300
299
  return storage_path
@@ -10,5 +10,5 @@ from lamindb_setup.core.upath import LocalPathClasses, UPath, infer_filesystem
10
10
 
11
11
  from ._anndata_sizes import size_adata
12
12
  from ._backed_access import AnnDataAccessor, BackedAccessor
13
- from .file import delete_storage, load_to_memory
14
- from .object import infer_suffix, write_to_file
13
+ from .objects import infer_suffix, write_to_file
14
+ from .paths import delete_storage, load_to_memory
@@ -22,7 +22,7 @@ from lamindb_setup.core.upath import UPath, create_mapper, infer_filesystem
22
22
  from lnschema_core import Artifact
23
23
  from packaging import version
24
24
 
25
- from lamindb.core.storage.file import filepath_from_artifact
25
+ from lamindb.core.storage.paths import filepath_from_artifact
26
26
 
27
27
  if TYPE_CHECKING:
28
28
  from pathlib import Path
@@ -743,15 +743,15 @@ def backed_access(
743
743
 
744
744
  if filepath.suffix in (".h5", ".hdf5", ".h5ad"):
745
745
  conn, storage = registry.open("h5py", filepath)
746
- elif filepath.suffix in (".zarr", ".zrad"):
746
+ elif filepath.suffix == ".zarr":
747
747
  conn, storage = registry.open("zarr", filepath)
748
748
  else:
749
749
  raise ValueError(
750
- "file should have .h5, .hdf5, .h5ad, .zarr or .zrad suffix, not"
750
+ "file should have .h5, .hdf5, .h5ad, .zarr suffix, not"
751
751
  f" {filepath.suffix}."
752
752
  )
753
753
 
754
- if filepath.suffix in (".h5ad", ".zrad"):
754
+ if filepath.suffix in (".h5ad", ".zarr"):
755
755
  return AnnDataAccessor(conn, storage, name)
756
756
  else:
757
757
  if get_spec(storage).encoding_type == "anndata":
@@ -21,11 +21,10 @@ def infer_suffix(dmem, adata_format: str | None = None):
21
21
  """Infer LaminDB storage file suffix from a data object."""
22
22
  if isinstance(dmem, AnnData):
23
23
  if adata_format is not None:
24
- # below should be zrad, not zarr
25
- if adata_format not in ("h5ad", "zarr", "zrad"):
24
+ if adata_format not in ("h5ad", "zarr"):
26
25
  raise ValueError(
27
26
  "Error when specifying AnnData storage format, it should be"
28
- f" 'h5ad', 'zarr' or 'zrad', not '{adata_format}'. Check 'format'"
27
+ f" 'h5ad', 'zarr', not '{adata_format}'. Check 'format'"
29
28
  " or the suffix of 'key'."
30
29
  )
31
30
  return "." + adata_format
@@ -109,23 +109,23 @@ def read_adata_h5ad(filepath, **kwargs) -> ad.AnnData:
109
109
  return adata
110
110
 
111
111
 
112
- def store_artifact(localpath: UPathStr, storagepath: UPath) -> None:
113
- """Store directory or file to configured storage location."""
114
- localpath = Path(localpath)
115
- if not isinstance(storagepath, LocalPathClasses):
112
+ def store_file_or_folder(local_path: UPathStr, storage_path: UPath) -> None:
113
+ """Store file or folder (localpath) at storagepath."""
114
+ local_path = Path(local_path)
115
+ if not isinstance(storage_path, LocalPathClasses):
116
116
  # this uploads files and directories
117
- storagepath.upload_from(localpath, recursive=True, print_progress=True)
117
+ storage_path.upload_from(local_path, recursive=True, print_progress=True)
118
118
  else: # storage path is local
119
- storagepath.parent.mkdir(parents=True, exist_ok=True)
120
- if localpath.is_file():
119
+ storage_path.parent.mkdir(parents=True, exist_ok=True)
120
+ if local_path.is_file():
121
121
  try:
122
- shutil.copyfile(localpath, storagepath)
122
+ shutil.copyfile(local_path, storage_path)
123
123
  except shutil.SameFileError:
124
124
  pass
125
125
  else:
126
- if storagepath.exists():
127
- shutil.rmtree(storagepath)
128
- shutil.copytree(localpath, storagepath)
126
+ if storage_path.exists():
127
+ shutil.rmtree(storage_path)
128
+ shutil.copytree(local_path, storage_path)
129
129
 
130
130
 
131
131
  def delete_storage_using_key(
@@ -212,7 +212,7 @@ def load_to_memory(filepath: UPathStr, stream: bool = False, **kwargs):
212
212
  """
213
213
  filepath = create_path(filepath)
214
214
 
215
- if filepath.suffix not in {".h5ad", ".zarr", ".zrad"}:
215
+ if filepath.suffix not in {".h5ad", ".zarr"}:
216
216
  stream = False
217
217
 
218
218
  if not stream:
@@ -229,7 +229,6 @@ def load_to_memory(filepath: UPathStr, stream: bool = False, **kwargs):
229
229
  ".parquet": pd.read_parquet,
230
230
  ".fcs": read_fcs,
231
231
  ".zarr": read_adata_zarr,
232
- ".zrad": read_adata_zarr,
233
232
  ".html": load_html,
234
233
  ".json": load_json,
235
234
  ".h5mu": read_mdata_h5mu,
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: lamindb
3
- Version: 0.70.0
3
+ Version: 0.70.1
4
4
  Summary: A data framework for biology.
5
5
  Author-email: Lamin Labs <open-source@lamin.ai>
6
6
  Requires-Python: >=3.8
@@ -9,7 +9,7 @@ Classifier: Programming Language :: Python :: 3.8
9
9
  Classifier: Programming Language :: Python :: 3.9
10
10
  Classifier: Programming Language :: Python :: 3.10
11
11
  Classifier: Programming Language :: Python :: 3.11
12
- Requires-Dist: lnschema_core==0.65.0
12
+ Requires-Dist: lnschema_core==0.65.1
13
13
  Requires-Dist: lamindb_setup==0.69.2
14
14
  Requires-Dist: lamin_utils==0.13.1
15
15
  Requires-Dist: lamin_cli==0.12.3
@@ -27,7 +27,7 @@ Requires-Dist: urllib3<2 ; extra == "aws"
27
27
  Requires-Dist: aiobotocore[boto3]>=2.5.4,<3.0.0 ; extra == "aws"
28
28
  Requires-Dist: s3fs==2023.12.2 ; extra == "aws"
29
29
  Requires-Dist: fsspec[s3]==2023.12.2 ; extra == "aws"
30
- Requires-Dist: bionty==0.42.8 ; extra == "bionty"
30
+ Requires-Dist: bionty==0.42.9 ; extra == "bionty"
31
31
  Requires-Dist: pandas<2 ; extra == "dev"
32
32
  Requires-Dist: pre-commit ; extra == "dev"
33
33
  Requires-Dist: nox ; extra == "dev"
@@ -1,20 +1,20 @@
1
- lamindb/__init__.py,sha256=BT6UZlIvg7VG1sTaQ_k81e1b2ATVgR3eTSMjFitNerA,2163
1
+ lamindb/__init__.py,sha256=z8Z1Bsb9A_xPvukQCyt7I2d5w_FsWd27bMZlULQJ7JU,2163
2
2
  lamindb/_annotate.py,sha256=BXYWFATifbfRVmLFIgE4cZ4Fls4lkH2WXAEL2o7v-XM,43035
3
- lamindb/_artifact.py,sha256=eUh0_dCD_wLMUL7HxWTKjk7WGeyFh1olJVMkQETzLUU,37193
4
- lamindb/_can_validate.py,sha256=qA6Ni9scObcIeYzuudVymgOjQVLLxnGNofBSDNDaqfY,14557
5
- lamindb/_collection.py,sha256=Yo72YdmAKP4O6awoJAFhRKKzM6rKelS0inII8sKk0ls,14545
3
+ lamindb/_artifact.py,sha256=BUl_3WYwrZ28P93Pb9AiwriVFBSLvBUEQjYEyYCrkZ0,37307
4
+ lamindb/_can_validate.py,sha256=nvoZG-35n3HofkY4Xc6hBv9AV54_RDan7Hzp5TuqY9I,14709
5
+ lamindb/_collection.py,sha256=wf7ClfiD3vsetts_iSUk4UihWsHq0IdOF8LdIIHS7JU,14536
6
6
  lamindb/_feature.py,sha256=srAKchY7gqD-h-cWlEiAWuHlpFKFwv0PWIA-JX0Go8c,6758
7
7
  lamindb/_feature_set.py,sha256=AzjOcHzQajpeikPOAic-aj0z_C5b7VpHVegg3ThRSLw,9045
8
8
  lamindb/_filter.py,sha256=xnjJzjF3Zj4dK_Kfymvhgczk27MhhXz5ZYc7XINbgHY,1331
9
9
  lamindb/_finish.py,sha256=SIPIIMAXM2d00L6VHMf2qFiOHuTyAlLy-5qRJ-BYaIQ,8107
10
- lamindb/_from_values.py,sha256=Mupz-mW_aftlhSktH1cgSD4hVaQJW93VehoFJhD15h4,12207
10
+ lamindb/_from_values.py,sha256=DVXjnQ2wwNw-2bFzy0uXLdVlqoprrn95hTnrXwn-KqM,12638
11
11
  lamindb/_is_versioned.py,sha256=0PgRCmxEmYDcAjllLSOYZm132B1lW6QgmBBERhRyFt0,1341
12
12
  lamindb/_parents.py,sha256=N9T8jbd3eaoHDLE9TD1y1QgGcO81E6Brapy8LILzRCQ,14790
13
13
  lamindb/_query_manager.py,sha256=3zokXqxgj9vTJBnN2sbYKS-q69fyDDPF_aGq_rFHzXU,4066
14
14
  lamindb/_query_set.py,sha256=fy6xMK9MPGbD8D_i5iNzR8XA009W05ud4tbgrzd5-Vg,11287
15
- lamindb/_registry.py,sha256=CL-KlCC23HPWQgSeYg7Od2kbZdNViAjFqqdiGpKJKw8,19293
15
+ lamindb/_registry.py,sha256=-Bv10zSr6IY7QM5pu_35NiVjQDJnBcXRECVe9h7GEuY,19336
16
16
  lamindb/_run.py,sha256=b7A52M1On3QzFgIYyfQoz5Kk7V3wcu9p_Prq5bzd8v8,1838
17
- lamindb/_save.py,sha256=aqvE0ryZs4-sDk6DZPn-Ki724gHeLyA9w-1oN5m_XMU,11425
17
+ lamindb/_save.py,sha256=x16FBwltaTd1tnXm_zCxkvuVxyon6vRtekf37CfepXg,11426
18
18
  lamindb/_storage.py,sha256=VW8xq3VRv58-ciholvOdlcgvp_OIlLxx5GxLt-e2Irs,614
19
19
  lamindb/_transform.py,sha256=rxojJ91qQSkeYDHYbwqjFAYxBMgJd3cq_K7Z0n5g8Aw,3482
20
20
  lamindb/_ulabel.py,sha256=e5dw9h1tR0_u-DMn7Gzx0WhUhV5w7j4v3QbnLWQV7eI,1941
@@ -38,17 +38,17 @@ lamindb/core/versioning.py,sha256=DsEHpCueNwhRiIaRH5-O8H_1fJVNtWslCRx30YiIS5o,30
38
38
  lamindb/core/datasets/__init__.py,sha256=zRP98oqUAaXhqWyKMiH0s_ImVIuNeziQQ2kQ_t0f-DI,1353
39
39
  lamindb/core/datasets/_core.py,sha256=36vUOYFkX_4hBAnM_BujV5BRARMI5b9iI_SM9qS7wGc,20191
40
40
  lamindb/core/datasets/_fake.py,sha256=BZF9R_1iF0HDnvtZNqL2FtsjSMuqDIfuFxnw_LJYIh4,953
41
- lamindb/core/storage/__init__.py,sha256=9alBNtyH59VnoWJS-IdjLwFKlK-kgeCGl6jXk0_wGeQ,369
41
+ lamindb/core/storage/__init__.py,sha256=zsVbIseNLJfObDl7cuCbULr6rnux_R_N8EVV843XmIU,371
42
42
  lamindb/core/storage/_anndata_sizes.py,sha256=aXO3OB--tF5MChenSsigW6Q-RuE8YJJOUTVukkLrv9A,1029
43
- lamindb/core/storage/_backed_access.py,sha256=uW0zaeKune6k2zYJcLazIA7Xux9TS2tAHDNdz1syYZw,24557
43
+ lamindb/core/storage/_backed_access.py,sha256=DweJdYP8tKEOZbfJ1UKFQgAIzQjsJqdqj8U9y7T0oXo,24538
44
44
  lamindb/core/storage/_zarr.py,sha256=0i9-cJPjieIsp5UpK-IyRPkHAF-iKkWgpkWviSni2MM,2900
45
- lamindb/core/storage/file.py,sha256=AEMbrC6oWoIp3vs4F2bgm50EVBxkCGbN9R4na7Wanaw,7754
46
- lamindb/core/storage/object.py,sha256=37p8CSlfSlWPVuuD3MFcwQRj1n_kovLKVImh9SCR4Eg,1601
45
+ lamindb/core/storage/objects.py,sha256=5LbBeZVKuOOB8DceSE-PN8elKY0N9OhFXZPQJE4lK48,1538
46
+ lamindb/core/storage/paths.py,sha256=XWfSHK5b3_TFiK-IMvH-srvxO0bZStzA_rwjNaTxQU4,7725
47
47
  lamindb/integrations/__init__.py,sha256=aH2PmO2m4-vwIifMYTB0Fyyr_gZWtVnV71jT0tVWSw0,123
48
48
  lamindb/integrations/_vitessce.py,sha256=l3GPkzQXcwnMypbm8vDkITjognELjX8ucLaiqy99Jgg,2131
49
49
  lamindb/setup/__init__.py,sha256=OwZpZzPDv5lPPGXZP7-zK6UdO4FHvvuBh439yZvIp3A,410
50
50
  lamindb/setup/core/__init__.py,sha256=SevlVrc2AZWL3uALbE5sopxBnIZPWZ1IB0NBDudiAL8,167
51
- lamindb-0.70.0.dist-info/LICENSE,sha256=xx0jnfkXJvxRnG63LTGOxlggYnIysveWIZ6H3PNdCrQ,11357
52
- lamindb-0.70.0.dist-info/WHEEL,sha256=EZbGkh7Ie4PoZfRQ8I0ZuP9VklN_TvcZ6DSE5Uar4z4,81
53
- lamindb-0.70.0.dist-info/METADATA,sha256=Mj16sNRVTgeMpFSL9mNUzF9HBaGo1RzERYp2ejiW8Xk,2835
54
- lamindb-0.70.0.dist-info/RECORD,,
51
+ lamindb-0.70.1.dist-info/LICENSE,sha256=xx0jnfkXJvxRnG63LTGOxlggYnIysveWIZ6H3PNdCrQ,11357
52
+ lamindb-0.70.1.dist-info/WHEEL,sha256=EZbGkh7Ie4PoZfRQ8I0ZuP9VklN_TvcZ6DSE5Uar4z4,81
53
+ lamindb-0.70.1.dist-info/METADATA,sha256=qbHYrCM8tdhGUBT-70lupGW7AQ5RVNA7gg9yRTvihwA,2835
54
+ lamindb-0.70.1.dist-info/RECORD,,