Files

Wheel Generation

This directory contains scripts to generate precompiled python wheels for GridFire

Notes

  • MacOS wheels can only be generated on macos
  • aarch64 wheels can only be generated on aarch64 machines
  • x86_64 wheels can only be generated on x86_64 machines
  • linux wheels can be generated on any linux machine, but the target architecture must match the machine architecture
  • Running each script will take a very long time (could be upwards of half of a day depending on your system) and will require roughly 2GB of disk space
  • When generating MacOS wheels, you must have all the correct versions of python installed with pyenv. Run the script utils/wheels/installPyEnvVersions.sh to install the correct versions of python.

Usage

Once you know you are on the correct machine, run the script for your desired architecture and operating system. For example, to generate a macos x86_64 wheel, run:

./build-wheels-macos-aarch64.sh https://github.com/4D-STAR/GridFire

Once you have all the wheels generated (which will likely require multiple systems), copy all the wheels into a single directory (lets assume its called wheels and in the root of the directory) and then run (from the root of the repository):

python -m pip install --upgrade build
python -m build --sdist --outdir wheels
twine upload wheels/*

Thie will also take a while (it needs to upload all the wheels to PyPI) but will result in all the wheels being uploaded to PyPI.