[PATCH] Repo layout
Ben Collins-Sussman
sussman at red-bean.com
Tue Dec 20 13:11:24 CST 2005
Uncle.
On 12/20/05, C. Michael Pilato <cmpilato at red-bean.com> wrote:
> Ben Collins-Sussman wrote:
>
> > Why is it easier to manage N separate lists of users, N separate lists
> > of authorization rules, and N separate sets of hook scripts, rather
> > than just managing 1 of each? You say that this proposition isn't
> > universally true, but don't say why. I've never heard anyone argue
> > the other direction.
>
> In theory, the management of N repositories of one "project"[1] each
> versus one repository of N projects should lean heavily towards "the
> fewer the repositories, the easier." But it doesn't always turn out to
> be so clear-cut.
>
> In terms of configuration and hook scripts and such, it tends to boil
> down to namespace splitting -- either your configuration splits your
> projects into repositories and your hooks operate across the whole
> repository, or your configuration does no splitting and your hooks have
> to be taught about how to split the repository into logical projects.
> While mailer.py and Subversion authstuffs might be able to handle
> arbitrary splitting, there are many other hook scripts (even the simple
> "disallow empty log messages" shell code) that aren't so wise, and have
> to be tweaked to apply their policies to subsets of the repository
> instead of the whole thing. Also, the claim that you have to maintain N
> sets of hooks is also largely false, because on supporting systems, each
> repository's hooks *can* be symlinks to (or thin wrappers around) a
> single set of real scripts.
>
> In my opinion, where every project has the exact same needs in terms of
> configury and hook scripts, yeah, use a single repository. But when
> this ideal uniform landscape isn't feasible, you're better off with
> multiple repositories.
>
> [1] I'm using "project" to mean "logical grouping of versioned
> artifacts which can live in a distinct directory tree disjoint
> from other such groupings" -- please afford me much fuzz in
> that definition... you ultimately know what I mean.
>
More information about the svnbook-dev
mailing list