commit | 75ef830c80b0edcbd3604eb013497e1792dfca69 | [log] [tgz] |
---|---|---|
author | William Ayd <william.ayd@icloud.com> | Thu Sep 05 11:25:48 2024 -0400 |
committer | GitHub <noreply@github.com> | Thu Sep 05 10:25:48 2024 -0500 |
tree | cf29cda5fe161eaaaff64737392bdec80b021b97 | |
parent | 9aa1414797b08d8e25063a644cabfcad0f001009 [diff] |
chore(ci): Add Meson build with Werror (#448) This should be a relatively easy way to enforce -Werror in CI; moved the Meson build from a scheduled job to be part of the normal CI runs.
The nanoarrow libraries are a set of helpers to produce and consume Arrow data, including the Arrow C Data, Arrow C Stream, and Arrow C Device, structures and the serialized Arrow IPC format. The vision of nanoarrow is that it should be trivial for libraries to produce and consume Arrow data: it helps fulfill this vision by providing high-quality, easy-to-adopt helpers to produce, consume, and test Arrow data types and arrays.
The nanoarrow libraries were built to be:
The nanoarrow Python bindings are available from PyPI and conda-forge:
pip install nanoarrow conda install nanoarrow -c conda-forge
The nanoarrow R package is available from CRAN:
install.packages("nanoarrow")
The C library can be used by generating bundled versions of the core library and its components. This is the version used internally by the R and Python bindings.
python ci/scripts/bundle.py \ --source-output-dir=dist \ --include-output-dir=dist \ --header-namespace= \ --with-device \ --with-ipc \ --with-testing \ --with-flatcc
CMake is also supported via a build/install with find_package()
or using FetchContent
:
fetchcontent_declare(nanoarrow URL "https://www.apache.org/dyn/closer.lua?action=download&filename=arrow/nanoarrow-0.5.0/apache-arrow-0.5.0.tar.gz") fetchcontent_makeavailable(nanoarrow)
The C library can also be used as a Meson subproject installed with:
mkdir subprojects
meson wrap install nanoarrow
...and declared as a dependency with:
nanoarrow_dep = dependency('nanoarrow') example_exec = executable('example_meson_minimal_app', 'src/app.cc', dependencies: [nanoarrow_dep])
See the nanoarrow Documentation for extended tutorials and API reference for the C, C++, Python, and R libraries.
The nanoarrow GitHub repository additionally provides a number of examples covering how to use nanoarrow in a variety of build configurations.
CMake is the primary build system used to develop and test the nanoarrow C library. You can build nanoarrow with:
mkdir build && cd build cmake .. cmake --build .
Building nanoarrow with tests currently requires Arrow C++. If installed via a system package manager like apt
, dnf
, or brew
, the tests can be built with:
mkdir build && cd build cmake .. -DNANOARROW_BUILD_TESTS=ON cmake --build .
Tests can be run with ctest
.
CMake is the officially supported build system for nanoarrow. However, the Meson backend is an experimental feature you may also wish to try.
meson setup builddir
cd builddir
After setting up your project, be sure to enable the options you want:
meson configure -Dtests=true -Dbenchmarks=true
If Arrow is installed in a non-standard location on your system, you may need to pass the --pkg-config-path <path to directory with arrow.pc>
argument to either the setup or configure steps above.
With the above out of the way, the compile
command should take care of the rest:
meson compile
Upon a successful build you can execute the test suite and benchmarks with the following commands:
meson test nanoarrow: # default test run meson test nanoarrow: --wrap valgrind # run tests under valgrind meson test nanoarrow: --benchmark --verbose # run benchmarks