Release procedure

This page is WIP. The following procedure is not yet approved for use

Trunk

Meson operates under the principle that trunk should (in theory) be always good enough for release. That is, all code merged in trunk must pass all unit tests. Any broken code should either be fixed or reverted immediately.

People who are willing to tolerate the occasional glitch should be able to use Meson trunk for their day to day development if they so choose.

Major releases

Major releases are currently in the form 0.X.0, where X is an increasing number. We aim to do a major release roughly once every 3 to 4 months, though the schedule is not set in stone.

Before a major release is made a stable branch will be made, and 0.X.0-rc1 release candidate will be made. A new milestone for 0.X.0 will be made, and all bugs effecting the RC will be assigned to this milestone. Patches fixing bugs in the milestone will be picked to the stable branch, and normal development will continue on the master branch. Every week after this a new release candidate will be made until all bugs are resolved in that milestone. When all of the bugs are fixed the 0.X.0 release will be made.

Bugfix releases

Bugfix releases contain only minor fixes to major releases and are designated by incrementing the last digit of the version number. The criteria for a bug fix release is one of the following:

  • release has a major regression compared to the previous release (making existing projects unbuildable)
  • the release has a serious bug causing data loss or equivalent
  • other unforeseen major issue

In these cases a bug fix release can be made. It shall contain only the fix for the issue (or issues) in question and other minor bug fixes. Only changes that have already landed in trunk will be considered for inclusion. No new functionality shall be added.

Requesting a bug fix release

The process for requesting that a bug fix release be made goes roughly as follows:

  • file a bug about the core issue
  • file a patch fixing it if possible
  • contact the development team and request a bug fix release (IRC is the preferred contact medium)

The request should contain the following information:

  • the issue in question
  • whether it has already caused problems for real projects
  • an estimate of how many people and projects will be affected

There is no need to write a long and complicated request report. Something like the following is sufficient:

The latest release has a regression where trying to do Foo using Bar breaks. This breaks all projects that use both, which includes at least [list of affected projects]. This causes problems for X amount of people and because of this we should do a bugfix release.

The results of the search are