From: Eric Wong <normalperson@yhbt.net>
To: Sam Vilain <sam@vilain.net>
Cc: Git Mailing List <git@vger.kernel.org>
Subject: Re: Tracking and committing back to Subversion?
Date: Fri, 3 Feb 2006 21:40:57 -0800 [thread overview]
Message-ID: <20060204054056.GB24314@Muzzle> (raw)
In-Reply-To: <1138834301.21899.40.camel@wilber.wgtn.cat-it.co.nz>
Sam Vilain <sam@vilain.net> wrote:
> Hi all,
>
> Has anyone done any work on bidirectional access to SVN repositories?
> ie, tracking and committing.
AFAIK, Not yet. But it's something that's been on the back of my mind
for a while. I've attempted similar things with Arch <-> SVN in the
past but didn't get anything extremely robust going from Arch -> SVN
although I'm pretty satisfied with my SVN -> Arch product
(svn-arch-mirror).
> That would be porcelain that behaves like SVK (http://svk.elixus.org)
>
> Ideally it would probably need to link against the Subversion RA (remote
> access) library, neon.
I prefer to use git-svnimport for pulling from svn since it's pretty
good at what it does. That already depends on SVN::Core and SVN::Ra.
SVK is really nice tool, just a bit slow after I've been using git for a
while.
> I can see forsee two potential issues;
>
> 1. file properties - such as mime type, ignores and custom properties.
> Linus, when I asked you about this in Dunedin, you mentioned that
> there is a place at the end of the directory entry where this could
> fit without breaking backwards compatibility. Perhaps this could
> be an optional pointer to another directory node;
Mostly ignore-able, imho. svn:executable is the one that makes the most
sense (and is easiest) to support.
svn:ignore <-> .gitignore mapping are pretty close (identical, save for
recursive properties that svn gets very wrong. I don't think svn:ignore
is affected by line order, whereas .gitignore is a plain file and line
order does matter.
svn:external is almost definitely better off ignored entirely when
interfacing with other RCSes
svn:keywords: I don't think there's a way to disable this like there
is with CVS, is there? keywords are evil imho.
I don't use or know much about the other properties...
> 2. "forensic" file movement history - as opposed to the uncached,
> (and unversioned), automatic "analytical" file movement history.
>
> It would be easy for a tool to provide 100% interface compatibility
> with SVN client/SVK using properties, but properties that hang off
> the head rather than the file itself (so that they don't stuff up
> the ability to merge identical trees reached via independent
> paths). SVN calls these "revision properties". If a good
> convention is adopted for this, it could be used as a nice way to
> supplement git's automatic analysis of the revision history.
Just parsing the output of diff-tree -C and marking them in SVN as
copies/renames should be sufficient for letting SVN do its thing.
Doing this kind of file movement history on the git side sounds like
overkill to me. I was a _huge_ fan of logical file-identities in GNU
Arch in the past, but the complexity destroyed it from both a UI and
performance perspective.
--
Eric Wong
next prev parent reply other threads:[~2006-02-04 5:41 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-02-01 22:51 Tracking and committing back to Subversion? Sam Vilain
2006-02-04 5:40 ` Eric Wong [this message]
2006-02-04 19:51 ` Seth Falcon
2006-02-06 23:12 ` Sam Vilain
2006-02-04 15:27 ` Brian Smith
2006-02-06 23:23 ` Sam Vilain
2006-02-10 0:50 ` Brian Smith
2006-02-10 0:54 ` Junio C Hamano
2006-02-10 1:06 ` Brian Smith
2006-02-10 4:27 ` Sam Vilain
2006-02-10 7:01 ` Brian Smith
2006-02-10 11:16 ` Sam Vilain
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20060204054056.GB24314@Muzzle \
--to=normalperson@yhbt.net \
--cc=git@vger.kernel.org \
--cc=sam@vilain.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).