Skip to content

travisdriver/gtsam-manylinux-build

 
 

Repository files navigation

GTSAM Python Wheel Builder

CI Pybind11 CI

How to Build on Linux

Run:

sudo docker run --rm -e PLAT=manylinux2014_x86_64 -v `pwd`:/io quay.io/pypa/manylinux2014_x86_64 /io/build-wheels.sh

You will need to rename the built files to a valid name:

mv gtsam-4.1.0-cp36-cp36m-manylinux2014_x86_64.none-manylinux2014_x86_64.whl gtsam-4.1.0-cp36-none-any.whl

How to Build on macOS

Please consult build-macos.h.

Current Build Date

2022-11-29

We are building for the 4.2a8 release.

Wheel Update Instructions

For all OSs and architectures we support:

First check if the wheels you have built can actually install and run by:

  1. Create a clean virtual environment
  2. pip install {WHEEL}.whl to install the wheel
  3. run the GTSAM unit tests to make sure the wheel works by going to gtsam_repo/python/gtsam/tests and python -m unittest discover
  • The most probable failures at this stage are:
    • The wheel repair (auditwheel/delocate) programs have bugs and produced wrong binaries.
    • Which needs manual patching, contact @ProfFan immediately

If you have confirmed that it works, you can then:

  • Run pip install twine to install Twine
  • After that, upload to Test PyPI by:
twine upload --repository testpypi {WHEEL_FILE_NAME}.whl
  • Now, uninstall gtsam in the virtual env, do
pip install --index-url https://test.pypi.org/simple {PACKAGE_NAME}

and test again with the unit tests

  • The most probable failures at this stage are:

    • Inconsistent version tags between the METADATA and the file name of the wheel
    • You did not test the wheel you uploaded in a fresh machine, so it's linking is not correct (only works for you)
  • If that still works, you can try upload to REAL PyPI (THIS IS IRREVERSIBLE!!!)

twine upload {WHEEL_FILE_NAME}.whl
# OR if you tested all 8 wheels on Test PyPI and possible users
twine upload {directory containing all wheels}
  • Finally test again by using normal pip install gtsam
  • Rinse and repeat with every architecture that you are concerned with.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Shell 100.0%