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.rst
todoc/release/release_dev.rst
for the next release. - Update
doc/news.rst
.
- Review and cleanup
Toggle
dev = True
todev = False
innetworkx/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
upstream
is the name of the github.com:networkx/networkx
repository.)
- (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
documentation
repo: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 = False
todev = True
innetworkx/release.py
.- Update
major
andminor
innetworkx/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 github
when your branch is out of sync, it creates headaches. - Update
_templates/sidebar_versions.html
. - Edit
_static/docversions.js
and commit - Push your changes to the repo.
- Deploy using
make github
.
- Sync your branch with the remote repo:
- Post release notes on mailing list.