-
Notifications
You must be signed in to change notification settings - Fork 217
Maintainer Documentation
You are here: Home > Maintainer Documentation
Welcome to the PIConGPU Maintainer section of our wiki! We collect administrative tasks and policies here.
The workflow to update PIConGPU dependencies is documented in this page. Please make sure all according places are update before accepting PRs!
- How to "Code Review": See the Code Review guide
- Labels for pull requests and issues
- Compile Suite Documentation
- Policies for acknowledgements and co-authors in PIConGPU releated publications
update version names/numbers
Use the src/tools/bin/newVersion.sh
script for updating all versions!
- PIConGPU:
src/picongpu/include/version.hpp
- sphinx (rtd) docs:
./docs/source/conf.py
- future:
Version:
inpicongpu.pc
- future: (all
CMakeLists.txt
:project(... VERSION X.Y.Z LANGUAGES CXX)
)
When the next release branch for master
is opened from dev
, updated the dev
branch to the next (expected) release number.
see semver.org
check & update dependencies
- are all dependencies in their minimal and latest stable release version working?
- are included/shipped
thirdParty
dependencies up-to-date?
check documentation
- is readthedocs still building successfully?
- after release, enable the new version so it can be selected by users
how to collect & write the change log
- create a release branch from
dev
:git checkout -b release-<to-be-tag-name>
- get all logs from
git log --oneline --graph --decorate --first-parent master..
indev
oderrelease-X.Y.Z
- read the issues related to it and group bugs/features/misc
- now compare the changes in
.param
and.unitless
files again, make sure they are highlighted in the change log:cd src/picongpu/include/simulation_defines/ ; git diff master.. .
- find related issues with
git blame <pathToParam-File>
- use the commits sha to search for the issue on GitHub (use the top row search bar) or viagit log <sha>
todo: write a script that finds the associated pulls itself - maybe https://github.com/skywinder/github-changelog-generator can help us?
- mention all authors that contributed to this release: sorted by commits
git shortlog --no-merges -s -n [-e] lastReleaseTag..
- commit the change log
- publish the release branch and "wait" for further bug fixes only
- start a pull request to
master
(ideally, this should be a fast-forward, but we will force a merge commit via --no-ff) - tag the new commit in
master
and sign this tag (see below) - release on Zenodo
- revision: same authors as last stable release + bugfix authors
- major release: all authors that contributed
- meta: add EU fundings, cross-link via DOI previous release (and in previous release: this new release)
- add Zenodo DOI badge to release description (disable its webhook for that step to avoid dbl release)
- sync back the change log and version changes to
dev
with a new pull request frommaster
Update the default docs version
- build the new tag in RTDs: https://readthedocs.org/projects/picongpu/versions/
- change the default for
/
in the docs to it: https://readthedocs.org/dashboard/picongpu/versions/
back porting bug fixes
- minimal changes (no API/.param changes)
- create a revision for 1 to N combined fixes (the
Z
in theX.Y.Z
version number)
All wiki entries describe the dev branch. Features may be different in the current master branch.
Before you start please read our README!
PIConGPU is a scientific project. If you present and/or publish scientific results that used PIConGPU, you should set a reference to show your support. Our according up-to-date publication at the time of your publication should be inquired from:
The documentation in this wiki is still not complete and we need your help keeping it up to date. Feel free to help improving this wiki!