[Zope3-dev] Change in repository approach to software sharing

Chris Withers chris at simplistix.co.uk
Thu May 6 04:09:06 EDT 2004


Jim Fulton wrote:

> We'll also have a top-level ZConfig project directory.  The "trunk"
> of the ZConfig Python package will be in ZConfig/trunk/src/ZConfig.
> If we create a tag T1 of ZConfig, then the Python package for that tag
> will be in ZConfig/tags/T1/src/ZConfig.

The /src/ in the above paths seems like a dead chicken to me, why's it there?

> Now, when we set up the Zope 3 repository, we will create the ZConfig
> package in Zope 3 by copying a *tag* from the ZConfig project:
> 
>   svn copy svn+ssh://svn.zope.org/repos/ZConfig/tags/T1/src/ZConfig \
>            svn+ssh://svn.zope.org/repos/Zope3/trunk/src/ZConfig
>            -m 'Bring ZConfig T1 into main branch'

I think you'll find this doesn't work when 
svn+ssh://svn.zope.org/repos/Zope3/trunk/src/ZConfig already exists. It's the 
one thing that's disappointed me about SVN so far :-(
(well, that and not beign able t odo inter-repository operations ;-)

> Later, we may decide to upgrade the Zope 3 head to use ZConfig tag 3.
> At that point, we can recopy from the tag, or we can merge changes
> made between the two tags.

My experience has been that it's best just to have shared software "exist" in 
each location where it's used and maintained in those places with new versions 
being brought across via merges. Merges in SVN have ended up feeling a LOT nicer 
for me that with CVS, but the key is still to keep the number of maintained 
locations of a piece of shared software to an absolute minimum, as Tim points out.

Another option, and one which I'd really strongly suggest here if it could be 
made to work is the "external definitions" stuff:
http://svnbook.red-bean.com/svnbook/ch07s03.html

The svn:externals way of doing things means you only develop the shared software 
it it's own tag/trunk/branches structure and just link to it from where you want 
to use it, which sounds like it might save a few grey hairs on Tim's part since 
there won't be any "local development" in the locations where the shared 
software is used...

cheers,

Chris

-- 
Simplistix - Content Management, Zope & Python Consulting
            - http://www.simplistix.co.uk




More information about the Zope3-dev mailing list