Update the release notes:
- Review and cleanup
doc/release/release_dev.rst, - Fix code in documentation by running
cd doc && make doctest. - Make a list of merges and contributors by running
doc/release/contribs.py <tag of previous release>. - Paste this list at the end of the
release_dev.rst. Scan the PR titles for highlights, deprecations, and API changes, and mention these in the relevant sections of the notes. - Rename to
doc/release/release_<major>.<minor>.rst. - Copy
doc/release/release_template.rsttodoc/release/release_dev.rstfor the next release. - Update
doc/news.rst.
- Review and cleanup
Toggle
dev = Truetodev = Falseinnetworkx/release.py.Commit changes.
Add the version number as a tag in git:
git tag -s [-u <key-id>] networkx-<major>.<minor>
(If you do not have a gpg key, use -m instead; it is important for Debian packaging that the tags are annotated)
Push the new meta-data to github:
git push --tags upstream master
- (where
upstreamis the name of the github.com:networkx/networkxrepository.)
- (where
Review the github release page:
Publish on PyPi:
git clean -fxd python setup.py sdist --formats=zip twine upload -s dist/networkx*.zip
Update documentation on the web: The documentation is kept in a separate repo: networkx/documentation
Wait for the NetworkX Travis Bot to deploy to GitHub Pages
Sync your branch with the remote repo:
git pull.Copy the documentation built by Travis. Assuming you are at the top-level of the
documentationrepo:cp -a latest networkx-<major>.<minor> git add networkx-<major>.<minor> ln -sfn networkx-<major>.<minor> stable git commit -m "Add <major>.<minor> docs" # maybe squash all the Deploy GitHub Pages commits # git rebase -i HEAD~XX where XX is the number of commits back # check you didn't break anything # diff -r latest networkx-<major>.<minor> # you will then need to force the push so be careful! git push
- Increase the version number
- Toggle
dev = Falsetodev = Trueinnetworkx/release.py.- Update
majorandminorinnetworkx/release.py.
- Update the web frontpage:
The webpage is kept in a separate repo: networkx/website
- Sync your branch with the remote repo:
git pull. If you try tomake githubwhen your branch is out of sync, it creates headaches. - Update
_templates/sidebar_versions.html. - Edit
_static/docversions.jsand commit - Push your changes to the repo.
- Deploy using
make github.
- Sync your branch with the remote repo:
- Post release notes on mailing list.