Hello.
We had a submodule that we deleted and then added back into the
repository at the same location as the former submodule. When running
fast-export, the newly 'added' files for the merge commit are listed and
then are followed with a:
M ... path/to/submodule/file
D path/to/submodule
On fast-import, the resultant repository becomes corrupt due to the
Delete instruction above occurring AFTER the file adds/modifications.
The new repository does not match the old repository where the
fast-export was performed.
I have included a repro script below. I have not been able to test this
on Git 1.7.7.1, but I have tested on Git 1.7.7 (msysGit version).
Please compare the differences between the generated main.fe and
newmain.fe files. newmain.fe has data loss.
I am not familiar with the fast-export code. Can anyone help out?
Thanks.
Josh
---------
rm -rf main brokenmain sub main.fenewmain.fe
# Create the submodule.
mkdir sub
cd sub
git init
echo file > file
git add file
git commit -m file
cd ..
# Create the main repository.
mkdir main
cd main
git init
# Add the submodule.
git submodule add ../sub sub
git commit -m "Add submodule"
# Remove the submodule.
rm -rf sub
git rm sub .gitmodules
git commit -m "Remove submodule"
# Add sub/file to the master branch.
mkdir sub
echo file > sub/file
git add sub/file
git commit -m "Add sub/file"
if [ -f sub/file ]; then
echo "main: master branch: sub/file exists."
fi
# Delete the submodule directory manually, because we know that the
incoming merge will need it gone.
git checkout -B will-be-broken HEAD^^
rm -rf sub
git merge --no-ff master
# sub/file exists within the 'will-be-broken' branch.
if [ -f sub/file ]; then
echo "main: will-be-broken branch: sub/file exists."
fi
# Export out the main repository.
git fast-export --all > ../main.fe
# Create the brokenmain repository.
cd ..
mkdir brokenmain
cd brokenmain
git init
# Import in everything from the main repository.
git fast-import < ../main.fe
# sub/file exists within the master branch.
git checkout master
if [ -f sub/file ]; then
echo "brokenmain: master branch: sub/file exists."
fi
# sub/file SHOULD exist within the 'will-be-broken' branch but doesn't.
git checkout will-be-broken
if [ ! -f sub/file ]; then
echo "brokenmain: will-be-broken branch: sub/file SHOULD exist but
doesn't."
fi
# Export out the brokenmain repository.
git fast-export --all > ../brokenmain.fe
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html