From: Andy Whitcroft <apw@shadowen.org>
To: Petr Baudis <pasky@suse.cz>
Cc: Junio C Hamano <junkio@cox.net>, git@vger.kernel.org
Subject: Re: [PATCH] [PATCH] git-mirror - exactly mirror another repository
Date: Fri, 27 Apr 2007 09:58:26 +0100 [thread overview]
Message-ID: <4631BB32.9080405@shadowen.org> (raw)
In-Reply-To: <20070427021505.1740.58136.stgit@rover>
Petr Baudis wrote:
> Sometimes its handy to be able to efficiently backup or mirror one
> Git repository to another Git repository by employing the native
> Git object transfer protocol. But when mirroring or backing up a
> repository you really want:
>
> 1) Every object in the source to go to the mirror.
> 2) Every ref in the source to go to the mirror.
> 3) Any ref removed from the source to be removed from the mirror.
>
> and since git-fetch doesn't do 2 and 3, here's a tool that does.
>
> This is based on Shawn Pearce's patch from 25 Sep 2006, updated to take
> Junio's and Sergey's review into account, to use few newer pieces of Git
> infrastructure and with few trivial tweaks. The repacking part was dropped
> since git-fetch does that on its own now.
>
> I actually still would kind of prefer this to be a git-fetch's feature but
> the general mood seems to be to have this as a separate command and I can't
> say I care at all.
>
> Signed-off-by: Petr Baudis <pasky@suse.cz>
> ---
>
> .gitignore | 1
> Documentation/config.txt | 6 ++
> Documentation/git-mirror.txt | 54 +++++++++++++++++++++
> Makefile | 2 -
> git-mirror.perl | 110 ++++++++++++++++++++++++++++++++++++++++++
> 5 files changed, 172 insertions(+), 1 deletions(-)
>
> diff --git a/.gitignore b/.gitignore
> index 4dc0c39..d0b67da 100644
> --- a/.gitignore
> +++ b/.gitignore
> @@ -80,6 +80,7 @@ git-merge-resolve
> git-merge-stupid
> git-merge-subtree
> git-mergetool
> +git-mirror
> git-mktag
> git-mktree
> git-name-rev
> diff --git a/Documentation/config.txt b/Documentation/config.txt
> index e0aff53..e05e4c5 100644
> --- a/Documentation/config.txt
> +++ b/Documentation/config.txt
> @@ -513,6 +513,12 @@ log.showroot::
> Tools like gitlink:git-log[1] or gitlink:git-whatchanged[1], which
> normally hide the root commit will now show it. True by default.
>
> +mirror.allowed::
> + If true, gitlink:git-mirror[1] will be allowed to run on the
> + repository. Please see its documentation for all the implications.
> +
> +mirror.
> +
Ok, I can see why you'd want to protect a user from going git-mirror
<foo> and losing their local changes. But you've only protected them
from mirroring at all. If they want to use this repo as a mirror of
somewhere X you have not stopped them from git-mirror Y'ing themselves.
Now yes if you know its a mirror then I guess you can recover with a
git-mirror X but ...
It seems to me if you are having a config option that perhaps it should
be the URL from whence the mirror comes, and the command should just be
'git mirror'.
[mirror]
url='somewhere'
-apw
prev parent reply other threads:[~2007-04-27 8:58 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-04-27 2:15 [PATCH] [PATCH] git-mirror - exactly mirror another repository Petr Baudis
2007-04-27 2:17 ` Petr Baudis
2007-04-27 2:47 ` A Large Angry SCM
2007-04-27 4:38 ` Petr Baudis
2007-04-27 18:00 ` Petr Baudis
2007-04-27 8:56 ` Johannes Schindelin
2007-04-27 8:58 ` Andy Whitcroft [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4631BB32.9080405@shadowen.org \
--to=apw@shadowen.org \
--cc=git@vger.kernel.org \
--cc=junkio@cox.net \
--cc=pasky@suse.cz \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).