 
Jonne Haß Sun 23 Sep 2012 10:38PM
Nobody actually read that proposal :P
First version would be 0.0.1.0 (release.major.minor.bugfix). And I'm aiming for the first release pretty soon once my new configuration system has proven stable enough. From that on I've my personal list of things to do but I won't assign that milestones, one of the benefits of SemVer is IMO that not you tell what a new version is but the changes you make. So lets just see what happens, releasing new versions as needed ;)
 
Sean Tilley Sun 23 Sep 2012 10:50PM
My bad, sorry Jonne. What I meant specifically was that I was wondering what we need to do still so that we can start officially making stable releases. IMO, it'd be useful for anyone trying to package Diaspora for different distributions.
 
goob Sun 7 Oct 2012 3:06PM
Have just seen the announcement on the mailing list of the first 'new' release. It all looks fantastic, and gives me real hope for the future. Thank you so much, Jonne, and everyone else involved in this initiative.
 
Jason Robinson Sun 7 Oct 2012 6:20PM
I guess the release cycle stuff is kind of open still. How we decide when to release, etc. I'm kind of thinking a monthly release cycle would be cool - just push out whatever is ready (by using a release branch of course) and bump the semver according to what kind of changes are included.
How do others feel about the releases? Personally I would like to see releases quite often, maybe monthly would be nice - not too fast but not too slow?
 
Sean Tilley Mon 8 Oct 2012 3:58AM
I think we're just doing SemVer-driven versioning and releases for the forseeable future, in which the version is bumped by the amount of actual changes and the relative scope of how much code is being changed. It's not so much that it's time-driven, so much that the code moves along and is updated automatically.
The real question is, at what level do we consider our code stable enough for release? What criteria would we need to ensure that the release build is green, that sweeping changes are documented? Finally, what strategies can we better adopt for getting the word out on releases?
 
goob Mon 8 Oct 2012 1:36PM
I think we (or rather, the devs) will have to play it by ear a bit to start with, until there is a good pool of devs and work is rolling. A fixed release cycle with frequent updates might put too much pressure on the few core devs we have at the moment. (I think it's only a few still, in any case.)
So I think for the time being, it would be better to have a release when there is something ready to be released and worth of a release update, rather than on an fixed time scale. The main thing is 1) to keep things moving, so that we don't again hit a patch in which nothing is (apparently) happening with D* development, and 2) not to promise anything which then isn't delivered. As long as things are happening, even if there is no new release for a while because the devs are hard at work on a major structural change which is taking a long time (for example), there doesn't need to be a release every few weeks, in my opinion. This is where Sean and others can help things along with regular and open communication about what is happening behind the scenes. I say open, because for a time the communication we did get with the core team was opaque, and that compounded the problems the D* community was experiencing.
All this is said as a non-dev, so might be completely wrong. I guess it is for Jonne and the other core devs to decide amongst themselves what is the best release scheme.
The questions in Sean's second paragraph are worth asking, and one reason I'd be wary of a fixed-time release cycle would be the possibility of rushing something out before it has been fully tested, in order to meet the deadline. If communication about progress is frequent and open, I don't think new code needs to be released so frequently.
(I assume preparing a release and release notes also takes dev time, so it might be good to wait until there is a significant change in the code before releasing for this reason as well.)
Apologies if any of this is off-beam; as I say, unfortunately I know next to nothing about coding and so can't help with this.
 
goob Mon 8 Oct 2012 1:37PM
Blimey that was a long post. Sorry. Without being able to preview, and because the input box remains small so text disappears upwards, I seem to end up writing far more than I realised, and then not being able to edit it down.
 
Florian Staudacher Mon 8 Oct 2012 4:30PM
since we successfully adopted the versioning scheme (whis is what the headline says), I'd say everything else could go into a new discussion? or how do we wanna handle it? (just hijack the thread or start a new one?)
 
Jason Robinson Mon 8 Oct 2012 4:48PM
The topic is " Adopt a versioning scheme and release cycle" so seems right to me? :) A discussion is different from a proposal, there is no reason we cannot discuss here and have more proposals relating to the subject. Adding extra discussions will just fragment the discussion imho.
 
goob Fri 19 Oct 2012 3:16PM
Just a thought: now there's a proper versioning scheme and we've had our first proper release, is it time to remove the alpha symbol from the top left of the menu bar? Not sure whether this is all pods or just jd.com.
I realise it's still early days, and it's useful when people are moaning about not everything working perfectly to say that it's still alpha software and not a full production release, but thought I'd mention it for those of you involved in development to decide on.
 
Sean Tilley Fri 19 Oct 2012 6:42PM
Yeah, I'd definitely say so. Nice catch, Goob!
 
Sean Tilley Fri 19 Oct 2012 6:50PM
 
goob Fri 19 Oct 2012 7:17PM
Good man. Visible progress!
 
Sean Tilley Fri 19 Oct 2012 9:14PM
It might be handy in the long run to display a version number on pods, just for the sake of making bug reporting easier.
 
Jason Robinson Sat 20 Oct 2012 12:52PM
The whole right panel thing needs cleanup and imho redesign - maybe the version number could be there as the last item - would be cool to show it for sure.
 
Jason Robinson Thu 8 Nov 2012 9:05AM
I think there is some misunderstanding on what is a major, minor and patch.
AFAIK in SemVer this is, for X.Y.Z:
X = major
Y = minor
Z = patch
This is pretty much universal in the software world. Do we agree to follow this standard? Currently Diaspora* is running the first patch and personally I would like minor changes to increment a minor version, not just a patch.
 
Jonne Haß Thu 8 Nov 2012 11:37AM
So you didn't actually read the proposal you voted on?
 
Florian Staudacher Thu 8 Nov 2012 11:51AM
get over it, nobody read it :P
 
Jason Robinson Thu 8 Nov 2012 12:17PM
"The version is prefixed with another number which will be increased at community decision instead of a major release. This is to avoid a false sense of rapid development and increasing stability while still maintaining a meaning in the version number changes from the start."
Ah must admit I didn't read it. OK so I agreed. Proposals are only valid until another proposal is accepted (if we want to be rude we can...).
Anyway, if we don't want to be rude, just saying now that I don't think this is a good idea after all. It doesn't follow good practices that have been found to work well in the software world. Take anyone from the internet who knows semver and give them our version number and they will think we haven't even reached the first minor version yet. It just doesn't look good IMHO.
Did someone actually read that paragraph of the proposal and agrees to it? Then it is fine to me - I just assume there was a big misunderstanding here and that we should follow major.minor.patch as most of the projects on in the world (pure semver or not).
 
Sean Tilley Thu 8 Nov 2012 12:31PM
Jason, you are welcome to write a proposal if you think something needs to be improved. We're a FOSS project, not The United States Congress. Change for the sake of improvement is the very nature of good development.
 
Jason Robinson Thu 8 Nov 2012 12:35PM
I just want to clear what I thought was a misunderstanding :) I don't have a big fuss with the deal now that I know it was actually in the proposal. Still, I don't look forward to telling everyone who I talk about Diaspora* to that "no the version number is so small because we decided, not because it implies the state of the software", done a few of those already..
I won't fuss with a proposal to change if no one else agrees with my view. And if no one agrees, I will promise not to talk about it any more :P
 
goob Thu 8 Nov 2012 12:37PM
Perhaps the first figure could be substituted for a letter to signify community decision rather than a major release. So we would now be on A1.1.2 (I think). Either that or just drop that variable from the version numbers. Or leave it as it is.
 
Sean Tilley Thu 8 Nov 2012 12:41PM
I don't disagree with you, Jason, and others may feel the same way. My point is, you're not going to know the true value of some ideas without discussing/proposing it. You may find yourself pleasantly surprised. You can't objectively know whether an idea will be supported or not without giving it a good shot. And if things stay the same, that's okay, too.
Consensus isn't about steering a project by majority rule; it's about figuring out good compromises that everyone can more or less say "I'm okay with this, it's been on my mind too, let's do it and see how it works out."
 
Jonne Haß Thu 8 Nov 2012 2:25PM
The point of prefixing is perception. With the first major feature added we need to bump the major release and would reach 1.0. And more people will think "Oh, it's stable now" then "Oh, they added a major feature because they're following SemVer". It's just to prevent false sense of progress and stability where there's none.
 
Jason Robinson Thu 8 Nov 2012 7:43PM
Well, actually:
"Major version zero (0.y.z) is for initial development. Anything may change at any time. The public API should not be considered stable.
Version 1.0.0 defines the public API. The way in which the version number is incremented after this release is dependent on this public API and how it changes."
So I'd say 1.0 would very much be up to us to define - software doesn't just jump there without it being declared stable ;)
But let's keep things as they are. If someone else raises the same concerns as I do at some point we can discuss more :)
 
Flaburgan Mon 12 Nov 2012 10:07PM
My 2 cents : i don't want to see a 1 in the major version number until there still is bugs known but not fixed :)
By the way, we need a place to post changelog of every version, and maybe not only in the wiki (or, at least, make a direct link from Diaspora to this page). This page already exists somewhere ? Where is the current draft of the v0.0.2.0 changelog ?
 
Sean Tilley · Sun 23 Sep 2012 9:02PM
Excellent. Should we consider a v 0.1 stable release soon, or should we clearly detail out some milestones we should hit to get there? (Anything to get away from the Alpha/Beta scheme)