mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-16 13:26:36 +00:00
6e8841efd9
Original commit message from CVS: added branch merging comments
146 lines
6.2 KiB
Text
146 lines
6.2 KiB
Text
GStreamer Release Policies (or: why we should become a country and pass laws)
|
|
--------------------------
|
|
|
|
Development Period
|
|
------------------
|
|
Development period is marked by having a fourth (nano) version number of 1.
|
|
During development anything goes short of wiping the tree.
|
|
Just try doing a few basic things :
|
|
- make sure it builds for you !
|
|
- check what you're about to commit with cvs -Q diff -r
|
|
- preferably, keep an anonymous checkout around as well so you can
|
|
immediately update and check if your changes work in a clean tree as well
|
|
|
|
Prerelease Period
|
|
-----------------
|
|
After a bit of development, people want a new release. This generally happens
|
|
when :
|
|
- core developers get anxious to apply massive changes to the core bound
|
|
to break everything
|
|
- a few important plugins decide, as if by magic, to work again (avi, mad, ...)
|
|
- Uraeus and thomasvs get tired of the general laziness
|
|
|
|
Also, this should only be allowed after passing a few sanity checks :
|
|
- make distcheck should pass
|
|
- rpms should build
|
|
- FIXME: should debs be built here ? If so, how ?
|
|
|
|
At this time, we need to do a few prereleases for general checking by all
|
|
interested developers. To minimize the impact on the rest of the core hacking,
|
|
we create a new CVS branch which will go through the pre-releases and finally
|
|
contain the definitive tarball for that version.
|
|
|
|
TODO :
|
|
- Decide on the next version number (major, minor or micro upgrade ?)
|
|
- Create branch; with 0.3.3 as an example, tag is BRANCH-RELEASE-0_3_3
|
|
cvs tag BRANCH-RELEASE-0_3_3-ROOT
|
|
cvs tag -b BRANCH-RELEASE-0_3_3
|
|
cvs update -r BRANCH-RELEASE-0_3_3
|
|
- Set the nano to 2 (in configure.ac, AS_VERSION)
|
|
- Do all updates/patches/changes for the release tarball in this branch
|
|
- Think of a good codename for the release
|
|
- create a new version dir in www/releases and add that to cvs
|
|
- copy files from the last one to this new release dir
|
|
- Start updating the release notes on the www cvs tree
|
|
- Log in to sourceforge and run www-update.sh in the gstreamer root dir
|
|
- depending on how the API has changed update the libtool versioning
|
|
in configure.ac, AS_LIBTOOL
|
|
(Look at the libtool info page about versioning for guidelines)
|
|
- FIXME: autotools have latest config.{guess,sub}
|
|
This is needed in order to support newer platforms.
|
|
On Debian install the autotools-dev package to get these.
|
|
Someone please add some more useful info here on how to do this
|
|
- copy new supporting RPMS to the htdocs/redhat dir in various places,
|
|
update README, and update symlinks to these packages in the release dir
|
|
- while (IS_PRERELEASE)
|
|
{
|
|
- increase the nano number (starting with 2)
|
|
- FIXME: do the devhelp stuff
|
|
go into docs/devhelp, rm *.devhelp, make devhelp
|
|
check if ok, and commit to cvs
|
|
|
|
- check out a fresh anonymous copy
|
|
cvs -d:pserver:anonymous@cvs.gstreamer.sf.net:/cvsroot/gstreamer \
|
|
co -rBRANCH-RELEASE-0_3_3 gstreamer
|
|
- make distcheck, rpm build should pass, from a FRESH cvs tree
|
|
- media tests should be done
|
|
- source tarball should be installed and tested
|
|
- rpms should be installed and tested
|
|
- put up tarball for a day
|
|
}
|
|
|
|
|
|
Release Period
|
|
--------------
|
|
When we're satisfied with the prereleases, it's time to make the final tarball.
|
|
It's very important that the tarball we put out is fully checked, works as
|
|
planned, and generally is generated only ONCE by someone with a relatively
|
|
clean (and reference) system. We don't want to put out more than one tarball
|
|
with the same name.
|
|
|
|
TODO :
|
|
- give the latest prerelease another good testing
|
|
- proofread the release notes (notice.php) and the index (index.php)
|
|
- change the symlinks on the website :
|
|
- change the releases/current symbolic link to point to the new release dir
|
|
- change the releases/cvs symlink to point to the next release dir
|
|
- run www-update.sh on sourceforge
|
|
- make a text copy of the release notes to be included in the tarball :
|
|
lynx -dump http://gstreamer.net/releases/current/notice.php?clean=1 > RELEASE
|
|
- update web site docs
|
|
- release-specific docs should go in CVS
|
|
- change docs/current symlink
|
|
- remove the nano version number in configure.ac, AS_VERSION
|
|
- FIXME: run a build and generate devhelp stuff
|
|
- tag tree
|
|
- policy is at http://gstreamer.net/dev/cvs.php
|
|
- decide on a tag name : RELEASE_(VERSION)_(CODE)
|
|
- tag; for example for 0.3.3 :
|
|
cvs tag RELEASE-0_3_3-GUADECBYFOOT
|
|
- add tag codename in www/dev/cvs.php
|
|
- roll the tarball, build rpms
|
|
- FIXME: update status table cvs status and then click on the release link
|
|
http://gstreamer.net/admin.php is the portal to all of this
|
|
where to get the password, what should we do here ?
|
|
|
|
Post-Release Period
|
|
-------------------
|
|
Time to bring the new version under the eyes of the public.
|
|
|
|
TODO :
|
|
- FIXME: should we md5 the tarballs?
|
|
- upload to sourceforge
|
|
upload.sourceforge.net/incoming
|
|
administer the release
|
|
|
|
- FIXME: announcements
|
|
- gstreamer-{devel, announce} : a simple mail with RELEASE
|
|
- freshmeat
|
|
- linux-audio-dev (if it's a big release) : a simple mail with RELEASE
|
|
- gnome lists (?)
|
|
- lwn (if it's a big release)
|
|
- Kick back, have a party, enjoy people coming in on IRC telling us how
|
|
GStreamer rocks.
|
|
- Later on, if necessary, merge back latest release branch to current dev
|
|
branch (if patches to source were made)
|
|
* change to a HEAD branch, make sure it's updated
|
|
* cvs diff -r RELEASE-0_3_4-30SECONDFRENCHMAN -R
|
|
gives a list of differences between head and release tag
|
|
* cvs update -j BRANCH-RELEASE-0_3_4
|
|
merges the difference made in that branch to the current source
|
|
this is what you want to use when merging back the branch
|
|
resolve conflicts and commit
|
|
|
|
Some various random comments that might or might not make sense :
|
|
|
|
- Should work:
|
|
* autoconf feature to allow building outside source dir
|
|
|
|
- Package version policy
|
|
- Use major.minor.micro versioning
|
|
- Before 1.0.0, Update micro until code and API are fairly stable,
|
|
then update minor.
|
|
- After 1.0.0,
|
|
Update major when code and api hit new level of stability or major features.
|
|
Update minor on API changes.
|
|
Update micro on API-compatible changes.
|