mirror of https://github.com/ecmwf/eccodes.git
prototype of so-only wheel
This commit is contained in:
parent
b74bc1e46c
commit
b57ff447b9
|
@ -0,0 +1,46 @@
|
|||
# (C) Copyright 2024- ECMWF.
|
||||
#
|
||||
# This software is licensed under the terms of the Apache Licence Version 2.0
|
||||
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
||||
# In applying this licence, ECMWF does not waive the privileges and immunities
|
||||
# granted to it by virtue of its status as an intergovernmental organisation
|
||||
# nor does it submit to any jurisdiction.
|
||||
|
||||
|
||||
name: Build Python Wheel for Linux
|
||||
|
||||
on:
|
||||
# Trigger the workflow manually
|
||||
workflow_dispatch: ~
|
||||
|
||||
# Allow to be called from another workflow
|
||||
workflow_call: ~
|
||||
|
||||
# TODO automation trigger
|
||||
|
||||
jobs:
|
||||
build:
|
||||
name: Build manylinux_2_28
|
||||
runs-on: [self-hosted, Linux, platform-builder-Rocky-8.6]
|
||||
# TODO which manylinux do we want to build for? 2014? 2_28? 2_34? Matrix?
|
||||
container:
|
||||
image: eccr.ecmwf.int/wheelmaker/2_28:latest
|
||||
credentials:
|
||||
username: ${{ secrets.ECMWF_DOCKER_REGISTRY_USERNAME }}
|
||||
password: ${{ secrets.ECMWF_DOCKER_REGISTRY_ACCESS_TOKEN }}
|
||||
steps:
|
||||
# TODO convert this to be matrix-friendly. Note it's a bit tricky since
|
||||
# we'd ideally not reexecute the compile step multiple times, but it
|
||||
# (non-essentially) depends on a matrix-based step
|
||||
# NOTE we dont use action checkout because it doesnt cleanup after itself correctly
|
||||
- run: git clone --depth=1 --branch="${GITHUB_REF#refs/heads/}" https://github.com/$GITHUB_REPOSITORY /proj
|
||||
- run: cd /proj && /buildscripts/prepare_deps.sh ./python_wrapper/buildconfig 3.11
|
||||
- run: cd /proj && /buildscripts/compile.sh ./python_wrapper/buildconfig
|
||||
- run: cd /proj && PYTHONPATH=/buildscripts /buildscripts/wheel-linux.sh ./python_wrapper/buildconfig 3.11
|
||||
- run: cd /proj && /buildscripts/test-wheel.sh ./python_wrapper/buildconfig 3.11 /tmp/build/wheel/*whl
|
||||
- run: cd /proj && /buildscripts/upload-pypi.sh /tmp/build/wheel/*whl
|
||||
env:
|
||||
TWINE_USERNAME: __token__
|
||||
TWINE_PASSWORD: ${{ secrets.PYPI_API_TOKEN }}
|
||||
# NOTE temporary thing until all the mess gets cleared
|
||||
- run: rm -rf ./* ./.git ./.github
|
|
@ -0,0 +1,25 @@
|
|||
# (C) Copyright 2024- ECMWF.
|
||||
#
|
||||
# This software is licensed under the terms of the Apache Licence Version 2.0
|
||||
# which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
||||
# In applying this licence, ECMWF does not waive the privileges and immunities
|
||||
# granted to it by virtue of its status as an intergovernmental organisation
|
||||
# nor does it submit to any jurisdiction.
|
||||
|
||||
# to be source'd by wheelmaker's compile.sh *and* wheel-linux.sh
|
||||
# NOTE replace the whole thing with pyproject.toml? Less powerful, and quaint to use for sourcing ecbuild invocation
|
||||
# TODO we duplicate information -- pyproject.toml's `name` and `packages` are derivable from $NAME and must stay consistent
|
||||
|
||||
NAME="eccodes"
|
||||
|
||||
# TODO solve the libpng, libjpg, libaec problem
|
||||
CMAKE_PARAMS1="-DENABLE_PNG=0 -DENABLE_JPG=0 -DENABLE_AEC=0 -DENABLE_JPG_LIBJASPER=0 -DENABLE_JPG_LIBOPENJPEG=0"
|
||||
# -DOPENJPEG_DIR=$TOPDIR/install \
|
||||
CMAKE_PARAMS2="-DENABLE_NETCDF=0"
|
||||
CMAKE_PARAMS3="-DENABLE_EXAMPLES=0 -DENABLE_PYTHON=0 -DENABLE_BUILD_TOOLS=0 -DENABLE_INSTALL_ECCODES_DEFINITIONS=0 -DENABLE_INSTALL_ECCODES_SAMPLES=0"
|
||||
CMAKE_PARAMS4="-DENABLE_ECCODES_THREADS=1 -DENABLE_MEMFS=1"
|
||||
CMAKE_PARAMS="$CMAKE_PARAMS1 $CMAKE_PARAMS2 $CMAKE_PARAMS3 $CMAKE_PARAMS4"
|
||||
|
||||
PYPROJECT_DIR="python_wrapper"
|
||||
# TODO add eckit once the dependency is in place
|
||||
DEPENDENCIES='[]'
|
|
@ -0,0 +1,5 @@
|
|||
[metadata]
|
||||
description = "eccodeslib"
|
||||
long_description = file: README.md
|
||||
long_description_content_type = text/markdown
|
||||
author = file: AUTHORS
|
|
@ -0,0 +1,2 @@
|
|||
from setup_utils import plain_setup
|
||||
plain_setup()
|
Loading…
Reference in New Issue