* Converting from svn to git
@ 2008-08-10 13:11 David Neu
2008-08-10 13:24 ` Miklos Vajna
0 siblings, 1 reply; 8+ messages in thread
From: David Neu @ 2008-08-10 13:11 UTC (permalink / raw)
To: git
Hi,
I'm trying to move an svn repo to git. I'm not going to be committing
back to the svn repo, but will simply retire it and use git.
The issue I'm having is that the svn repo has sub directories that I'd
like to be separate git repos.
I can easily accomplish this for the sub directories like this:
git-svn clone svn-url/subdir1
git-svn clone svn-url/subdir2
etc.
but for the files in the base directory
git-svn clone svn-url
pulls the entire directory tree.
Is there a git-svn strategy similar to git-svnimport -P that would do the trick?
My git version 1.5.6.4 doesn't include git-svnimport, and I'm getting
the impression
it's be deprecated.
Many thanks for any help!
Cheers,
David
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: Converting from svn to git
2008-08-10 13:11 Converting from svn to git David Neu
@ 2008-08-10 13:24 ` Miklos Vajna
2008-08-10 14:54 ` David Neu
0 siblings, 1 reply; 8+ messages in thread
From: Miklos Vajna @ 2008-08-10 13:24 UTC (permalink / raw)
To: David Neu; +Cc: git
[-- Attachment #1: Type: text/plain, Size: 563 bytes --]
On Sun, Aug 10, 2008 at 09:11:43AM -0400, David Neu <david@davidneu.com> wrote:
> Is there a git-svn strategy similar to git-svnimport -P that would do the trick?
> My git version 1.5.6.4 doesn't include git-svnimport, and I'm getting
> the impression
> it's be deprecated.
Sure, it is. Though if you _really_ need it, it's still under
/contrib/examples.
Anyway, if you do a single conversion, then probably speed does not
matter a lot; I would do a full import then use the subdirectory-filter
of git filter-branch do drop everything outside the subdirectory.
[-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --]
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: Converting from svn to git
2008-08-10 13:24 ` Miklos Vajna
@ 2008-08-10 14:54 ` David Neu
2008-08-10 15:32 ` Michael J Gruber
0 siblings, 1 reply; 8+ messages in thread
From: David Neu @ 2008-08-10 14:54 UTC (permalink / raw)
To: Miklos Vajna; +Cc: git
Thanks for the reply - this looks like what I'd need, but
I can't see how to keep the contents of the base dir and
lose the subdirs, e.g.
$ git-filter-branch --subdirectory-filter . HEAD
removes all subdirs and the contents of the base dir.
So, I figure I'd remove each subdir, using
$ git-filter-branch --tree-filter 'rm -rf subdir1/' HEAD
but this complains if subdir1 contains subdirectories, it
says: Namespace refs/original/ not empty
Many thanks!
Cheers,
David
On Sun, Aug 10, 2008 at 9:24 AM, Miklos Vajna <vmiklos@frugalware.org> wrote:
>
> On Sun, Aug 10, 2008 at 09:11:43AM -0400, David Neu <david@davidneu.com> wrote:
> > Is there a git-svn strategy similar to git-svnimport -P that would do the trick?
> > My git version 1.5.6.4 doesn't include git-svnimport, and I'm getting
> > the impression
> > it's be deprecated.
>
> Sure, it is. Though if you _really_ need it, it's still under
> /contrib/examples.
>
> Anyway, if you do a single conversion, then probably speed does not
> matter a lot; I would do a full import then use the subdirectory-filter
> of git filter-branch do drop everything outside the subdirectory.
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: Converting from svn to git
2008-08-10 14:54 ` David Neu
@ 2008-08-10 15:32 ` Michael J Gruber
2008-08-10 15:48 ` David Neu
0 siblings, 1 reply; 8+ messages in thread
From: Michael J Gruber @ 2008-08-10 15:32 UTC (permalink / raw)
To: git
David Neu venit, vidit, dixit 10.08.2008 16:54:
> Thanks for the reply - this looks like what I'd need, but
> I can't see how to keep the contents of the base dir and
> lose the subdirs, e.g.
>
> $ git-filter-branch --subdirectory-filter . HEAD
>
> removes all subdirs and the contents of the base dir.
>
> So, I figure I'd remove each subdir, using
>
> $ git-filter-branch --tree-filter 'rm -rf subdir1/' HEAD
>
> but this complains if subdir1 contains subdirectories, it
> says: Namespace refs/original/ not empty
It complains because filter-branch stores the original refs in that
namespace, and on the second filter-branch run it wants to do this
again. You can avoid this by using the "-f" option to filter-branch, or
by removing all subsirs in one go ("rm -rf subdir1 subdir2..."). Also,
you might want to rewrite all refs ("--all"), not just HEAD.
Michael
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: Converting from svn to git
2008-08-10 15:32 ` Michael J Gruber
@ 2008-08-10 15:48 ` David Neu
2008-08-11 17:46 ` David Neu
0 siblings, 1 reply; 8+ messages in thread
From: David Neu @ 2008-08-10 15:48 UTC (permalink / raw)
To: Michael J Gruber; +Cc: git
That's great - thanks to everyone!
On Sun, Aug 10, 2008 at 11:32 AM, Michael J Gruber
<michaeljgruber+gmane@fastmail.fm> wrote:
> David Neu venit, vidit, dixit 10.08.2008 16:54:
>>
>> Thanks for the reply - this looks like what I'd need, but
>> I can't see how to keep the contents of the base dir and
>> lose the subdirs, e.g.
>>
>> $ git-filter-branch --subdirectory-filter . HEAD
>>
>> removes all subdirs and the contents of the base dir.
>>
>> So, I figure I'd remove each subdir, using
>>
>> $ git-filter-branch --tree-filter 'rm -rf subdir1/' HEAD
>>
>> but this complains if subdir1 contains subdirectories, it
>> says: Namespace refs/original/ not empty
>
> It complains because filter-branch stores the original refs in that
> namespace, and on the second filter-branch run it wants to do this again.
> You can avoid this by using the "-f" option to filter-branch, or by removing
> all subsirs in one go ("rm -rf subdir1 subdir2..."). Also, you might want to
> rewrite all refs ("--all"), not just HEAD.
>
> Michael
>
> --
> To unsubscribe from this list: send the line "unsubscribe git" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
>
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: Converting from svn to git
2008-08-10 15:48 ` David Neu
@ 2008-08-11 17:46 ` David Neu
2008-08-15 13:58 ` Michael J Gruber
0 siblings, 1 reply; 8+ messages in thread
From: David Neu @ 2008-08-11 17:46 UTC (permalink / raw)
To: Michael J Gruber; +Cc: git
OK, I did
$ git-filter-branch --tree-filter 'rm -rf subdir1/ subdir2/ subdir3/' -- --all
which looks good, except when I open gitk, I still see "empty" commits
that correspond to subdir1/, subdir2/ and subdir3/.
Is there anyway to remove those?
Many thanks!
Cheers,
David
On Sun, Aug 10, 2008 at 11:48 AM, David Neu <david@davidneu.com> wrote:
> That's great - thanks to everyone!
>
> On Sun, Aug 10, 2008 at 11:32 AM, Michael J Gruber
> <michaeljgruber+gmane@fastmail.fm> wrote:
>> David Neu venit, vidit, dixit 10.08.2008 16:54:
>>>
>>> Thanks for the reply - this looks like what I'd need, but
>>> I can't see how to keep the contents of the base dir and
>>> lose the subdirs, e.g.
>>>
>>> $ git-filter-branch --subdirectory-filter . HEAD
>>>
>>> removes all subdirs and the contents of the base dir.
>>>
>>> So, I figure I'd remove each subdir, using
>>>
>>> $ git-filter-branch --tree-filter 'rm -rf subdir1/' HEAD
>>>
>>> but this complains if subdir1 contains subdirectories, it
>>> says: Namespace refs/original/ not empty
>>
>> It complains because filter-branch stores the original refs in that
>> namespace, and on the second filter-branch run it wants to do this again.
>> You can avoid this by using the "-f" option to filter-branch, or by removing
>> all subsirs in one go ("rm -rf subdir1 subdir2..."). Also, you might want to
>> rewrite all refs ("--all"), not just HEAD.
>>
>> Michael
>>
>> --
>> To unsubscribe from this list: send the line "unsubscribe git" in
>> the body of a message to majordomo@vger.kernel.org
>> More majordomo info at http://vger.kernel.org/majordomo-info.html
>>
>
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: Converting from svn to git
2008-08-11 17:46 ` David Neu
@ 2008-08-15 13:58 ` Michael J Gruber
2008-08-17 9:11 ` Sam Vilain
0 siblings, 1 reply; 8+ messages in thread
From: Michael J Gruber @ 2008-08-15 13:58 UTC (permalink / raw)
To: git
David Neu venit, vidit, dixit 11.08.2008 19:46:
> OK, I did
>
> $ git-filter-branch --tree-filter 'rm -rf subdir1/ subdir2/ subdir3/' -- --all
>
> which looks good, except when I open gitk, I still see "empty" commits
> that correspond to subdir1/, subdir2/ and subdir3/.
>
> Is there anyway to remove those?
A while ago I "complained" that rebase would skip empty commits. You
might experiment with that. Alternatively, the following works for me:
git filter-branch --commit-filter 'cmd="git commit-tree"; test `git show
--pretty=oneline $GIT_COMMIT|wc -l` = 1 && cmd="skip_commit"; $cmd "$@"'
-- --all
This skips all commits which introduce no diff. It will not remove
branches or tags which are related only to those subdirs.
I am sure there will be more elegant ways to do that (esp. the test with
wc).
Michael
^ permalink raw reply [flat|nested] 8+ messages in thread
* Re: Converting from svn to git
2008-08-15 13:58 ` Michael J Gruber
@ 2008-08-17 9:11 ` Sam Vilain
0 siblings, 0 replies; 8+ messages in thread
From: Sam Vilain @ 2008-08-17 9:11 UTC (permalink / raw)
To: Michael J Gruber; +Cc: git
On Fri, 2008-08-15 at 15:58 +0200, Michael J Gruber wrote:
> A while ago I "complained" that rebase would skip empty commits. You
> might experiment with that. Alternatively, the following works for me:
>
> git filter-branch --commit-filter 'cmd="git commit-tree"; test `git show
> --pretty=oneline $GIT_COMMIT|wc -l` = 1 && cmd="skip_commit"; $cmd "$@"'
> -- --all
>
> This skips all commits which introduce no diff. It will not remove
> branches or tags which are related only to those subdirs.
>
> I am sure there will be more elegant ways to do that (esp. the test with
> wc).
something like this should work:
--commit-filter 'if [ "$1" = `git rev-parse HEAD^{tree}` ]; then
skip_commit "$@"; else git commit-tree "$@"; fi'
Sam.
^ permalink raw reply [flat|nested] 8+ messages in thread
end of thread, other threads:[~2008-08-17 9:13 UTC | newest]
Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-08-10 13:11 Converting from svn to git David Neu
2008-08-10 13:24 ` Miklos Vajna
2008-08-10 14:54 ` David Neu
2008-08-10 15:32 ` Michael J Gruber
2008-08-10 15:48 ` David Neu
2008-08-11 17:46 ` David Neu
2008-08-15 13:58 ` Michael J Gruber
2008-08-17 9:11 ` Sam Vilain
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).