Thanks for your interest in TileDB-Py. The notes below give some pointers for filing issues and bug reports, or contributing to the code.
- Reporting a bug? Please include the following information
- operating system and version (windows, linux, macos, etc.)
- the output of
tiledb.version()
andtiledb.libtiledb.version()
- if possible, a minimal working example demonstrating the bug or issue (along with any data to re-create, when feasible)
- Please paste code blocks with triple backquotes (```) so that github will format it nicely. See GitHub's guide on Markdown for more formatting tricks.
By contributing code to TileDB-Py, you are agreeing to release it under the MIT License.
-
Quick steps to build locally:
-
install prerequisites via pip or conda:
pybind11
cython
numpy
pandas
pyarrow
-
recommended: install TileDB embedded (libtiledb)
NOTE: if libtiledb path is not specified with
--tiledb
, it will be built automatically bysetup.py
. However, this build is internal to the source tree and somewhat difficult to modify. When working on both projects simultaneously, it is strongly suggested to build libtiledb separately. Changes to libtiledb must bemake install-tiledb
todist
in order to be used with--tiledb
.- from latest release build: https://github.com/TileDB-Inc/TileDB/releases
tar xf tiledb-<platform>-<hash>.tar.gz -C /path/to/extract
- use
--tiledb=/path/to/extract
(note: this path should contain thelib
directory)
- from conda-forge:
mamba install tiledb
--tiledb=$CONDA_PREFIX
- from source: https://docs.tiledb.com/main/how-to/installation/building-from-source/c-cpp
- use
--tiledb=/path/to/tiledb/dist
option when runningsetup.py
in the step below - if building libtiledb from source, to enable serialization pass
--enable-serialization
to thebootstrap
script before compiling
- use
- serialization is optional. if libtiledb is not build with serialization, then it will not be enabled in TileDB-Py
- from latest release build: https://github.com/TileDB-Inc/TileDB/releases
-
build TileDB-Py
git clone https://github.com/TileDB-Inc/TileDB-Py cd TileDB-Py python setup.py develop --tiledb=</path/to/tiledb/dist>
-
-
Make changes locally, then rebuild with
python setup.py develop [--tiledb=<>]
-
Make sure to run
pytest
to verify changes against tests (add new tests where applicable).- Execute the tests as
pytest tiledb
from the top-level directory orpytest
in thetiledb/
directory.
- Execute the tests as
-
Please submit pull requests against the default
main
branch of TileDB-Py