Just 2 cents--<div><br></div><div>I've spent a good deal of time in 'sandbox hell.' My own fault, to be sure. But I have often felt that more sophisticated merge tool's like gits' would have helped me get out of it: more fluidly contributing back from a sandbox on which some app I was working on depended and pulling core work back in, with the goal of getting all the way back to core.</div>
<div><br></div><div>(These were cases where my development schedule made it hard to be a good citizen in the short run.)</div><div><br></div><div>As for unpublished forks, one nice thing about github is that it tracks forking, provides notifications, and generally encourages the social network around the network of code branching and experimentation so that the community isn't lost despite the decentralization.<br>
<div><br></div><div><br><br><div class="gmail_quote">On Sat, Apr 17, 2010 at 10:56 AM, <span dir="ltr"><<a href="mailto:christopher.schmidt@nokia.com">christopher.schmidt@nokia.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex;">
<div>
<p></p><div class="im">----- Original message -----
<br>> On Sat, Apr 17, 2010 at 02:58:13PM +0200, <a href="mailto:christopher.schmidt@nokia.com" target="_blank">christopher.schmidt@nokia.com</a>
<br>> wrote:
<br>> > > For all intents and purposes those patches
<br>> > > are dead. If we had git, it would be much easier to maintain those
<br>> patches
<br>> > > somewhere until somebody decides what to do with them.
<br>> >
<br>> > Would it be easier than putting them into an SVN sandbox?
<br>>
<br>> Yes. I'd rather have one place for all my stuff (my git repository) than
<br>> a
<br>> different one for each project.
<br>>
<br>> > > Maybe they go into
<br>> > > core, maybe they'll end up in some community maintained "extras"
<br>> repository,
<br>> > > maybe they'll forever be just part of my personal "fork".
<br>> >
<br>> > All of which can still happen without Git.
<br>>
<br>> Yes, but git was designed for this. Why not use it.
<br>
<br></div>OL sandboxes were designed to solve this problem before Git made sense: why not use them?
<br><div class="im">
<br>> > > > I realize that this is mostly a selfish point of view, but I fear
<br>> > > > making it easy for organizations to fork, whether it be big or
<br>> small.
<br>> > > > THe motivation to contribute back to OpenLayers is reasonably
<br>> small
<br>> > > > already, due to the turnaround time on OpenLayers mainline
<br>> commits;
<br>> > > > moving to Git to me feels like simply giving up.
<br>> > >
<br>> > > I agree with Chris that the current OL management has worked well
<br>> for the
<br>> > > core of OL, but I think that git could help all those at the fringes
<br>> of
<br>> > > OL experimenting with new functionality. Those people on the
<br>> fringes,
<br>> > > if you keep them happy, some of them will move into core
<br>> development.
<br>> > > In the long run, they'll keep the project healthy.
<br>> >
<br>> > So, I guess the question is: "Why aren't OL sandboxes being used for
<br>> this?" I always started the sandbox development idea with that in mind,
<br>> and I think that other projects have had success with this model within
<br>> SVN (GDAL, for example); why is that not working for OL?
<br>>
<br>> Barrier of entry, again. I didn't even think about asking for sandbox
<br>> access,
<br>> because I think of it as something only for "serious" OL developers.
<br>
<br></div>A social bug: the entire goal around sandboxes was the opposite of that.
<br><div class="im">
<br>> A
<br>> git
<br>> repository has a lower barrier, because you don't have to ask anybody
<br>> and
<br>> because it *feels* easier.
<br>
<br></div>"You don't have to ask anyone" is technically fixable. The latter sounds like a personal preference; reasonable, but I wouldn't agree personally.
<br><div class="im">
<br>> I don't have to think about whether the stuff
<br>> I
<br>> am working on is "important" enough for a sandbox.
<br>
<br></div>"Yes" :) Regardless of the stuff, the answer to this should always be "yes."
<br><div class="im">
<br>> I can just play with
<br>> it
<br>> in my own backyard (ie git repos) and it still can be shared. And if I
<br>> work
<br>> on 10 different things I can have them in one repos or in 10.
<br>>
<br>> I think we are talking about two different things here and we should
<br>> keep
<br>> them separate: One is the SVN vs. git technical debate. The other is the
<br>> question on how to encourage more people to get involved with the
<br>> project.
<br>> You are probably right if you say everything that can technically be
<br>> done
<br>> with SVN can be done with git. But thats not the important point. Both
<br>> these
<br>> names stand in a way for different development models. SVN for a more
<br>> centralized approach and git for the more distributed approach.
<br>
<br></div>Our SVN sandbox model was designed as a centrally located home for those things which might otherwise go to Git. Having it centrally located lets other OL devs participate, and lets other people find it -- GitHub encourages this, but Git in general doesn't solve that problem.
<br><div class="im">
<br>> I think I prefer the distributed approach, but I am a bit unclear on
<br>> where you
<br>> stand. You say you "fear making it easy for organizations to fork", yet
<br>> you
<br>> want the sandbox model (which creates lots of forks, doesn't it?).
<br>
<br></div>My concern is private, hidden, or ill-published forks. Public forks are great: more development is better. Private forks hide useful code from the world. Sandboxes are a great way to create public, open forks.
<br>
<br>-- Chris<p></p>
</div>
<br>_______________________________________________<br>
Dev mailing list<br>
<a href="mailto:Dev@openlayers.org">Dev@openlayers.org</a><br>
<a href="http://openlayers.org/mailman/listinfo/dev" target="_blank">http://openlayers.org/mailman/listinfo/dev</a><br>
<br></blockquote></div><br><br clear="all"><br>-- <br>Sebastian Benthall<br>OpenGeo - <a href="http://opengeo.org">http://opengeo.org</a><br><br>
</div></div>