Skip to content

Commit

Permalink
patch out need for system lz4
Browse files Browse the repository at this point in the history
  • Loading branch information
tomjakubowski committed Oct 8, 2024
1 parent ee23fbc commit 3a5ae0f
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 9 deletions.
16 changes: 7 additions & 9 deletions recipe/meta.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ source:
- patches/fix_maturin.diff
- patches/disable_protobuf_src.diff
- patches/fix_windows.diff
- patches/fix_arrow.patch

build:
number: 0
Expand Down Expand Up @@ -45,15 +46,12 @@ requirements:
- pnpm
- pkg-config
- libprotobuf # for protoc
# XXX(tom): emsdk? no, use `jupyterlab` tooling to build extension from npm source (which will DL wasm blob)
# vendored Arrow build is broken here:
# CMake Warning at /home/conda/feedstock_root/build_artifacts/debug_1728070755516/work/rust/target/x86_64-unknown-linux-gnu/release/build/perspective-server-ee5a4104f4b826d0/out/build/arrow-src/cpp/cmake_modules/Findlz4Alt.cmake:29 (find_package):
- xsimd # XXX(tom): Andrew says we shouldn't need this b/c we disable SIMD in arrow build
- lz4 # XXX(tom): likewise, this should be built from source downloaded by psp repo script. and yet the build fails without it
# Seems relevant, from the build spew:
# By not providing "Findlz4.cmake" in CMAKE_MODULE_PATH this project has
# asked CMake to find a package configuration file provided by "lz4", but
# CMake did not find one.
# Shouldn't need this b/c perspective disables ARROW_SIMD_LEVEL and
# ARROW_RUNTIME_SIMD_LEVEL in arrow build. Funny thing is: without this
# package, the build fails -- can't find Findxsimd.cmake. But if you
# immediately try rebuilding, it will then succeed, without xsimd on the
# system. Bewitching cmake cache behavior?
- xsimd
host:
- python
- pip
Expand Down
13 changes: 13 additions & 0 deletions recipe/patches/fix_arrow.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
diff --git a/cpp/perspective/CMakeLists.txt b/cpp/perspective/CMakeLists.txt
index 29f0be177..f79514cd9 100644
--- a/cpp/perspective/CMakeLists.txt
+++ b/cpp/perspective/CMakeLists.txt
@@ -364,6 +364,8 @@ psp_build_dep("flatbuffers" "${PSP_CMAKE_MODULE_PATH}/flatbuffers.txt.in")
psp_build_dep("lz4" "${PSP_CMAKE_MODULE_PATH}/lz4.txt.in")

# Build minimal arrow itself
+# Arrow detects conda and seeks dependencies that way. We want it to use our bundled lz4
+set(ARROW_DEPENDENCY_SOURCE "AUTO")
psp_build_dep("arrow" "${PSP_CMAKE_MODULE_PATH}/arrow.txt.in")

if(PSP_PYTHON_BUILD AND NOT PSP_PYODIDE)

0 comments on commit 3a5ae0f

Please sign in to comment.