summaryrefslogtreecommitdiff
path: root/docs/random/release
blob: 4e399b14b1cc3a81872e5c7f64e34bc7e2a4b46e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
maybe we should be doing releases on branches from the trunk so that the package
version in CVS can always be date-generated and core hacking isn't discouraged
during the release cycle.

Release TODO
------------

* make distcheck should pass
* rpms should build
* debs should build

Packaging issues will hopefully be less difficult in the future as the build
system stabilizes.

* after a release, we move in cvs mode and use a .1 nano version number

* close to the next release, we make prereleases by upping the nano version

* update web site release notes

* add release notes to cvs -- why?

* take a FRESH cvs checkout

* make distcheck should pass

* test suite should pass

* rpms should build and install

* 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.

* depending on how the API has changed update the libtool versioning
  in configure.ac.  Look at the libtool info page about versioning for
  guidelines.

* update package version

* roll a preliminary distribution tarball, make sure that it installs fine,
registers fine, runs the media tests fine, and uninstalls as well

* tag tree
  http://gstreamer.net/dev/cvs.php
  add tag to above page

* relink current and cvs in the redhat dir and copy the symlinks from the
  current to the new release treee

* update web site release notes: added to cvs
  - change the releases/current symbolic link
  - text version of release announcement can be made from 
    lynx -dump http://gstreamer.net/releases/current/notice.php?clean=1

* update web site docs
  - release-specific docs should go in CVS
  - change docs/current symlink

* update status table cvs status and then click on the release link
  http://gstreamer.net/admin.php is the portal to all of this

* update web site news items for release
  again, the admin.php page

* upload to sourceforge
  - should we md5 the tarballs?

* announce to:
  freshmeat
  gstreamer-{devel, announce}
  linux-audio-dev (if it's a big release)
  gnome lists (?)
  lwn (if it's a big release)


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.