From 4ab98d80d67bd0fcab23dcc8e7bd711426604833 Mon Sep 17 00:00:00 2001 From: Joe Abraham Date: Tue, 3 Sep 2024 14:33:48 +0530 Subject: [PATCH] xxx --- scripts/setup-macos.sh | 66 +++++++++++++-------------- velox/functions/remote/CMakeLists.txt | 12 +++++ 2 files changed, 44 insertions(+), 34 deletions(-) diff --git a/scripts/setup-macos.sh b/scripts/setup-macos.sh index 5d01171052c29..823f3f5c6a5d3 100755 --- a/scripts/setup-macos.sh +++ b/scripts/setup-macos.sh @@ -14,7 +14,7 @@ # limitations under the License. # This script documents setting up a macOS host for Velox -# development. Running it should make you ready to compile. +# development. Running it should make you ready to compile. # # Environment variables: # * INSTALL_PREREQUISITES="N": Skip installation of brew/pip deps. @@ -43,9 +43,8 @@ BOOST_VERSION="boost-1.84.0" function update_brew { DEFAULT_BREW_PATH=/usr/local/bin/brew - if [ `arch` == "arm64" ] ; - then - DEFAULT_BREW_PATH=$(which brew) ; + if [ "$(arch)" == "arm64" ]; then + DEFAULT_BREW_PATH=$(which brew) fi BREW_PATH=${BREW_PATH:-$DEFAULT_BREW_PATH} $BREW_PATH update --auto-update --verbose @@ -54,65 +53,64 @@ function update_brew { function install_from_brew { pkg=$1 - if [[ "${pkg}" =~ ^([0-9a-z-]*):([0-9](\.[0-9\])*)$ ]]; - then + if [[ "${pkg}" =~ ^([0-9a-z-]*):([0-9](\.[0-9\])*)$ ]]; then pkg=${BASH_REMATCH[1]} ver=${BASH_REMATCH[2]} echo "Installing '${pkg}' at '${ver}'" tap="velox/local-${pkg}" brew tap-new "${tap}" brew extract "--version=${ver}" "${pkg}" "${tap}" - brew install "${tap}/${pkg}@${ver}" || ( echo "Failed to install ${tap}/${pkg}@${ver}" ; exit 1 ) + brew install "${tap}/${pkg}@${ver}" || { echo "Failed to install ${tap}/${pkg}@${ver}"; exit 1; } else - ( brew install --formula "${pkg}" && echo "Installation of ${pkg} is successful" || brew upgrade --formula "$pkg" ) || ( echo "Failed to install ${pkg}" ; exit 1 ) + (brew install --formula "${pkg}" && echo "Installation of ${pkg} is successful") || brew upgrade --formula "${pkg}" || { echo "Failed to install ${pkg}"; exit 1; } fi } function install_build_prerequisites { - for pkg in ${MACOS_BUILD_DEPS} - do + for pkg in ${MACOS_BUILD_DEPS}; do install_from_brew ${pkg} done if [ ! -f ${PYTHON_VENV}/pyvenv.cfg ]; then echo "Creating Python Virtual Environment at ${PYTHON_VENV}" python3 -m venv ${PYTHON_VENV} fi - source ${PYTHON_VENV}/bin/activate; pip3 install cmake-format regex pyyaml + source ${PYTHON_VENV}/bin/activate + pip3 install cmake-format regex pyyaml } function install_xsimd { - wget_and_untar https://github.com/xtensor-stack/xsimd/archive/refs/tags/${XSIMD_VERSION}.tar.gz xsimd - cmake_install xsimd - } + wget_and_untar https://github.com/xtensor-stack/xsimd/archive/refs/tags/${XSIMD_VERSION}.tar.gz xsimd + cmake_install xsimd +} function install_velox_deps_from_brew { - for pkg in ${MACOS_VELOX_DEPS} - do + for pkg in ${MACOS_VELOX_DEPS}; do install_from_brew ${pkg} done } +function install_boost { + wget_and_untar https://github.com/boostorg/boost/releases/download/${BOOST_VERSION}/${BOOST_VERSION}.tar.gz boost + ( + cd boost + if [[ ${USE_CLANG} != "false" ]]; then + ./bootstrap.sh --prefix=/usr/local --with-toolset="clang-15" + # Switch the compiler from the clang-15 toolset which doesn't exist (clang-15.jam) to + # clang of version 15 when toolset clang-15 is used. + # This reconciles the project-config.jam generation with what the b2 build system allows for customization. + sed -i 's/using clang-15/using clang : 15/g' project-config.jam + ${SUDO} ./b2 "-j${NPROC}" -d0 install threading=multi toolset=clang-15 --without-python + else + ./bootstrap.sh --prefix=/usr/local + ${SUDO} ./b2 "-j${NPROC}" -d0 install threading=multi --without-python + fi + ) +} + function install_proxygen { - github_checkout facebook/proxygen "${FB_OS_VERSION}" + wget_and_untar https://github.com/facebook/proxygen/archive/refs/tags/${FB_OS_VERSION}.tar.gz proxygen cmake_install -DBUILD_TESTS=OFF } -function install_boost { - wget_and_untar https://github.com/boostorg/boost/releases/download/${BOOST_VERSION}/${BOOST_VERSION}.tar.gz boost - ( - cd boost - if [[ ${USE_CLANG} != "false" ]]; then - ./bootstrap.sh --prefix=/usr/local --with-toolset="clang-15" - # Switch the compiler from the clang-15 toolset which doesn't exist (clang-15.jam) to - # clang of version 15 when toolset clang-15 is used. - # This reconciles the project-config.jam generation with what the b2 build system allows for customization. - sed -i 's/using clang-15/using clang : 15/g' project-config.jam - ${SUDO} ./b2 "-j${NPROC}" -d0 install threading=multi toolset=clang-15 --without-python - else - ./bootstrap.sh --prefix=/usr/local - ${SUDO} ./b2 "-j${NPROC}" -d0 install threading=multi --without-python - fi - ) - } function install_folly { wget_and_untar https://github.com/facebook/folly/archive/refs/tags/${FB_OS_VERSION}.tar.gz folly diff --git a/velox/functions/remote/CMakeLists.txt b/velox/functions/remote/CMakeLists.txt index a38c65894a2ff..c5f32ca662cb4 100644 --- a/velox/functions/remote/CMakeLists.txt +++ b/velox/functions/remote/CMakeLists.txt @@ -14,10 +14,22 @@ if(NOT DEFINED PROXYGEN_LIBRARIES) find_package(Sodium REQUIRED) + find_library(PROXYGEN proxygen) find_library(PROXYGEN_HTTP_SERVER proxygenhttpserver) find_library(FIZZ fizz) find_library(WANGLE wangle) + + if(NOT PROXYGEN + OR NOT PROXYGEN_HTTP_SERVER + OR NOT FIZZ + OR NOT WANGLE) + message( + FATAL_ERROR + "One or more proxygen libraries were not found. Please ensure proxygen, proxygenhttpserver, fizz, and wangle are installed." + ) + endif() + set(PROXYGEN_LIBRARIES ${PROXYGEN_HTTP_SERVER} ${PROXYGEN} ${WANGLE} ${FIZZ}) endif()