* git-svn init from Avogadro SVN repo - deleted files showing
@ 2007-12-10 0:24 Marcus D. Hanwell
2007-12-10 10:42 ` Peter Baumann
0 siblings, 1 reply; 9+ messages in thread
From: Marcus D. Hanwell @ 2007-12-10 0:24 UTC (permalink / raw)
To: git, Peter Baumann
Hi,
I am quite new to git and git-svn but have been using both for my
development work recently. I imported the Avogadro subversion repository
(hosted on Sourceforge) using the following commands,
git svn init -t tags -b branches -T trunk
https://avogadro.svn.sourceforge.net/svnroot/avogadro
git svn fetch
The files avogadro.pro and README in the trunk/ directory appear in my
imported git repository but not in Avogadro subversion trunk. We also
had trunk/src/ and all its files/subdirectories appearing in the git
checkout but not in subversion trunk. We deleted this using git and git
svn which removed it from the git checkouts too after r858.
I have been talking to Peter who confirmed this and pointed out that the
repo was reorganised several times in the past. Please CC me on replies
as I am not on the list. There is a copy of my git repo at
http://platinum.cryos.net/avogadro.git/ if you would rather skip the
import. Other than that everything has been working great. It would be
good to get rid of this bug if possible. Let me know if there is
anything else I can do to help.
Thanks,
Marcus
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: git-svn init from Avogadro SVN repo - deleted files showing
2007-12-10 0:24 git-svn init from Avogadro SVN repo - deleted files showing Marcus D. Hanwell
@ 2007-12-10 10:42 ` Peter Baumann
2007-12-10 11:40 ` Peter Baumann
2007-12-13 16:41 ` Eric Wong
0 siblings, 2 replies; 9+ messages in thread
From: Peter Baumann @ 2007-12-10 10:42 UTC (permalink / raw)
To: Marcus D. Hanwell; +Cc: Eric Wong, git
On Sun, Dec 09, 2007 at 07:24:40PM -0500, Marcus D. Hanwell wrote:
> Hi,
>
> I am quite new to git and git-svn but have been using both for my
> development work recently. I imported the Avogadro subversion repository
> (hosted on Sourceforge) using the following commands,
>
> git svn init -t tags -b branches -T trunk
> https://avogadro.svn.sourceforge.net/svnroot/avogadro
>
> git svn fetch
>
>
> The files avogadro.pro and README in the trunk/ directory appear in my
> imported git repository but not in Avogadro subversion trunk. We also had
> trunk/src/ and all its files/subdirectories appearing in the git checkout
> but not in subversion trunk. We deleted this using git and git svn which
> removed it from the git checkouts too after r858.
>
> I have been talking to Peter who confirmed this and pointed out that the
> repo was reorganised several times in the past. Please CC me on replies as
> I am not on the list. There is a copy of my git repo at
> http://platinum.cryos.net/avogadro.git/ if you would rather skip the
> import. Other than that everything has been working great. It would be good
> to get rid of this bug if possible. Let me know if there is anything else I
> can do to help.
>
[ Eric Cc'ed, as the author of git-svn ]
I can confirm that this looks like an import problem.
(e.g see svn log -v -r33:78 https://avogadro.svn.sourceforge.net/svnroot/avogadro)
I did my analysis on the file /trunk/avogadro.pro, because the error
happens really early in the history so could just import up to revision 76
to see what goes wrong. (The file gets never deleted in the import, as it
should be!)
trunk/avogadro.pro is added here:
------------------------------------------------------------------------
r33 | dcurtis3 | 2006-08-21 07:34:10 +0200 (Mon, 21 Aug 2006) | 3 lines
Changed paths:
A /trunk/avogadro.pro
Does a recursive build.
Here the refactoring starts (a new directory not tracked by git is added):
------------------------------------------------------------------------
r66 | dcurtis3 | 2007-01-03 06:42:45 +0100 (Wed, 03 Jan 2007) | 3 lines
Changed paths:
A /avogadro
Making room for libavogadro.
/branches is moved to /avogadro/branches
------------------------------------------------------------------------
r67 | dcurtis3 | 2007-01-03 06:47:11 +0100 (Wed, 03 Jan 2007) | 3 lines
Changed paths:
A /avogadro/branches (from /branches:66)
D /branches
Making room for libavogadro
ERROR HAPPENS HERE:
====================
/trunk and /tags are moved, too.
(/trunk/avogadro.pro becomes /avogadro/trunk/avogadro.pro):
------------------------------------------------------------------------
r68 | dcurtis3 | 2007-01-03 06:47:34 +0100 (Wed, 03 Jan 2007) | 3 lines
Changed paths:
A /avogadro/tags (from /tags:66)
A /avogadro/trunk (from /trunk:66)
D /tags
D /trunk
Making room for libavogadro.
The above delete/move of trunk isn't recorded anywhere in the git svn import.
'git-svn find-rev r66' doesn't produce any output!
And later git-svn thinks that /trunk and all its files are still there, so
e.g. /trunk/avogadro.pro stays in the repo forever.
-Peter
This is just for consistency here and for anyone interested in further
analyses.
Here is the rest of the import analyses I've done. Look how "interesting" the
repo is and how many times the files are moved.
/libavogadro is added
------------------------------------------------------------------------
r69 | dcurtis3 | 2007-01-03 06:50:58 +0100 (Wed, 03 Jan 2007) | 3 lines
Changed paths:
A /libavogadro
A /libavogadro/CMakeLists.txt
A /libavogadro/FindOpenBabel.cmake
A /libavogadro/src
A /libavogadro/src/CMakeLists.txt
A /libavogadro/src/color.cpp
A /libavogadro/src/color.h
A /libavogadro/src/engine.h
A /libavogadro/src/engines
A /libavogadro/src/engines/CMakeLists.txt
A /libavogadro/src/engines/ResidueSphereEngine.cpp
A /libavogadro/src/engines/ResidueSphereEngine.h
A /libavogadro/src/engines/SphereEngine.cpp
A /libavogadro/src/engines/SphereEngine.h
A /libavogadro/src/engines/StickEngine.cpp
A /libavogadro/src/engines/StickEngine.h
A /libavogadro/src/engines/WireframeEngine.cpp
A /libavogadro/src/engines/WireframeEngine.h
A /libavogadro/src/engines/bsengine.cpp
A /libavogadro/src/engines/bsengine.h
A /libavogadro/src/engines/vertexarray.cpp
A /libavogadro/src/engines/vertexarray.h
A /libavogadro/src/glwidget.cpp
A /libavogadro/src/glwidget.h
A /libavogadro/src/primitives.cpp
A /libavogadro/src/primitives.h
Added libavogadro.
Create /libavogadro/{trunk,branches,tags} and move anything below the
former /libavogadro into /libavogadro/trunk
------------------------------------------------------------------------
r70 | dcurtis3 | 2007-01-03 06:53:13 +0100 (Wed, 03 Jan 2007) | 3 lines
Changed paths:
D /libavogadro/CMakeLists.txt
D /libavogadro/FindOpenBabel.cmake
A /libavogadro/branches
D /libavogadro/src
A /libavogadro/tags
A /libavogadro/trunk
A /libavogadro/trunk/CMakeLists.txt (from /libavogadro/CMakeLists.txt:69)
A /libavogadro/trunk/FindOpenBabel.cmake (from /libavogadro/FindOpenBabel.cmake:69)
A /libavogadro/trunk/src (from /libavogadro/src:69)
Putting in trunk / branches / tags.
------------------------------------------------------------------------
r72 | dcurtis3 | 2007-01-03 08:55:32 +0100 (Wed, 03 Jan 2007) | 3 lines
Changed paths:
A /avogadro/trunk/CMakeLists.txt
A /avogadro/trunk/FindAvogadro.cmake
A /avogadro/trunk/FindOpenBabel.cmake
D /avogadro/trunk/src/Engine.h
D /avogadro/trunk/src/GLWidget.cpp
D /avogadro/trunk/src/GLWidget.h
D /avogadro/trunk/src/MainWindow.cpp
D /avogadro/trunk/src/MainWindow.h
D /avogadro/trunk/src/Primitives.cpp
D /avogadro/trunk/src/Primitives.h
D /avogadro/trunk/src/Renderer.h
D /avogadro/trunk/src/Tool.cpp
D /avogadro/trunk/src/Tool.h
D /avogadro/trunk/src/Views.cpp
D /avogadro/trunk/src/Views.h
D /avogadro/trunk/src/color.cpp
D /avogadro/trunk/src/color.h
D /avogadro/trunk/src/engines
M /avogadro/trunk/src/main.cpp
A /avogadro/trunk/src/mainwindow.cpp (from /avogadro/trunk/src/MainWindow.cpp:70)
A /avogadro/trunk/src/mainwindow.h (from /avogadro/trunk/src/MainWindow.h:70)
A /avogadro/trunk/src/tool.cpp (from /avogadro/trunk/src/Tool.cpp:70)
A /avogadro/trunk/src/tool.h (from /avogadro/trunk/src/Tool.h:70)
A /avogadro/trunk/untitled01.gpr
Now uses libavogadro. Starting to think we should package this a
little different.
Renamed /libavogadro to /avogadro-lib
------------------------------------------------------------------------
r73 | dcurtis3 | 2007-01-03 16:48:02 +0100 (Wed, 03 Jan 2007) | 3 lines
Changed paths:
A /avogadro-lib (from /libavogadro:72)
D /libavogadro
Refactor
mv /avogadro/trunk/avogadro.pro /trunk/avogadro/avogadro.pro
------------------------------------------------------------------------
r75 | dcurtis3 | 2007-01-03 20:49:35 +0100 (Wed, 03 Jan 2007) | 2 lines
Changed paths:
D /avogadro
D /avogadro-lib
A /branches
A /tags
A /trunk
A /trunk/avogadro (from /avogadro/trunk:74)
A /trunk/libavogadro (from /avogadro-lib/trunk:74)
Moving things around. Conforming to a more KDE-like layout in SVN.
I'm going nuts. SOrry
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: git-svn init from Avogadro SVN repo - deleted files showing
2007-12-10 10:42 ` Peter Baumann
@ 2007-12-10 11:40 ` Peter Baumann
2007-12-13 16:41 ` Eric Wong
1 sibling, 0 replies; 9+ messages in thread
From: Peter Baumann @ 2007-12-10 11:40 UTC (permalink / raw)
To: Marcus D. Hanwell; +Cc: Eric Wong, git
On Mon, Dec 10, 2007 at 11:42:35AM +0100, Peter Baumann wrote:
> On Sun, Dec 09, 2007 at 07:24:40PM -0500, Marcus D. Hanwell wrote:
> > Hi,
> >
> > I am quite new to git and git-svn but have been using both for my
> > development work recently. I imported the Avogadro subversion repository
> > (hosted on Sourceforge) using the following commands,
> >
> > git svn init -t tags -b branches -T trunk
> > https://avogadro.svn.sourceforge.net/svnroot/avogadro
> >
> > git svn fetch
> >
> >
> > The files avogadro.pro and README in the trunk/ directory appear in my
> > imported git repository but not in Avogadro subversion trunk. We also had
> > trunk/src/ and all its files/subdirectories appearing in the git checkout
> > but not in subversion trunk. We deleted this using git and git svn which
> > removed it from the git checkouts too after r858.
> >
> > I have been talking to Peter who confirmed this and pointed out that the
> > repo was reorganised several times in the past. Please CC me on replies as
> > I am not on the list. There is a copy of my git repo at
> > http://platinum.cryos.net/avogadro.git/ if you would rather skip the
> > import. Other than that everything has been working great. It would be good
> > to get rid of this bug if possible. Let me know if there is anything else I
> > can do to help.
> >
>
> [ Eric Cc'ed, as the author of git-svn ]
>
> I can confirm that this looks like an import problem.
> (e.g see svn log -v -r33:78 https://avogadro.svn.sourceforge.net/svnroot/avogadro)
>
> I did my analysis on the file /trunk/avogadro.pro, because the error
> happens really early in the history so could just import up to revision 76
> to see what goes wrong. (The file gets never deleted in the import, as it
> should be!)
>
>
>
> trunk/avogadro.pro is added here:
>
> ------------------------------------------------------------------------
> r33 | dcurtis3 | 2006-08-21 07:34:10 +0200 (Mon, 21 Aug 2006) | 3 lines
> Changed paths:
> A /trunk/avogadro.pro
>
> Does a recursive build.
>
>
> Here the refactoring starts (a new directory not tracked by git is added):
> ------------------------------------------------------------------------
> r66 | dcurtis3 | 2007-01-03 06:42:45 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro
>
> Making room for libavogadro.
>
>
> /branches is moved to /avogadro/branches
> ------------------------------------------------------------------------
> r67 | dcurtis3 | 2007-01-03 06:47:11 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro/branches (from /branches:66)
> D /branches
>
> Making room for libavogadro
>
>
>
>
> ERROR HAPPENS HERE:
> ====================
>
> /trunk and /tags are moved, too.
> (/trunk/avogadro.pro becomes /avogadro/trunk/avogadro.pro):
> ------------------------------------------------------------------------
> r68 | dcurtis3 | 2007-01-03 06:47:34 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro/tags (from /tags:66)
> A /avogadro/trunk (from /trunk:66)
> D /tags
> D /trunk
>
> Making room for libavogadro.
>
> The above delete/move of trunk isn't recorded anywhere in the git svn import.
> 'git-svn find-rev r66' doesn't produce any output!
Sorry. I meant r67 and r68 instead of r66.
> And later git-svn thinks that /trunk and all its files are still there, so
> e.g. /trunk/avogadro.pro stays in the repo forever.
>
>
> -Peter
>
> This is just for consistency here and for anyone interested in further
> analyses.
>
> Here is the rest of the import analyses I've done. Look how "interesting" the
> repo is and how many times the files are moved.
>
>
>
>
> /libavogadro is added
> ------------------------------------------------------------------------
> r69 | dcurtis3 | 2007-01-03 06:50:58 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /libavogadro
> A /libavogadro/CMakeLists.txt
> A /libavogadro/FindOpenBabel.cmake
> A /libavogadro/src
> A /libavogadro/src/CMakeLists.txt
> A /libavogadro/src/color.cpp
> A /libavogadro/src/color.h
> A /libavogadro/src/engine.h
> A /libavogadro/src/engines
> A /libavogadro/src/engines/CMakeLists.txt
> A /libavogadro/src/engines/ResidueSphereEngine.cpp
> A /libavogadro/src/engines/ResidueSphereEngine.h
> A /libavogadro/src/engines/SphereEngine.cpp
> A /libavogadro/src/engines/SphereEngine.h
> A /libavogadro/src/engines/StickEngine.cpp
> A /libavogadro/src/engines/StickEngine.h
> A /libavogadro/src/engines/WireframeEngine.cpp
> A /libavogadro/src/engines/WireframeEngine.h
> A /libavogadro/src/engines/bsengine.cpp
> A /libavogadro/src/engines/bsengine.h
> A /libavogadro/src/engines/vertexarray.cpp
> A /libavogadro/src/engines/vertexarray.h
> A /libavogadro/src/glwidget.cpp
> A /libavogadro/src/glwidget.h
> A /libavogadro/src/primitives.cpp
> A /libavogadro/src/primitives.h
>
> Added libavogadro.
>
>
> Create /libavogadro/{trunk,branches,tags} and move anything below the
> former /libavogadro into /libavogadro/trunk
> ------------------------------------------------------------------------
> r70 | dcurtis3 | 2007-01-03 06:53:13 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> D /libavogadro/CMakeLists.txt
> D /libavogadro/FindOpenBabel.cmake
> A /libavogadro/branches
> D /libavogadro/src
> A /libavogadro/tags
> A /libavogadro/trunk
> A /libavogadro/trunk/CMakeLists.txt (from /libavogadro/CMakeLists.txt:69)
> A /libavogadro/trunk/FindOpenBabel.cmake (from /libavogadro/FindOpenBabel.cmake:69)
> A /libavogadro/trunk/src (from /libavogadro/src:69)
>
> Putting in trunk / branches / tags.
>
>
> ------------------------------------------------------------------------
> r72 | dcurtis3 | 2007-01-03 08:55:32 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro/trunk/CMakeLists.txt
> A /avogadro/trunk/FindAvogadro.cmake
> A /avogadro/trunk/FindOpenBabel.cmake
> D /avogadro/trunk/src/Engine.h
> D /avogadro/trunk/src/GLWidget.cpp
> D /avogadro/trunk/src/GLWidget.h
> D /avogadro/trunk/src/MainWindow.cpp
> D /avogadro/trunk/src/MainWindow.h
> D /avogadro/trunk/src/Primitives.cpp
> D /avogadro/trunk/src/Primitives.h
> D /avogadro/trunk/src/Renderer.h
> D /avogadro/trunk/src/Tool.cpp
> D /avogadro/trunk/src/Tool.h
> D /avogadro/trunk/src/Views.cpp
> D /avogadro/trunk/src/Views.h
> D /avogadro/trunk/src/color.cpp
> D /avogadro/trunk/src/color.h
> D /avogadro/trunk/src/engines
> M /avogadro/trunk/src/main.cpp
> A /avogadro/trunk/src/mainwindow.cpp (from /avogadro/trunk/src/MainWindow.cpp:70)
> A /avogadro/trunk/src/mainwindow.h (from /avogadro/trunk/src/MainWindow.h:70)
> A /avogadro/trunk/src/tool.cpp (from /avogadro/trunk/src/Tool.cpp:70)
> A /avogadro/trunk/src/tool.h (from /avogadro/trunk/src/Tool.h:70)
> A /avogadro/trunk/untitled01.gpr
>
> Now uses libavogadro. Starting to think we should package this a
> little different.
>
>
>
> Renamed /libavogadro to /avogadro-lib
> ------------------------------------------------------------------------
> r73 | dcurtis3 | 2007-01-03 16:48:02 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro-lib (from /libavogadro:72)
> D /libavogadro
>
> Refactor
>
>
> mv /avogadro/trunk/avogadro.pro /trunk/avogadro/avogadro.pro
> ------------------------------------------------------------------------
> r75 | dcurtis3 | 2007-01-03 20:49:35 +0100 (Wed, 03 Jan 2007) | 2 lines
> Changed paths:
> D /avogadro
> D /avogadro-lib
> A /branches
> A /tags
> A /trunk
> A /trunk/avogadro (from /avogadro/trunk:74)
> A /trunk/libavogadro (from /avogadro-lib/trunk:74)
>
> Moving things around. Conforming to a more KDE-like layout in SVN.
> I'm going nuts. SOrry
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: git-svn init from Avogadro SVN repo - deleted files showing
2007-12-10 10:42 ` Peter Baumann
2007-12-10 11:40 ` Peter Baumann
@ 2007-12-13 16:41 ` Eric Wong
2007-12-13 18:13 ` Peter Baumann
1 sibling, 1 reply; 9+ messages in thread
From: Eric Wong @ 2007-12-13 16:41 UTC (permalink / raw)
To: Peter Baumann; +Cc: Marcus D. Hanwell, git
Peter Baumann <waste.manager@gmx.de> wrote:
> On Sun, Dec 09, 2007 at 07:24:40PM -0500, Marcus D. Hanwell wrote:
> > Hi,
> >
> > I am quite new to git and git-svn but have been using both for my
> > development work recently. I imported the Avogadro subversion repository
> > (hosted on Sourceforge) using the following commands,
> >
> > git svn init -t tags -b branches -T trunk
> > https://avogadro.svn.sourceforge.net/svnroot/avogadro
> >
> > git svn fetch
> >
> >
> > The files avogadro.pro and README in the trunk/ directory appear in my
> > imported git repository but not in Avogadro subversion trunk. We also had
> > trunk/src/ and all its files/subdirectories appearing in the git checkout
> > but not in subversion trunk. We deleted this using git and git svn which
> > removed it from the git checkouts too after r858.
> >
> > I have been talking to Peter who confirmed this and pointed out that the
> > repo was reorganised several times in the past. Please CC me on replies as
> > I am not on the list. There is a copy of my git repo at
> > http://platinum.cryos.net/avogadro.git/ if you would rather skip the
> > import. Other than that everything has been working great. It would be good
> > to get rid of this bug if possible. Let me know if there is anything else I
> > can do to help.
> >
>
> [ Eric Cc'ed, as the author of git-svn ]
>
> I can confirm that this looks like an import problem.
> (e.g see svn log -v -r33:78 https://avogadro.svn.sourceforge.net/svnroot/avogadro)
>
> I did my analysis on the file /trunk/avogadro.pro, because the error
> happens really early in the history so could just import up to revision 76
> to see what goes wrong. (The file gets never deleted in the import, as it
> should be!)
>
>
>
> trunk/avogadro.pro is added here:
>
> ------------------------------------------------------------------------
> r33 | dcurtis3 | 2006-08-21 07:34:10 +0200 (Mon, 21 Aug 2006) | 3 lines
> Changed paths:
> A /trunk/avogadro.pro
>
> Does a recursive build.
>
>
> Here the refactoring starts (a new directory not tracked by git is added):
> ------------------------------------------------------------------------
> r66 | dcurtis3 | 2007-01-03 06:42:45 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro
>
> Making room for libavogadro.
>
>
> /branches is moved to /avogadro/branches
> ------------------------------------------------------------------------
> r67 | dcurtis3 | 2007-01-03 06:47:11 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro/branches (from /branches:66)
> D /branches
>
> Making room for libavogadro
>
>
>
>
> ERROR HAPPENS HERE:
> ====================
>
> /trunk and /tags are moved, too.
> (/trunk/avogadro.pro becomes /avogadro/trunk/avogadro.pro):
> ------------------------------------------------------------------------
> r68 | dcurtis3 | 2007-01-03 06:47:34 +0100 (Wed, 03 Jan 2007) | 3 lines
> Changed paths:
> A /avogadro/tags (from /tags:66)
> A /avogadro/trunk (from /trunk:66)
> D /tags
> D /trunk
>
> Making room for libavogadro.
>
> The above delete/move of trunk isn't recorded anywhere in the git svn import.
> 'git-svn find-rev r66' doesn't produce any output!
> And later git-svn thinks that /trunk and all its files are still there, so
> e.g. /trunk/avogadro.pro stays in the repo forever.
Hi,
Thanks for the analysis, Peter.
git-svn ignores deletions to the directory we're tracking in order to
represent renames when the follow-parent case is hit.
Unfortunately, this never took into account the directory we're tracking
reappearing later in history. I'll try to have a fix later tonight or
over the weekend.
> mv /avogadro/trunk/avogadro.pro /trunk/avogadro/avogadro.pro
> ------------------------------------------------------------------------
> r75 | dcurtis3 | 2007-01-03 20:49:35 +0100 (Wed, 03 Jan 2007) | 2 lines
> Changed paths:
> D /avogadro
> D /avogadro-lib
> A /branches
> A /tags
> A /trunk
> A /trunk/avogadro (from /avogadro/trunk:74)
> A /trunk/libavogadro (from /avogadro-lib/trunk:74)
>
> Moving things around. Conforming to a more KDE-like layout in SVN.
> I'm going nuts. SOrry
Instead of handling the full delete of everything in r68, I think I'll
make it so importing r75 will clobber all the stuff in trunk/ we ignored
deleting in r68 before adding the contents of trunk/ in r75.
--
Eric Wong
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: git-svn init from Avogadro SVN repo - deleted files showing
2007-12-13 16:41 ` Eric Wong
@ 2007-12-13 18:13 ` Peter Baumann
2007-12-14 16:39 ` [PATCH] git-svn: handle our top-level path is deleted and later re-added Eric Wong
0 siblings, 1 reply; 9+ messages in thread
From: Peter Baumann @ 2007-12-13 18:13 UTC (permalink / raw)
To: Eric Wong; +Cc: Marcus D. Hanwell, git
On Thu, Dec 13, 2007 at 08:41:34AM -0800, Eric Wong wrote:
> Peter Baumann <waste.manager@gmx.de> wrote:
> > On Sun, Dec 09, 2007 at 07:24:40PM -0500, Marcus D. Hanwell wrote:
> > > Hi,
> > >
> > > I am quite new to git and git-svn but have been using both for my
> > > development work recently. I imported the Avogadro subversion repository
> > > (hosted on Sourceforge) using the following commands,
> > >
> > > git svn init -t tags -b branches -T trunk
> > > https://avogadro.svn.sourceforge.net/svnroot/avogadro
> > >
> > > git svn fetch
> > >
> > >
> > > The files avogadro.pro and README in the trunk/ directory appear in my
> > > imported git repository but not in Avogadro subversion trunk. We also had
> > > trunk/src/ and all its files/subdirectories appearing in the git checkout
> > > but not in subversion trunk. We deleted this using git and git svn which
> > > removed it from the git checkouts too after r858.
> > >
> > > I have been talking to Peter who confirmed this and pointed out that the
> > > repo was reorganised several times in the past. Please CC me on replies as
> > > I am not on the list. There is a copy of my git repo at
> > > http://platinum.cryos.net/avogadro.git/ if you would rather skip the
> > > import. Other than that everything has been working great. It would be good
> > > to get rid of this bug if possible. Let me know if there is anything else I
> > > can do to help.
> > >
> >
> > [ Eric Cc'ed, as the author of git-svn ]
> >
> > I can confirm that this looks like an import problem.
> > (e.g see svn log -v -r33:78 https://avogadro.svn.sourceforge.net/svnroot/avogadro)
> >
> > I did my analysis on the file /trunk/avogadro.pro, because the error
> > happens really early in the history so could just import up to revision 76
> > to see what goes wrong. (The file gets never deleted in the import, as it
> > should be!)
> >
> >
> >
> > trunk/avogadro.pro is added here:
> >
> > ------------------------------------------------------------------------
> > r33 | dcurtis3 | 2006-08-21 07:34:10 +0200 (Mon, 21 Aug 2006) | 3 lines
> > Changed paths:
> > A /trunk/avogadro.pro
> >
> > Does a recursive build.
> >
> >
> > Here the refactoring starts (a new directory not tracked by git is added):
> > ------------------------------------------------------------------------
> > r66 | dcurtis3 | 2007-01-03 06:42:45 +0100 (Wed, 03 Jan 2007) | 3 lines
> > Changed paths:
> > A /avogadro
> >
> > Making room for libavogadro.
> >
> >
> > /branches is moved to /avogadro/branches
> > ------------------------------------------------------------------------
> > r67 | dcurtis3 | 2007-01-03 06:47:11 +0100 (Wed, 03 Jan 2007) | 3 lines
> > Changed paths:
> > A /avogadro/branches (from /branches:66)
> > D /branches
> >
> > Making room for libavogadro
> >
> >
> >
> >
> > ERROR HAPPENS HERE:
> > ====================
> >
> > /trunk and /tags are moved, too.
> > (/trunk/avogadro.pro becomes /avogadro/trunk/avogadro.pro):
> > ------------------------------------------------------------------------
> > r68 | dcurtis3 | 2007-01-03 06:47:34 +0100 (Wed, 03 Jan 2007) | 3 lines
> > Changed paths:
> > A /avogadro/tags (from /tags:66)
> > A /avogadro/trunk (from /trunk:66)
> > D /tags
> > D /trunk
> >
> > Making room for libavogadro.
> >
> > The above delete/move of trunk isn't recorded anywhere in the git svn import.
> > 'git-svn find-rev r66' doesn't produce any output!
> > And later git-svn thinks that /trunk and all its files are still there, so
> > e.g. /trunk/avogadro.pro stays in the repo forever.
>
> Hi,
>
> Thanks for the analysis, Peter.
>
> git-svn ignores deletions to the directory we're tracking in order to
> represent renames when the follow-parent case is hit.
>
> Unfortunately, this never took into account the directory we're tracking
> reappearing later in history. I'll try to have a fix later tonight or
> over the weekend.
>
> > mv /avogadro/trunk/avogadro.pro /trunk/avogadro/avogadro.pro
> > ------------------------------------------------------------------------
> > r75 | dcurtis3 | 2007-01-03 20:49:35 +0100 (Wed, 03 Jan 2007) | 2 lines
> > Changed paths:
> > D /avogadro
> > D /avogadro-lib
> > A /branches
> > A /tags
> > A /trunk
> > A /trunk/avogadro (from /avogadro/trunk:74)
> > A /trunk/libavogadro (from /avogadro-lib/trunk:74)
> >
> > Moving things around. Conforming to a more KDE-like layout in SVN.
> > I'm going nuts. SOrry
>
> Instead of handling the full delete of everything in r68, I think I'll
> make it so importing r75 will clobber all the stuff in trunk/ we ignored
> deleting in r68 before adding the contents of trunk/ in r75.
>
Sorry, that last sentence I can't parse/understand. But I trust you to do the
right thing.
-Peter
^ permalink raw reply [flat|nested] 9+ messages in thread
* [PATCH] git-svn: handle our top-level path is deleted and later re-added
2007-12-13 18:13 ` Peter Baumann
@ 2007-12-14 16:39 ` Eric Wong
2007-12-14 16:43 ` Eric Wong
` (2 more replies)
0 siblings, 3 replies; 9+ messages in thread
From: Eric Wong @ 2007-12-14 16:39 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Peter Baumann, Marcus D. Hanwell, git
Previously, git-svn would ignore cases where the path we're
tracking is removed from the repository. This was to prevent
heads with follow-parent from ending up with a tree full of
empty revisions (and thus breaking rename detection).
The previous behavior is fine until the path we're tracking
is re-added later on, leading to the old files being merged
in with the new files in the directory (because the old
files were never marked as deleted)
We will now only remove all the old files locally that were
deleted remotely iff we detect the directory we're in is being
created from scratch.
Thanks for Marcus D. Hanwell for the bug report and
Peter Baumann for the analysis.
Signed-off-by: Eric Wong <normalperson@yhbt.net>
---
Peter Baumann <waste.manager@gmx.de> wrote:
> On Thu, Dec 13, 2007 at 08:41:34AM -0800, Eric Wong wrote:
> > Peter Baumann <waste.manager@gmx.de> wrote:
> > > On Sun, Dec 09, 2007 at 07:24:40PM -0500, Marcus D. Hanwell wrote:
> > > /trunk and /tags are moved, too.
> > > (/trunk/avogadro.pro becomes /avogadro/trunk/avogadro.pro):
> > > ------------------------------------------------------------------------
> > > r68 | dcurtis3 | 2007-01-03 06:47:34 +0100 (Wed, 03 Jan 2007) | 3 lines
> > > Changed paths:
> > > A /avogadro/tags (from /tags:66)
> > > A /avogadro/trunk (from /trunk:66)
> > > D /tags
> > > D /trunk
> > >
> > > Making room for libavogadro.
> > >
> > > The above delete/move of trunk isn't recorded anywhere in the git svn import.
> > > 'git-svn find-rev r66' doesn't produce any output!
> > > And later git-svn thinks that /trunk and all its files are still there, so
> > > e.g. /trunk/avogadro.pro stays in the repo forever.
> >
> > Hi,
> >
> > Thanks for the analysis, Peter.
> >
> > git-svn ignores deletions to the directory we're tracking in order to
> > represent renames when the follow-parent case is hit.
> >
> > Unfortunately, this never took into account the directory we're tracking
> > reappearing later in history. I'll try to have a fix later tonight or
> > over the weekend.
> >
> > > mv /avogadro/trunk/avogadro.pro /trunk/avogadro/avogadro.pro
> > > ------------------------------------------------------------------------
> > > r75 | dcurtis3 | 2007-01-03 20:49:35 +0100 (Wed, 03 Jan 2007) | 2 lines
> > > Changed paths:
> > > D /avogadro
> > > D /avogadro-lib
> > > A /branches
> > > A /tags
> > > A /trunk
> > > A /trunk/avogadro (from /avogadro/trunk:74)
> > > A /trunk/libavogadro (from /avogadro-lib/trunk:74)
> > >
> > > Moving things around. Conforming to a more KDE-like layout in SVN.
> > > I'm going nuts. SOrry
> >
> > Instead of handling the full delete of everything in r68, I think I'll
> > make it so importing r75 will clobber all the stuff in trunk/ we ignored
> > deleting in r68 before adding the contents of trunk/ in r75.
> >
>
> Sorry, that last sentence I can't parse/understand. But I trust you to do the
> right thing.
I hope the commit message was a better explanation. Or the code
and test case I've added makes perfect sense :)
git-svn.perl | 14 +++++++++
t/t9103-git-svn-tracked-directory-removed.sh | 39 ++++++++++++++++++++++++++
2 files changed, 53 insertions(+), 0 deletions(-)
create mode 100755 t/t9103-git-svn-tracked-directory-removed.sh
diff --git a/git-svn.perl b/git-svn.perl
index 3aa7f8c..d411a34 100755
--- a/git-svn.perl
+++ b/git-svn.perl
@@ -3045,6 +3045,20 @@ sub add_file {
sub add_directory {
my ($self, $path, $cp_path, $cp_rev) = @_;
+ my $gpath = $self->git_path($path);
+ if ($gpath eq '') {
+ my ($ls, $ctx) = command_output_pipe(qw/ls-tree
+ -r --name-only -z/,
+ $self->{c});
+ local $/ = "\0";
+ while (<$ls>) {
+ chomp;
+ $self->{gii}->remove($_);
+ print "\tD\t$_\n" unless $::_q;
+ }
+ command_close_pipe($ls, $ctx);
+ $self->{empty}->{$path} = 0;
+ }
my ($dir, $file) = ($path =~ m#^(.*?)/?([^/]+)$#);
delete $self->{empty}->{$dir};
$self->{empty}->{$path} = 1;
diff --git a/t/t9103-git-svn-tracked-directory-removed.sh b/t/t9103-git-svn-tracked-directory-removed.sh
new file mode 100755
index 0000000..0f0b0fd
--- /dev/null
+++ b/t/t9103-git-svn-tracked-directory-removed.sh
@@ -0,0 +1,39 @@
+#!/bin/sh
+#
+# Copyright (c) 2007 Eric Wong
+#
+
+test_description='git-svn tracking removed top-level path'
+. ./lib-git-svn.sh
+
+test_expect_success 'make history for tracking' '
+ mkdir import &&
+ mkdir import/trunk &&
+ echo hello >> import/trunk/README &&
+ svn import -m initial import $svnrepo &&
+ rm -rf import &&
+ svn co $svnrepo/trunk trunk &&
+ echo bye bye >> trunk/README &&
+ svn rm -m "gone" $svnrepo/trunk &&
+ rm -rf trunk &&
+ mkdir trunk &&
+ echo "new" > trunk/FOLLOWME &&
+ svn import -m "new trunk" trunk $svnrepo/trunk
+'
+
+test_expect_success 'clone repo with git' '
+ git svn clone -s $svnrepo x &&
+ test -f x/FOLLOWME &&
+ test ! -f x/README
+'
+
+test_expect_success 'make sure r2 still has old file' '
+ cd x &&
+ test -n "$(git svn find-rev r1)" &&
+ git reset --hard $(git svn find-rev r1) &&
+ test -f README &&
+ test ! -f FOLLOWME &&
+ test x$(git svn find-rev r2) = x
+'
+
+test_done
--
Eric Wong
^ permalink raw reply related [flat|nested] 9+ messages in thread
* Re: [PATCH] git-svn: handle our top-level path is deleted and later re-added
2007-12-14 16:39 ` [PATCH] git-svn: handle our top-level path is deleted and later re-added Eric Wong
@ 2007-12-14 16:43 ` Eric Wong
2007-12-15 0:24 ` cho
2007-12-15 16:35 ` Peter Baumann
2 siblings, 0 replies; 9+ messages in thread
From: Eric Wong @ 2007-12-14 16:43 UTC (permalink / raw)
To: Junio C Hamano; +Cc: Peter Baumann, Marcus D. Hanwell, git
> Subject: [PATCH] git-svn: handle our top-level path is deleted and later re-added
That should read:
Subject: [PATCH] git-svn: handle our top-level path being deleted and later re-added
> ---
> Peter Baumann <waste.manager@gmx.de> wrote:
> > On Thu, Dec 13, 2007 at 08:41:34AM -0800, Eric Wong wrote:
> > > Instead of handling the full delete of everything in r68, I think I'll
> > > make it so importing r75 will clobber all the stuff in trunk/ we ignored
> > > deleting in r68 before adding the contents of trunk/ in r75.
> > >
> >
> > Sorry, that last sentence I can't parse/understand. But I trust you to do the
> > right thing.
>
> I hope the commit message was a better explanation. Or the code
> and test case I've added makes perfect sense :)
My language generation module seems broken these days.
--
Eric Wong
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH] git-svn: handle our top-level path is deleted and later re-added
2007-12-14 16:39 ` [PATCH] git-svn: handle our top-level path is deleted and later re-added Eric Wong
2007-12-14 16:43 ` Eric Wong
@ 2007-12-15 0:24 ` cho
2007-12-15 16:35 ` Peter Baumann
2 siblings, 0 replies; 9+ messages in thread
From: cho @ 2007-12-15 0:24 UTC (permalink / raw)
To: git
Thanks, this fixes a problem I had reported previously:
http://permalink.gmane.org/gmane.comp.version-control.git/61516
I'm not sure how I get to keep the git repository (branches) I previously
had, but it's not too bad.
^ permalink raw reply [flat|nested] 9+ messages in thread
* Re: [PATCH] git-svn: handle our top-level path is deleted and later re-added
2007-12-14 16:39 ` [PATCH] git-svn: handle our top-level path is deleted and later re-added Eric Wong
2007-12-14 16:43 ` Eric Wong
2007-12-15 0:24 ` cho
@ 2007-12-15 16:35 ` Peter Baumann
2 siblings, 0 replies; 9+ messages in thread
From: Peter Baumann @ 2007-12-15 16:35 UTC (permalink / raw)
To: Eric Wong; +Cc: Junio C Hamano, Marcus D. Hanwell, git
On Fri, Dec 14, 2007 at 08:39:09AM -0800, Eric Wong wrote:
> Previously, git-svn would ignore cases where the path we're
> tracking is removed from the repository. This was to prevent
> heads with follow-parent from ending up with a tree full of
> empty revisions (and thus breaking rename detection).
>
> The previous behavior is fine until the path we're tracking
> is re-added later on, leading to the old files being merged
> in with the new files in the directory (because the old
> files were never marked as deleted)
>
> We will now only remove all the old files locally that were
> deleted remotely iff we detect the directory we're in is being
> created from scratch.
>
> Thanks for Marcus D. Hanwell for the bug report and
> Peter Baumann for the analysis.
>
> Signed-off-by: Eric Wong <normalperson@yhbt.net>
[...]
It seems to solve the problem seen in the avogadro repo. At least
the suspicious revisions I checked looked identical in the imported
version.
-Peter
^ permalink raw reply [flat|nested] 9+ messages in thread
end of thread, other threads:[~2007-12-15 16:35 UTC | newest]
Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-12-10 0:24 git-svn init from Avogadro SVN repo - deleted files showing Marcus D. Hanwell
2007-12-10 10:42 ` Peter Baumann
2007-12-10 11:40 ` Peter Baumann
2007-12-13 16:41 ` Eric Wong
2007-12-13 18:13 ` Peter Baumann
2007-12-14 16:39 ` [PATCH] git-svn: handle our top-level path is deleted and later re-added Eric Wong
2007-12-14 16:43 ` Eric Wong
2007-12-15 0:24 ` cho
2007-12-15 16:35 ` Peter Baumann
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).