Re: repack behaves unexpectedly if called in a bare _subrepo_

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Junio C Hamano, Sun, Jun 17, 2007 19:22:39 +0200:
> > Just a heads-up. This took me by surprise. And I suppose it will be
> > the same even if the subrepo is a real subproject.
> >
> > To illustrate:
> >
> > (
> >     mkdir super && cd super
> >     git init
> >     echo 0 > a; git add a; git commit -m0
> >     echo 2 >> a; git commit -a -m1
> >     echo 3 >> a; git commit -a -m2
> >     cp -a .git sub
> >     cd sub
> >     git --bare config --bool core.bare true
> >     git repack -a -d
> > )
> 
> I think what is happening is that in that bare repository 'sub',
> the sequence we find where a git repository is is defined so
> that the current directory is checked way after "one of my
> parents with .git/ subdirectory" check.

Yes, that's what I found. Couldn't convince myself it could be wrong,
feels right to me.

> If super (a directory) has a subproject sub as its subproject,
> then you would be copying .git to sub/.git, not sub/, wouldn't
> you?

Yes, very likely. But it is not a super project in subproject sense,
and why? Is there a reason I can't have a bare subproject?

> What are you trying to achieve?

I mirror some projects I am interested in. There is a directory where
all the mirrors are: ~/src. It contains the git/git-svn/git-cvs
repositories _and_ the scripts which do the mirroring:

$ ls -a
./                  gitk/          motion.gitsvn/  uclibc.gitsvn/
../                 gnulib.git/    moto4lin/       udev/
busybox.gitsvn/     gpsbabel.git/  mutt/           udhcp.gitsvn/
coreutils.git/      historic/      rt2500/         update-gits*
count-git-objects*  .htaccess      sparse/         use-src/
dclock/             iproute2.git/  sunset/         wireless-2.6.git/
git/                klibc/         tig/
.git/               linux.git/     torsmo/
.gitignore          mimesplit3/    tuner/

The super in my example is this ~/src, and it keeps track of changes
to the scripts (some mirrors can be complicated, so I wanted to be
prepared). Felt kind of natural to do it this way. Until I tried to
repack the mirrored repos, and it didn't work as I expected. The repos
are not tracked as subprojects (in fact, they're .gitignored).
There is no point for me to have working directories for the mirrors:
it is my home server, if I do something, I do it elsewhere.

It is not exactly a "problem", and anyway there is a couple of
solutions (pass --bare, create <mirror>/.git, for instance), I just
fall into it and though it'd be a good idea to let others know.

-
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

[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux