MIC-DKFZ / HD-BET

MRI brain extraction tool
Apache License 2.0
255 stars 61 forks source link

Support publishing to PyPI #56

Open ebrahimebrahim opened 1 month ago

ebrahimebrahim commented 1 month ago

This adds support for publishing to PyPI by transitioning from the legacy setup.py to pyproject.toml.

The changes are adapted from the output of cookiecutter scientific-python/cookie based off scientific-python/cookie@8c0a1627. See https://learn.scientific-python.org/development/

Changes include:

The major benefit of this proposed update is that HD_BET can be more easily maintained and automatically published to PyPI upon release. This helps bring HD_BET further into the larger python neuroimaging ecosystem by allowing other packages to mark it as a dependency.

The only required step on your side will be to create a pending publisher on PyPI so that the GitHub workflow can automatically publish the package upon release creation. Would be happy to provide more details on any of this.

ebrahimebrahim commented 3 weeks ago

@FabianIsensee What do you think of this approach to publishing the project and automating some of the routine maintenance? Happy to provide some help in keeping this wonderful project alive!

FabianIsensee commented 3 days ago

Hey, thanks for the PR. This project is no longer actively developed and I welcome ways of reducing the amount of work we have to invest into keeping it running for everyone. Can you please enlighten me how I can integrate the automatic pypi publishing once it is merged?

ebrahimebrahim commented 3 days ago

Once it is merged the steps to publish would be:

(The "automatic" aspect of it is that the publish step is triggered automatically whenever you create a release on github. This is achieved by the configuration in the cd.yml file that is added in this PR)

FabianIsensee commented 3 days ago

Thanks, will do. Might need some more days because I need to fix some things on our end