achow101
commented at 6:23 pm on October 22, 2020:
member
Removes the leading 0 from the version number. The minor version, which we had been using as the major version, is now the major version. The revision, which we had been using as the minor version, is now the minor version. The revision number is dropped. The build number is promoted to being part of the version number. This also avoids issues where it was accidentally not included in the version number.
The CLIENT_VERSION remains the same format as previous as previously, as the Major version was 0 so it never actually got included in it.
The user agent string formatter is updated to follow this new versioning.
Honestly I’m just tired of all of the people asking for “1.0” that maybe this’ll shut them up. Skip the whole 1.0 thing and go straight to version 22.0!
Also, this means that the terminology we commonly use lines up with how the variables are named. So major versions are actually bumping the major version number, etc.
laanwj
commented at 6:40 pm on October 22, 2020:
member
Concept ACK
practicalswift
commented at 6:42 pm on October 22, 2020:
contributor
Concept ACK: a.) number go up is good, and b.) big number going up is obviously better than small number going up! :)
DrahtBot added the label
Build system
on Oct 22, 2020
DrahtBot added the label
Docs
on Oct 22, 2020
DrahtBot added the label
GUI
on Oct 22, 2020
achow101 force-pushed
on Oct 22, 2020
hebasto
commented at 7:46 pm on October 22, 2020:
member
Concept ACK for 0.22.0 -> 22.0
Emzy
commented at 8:01 pm on October 22, 2020:
contributor
Concept ACK for 0.22.0 -> 22.0
michaelfolkson
commented at 8:48 pm on October 22, 2020:
contributor
Concept ACK
Redundancy is generally worth considering but this 0.x redundancy seems unnecessary for all possible future scenarios. I’m assuming we don’t need to look as far ahead as v99, v100… :)
luke-jr
commented at 9:13 pm on October 22, 2020:
member
Concept NACK, we should stick to a standard versioning system. Either semver (0.features.bugfixes or features.0.bugfixes) or calendar versioning (yy.mm.bugfixes). Whatever we do, CLIENT_VERSION and the UA should reflect it properly. If we go with calendar versioning, replacing 0.21 with 20.11 would make a smoother migration than a 21.N following 0.21.
fjahr
commented at 9:53 pm on October 22, 2020:
member
Following the discussion in the meeting today I am somewhat indifferent towards making a change. I guess I just have not been asked about a 1.0 enough ;) But if we do change anything I strongly prefer this to all the other approaches that were discussed because it’s a simple change and simple to explain to outsiders.
DrahtBot
commented at 10:32 pm on October 22, 2020:
member
The following sections might be updated with supplementary metadata relevant to reviewers and maintainers.
Conflicts
Reviewers, this pull request conflicts with the following ones:
#18980 (build: Decouple clientversion.cpp from the git repo by hebasto)
#18261 (Erlay: bandwidth-efficient transaction relay protocol by naumenkogs)
If you consider this pull request important, please also help to review the conflicting pull requests. Ideally, start with the one that should be merged first.
JeremyRubin
commented at 11:07 pm on October 22, 2020:
contributor
I’d prefer if we track the calendar, e.g. 20.11 for a november 2020 release as luke suggests.
But if it’s too late to make that happen I am happy to just drop the 0.
MarcoFalke removed the label
Docs
on Oct 23, 2020
MarcoFalke removed the label
GUI
on Oct 23, 2020
MarcoFalke added this to the milestone 0.22.0
on Oct 23, 2020
MarcoFalke removed this from the milestone 22.0
on Oct 23, 2020
MarcoFalke added this to the milestone 22.0
on Oct 23, 2020
MarcoFalke
commented at 7:54 am on October 23, 2020:
member
Concept ACK
Assigned 22.0 milestone
jnewbery
commented at 7:59 am on October 23, 2020:
member
Do you mean in the NACK sense (“don’t drop the leading zero”), or in the use calendar version sense (“20.11” would be November 2020)? :)
luke-jr
commented at 1:33 pm on October 24, 2020:
member
It makes sense to me because versions like 0.19.0.1 wouldn’t exist.
0.19.0.1 is fundamentally different from typical bugfix releases, which are normally using the 3rd int.
promag
commented at 1:51 pm on October 24, 2020:
member
@luke-jr fundamentally different? At the time, if it was 19.0.0, we would just tag 19.0.1, or am I wrong?
luke-jr
commented at 2:42 pm on October 24, 2020:
member
@promag Anything is possible with such hypotheticals. If we had 19.0.0, we should never have 19.1.0 because we don’t do minor feature releases…
luke-jr
commented at 2:42 pm on October 24, 2020:
member
(Hmm, unless we decide softforks count as minor features?)
theStack
commented at 11:56 am on October 25, 2020:
member
Is there any strong fundamental long-term drawback on the calendar versioning, i.e. yy.mm.bugfixes (as suggested by JeremyRubin, luke-jr), other than “dropping the zero is simpler”? If not, I’d prefer the calendar versioning as well, it’s just nice that you can immediately deduce when a client/node has been last updated by looking at the version, w/o having to look up the version history.
luke-jr
commented at 1:56 pm on October 25, 2020:
member
@theStack Calendar versions don’t do that… 2020.11.5 may very well have been released in 2022 and up to date.
theStack
commented at 3:11 pm on October 25, 2020:
member
@theStack Calendar versions don’t do that… 2020.11.5 may very well have been released in 2022 and up to date.
True, that doesn’t work with bugfix releases (obviously), but at least it gives a lower bound in the sense of “not older than”. I’d still not consider a node “up to date” if it has the latest bugfixes but is based on a years old feature set…
achow101
commented at 4:30 pm on October 25, 2020:
member
Is there any strong fundamental long-term drawback on the calendar versioning, i.e. yy.mm.bugfixes (as suggested by JeremyRubin, luke-jr), other than “dropping the zero is simpler”? If not, I’d prefer the calendar versioning as well, it’s just nice that you can immediately deduce when a client/node has been last updated by looking at the version, w/o having to look up the version history.
I think the main drawback is user confusion. Changing the version number to a new scheme will cause confusion in the short term, but in the long term, when referring to older releases, there may also be confusion there. I think that with this change, there will be less confusion. It’s easier to explain that the versioning is the same but just without the leading zero, than it is to explain that, e.g. 20.11 is the major release and there are no versions 20.0 - 20.10.
In terms of code changes, both switching to calendar versioning and this change are probably the same amount of changes in roughly the same places. It’s just that conceptually it’s easier to understand “drop the unused zero” than it is to understand switching to something entirely new.
kristapsk
commented at 10:25 pm on October 26, 2020:
contributor
Do you mean in the NACK sense (“don’t drop the leading zero”), or in the use calendar version sense (“20.11” would be November 2020)? :)
NACK. I don’t see a problem with leading zero.
sipa
commented at 10:30 pm on October 26, 2020:
member
Concept ACK.
I see this more as making the versioning scheme reflect reality than anything else. We already call our 0.X releases “major” and 0.X.Y releases “minor”, so the 0 doesn’t seem to convey any information whatsoever.
I’m not opposed to a date-based YY.MM.minor scheme, though my personal preference is just dropping the zero.
fanquake
commented at 7:45 am on October 27, 2020:
member
Concept ACK
I’m not opposed to a date-based YY.MM.minor scheme, though my personal preference is just dropping the zero.
FWIW I am opposed to a date-based scheme. Let’s just drop the 0 and get this over with.
ajtowns
commented at 5:07 am on October 29, 2020:
member
Concept ACK. I’d also mildly prefer year based, but just dropping the zero is certainly simplest. Don’t see a practical benefit to putting consensus changes (particularly versus standardness changes) into the version.
DrahtBot added the label
Needs rebase
on Nov 18, 2020
Drop the leading 0 from the version number
Removes the leading 0 from the version number. The minor version, which
we had been using as the major version, is now the major version. The
revision, which we had been using as the minor version, is now the minor
version. The revision number is dropped. The build number is promoted to
being part of the version number. This also avoids issues where it was
accidentally not included in the version number.
The CLIENT_VERSION remains the same format as previous as previously,
the Major version was 0 so that was never a factor in CLIENT_VERSION.
8f7b930475
achow101 force-pushed
on Nov 18, 2020
DrahtBot removed the label
Needs rebase
on Nov 18, 2020
jnewbery
commented at 12:00 pm on November 20, 2020:
member
Code review ACK8f7b930475
MarcoFalke renamed this:
Drop the leading 0 from the version number
build: Drop the leading 0 from the version number
on Nov 20, 2020
MarcoFalke
commented at 2:41 pm on November 20, 2020:
member
python: error while loading shared libraries: libpython3.8.so.1.0: cannot open shared object file: No such file or directory
MarcoFalke merged this
on Nov 20, 2020
MarcoFalke closed this
on Nov 20, 2020
MarcoFalke
commented at 2:45 pm on November 20, 2020:
member
(also tested that CLIENT_VERSION is unchanged)
domob1812 referenced this in commit
793b8c2a83
on Nov 23, 2020
laanwj referenced this in commit
b0c9024a7c
on Nov 23, 2020
sidhujag referenced this in commit
abdd7cf572
on Nov 23, 2020
kallewoof
commented at 4:44 am on November 27, 2020:
member
Fixes the closed-since-April #9653. Not sure what changed, but I’m happy about the decision obviously.
MarcoFalke
commented at 7:58 am on November 27, 2020:
member
I wouldn’t say anything changed. When it comes to user experience, p2p features, bugfixes, hardening, testing improvements, and literally everything else, the leading 0 in the version is an insignificant stylistic choice. We have enough “real” issues so that tracking issues for stylistic questions are probably eating away resources from more important topics ( #9653 (comment) )
whitslack
commented at 9:14 am on November 29, 2020:
contributor
I’m surprised nobody mentioned the obvious implication here: Bitcoin Core is now officially out of beta! 🚀
sipa
commented at 9:21 am on November 29, 2020:
member
It hasn’t had a “beta” label since 2014 (see #4221), and even then it was already hardly applicable.
whitslack
commented at 9:25 am on November 29, 2020:
contributor
This is not to say that the system is mature now, suddenly.
So are we now saying that the system is mature? 😄 Typically software projects use version numbers less than 1.0 to denote that their software is not yet production-ready. Advancing the version number to something greater than 1.0 sends the signal that the software is now ready for prime time.
sipa
commented at 9:31 am on November 29, 2020:
member
And that’s exactly what we wanted to avoid, by not going to 1.0, and instead just dropping the zero. We have for years been calling the X in 0.X.Y the major release number. I don’t know what mature means, but Bitcoin Core has had a release process with test procedures, multiple release candidates, goals of compatibility, … for a better part of a decade now.
There is no dramatic change here, no big milestone, and no need for celebrations or whatever. It’s just dropping a zero that was redundant.
mjdietzx referenced this in commit
ae409294c1
on Dec 27, 2020
mjdietzx referenced this in commit
8d1873b940
on Dec 27, 2020
davidlj95
commented at 6:45 pm on November 15, 2021:
none
This is a metadata mirror of the GitHub repository
bitcoin/bitcoin.
This site is not affiliated with GitHub.
Content is generated from a GitHub metadata backup.
generated: 2025-01-21 21:12 UTC
This site is hosted by @0xB10C More mirrored repositories can be found on mirror.b10c.me