-
Notifications
You must be signed in to change notification settings - Fork 19
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Move I/O operations to separate
geoarrow-rust-io
Python package (#754)
- Loading branch information
1 parent
e09f4af
commit eed1379
Showing
132 changed files
with
10,201 additions
and
3,376 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,277 @@ | ||
name: Python Wheels (IO) | ||
|
||
on: | ||
push: | ||
tags: | ||
- "py-v*" | ||
workflow_dispatch: | ||
|
||
concurrency: | ||
group: ${{ github.workflow }}-${{ github.ref }} | ||
cancel-in-progress: true | ||
|
||
jobs: | ||
linux: | ||
runs-on: ubuntu-latest | ||
strategy: | ||
matrix: | ||
target: [x86_64] | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: 3.8 | ||
architecture: x64 | ||
|
||
- name: Build wheels | ||
uses: PyO3/maturin-action@v1 | ||
with: | ||
target: ${{ matrix.target }} | ||
manylinux: manylinux_2_28 | ||
args: --release --out dist -m python/geoarrow-io/Cargo.toml | ||
before-script-linux: | | ||
yum update -y | ||
yum install openssl openssl-devel perl-IPC-Cmd -y | ||
- name: Install built wheel | ||
if: matrix.target == 'x86_64' | ||
run: | | ||
pip install geoarrow-rust-io --no-index --find-links dist --force-reinstall | ||
python -c "import geoarrow.rust.io" | ||
# Have to set path from root | ||
# https://github.com/actions/upload-artifact/issues/232#issuecomment-964235360 | ||
- name: Upload wheels | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: wheels | ||
path: dist/*.whl | ||
|
||
# linux-cross: | ||
# runs-on: ubuntu-latest | ||
# strategy: | ||
# matrix: | ||
# target: [aarch64, armv7, s390x, ppc64le, ppc64] | ||
# steps: | ||
# - uses: actions/checkout@v4 | ||
# - uses: actions/setup-python@v4 | ||
# with: | ||
# python-version: 3.8 | ||
|
||
# - name: Build wheels | ||
# uses: PyO3/maturin-action@v1 | ||
# with: | ||
# target: ${{ matrix.target }} | ||
# manylinux: auto | ||
# args: --release --out dist -m python/geoarrow-io/Cargo.toml | ||
|
||
# # This is currently failing with | ||
# # python: command not found | ||
|
||
# # - uses: uraimo/run-on-arch-action@v2.5.1 | ||
# # if: matrix.target == 'aarch64' | ||
# # name: Install built wheel | ||
# # with: | ||
# # arch: ${{ matrix.target }} | ||
# # distro: ubuntu20.04 | ||
# # githubToken: ${{ github.token }} | ||
# # install: | | ||
# # apt-get update | ||
# # apt-get install -y --no-install-recommends python3 python3-pip | ||
# # pip3 install -U pip | ||
# # run: | | ||
# # pip install geoarrow-rust-io --no-index --find-links dist --force-reinstall | ||
# # python -c "import geoarrow.rust.io" | ||
|
||
# # Have to set path from root | ||
# # https://github.com/actions/upload-artifact/issues/232#issuecomment-964235360 | ||
# - name: Upload wheels | ||
# uses: actions/upload-artifact@v3 | ||
# with: | ||
# name: wheels | ||
# path: dist/*.whl | ||
|
||
macos: | ||
name: Build ${{ matrix.arch }} wheels on ${{ matrix.os }} | ||
strategy: | ||
fail-fast: false | ||
matrix: | ||
include: | ||
- os: macos-11 | ||
arch: x86_64 | ||
target: x86_64 | ||
python-version: 3.8 | ||
- os: macos-14 | ||
arch: arm64 | ||
target: aarch64 | ||
# Earliest python version on Github for macos arm64 | ||
# https://raw.githubusercontent.com/actions/python-versions/main/versions-manifest.json | ||
python-version: 3.11.3 | ||
runs-on: ${{ matrix.os }} | ||
steps: | ||
- uses: actions/checkout@v4 | ||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: ${{ matrix.python-version }} | ||
|
||
- uses: dtolnay/rust-toolchain@stable | ||
|
||
- name: Build wheels - ${{ matrix.target }} | ||
uses: PyO3/maturin-action@v1 | ||
with: | ||
target: ${{ matrix.target }} | ||
args: --release --out dist --sdist -m python/geoarrow-io/Cargo.toml | ||
|
||
- name: Install built wheel - ${{ matrix.target }} | ||
run: | | ||
pip install geoarrow-rust-io --no-index --find-links dist --force-reinstall | ||
python -c "import geoarrow.rust.io" | ||
# Have to set path from root | ||
# https://github.com/actions/upload-artifact/issues/232#issuecomment-964235360 | ||
- name: Upload wheels | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: wheels | ||
path: dist | ||
|
||
windows: | ||
runs-on: windows-latest | ||
strategy: | ||
matrix: | ||
target: [x64, x86] | ||
steps: | ||
- uses: actions/checkout@v4 | ||
|
||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: 3.8 | ||
architecture: ${{ matrix.target }} | ||
|
||
- uses: dtolnay/rust-toolchain@stable | ||
|
||
- name: Build wheels | ||
uses: PyO3/maturin-action@v1 | ||
with: | ||
target: ${{ matrix.target }} | ||
args: --release --out dist -m python/geoarrow-io/Cargo.toml | ||
|
||
- name: Install built wheel | ||
run: | | ||
pip install geoarrow-rust-io --no-index --find-links dist --force-reinstall | ||
python -c "import geoarrow.rust.io" | ||
- name: Upload wheels | ||
uses: actions/upload-artifact@v3 | ||
with: | ||
name: wheels | ||
path: dist/*.whl | ||
|
||
# NOTE: musllinux builds are commented out because importing them failed with: | ||
# ImportError: Error loading shared library libgcc_s-60abea67.so.1: No such file or directory | ||
|
||
# musllinux: | ||
# runs-on: ubuntu-latest | ||
# strategy: | ||
# matrix: | ||
# target: | ||
# - x86_64-unknown-linux-musl | ||
# - i686-unknown-linux-musl | ||
# steps: | ||
# - uses: actions/checkout@v4 | ||
# - uses: actions/setup-python@v4 | ||
# with: | ||
# python-version: 3.8 | ||
# architecture: x64 | ||
|
||
# - name: Build wheels | ||
# uses: PyO3/maturin-action@v1 | ||
# with: | ||
# target: ${{ matrix.target }} | ||
# manylinux: musllinux_1_2 | ||
# args: --release --out dist -m python/geoarrow-io/Cargo.toml | ||
|
||
# - name: Install built wheel | ||
# if: matrix.target == 'x86_64-unknown-linux-musl' | ||
# uses: addnab/docker-run-action@v3 | ||
# with: | ||
# image: alpine:latest | ||
# options: -v ${{ github.workspace }}:/io -w /io | ||
# run: | | ||
# apk add py3-pip | ||
# pip3 install -U pip | ||
# pip3 install geoarrow-rust-io --no-index --find-links /io/dist/ --force-reinstall | ||
# python3 -c "import geoarrow.rust.io" | ||
|
||
# - name: Upload wheels | ||
# uses: actions/upload-artifact@v3 | ||
# with: | ||
# name: wheels | ||
# path: dist | ||
|
||
# musllinux-cross: | ||
# runs-on: ubuntu-latest | ||
# strategy: | ||
# matrix: | ||
# platform: | ||
# - target: aarch64-unknown-linux-musl | ||
# arch: aarch64 | ||
# - target: armv7-unknown-linux-musleabihf | ||
# arch: armv7 | ||
|
||
# steps: | ||
# - uses: actions/checkout@v4 | ||
|
||
# - uses: actions/setup-python@v4 | ||
# with: | ||
# python-version: 3.8 | ||
|
||
# - name: Build wheels | ||
# uses: PyO3/maturin-action@v1 | ||
# with: | ||
# target: ${{ matrix.platform.target }} | ||
# manylinux: musllinux_1_2 | ||
# args: --release --out dist -m python/geoarrow-io/Cargo.toml | ||
|
||
# - uses: uraimo/run-on-arch-action@v2.5.1 | ||
# name: Install built wheel | ||
# with: | ||
# arch: ${{ matrix.platform.arch }} | ||
# distro: alpine_latest | ||
# githubToken: ${{ github.token }} | ||
# install: | | ||
# apk add py3-pip | ||
# pip3 install -U pip | ||
# run: | | ||
# pip3 install geoarrow-rust-io --no-index --find-links dist/ --force-reinstall | ||
# python3 -c "import geoarrow.rust.io" | ||
|
||
# - name: Upload wheels | ||
# uses: actions/upload-artifact@v3 | ||
# with: | ||
# name: wheels | ||
# path: dist | ||
|
||
release: | ||
name: Release | ||
environment: | ||
name: release | ||
url: https://pypi.org/p/geoarrow-rust-io | ||
permissions: | ||
# IMPORTANT: this permission is mandatory for trusted publishing | ||
id-token: write | ||
runs-on: ubuntu-latest | ||
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags') | ||
needs: [macos, windows, linux] | ||
steps: | ||
- uses: actions/download-artifact@v3 | ||
with: | ||
name: wheels | ||
path: dist | ||
|
||
- uses: actions/setup-python@v4 | ||
with: | ||
python-version: 3.8 | ||
|
||
- name: Publish package distributions to PyPI | ||
uses: pypa/gh-action-pypi-publish@release/v1 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
Oops, something went wrong.