Shawn O. Pearce 4191c35671 git-fetch: avoid local fetching from alternate (again)
Back in e3c6f240fd Junio taught
git-fetch to avoid copying objects when we are fetching from
a repository that is already registered as an alternate object
database.  In such a case there is no reason to copy any objects
as we can already obtain them through the alternate.

However we need to ensure the objects are all reachable, so we
run `git rev-list --objects $theirs --not --all` to verify this.
If any object is missing or unreadable then we need to fetch/copy
the objects from the remote.  When a missing object is detected
the git-rev-list process will exit with a non-zero exit status,
making this condition quite easy to detect.

Although git-fetch is currently a builtin (and so is rev-list)
we cannot invoke the traverse_objects() API at this point in the
transport code.  The object walker within traverse_objects() calls
die() as soon as it finds an object it cannot read.  If that happens
we want to resume the fetch process by calling do_fetch_pack().
To get around this we spawn git-rev-list into a background process
to prevent a die() from killing the foreground fetch process,
thus allowing the fetch process to resume into do_fetch_pack()
if copying is necessary.

We aren't interested in the output of rev-list (a list of SHA-1
object names that are reachable) or its errors (a "spurious" error
about an object not being found as we need to copy it) so we redirect
both stdout and stderr to /dev/null.

We run this git-rev-list based check before any fetch as we may
already have the necessary objects local from a prior fetch.  If we
don't then its very likely the first $theirs object listed on the
command line won't exist locally and git-rev-list will die very
quickly, allowing us to start the network transfer.  This test even
on remote URLs may save bandwidth if someone runs `git pull origin`,
sees a merge conflict, resets out, then redoes the same pull just
a short time later.  If the remote hasn't changed between the two
pulls and the local repository hasn't had git-gc run in it then
there is probably no need to perform network transfer as all of
the objects are local.

Documentation for the new quickfetch function was suggested and
written by Junio, based on his original comment in git-fetch.sh.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
2007-11-11 17:09:55 -08:00
2007-06-07 00:04:01 -07:00
2007-11-05 22:03:47 -08:00
2007-11-11 15:00:05 -08:00
2007-06-07 00:04:01 -07:00
2007-06-07 00:04:01 -07:00
2007-11-02 16:42:23 -07:00
2007-10-19 01:18:55 -04:00
2007-05-30 15:03:50 -07:00
2007-11-02 16:42:23 -07:00
2007-06-07 00:04:01 -07:00
2007-11-01 13:47:47 -07:00
2007-06-07 00:04:01 -07:00
2007-11-05 18:57:58 -08:00
2007-09-19 03:22:30 -07:00
2007-11-09 00:21:44 -08:00
2007-11-04 01:11:17 -07:00
2007-03-20 22:17:47 -07:00
2007-11-11 15:19:24 -08:00
2007-09-26 02:27:06 -07:00
2007-09-26 02:27:06 -07:00
2007-11-07 18:17:20 -08:00
2007-08-10 23:17:46 -07:00
2007-06-07 00:04:01 -07:00
2007-10-30 16:08:40 -07:00
2007-10-30 16:08:40 -07:00
2007-06-07 00:04:01 -07:00
2007-11-01 13:47:47 -07:00
2007-08-14 22:34:58 -07:00
2007-06-07 00:04:01 -07:00
2007-10-29 17:03:11 -07:00
2007-08-10 23:17:46 -07:00
2007-06-13 02:02:10 -07:00
2007-10-18 03:45:05 -04:00
2007-10-03 03:05:32 -07:00
2007-11-09 00:21:44 -08:00
2007-11-07 17:12:53 -08:00
2007-10-03 03:05:58 -07:00
2005-09-07 17:45:20 -07:00
2007-10-26 23:17:23 -07:00
2007-11-09 00:21:44 -08:00
2007-11-09 00:21:44 -08:00
2007-11-05 22:03:47 -08:00
2007-10-31 12:20:05 -07:00
2006-09-27 23:59:09 -07:00
2007-09-19 03:22:30 -07:00
2007-08-13 23:34:38 -07:00
2007-11-11 15:00:05 -08:00
2007-10-02 17:35:29 -07:00
2007-10-03 04:28:24 -07:00
2007-10-26 23:27:23 -07:00
2007-06-07 00:04:01 -07:00
2007-06-07 00:04:01 -07:00
2007-06-07 00:04:01 -07:00
2007-06-07 00:04:01 -07:00
2007-06-07 00:04:01 -07:00
2007-11-02 16:27:37 -07:00
2007-11-02 16:27:37 -07:00
2007-06-07 00:04:01 -07:00
2007-06-07 00:04:01 -07:00
2007-10-30 16:08:40 -07:00
2007-07-02 17:12:48 -07:00
2007-10-18 03:11:17 -04:00
2007-10-24 21:59:50 -07:00
2007-09-05 11:29:33 -07:00
2007-11-09 00:17:52 -08:00
2007-10-15 22:31:47 -04:00
2007-07-11 13:52:16 -07:00
2007-10-29 12:53:54 -07:00
2007-06-07 00:04:01 -07:00
2007-09-18 17:42:17 -07:00
2005-11-02 16:50:58 -08:00
2006-03-25 16:35:43 -08:00
2007-05-01 02:59:08 -07:00
2007-10-21 01:59:42 -04:00
2007-06-07 00:04:01 -07:00
2007-06-22 23:19:43 -07:00
2007-08-10 11:44:23 -07:00
2007-10-30 16:08:40 -07:00
2007-06-07 00:04:01 -07:00
2007-09-19 03:22:30 -07:00

////////////////////////////////////////////////////////////////

	GIT - the stupid content tracker

////////////////////////////////////////////////////////////////

"git" can mean anything, depending on your mood.

 - random three-letter combination that is pronounceable, and not
   actually used by any common UNIX command.  The fact that it is a
   mispronunciation of "get" may or may not be relevant.
 - stupid. contemptible and despicable. simple. Take your pick from the
   dictionary of slang.
 - "global information tracker": you're in a good mood, and it actually
   works for you. Angels sing, and a light suddenly fills the room.
 - "goddamn idiotic truckload of sh*t": when it breaks

Git is a fast, scalable, distributed revision control system with an
unusually rich command set that provides both high-level operations
and full access to internals.

Git is an Open Source project covered by the GNU General Public License.
It was originally written by Linus Torvalds with help of a group of
hackers around the net. It is currently maintained by Junio C Hamano.

Please read the file INSTALL for installation instructions.
See Documentation/tutorial.txt to get started, then see
Documentation/everyday.txt for a useful minimum set of commands,
and "man git-commandname" for documentation of each command.
CVS users may also want to read Documentation/cvs-migration.txt.

Many Git online resources are accessible from http://git.or.cz/
including full documentation and Git related tools.

The user discussion and development of Git take place on the Git
mailing list -- everyone is welcome to post bug reports, feature
requests, comments and patches to git@vger.kernel.org. To subscribe
to the list, send an email with just "subscribe git" in the body to
majordomo@vger.kernel.org. The mailing list archives are available at
http://marc.theaimsgroup.com/?l=git and other archival sites.

The messages titled "A note from the maintainer", "What's in
git.git (stable)" and "What's cooking in git.git (topics)" and
the discussion following them on the mailing list give a good
reference for project status, development direction and
remaining tasks.
Description
No description provided
Readme 999 MiB
Languages
C 50.4%
Shell 38.9%
Perl 4.3%
Tcl 3.1%
Python 0.8%
Other 2.3%