| @rem Licensed to the Apache Software Foundation (ASF) under one |
| @rem or more contributor license agreements. See the NOTICE file |
| @rem distributed with this work for additional information |
| @rem regarding copyright ownership. The ASF licenses this file |
| @rem to you under the Apache License, Version 2.0 (the |
| @rem "License"); you may not use this file except in compliance |
| @rem with the License. You may obtain a copy of the License at |
| @rem |
| @rem http://www.apache.org/licenses/LICENSE-2.0 |
| @rem |
| @rem Unless required by applicable law or agreed to in writing, |
| @rem software distributed under the License is distributed on an |
| @rem "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| @rem KIND, either express or implied. See the License for the |
| @rem specific language governing permissions and limitations |
| @rem under the License. |
| |
| @echo on |
| |
| set SOURCE_DIR=%1 |
| set CMAKE_INSTALL_PREFIX=%2 |
| set CPP_SOURCE_DIR=%SOURCE_DIR%\cpp |
| set CPP_BUILD_DIR=%SOURCE_DIR%\build |
| echo C++ source dir is %CPP_SOURCE_DIR% |
| |
| echo Building for Windows ... |
| |
| @REM List installed Pythons |
| py -0p |
| |
| %PYTHON_CMD% -m sysconfig || exit /B 1 |
| |
| @REM Setup MSVC environment |
| |
| call "C:\Program Files\Microsoft Visual Studio\2022\Enterprise\VC\Auxiliary\Build\vcvarsall.bat" x64 |
| @echo on |
| |
| echo "=== CCACHE Stats before build ===" |
| ccache -sv |
| |
| echo "=== Building Arrow C++ libraries ===" |
| set ARROW_ACERO=ON |
| set ARROW_DATASET=ON |
| set ARROW_FLIGHT=OFF |
| set ARROW_GANDIVA=OFF |
| set ARROW_GCS=OFF |
| set ARROW_HDFS=ON |
| set ARROW_MIMALLOC=ON |
| set ARROW_ORC=OFF |
| set ARROW_PARQUET=ON |
| set PARQUET_REQUIRE_ENCRYPTION=ON |
| set ARROW_SUBSTRAIT=ON |
| set ARROW_S3=ON |
| set ARROW_TENSORFLOW=ON |
| set ARROW_WITH_BROTLI=ON |
| set ARROW_WITH_BZ2=OFF |
| set ARROW_WITH_LZ4=ON |
| set ARROW_WITH_SNAPPY=ON |
| set ARROW_WITH_ZLIB=ON |
| set ARROW_WITH_ZSTD=ON |
| set CMAKE_BUILD_TYPE=Release |
| set CMAKE_GENERATOR=Ninja |
| set CMAKE_UNITY_BUILD=ON |
| |
| mkdir %CPP_BUILD_DIR% |
| pushd %CPP_BUILD_DIR% |
| |
| cmake ^ |
| -DARROW_ACERO=%ARROW_ACERO% ^ |
| -DARROW_BUILD_SHARED=ON ^ |
| -DARROW_BUILD_STATIC=OFF ^ |
| -DARROW_BUILD_TESTS=OFF ^ |
| -DARROW_COMPUTE=ON ^ |
| -DARROW_CSV=ON ^ |
| -DARROW_CXXFLAGS="/MP" ^ |
| -DARROW_DATASET=%ARROW_DATASET% ^ |
| -DARROW_DEPENDENCY_USE_SHARED=OFF ^ |
| -DARROW_FILESYSTEM=ON ^ |
| -DARROW_FLIGHT=%ARROW_FLIGHT% ^ |
| -DARROW_GANDIVA=%ARROW_GANDIVA% ^ |
| -DARROW_GCS=%ARROW_GCS% ^ |
| -DARROW_HDFS=%ARROW_HDFS% ^ |
| -DARROW_JSON=ON ^ |
| -DARROW_MIMALLOC=%ARROW_MIMALLOC% ^ |
| -DARROW_ORC=%ARROW_ORC% ^ |
| -DARROW_PARQUET=%ARROW_PARQUET% ^ |
| -DARROW_S3=%ARROW_S3% ^ |
| -DARROW_SUBSTRAIT=%ARROW_SUBSTRAIT% ^ |
| -DARROW_TENSORFLOW=%ARROW_TENSORFLOW% ^ |
| -DARROW_USE_CCACHE=ON ^ |
| -DARROW_WITH_BROTLI=%ARROW_WITH_BROTLI% ^ |
| -DARROW_WITH_BZ2=%ARROW_WITH_BZ2% ^ |
| -DARROW_WITH_LZ4=%ARROW_WITH_LZ4% ^ |
| -DARROW_WITH_SNAPPY=%ARROW_WITH_SNAPPY% ^ |
| -DARROW_WITH_ZLIB=%ARROW_WITH_ZLIB% ^ |
| -DARROW_WITH_ZSTD=%ARROW_WITH_ZSTD% ^ |
| -DCMAKE_BUILD_TYPE=%CMAKE_BUILD_TYPE% ^ |
| -DCMAKE_INSTALL_PREFIX=%CMAKE_INSTALL_PREFIX% ^ |
| -DCMAKE_UNITY_BUILD=%CMAKE_UNITY_BUILD% ^ |
| -DMSVC_LINK_VERBOSE=ON ^ |
| -DPARQUET_REQUIRE_ENCRYPTION=%PARQUET_REQUIRE_ENCRYPTION% ^ |
| -Dxsimd_SOURCE=BUNDLED ^ |
| -G "%CMAKE_GENERATOR%" ^ |
| %CPP_SOURCE_DIR% || exit /B 1 |
| cmake --build . --config %CMAKE_BUILD_TYPE% --target install || exit /B 1 |
| popd |
| |
| echo "=== CCACHE Stats after build ===" |
| ccache -sv |
| |
| echo "=== Building Python ===" |
| set PYARROW_BUILD_TYPE=%CMAKE_BUILD_TYPE% |
| set PYARROW_BUILD_VERBOSE=1 |
| set PYARROW_BUNDLE_ARROW_CPP=ON |
| set PYARROW_CMAKE_GENERATOR=%CMAKE_GENERATOR% |
| set PYARROW_WITH_ACERO=%ARROW_ACERO% |
| set PYARROW_WITH_DATASET=%ARROW_DATASET% |
| set PYARROW_WITH_FLIGHT=%ARROW_FLIGHT% |
| set PYARROW_WITH_GANDIVA=%ARROW_GANDIVA% |
| set PYARROW_WITH_GCS=%ARROW_GCS% |
| set PYARROW_WITH_HDFS=%ARROW_HDFS% |
| set PYARROW_WITH_ORC=%ARROW_ORC% |
| set PYARROW_WITH_PARQUET=%ARROW_PARQUET% |
| set PYARROW_WITH_PARQUET_ENCRYPTION=%PARQUET_REQUIRE_ENCRYPTION% |
| set PYARROW_WITH_SUBSTRAIT=%ARROW_SUBSTRAIT% |
| set PYARROW_WITH_S3=%ARROW_S3% |
| set ARROW_HOME=%CMAKE_INSTALL_PREFIX% |
| set CMAKE_PREFIX_PATH=%CMAKE_INSTALL_PREFIX% |
| |
| pushd %SOURCE_DIR%\python |
| |
| @REM Install Python build dependencies |
| %PYTHON_CMD% -m pip install --upgrade pip || exit /B 1 |
| %PYTHON_CMD% -m pip install -r requirements-build.txt || exit /B 1 |
| |
| @REM Build PyArrow |
| %PYTHON_CMD% -m pip install --no-deps --no-build-isolation -vv . || exit /B 1 |
| |
| popd |