* git-svn equivalent to "svn switch --relocate" @ 2008-06-17 16:06 Sam Hocevar 2008-06-17 21:42 ` Steven Walter 0 siblings, 1 reply; 2+ messages in thread From: Sam Hocevar @ 2008-06-17 16:06 UTC (permalink / raw) To: git I know this has been addressed a few times, but since I haven't found any reasonable way to relocate a git-svn repository (after a protocol change, or a server name change) I thought I'd share how I did it. Step 1 is to edit ".git/config" and modify the "url = " line so that it reflects the new repository address. For instance: - url = http://svn.gnome.org/svn/gimp + url = svn+ssh://svn.gnome.org/svn/gimp From now on, git-svn will basically stop working, because the "git-svn-id:" lines in the commit logs will no longer match its configuration. And git-filter-branch is of no use here either, because it will change the md5sum of each commit, and git-svn will no longer be able to track the commits. Step 2 is therefore to temporarily hack git-svn to make it think the commit messages do use the new URL. This is done at the end of the "extract_metadata" subroutine: ($rev, $uuid) = ($id =~/^\s*git-svn-id:\s(\d+)\@([a-f\d\-]+)/); } + $url =~ s|http://svn.gnome.org/svn/gimp/|svn+ssh://svn.gnome.org/svn/gimp/|; return ($url, $rev, $uuid); } This will usually be needed only until the next SVN commit is merged and the git-svn tree is rebased. Hope this can help a few. Unfortunately I don't understand the git-svn source code well enough to work on a cleaner way to do that. Cheers, -- Sam. ^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: git-svn equivalent to "svn switch --relocate" 2008-06-17 16:06 git-svn equivalent to "svn switch --relocate" Sam Hocevar @ 2008-06-17 21:42 ` Steven Walter 0 siblings, 0 replies; 2+ messages in thread From: Steven Walter @ 2008-06-17 21:42 UTC (permalink / raw) To: Sam Hocevar; +Cc: git On Tue, Jun 17, 2008 at 12:06 PM, Sam Hocevar <sam@zoy.org> wrote: > I know this has been addressed a few times, but since I haven't found > any reasonable way to relocate a git-svn repository (after a protocol > change, or a server name change) I thought I'd share how I did it. > > Step 1 is to edit ".git/config" and modify the "url = " line so > that it reflects the new repository address. For instance: > > - url = http://svn.gnome.org/svn/gimp > + url = svn+ssh://svn.gnome.org/svn/gimp > > From now on, git-svn will basically stop working, because the > "git-svn-id:" lines in the commit logs will no longer match its > configuration. And git-filter-branch is of no use here either, because > it will change the md5sum of each commit, and git-svn will no longer be > able to track the commits. It is not so hard to work around this problem. After you run filter-branch, make sure the ref used by git-svn in refs/remotes points to the new (altered) hash. Then, delete the .git/svn/<remote> directory corresponding to the svn-remote you changed (trunk, probably). When you next run "git svn fetch", git-svn will regenerate its revmap using the new hash, and everything should be peachy after that. -- -Steven Walter <stevenrwalter@gmail.com> "A human being should be able to change a diaper, plan an invasion, butcher a hog, conn a ship, design a building, write a sonnet, balance accounts, build a wall, set a bone, comfort the dying, take orders, give orders, cooperate, act alone, solve equations, analyze a new problem, pitch manure, program a computer, cook a tasty meal, fight efficiently, die gallantly. Specialization is for insects." -Robert Heinlein ^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2008-06-17 21:43 UTC | newest] Thread overview: 2+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2008-06-17 16:06 git-svn equivalent to "svn switch --relocate" Sam Hocevar 2008-06-17 21:42 ` Steven Walter
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).