Subject: Re: NetBSD-1.4.2_ALPHA ready for testing
To: None <xela@MIT.EDU>
From: None <Havard.Eidnes@runit.sintef.no>
List: current-users
Date: 12/25/1999 15:18:53
(Moved to current-users)

> I don't generally think much of "me too" messages, but as someone
> who found out about this bizarre approach to version numbering the
> hard way (and who still doesn't understand its logic), I very much
> agree.

There are a couple of reasons the versioning is the way it is.
Here's a few points which tries to explain some of this:

 o At the time e.g. the 1.5 release branch is created, we do not
   really know for certain in advance whether the next release will
   be 1.6 or 2.0.  Thus, it's in some sense more convenient to
   designate the development branch (past the 1.5 release branch is
   created) by 1.5A, 1.5B etc.

 o The letter in the development branch version designations (such
   as 1.5C) has traditionally designated a particular instance of
   the kernel-internal interfaces, especially those which LKMs
   depend on.  Note that it does not designate a user-land feature
   set, e.g. the development branch version designation was not
   updated when we upgraded to BIND 8.2.2-P5.

 o Note that the single-letter version designations do not denote a
   release, it merely marks certain points on the main development
   branch, what's otherwise referred to as "NetBSD-current".

 o When a release cycle is started, a separate branch in the CVS
   repository is created for the release (the "release branch"), and
   during the release cycle selected fixes from the main development
   branch are brought in to the release branch.  It is this
   "separate development thread" which makes it impossible to use
   the version designations along the main development branch to
   compare to a release branch to find if a given feature is present
   or not; while BIND 8.2.2 was pulled onto the 1.4 release branch
   on the way between 1.4.1 to 1.4.2, it was not part of the
   "-current" development branch until rather late, around 1.4L (?).

   Also, it is the intention to use the release cycle to only add
   (well-tested) bugfixes and non-intrusive changes to the system.
   The intention is to improve the stability of code on the release
   branch.  This is the reason that 1.4.2 on i386 will still use
   a.out as the object/executable format; moving to ELF would be a
   far too intrusive change, and would endanger the stability of the
   release branch code.

 o It's worth noting that 1.4A does *not* mean "alpha test version
   of 1.4".  The alpha test version of 1.4 is instead traditionally
   named 1.4_ALPHA.

I don't know whether this adds to the confusion or whether it makes
the current version designations conventions easier to comprehend...

> Havard's paragraph above, or something very like it, should
> *always* accompany announcements of snapshots and releases, and
> appear in their README filess.

I'll try to remember it.  I think we also should add some similar
text to the release notes.

Regards,

- H=E5vard