gitweb.git
Retire check-files.Junio C Hamano Thu, 4 Aug 2005 02:13:52 +0000 (19:13 -0700)

Retire check-files.

The king penguin said:

It has no point any more, all the tools check the file
status on their own, and yes, the thing should probably be
removed.

and the faithful servant makes it so.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Fix debian doc-baseKalle Valo Wed, 3 Aug 2005 23:39:48 +0000 (02:39 +0300)

[PATCH] Fix debian doc-base

Fixed location of HTML documents in debian doc-base file.

Without this fix debian package won't install properly (complains
about missing /usr/share/doc/git-core/html directory).

jc: thanks, Kalle. I think debian/rules is still broken around
etcdir area, though.

Signed-off-by: Junio C Hamano <junkio@cox.net>

git-send-pack: documentationJunio C Hamano Thu, 4 Aug 2005 00:15:44 +0000 (17:15 -0700)

git-send-pack: documentation

Describe the renaming push. The wording is horrible and I would
appreciate a rewrite, but it is better than nothing ;-).

Signed-off-by: Junio C Hamano <junkio@cox.net>

Renaming push.Junio C Hamano Wed, 3 Aug 2005 23:35:29 +0000 (16:35 -0700)

Renaming push.

This allows git-send-pack to push local refs to a destination
repository under different names.

Here is the name mapping rules for refs.

* If there is no ref mapping on the command line:

- if '--all' is specified, it is equivalent to specifying
<local> ":" <local> for all the existing local refs on the
command line
- otherwise, it is equivalent to specifying <ref> ":" <ref> for
all the refs that exist on both sides.

* <name> is just a shorthand for <name> ":" <name>

* <src> ":" <dst>

push ref that matches <src> to ref that matches <dst>.

- It is an error if <src> does not match exactly one of local
refs.

- It is an error if <dst> matches more than one remote refs.

- If <dst> does not match any remote refs, either

- it has to start with "refs/"; <dst> is used as the
destination literally in this case.

- <src> == <dst> and the ref that matched the <src> must not
exist in the set of remote refs; the ref matched <src>
locally is used as the name of the destination.

For example,

- "git-send-pack --all <remote>" works exactly as before;

- "git-send-pack <remote> master:upstream" pushes local master
to remote ref that matches "upstream". If there is no such
ref, it is an error.

- "git-send-pack <remote> master:refs/heads/upstream" pushes
local master to remote refs/heads/upstream, even when
refs/heads/upstream does not exist.

- "git-send-pack <remote> master" into an empty remote
repository pushes the local ref/heads/master to the remote
ref/heads/master.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Install sample hooksJunio C Hamano Tue, 2 Aug 2005 23:45:21 +0000 (16:45 -0700)

Install sample hooks

A template mechanism to populate newly initialized repository
with default set of files is introduced. Use it to ship example
hooks that can be used for update and post update checks, as
Josef Weidendorfer suggests.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Plug memory leaks in git-unpack-objectsSergey Vlasov Wed, 3 Aug 2005 12:11:00 +0000 (16:11 +0400)

[PATCH] Plug memory leaks in git-unpack-objects

- Call inflateEnd to release zlib state after use.
- After resolving delta, free base object data.

Signed-off-by: Sergey Vlasov <vsu@altlinux.ru>
Signed-off-by: Junio C Hamano <junkio@cox.net>

send-pack: handle partial pushes correctly.Junio C Hamano Wed, 3 Aug 2005 19:41:12 +0000 (12:41 -0700)

send-pack: handle partial pushes correctly.

When pushing into multi-user repository, or when pushing to a
repository from a local repository that has rebased branches
that has been pruned, the destination repository can have head
commits that are missing from the local repository.

This should not matter as long as the local head of the branch
being pushed is a proper superset of the destination branch, but
we ended up trying to run rev-list telling it to exclude objects
reachable from those heads missing from the local repository,
causing it to barf. Prune those heads from the rev-list
parameter list, and make sure we do not try to push a branch
whose remote head is something we lack.

Signed-off-by: Junio C Hamano <junkio@cox.net>

git-send-email-script: minimum whitespace cleanup.Junio C Hamano Mon, 1 Aug 2005 06:05:16 +0000 (23:05 -0700)

git-send-email-script: minimum whitespace cleanup.

Now it is ready to hit the "master" branch, clean up the script
for trailing whitespace and mixture of tabs and spaces.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Doc: update git-send-email-script documentation.Ryan Anderson Wed, 3 Aug 2005 01:45:22 +0000 (21:45 -0400)

[PATCH] Doc: update git-send-email-script documentation.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] git-send-email-script - Fix loops that limit... Ryan Anderson Wed, 3 Aug 2005 01:45:22 +0000 (21:45 -0400)

[PATCH] git-send-email-script - Fix loops that limit emails to unique values to be pedantically correct.

Email addresses aren't generally case sensitive in the real world, but
technically, they *can* be. So, let's do the right thing.

Additionally, fix the generated message-id to have the right template used.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] git-send-email-script - fix 2 small bugs that... Ryan Anderson Mon, 1 Aug 2005 00:04:25 +0000 (20:04 -0400)

[PATCH] git-send-email-script - fix 2 small bugs that snuck through an untested bout of editing.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Make the SMTP server used by git-sendm-email... Ryan Anderson Mon, 1 Aug 2005 00:04:24 +0000 (20:04 -0400)

[PATCH] Make the SMTP server used by git-sendm-email-script configurable on the command line with "--smtp-server"

git-send-email-script | 11 +++++++++--
1 files changed, 9 insertions(+), 2 deletions(-)

a21efe6d21d9f1aca09453ed2a4e2a2ff2d98ce6
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] git-send-email-script: Reformat readline interf... Ryan Anderson Mon, 1 Aug 2005 00:04:24 +0000 (20:04 -0400)

[PATCH] git-send-email-script: Reformat readline interface and generate a better message-id.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add "--chain-reply-to" to git-send-email-script... Ryan Anderson Mon, 1 Aug 2005 00:04:24 +0000 (20:04 -0400)

[PATCH] Add "--chain-reply-to" to git-send-email-script, to control whether or not the

Note, using --no-chain-reply-to means you probably want to put a special
message into the first email you send, i.e, a 0/N patch cover sheet.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Cleanup initial comments, add copyright notices.Ryan Anderson Mon, 1 Aug 2005 00:04:24 +0000 (20:04 -0400)

[PATCH] Cleanup initial comments, add copyright notices.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Convert from using quoted-printable to just... Ryan Anderson Mon, 1 Aug 2005 00:04:24 +0000 (20:04 -0400)

[PATCH] Convert from using quoted-printable to just 8bit encoding on all emails.

(Deleted some spurious comments)

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add new dependencies caused by git-send-email... Ryan Anderson Sun, 31 Jul 2005 08:17:25 +0000 (04:17 -0400)

[PATCH] Add new dependencies caused by git-send-email-script to debian/control

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add documentation for git-send-email-scriptRyan Anderson Sun, 31 Jul 2005 08:17:25 +0000 (04:17 -0400)

[PATCH] Add documentation for git-send-email-script

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add git-send-email-script - tool to send emails... Ryan Anderson Sun, 31 Jul 2005 08:17:25 +0000 (04:17 -0400)

[PATCH] Add git-send-email-script - tool to send emails from git-format-patch-script

This is based off of GregKH's script, send-lots-of-email.pl, and strives to do
all the nice things a good subsystem maintainer does when forwarding a patch or
50 upstream:

All the prior handlers of the patch, as determined by the
Signed-off-by: lines, and/or the author of the commit, are cc:ed on the
email.

All emails are sent as a reply to the previous email, making it easy to
skip a collection of emails that are uninteresting.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Parallelize pulling by sshbarkalow@iabervon.org Tue, 2 Aug 2005 23:46:29 +0000 (19:46 -0400)

[PATCH] Parallelize pulling by ssh

This causes ssh-pull to request objects in prefetch() and read then in
fetch(), such that it reduces the unpipelined round-trip time.

This also makes sha1_write_from_fd() support having a buffer of data
which it accidentally read from the fd after the object; this was
formerly not a problem, because it would always get a short read at
the end of an object, because the next object had not been
requested. This is no longer true.

Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Parallelize the pull algorithmbarkalow@iabervon.org Tue, 2 Aug 2005 23:46:10 +0000 (19:46 -0400)

[PATCH] Parallelize the pull algorithm

This processes objects in two simultaneous passes. Each object will
first be given to prefetch(), as soon as it is possible to tell that
it will be needed, and then will be given to fetch(), when it is the
next object that needs to be parsed. Unless an implementation does
something with prefetch(), this should have no effect.

Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Object library enhancementsbarkalow@iabervon.org Tue, 2 Aug 2005 23:45:48 +0000 (19:45 -0400)

[PATCH] Object library enhancements

Add function to look up an object which is entirely unknown, so that
it can be put in a list. Various other functions related to lists of
objects.

Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Make sure leading directories exist when pushing refs.Junio C Hamano Wed, 3 Aug 2005 01:27:57 +0000 (18:27 -0700)

Make sure leading directories exist when pushing refs.

It does not matter if the only refs you push are directly
underneath heads and tags, but we forgot to make sure we have
leading directories so pushing tags/v0.99/1 would not have
worked.

Signed-off-by: Junio C Hamano <junkio@cox.net>

receive-pack hooks updates.Junio C Hamano Tue, 2 Aug 2005 21:24:22 +0000 (14:24 -0700)

receive-pack hooks updates.

The earlier one conflated update and post-update hooks for no
good reason. Correct that ugly hack. Now post-update hooks
will take the list of successfully updated refs.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Make send-pack --all and explicit ref mutually exclusive.Junio C Hamano Tue, 2 Aug 2005 19:20:27 +0000 (12:20 -0700)

Make send-pack --all and explicit ref mutually exclusive.

send-pack had a confusing misfeature that "send-pack --all
master" updated all refs, while "send-pack --all" did not do
anything. Make --all and explicit refs mutually exclusive, and
make sure "send-pack --all" updates all refs.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] list shortlog items in commit orderNicolas Pitre Tue, 2 Aug 2005 21:18:57 +0000 (17:18 -0400)

[PATCH] list shortlog items in commit order

The current shortlog list is backward making it look odd.
This reverses it so things appear more logically.

[jc: Nico says that this restores the short-log behaviour from
the BK days.]

Signed-off-by: Nicolas Pitre <nico@cam.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Clean t/trash upon "make clean" as well.Junio C Hamano Wed, 3 Aug 2005 00:24:11 +0000 (17:24 -0700)

Clean t/trash upon "make clean" as well.

Signed-off-by: Junio C Hamano <junkio@cox.net>

GIT 0.99.3 v0.99.3Junio C Hamano Mon, 1 Aug 2005 22:19:34 +0000 (15:19 -0700)

GIT 0.99.3

Things have slowly but surely started to settle down, and the
http transport finally can natively grok packed repositories.
To give Pasky a good anchor point, hoping that he can start
split off the core part from Cogito, here is the 0.99.3, which
will be accompanied with its own tag.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] git-merge-cache -q doesn't complain about faili... Petr Baudis Fri, 29 Jul 2005 12:53:38 +0000 (14:53 +0200)

[PATCH] git-merge-cache -q doesn't complain about failing merge program

git-merge-cache reporting failed merge program is undesirable for
Cogito, since it emits its own more appropriate error message in that
case. However, I want to show other possible git-merge-cache error
messages. So -q will just silence this particular error.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Fix sparse warningsLinus Torvalds Mon, 1 Aug 2005 19:11:53 +0000 (12:11 -0700)

[PATCH] Fix sparse warnings

A few sparse warnings have crept in again since I checked last time:
undeclared variables with global scope.

Fix them by marking the private variables properly "static".

Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Do not rely on a sane wcJohannes Schindelin Mon, 1 Aug 2005 14:32:37 +0000 (16:32 +0200)

[PATCH] Do not rely on a sane wc

Some implementations of wc pad the line number with white space, which
expr does not grok as a number.

Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Updates to tutorial.txtJohannes Schindelin Mon, 1 Aug 2005 14:33:19 +0000 (16:33 +0200)

[PATCH] Updates to tutorial.txt

Fix a few typos.
Adapt to git-http-pull not borking on packed repositories.

Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>

CVS-like push-pull description update.Junio C Hamano Mon, 1 Aug 2005 19:33:05 +0000 (12:33 -0700)

CVS-like push-pull description update.

- Yes, push does not lock, but that does not mean it is not
meant for multi-user repository. It just ought to perform
correctly without using locks.

- Let's not pretend we know _the_ right way.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Updates for cvs-migration.txtJohannes Schindelin Mon, 1 Aug 2005 14:32:58 +0000 (16:32 +0200)

[PATCH] Updates for cvs-migration.txt

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Fix warning about non-void return in a void... A Large Angry SCM Mon, 1 Aug 2005 14:05:57 +0000 (10:05 -0400)

[PATCH] Fix warning about non-void return in a void function.

Signed-off-by: A Large Angry SCM <gitzilla@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Retire git-fetch-dumb-http and missing-revsJunio C Hamano Mon, 1 Aug 2005 07:41:49 +0000 (00:41 -0700)

Retire git-fetch-dumb-http and missing-revs

Now git-http-pull knows how to do packed repo, retire scripted
hacks I placed as a stop-gap measure.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Support downloading packs by HTTP (whitespace... barkalow@iabervon.org Mon, 1 Aug 2005 00:54:17 +0000 (20:54 -0400)

[PATCH] Support downloading packs by HTTP (whitespace fixed)

This adds support to http-pull for finding the list of pack files
available on the server, downloading the index files for those pack
files, and downloading pack files when they contain needed objects not
available individually. It retains the index files even if the pack
files were not needed, but downloads the list of pack files once per
run if an object is not found separately.

Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Functions for managing the set of packs the... barkalow@iabervon.org Mon, 1 Aug 2005 00:53:44 +0000 (20:53 -0400)

[PATCH] Functions for managing the set of packs the library is using (whitespace fixed)

This adds support for reading an uninstalled index, and installing a
pack file that was added while the program was running, as well as
functions for determining where to put the file.

Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Added hook in git-receive-packJosef Weidendorfer Sun, 31 Jul 2005 19:17:43 +0000 (21:17 +0200)

[PATCH] Added hook in git-receive-pack

Just before updating a ref,

$GIT_DIR/hooks/update refname old-sha1 new-sha1

is called if executable. The hook can decline the ref to be
updated by exiting with a non-zero status, or allow it to be
updated by exiting with a zero status. The mechanism also
allows e.g sending of a mail with pushed commits on the remote
repository.

Documentation update with an example hook is included.

jc: The credits of the basic idea and initial implementation go
to Josef, but I ended up rewriting major parts of his patch, so
bugs are all mine. Also I changed the semantics for the hook
from his original version (which were post-update hook) so that
the hook can optionally decline to update the ref, and also can
be used to implement the overall cleanups. The latter was
primarily to implement a suggestion from Linus that calling
update-server-info should be made optional.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Fix support for old libcurlbarkalow@iabervon.org Sun, 31 Jul 2005 19:59:20 +0000 (15:59 -0400)

[PATCH] Fix support for old libcurl

Old libcurl has curl_easy_setopt(), and http-pull requires it; it just
doesn't have one of the options.

Signed-off-by: Daniel Barkalow <barkalow@iabervon.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Fix typo in recent Makefile cleanup (again).Junio C Hamano Sun, 31 Jul 2005 19:06:22 +0000 (12:06 -0700)

Fix typo in recent Makefile cleanup (again).

Another instance of $(bin) was missed when it was renamed to
$(bindir).

Signed-off-by: Junio C Hamano <junkio@cox.net>

Teach parse_commit_buffer about grafting.Junio C Hamano Sat, 30 Jul 2005 07:58:28 +0000 (00:58 -0700)

Teach parse_commit_buffer about grafting.

Introduce a new file $GIT_DIR/info/grafts (or $GIT_GRAFT_FILE)
which is a list of "fake commit parent records". Each line of
this file is a commit ID, followed by parent commit IDs, all
40-byte hex SHA1 separated by a single SP in between. The
records override the parent information we would normally read
from the commit objects, allowing both adding "fake" parents
(i.e. grafting), and pretending as if a commit is not a child of
some of its real parents (i.e. cauterizing).

Signed-off-by: Junio C Hamano <junkio@cox.net>

Add a stupid "count objects" script.Junio C Hamano Sun, 31 Jul 2005 00:31:47 +0000 (17:31 -0700)

Add a stupid "count objects" script.

This counts the number of unpacked object files and disk space
consumed by them, to help you decide when it is a good time to
repack.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Fetch from a packed repository on dumb servers.Junio C Hamano Tue, 26 Jul 2005 05:42:18 +0000 (22:42 -0700)

Fetch from a packed repository on dumb servers.

Implement fetching from a packed repository over http/https
using the dumb server support files.

I consider some parts of the logic should be in a separate C
program, but it appears to work with my simple tests. I have
backburnered it for a bit too long for my liking, so let's throw
it out in the open and see what happens.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge with gitk.Junio C Hamano Sun, 31 Jul 2005 17:32:49 +0000 (10:32 -0700)

Merge with gitk.

Fix some bugs causing application error popups.Paul Mackerras Sun, 31 Jul 2005 11:35:21 +0000 (21:35 +1000)

Fix some bugs causing application error popups.

Specifically this should fix the following errors:

wrong # args: should be "startdiff ids" (fix from Junio Hamano)
can't read "filelines(....)": no such element in array
can't unset "treepending": no such variable

[PATCH] add NO_CURL option to the MakefileJohannes Schindelin Sun, 31 Jul 2005 00:14:23 +0000 (02:14 +0200)

[PATCH] add NO_CURL option to the Makefile

This patch implements Linus' idea that if you are not interested in
pulling by HTTP, you can now say

NO_CURL=1 make

to compile everything except git-http-pull (thus not needing curl at all).

Signed-off-by: Junio C Hamano <junkio@cox.net>

Fix merge-base from getting confused.Linus Torvalds Sat, 30 Jul 2005 22:10:20 +0000 (15:10 -0700)

Fix merge-base from getting confused.

On Sat, 30 Jul 2005, Linus Torvalds wrote:
>
> Yup, it's git-merge-base, and it is confused by the same thing that
> confused git-rev-list.

Hmm.. Here's a tentative fix. I'm not really happy with it, and maybe
somebody else can come up with a better one. I think this one ends up
being quite a bit more expensive than the old one (it will look up _all_
common parents that have a child that isn't common, and then select the
newest one of the bunch), but I haven't really thought it through very
much.

Signed-off-by: Linus Torvalds <torvalds@osdl.org>

[PATCH] Making it easier to find which change introduce... Linus Torvalds Sat, 30 Jul 2005 17:08:20 +0000 (10:08 -0700)

[PATCH] Making it easier to find which change introduced a bug

This adds a new "git bisect" command.

- "git bisect start"
start bisection search.

- "git bisect bad <rev>"
mark some version known-bad (if no arguments, then current HEAD)

- "git bisect good <revs>..."
mark some versions known-good (if no arguments, then current HEAD)

- "git bisect reset <branch>"
done with bisection search and go back to your work (if
no arguments, then "master").

The way you use it is:

git bisect start
git bisect bad # Current version is bad
git bisect good v2.6.13-rc2 # v2.6.13-rc2 was the last version
# tested that was good

When you give at least one bad and one good versions, it will
bisect the revision tree and say something like:

Bisecting: 675 revisions left to test after this

and check out the state in the middle. Now, compile that kernel, and boot
it. Now, let's say that this booted kernel works fine, then just do

git bisect good # this one is good

which will now say

Bisecting: 337 revisions left to test after this

and you continue along, compiling that one, testing it, and depending on
whether it is good or bad, you say "git bisect good" or "git bisect bad",
and ask for the next bisection.

Until you have no more left, and you'll have been left with the first bad
kernel rev in "refs/bisect/bad".

Oh, and then after you want to reset to the original head, do a

git bisect reset

to get back to the master branch, instead of being in one of the bisection
branches ("git bisect start" will do that for you too, actually: it will
reset the bisection state, and before it does that it checks that you're
not using some old bisection branch).

Not really any harder than doing series of "quilt push" and "quilt pop",
now is it?

[jc: This patch is a rework based on what Linus posted to the
list. The changes are:

- The original introduced four separate commands, which was
three too many, so I merged them into one with subcommands.

- Since the next thing you would want to do after telling it
"bad" and "good" is always to bisect, this version does it
automatically for you.

- I think the termination condition was wrong. The original
version checked if the set of revisions reachable from next
bisection but not rechable from any of the known good ones
is empty, but if the current bisection was a bad one, this
would not terminate, so I changed it to terminate it when
the set becomes a singleton or empty.

- Removed the use of shell array variable.

]

Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

NO_OPENSSL should really mean no openssl.Junio C Hamano Sat, 30 Jul 2005 05:43:06 +0000 (22:43 -0700)

NO_OPENSSL should really mean no openssl.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Fix typo in recent Makefile cleanup.Junio C Hamano Sat, 30 Jul 2005 01:38:15 +0000 (18:38 -0700)

Fix typo in recent Makefile cleanup.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] document git-rev-list betterMatthias Urlichs Fri, 29 Jul 2005 18:10:46 +0000 (20:10 +0200)

[PATCH] document git-rev-list better

Document new (and not-so-new) flags of git-rev-list.

Signed-off-By: Matthias Urlichs <smurf@smurf.noris.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Build commands through object filesPetr Baudis Fri, 29 Jul 2005 17:21:53 +0000 (19:21 +0200)

[PATCH] Build commands through object files

Separate the process of building the commands to compilation and
linkage. This makes it more consistent with the library objects, is the
traditional thing to do, and significantly speeds up the subsequent
rebuilds, especially for us the people who develop git on 300MHz
notebooks.

Ported from Cogito.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Skip --merge-order test when built with NO_OPENSSLJunio C Hamano Fri, 29 Jul 2005 22:32:43 +0000 (15:32 -0700)

Skip --merge-order test when built with NO_OPENSSL

When built with NO_OPENSSL, rev-list --merge-order does not
work, causing t6001 test to fail. Detect that and skip this
test to allow continuing to the rest of the tests.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Support for NO_OPENSSLPetr Baudis Fri, 29 Jul 2005 15:50:51 +0000 (17:50 +0200)

[PATCH] Support for NO_OPENSSL

Support for completely OpenSSL-less builds. FSF considers distributing GPL
binaries with OpenSSL linked in as a legal problem so this is trouble
e.g. for Debian, or some people might not want to install OpenSSL
anyway. If you

make NO_OPENSSL=1

you get completely OpenSSL-less build, disabling --merge-order and using
Mozilla's SHA1 implementation.

Ported from Cogito.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Reorder Makefile rulesPetr Baudis Fri, 29 Jul 2005 15:50:24 +0000 (17:50 +0200)

[PATCH] Reorder Makefile rules

The Makefile rules were massively reordered so that they are actually
logically grouped now. Captions were added to separate the sections. No
rule contents was touched during the process.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Remove the explicit Makefile dependencies descr... Petr Baudis Fri, 29 Jul 2005 15:48:50 +0000 (17:48 +0200)

[PATCH] Remove the explicit Makefile dependencies description

Remove about one gazillion of explicit dependency rules with few lines
describing the general dependency pattern and then the exceptions. This
noticably shortens the Makefile and makes it easier to touch it.

This is part of the Cogito Makefile changes port.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Improve the compilation-time settings interfacePetr Baudis Fri, 29 Jul 2005 15:48:26 +0000 (17:48 +0200)

[PATCH] Improve the compilation-time settings interface

Describe variables which make itself takes and adjusts compilation
accordingly (MOZILLA_SHA1, NO_OPENSSL, PPC_SHA1), and make adding
defines more convenient through the $DEFINES variable. $COPTS includes
-g as well now and is not overriden if it was already declared in the
environment. Also, $CFLAGS is appended to rather than reset, so that if
there was already a $CFLAGS environment variable, it's appended to. Some
more variables are also made overridable through the environment. Renamed
$bin to $bindir which is the name commonly used for this.

This is part of the Cogito Makefile changes port.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Unify usage strings declarationPetr Baudis Fri, 29 Jul 2005 09:01:26 +0000 (11:01 +0200)

[PATCH] Unify usage strings declaration

All usage strings are now declared as static const char [].

This is carried over from my old git-pb branch.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Trivial tidyupsPetr Baudis Fri, 29 Jul 2005 09:00:45 +0000 (11:00 +0200)

[PATCH] Trivial tidyups

Simple whitespace-related tidyups ensuring style consistency.

This is carried over from my old git-pb branch.

Signed-off-by: Petr Baudis <pasky@ucw.cz>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] mmap error handlingPavel Roskin Fri, 29 Jul 2005 14:49:14 +0000 (10:49 -0400)

[PATCH] mmap error handling

I have reviewed all occurrences of mmap() in git and fixed three types
of errors/defects:

1) The result is not checked.
2) The file descriptor is closed if mmap() succeeds, but not when it
fails.
3) Various casts applied to -1 are used instead of MAP_FAILED, which is
specifically defined to check mmap() return value.

[jc: This is a second round of Pavel's patch. He fixed up the problem
that close() potentially clobbering the errno from mmap, which
the first round had.]

Signed-off-by: Pavel Roskin <proski@gnu.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Documentation and tests: ls-files exclude pattern.Junio C Hamano Fri, 29 Jul 2005 06:53:29 +0000 (23:53 -0700)

Documentation and tests: ls-files exclude pattern.

Update the tests and documentation to match the new "last one
determines its fate" semantics.

Signed-off-by: Junio C Hamano <junkio@cox.net>

ls-files: rework exclude patterns.Junio C Hamano Fri, 29 Jul 2005 06:32:20 +0000 (23:32 -0700)

ls-files: rework exclude patterns.

Pasky and others raised many valid points on the problems
initial exclude pattern enhancement work had. Based on the
list discussion, rework the exclude logic to use "last match
determines its fate" rule, and order the list by exclude-from
(the fallback default pattern file), exclude-per-directory
(shallower to deeper, so deeper ones can override), and then
command line exclude patterns.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Fix interesting git-rev-list corner caseLinus Torvalds Fri, 29 Jul 2005 22:50:30 +0000 (15:50 -0700)

[PATCH] Fix interesting git-rev-list corner case

This corner-case was triggered by a kernel commit that was not in date
order, due to a misconfigured time zone that made the commit appear three
hours older than it was.

That caused git-rev-list to traverse the commit tree in a non-obvious
order, and made it parse several of the _parents_ of the misplaced commit
before it actually parsed the commit itself. That's fine, but it meant
that the grandparents of the commit didn't get marked uninteresting,
because they had been reached through an "interesting" branch.

The reason was that "mark_parents_uninteresting()" (which is supposed to
mark all existing parents as being uninteresting - duh) didn't actually
traverse more than one level down the parent chain.

NORMALLY this is fine, since with the date-based traversal order,
grandparents won't ever even have been looked at before their parents (so
traversing the chain down isn't needed, because the next time around when
we pick out the parent we'll mark _its_ parents uninteresting), but since
we'd gotten out of order, we'd already seen the parent and thus never got
around to mark the grandparents.

Anyway, the fix is simple. Just traverse parent chains recursively.
Normally the chain won't even exist (since the parent hasn't been parsed
yet), so this is not actually going to trigger except in this strange
corner-case.

Add a comment to the simple one-liner, since this was a bit subtle, and I
had to really think things through to understand how it could happen.

Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Tutorial: use a bit longer sample filenames.Junio C Hamano Fri, 29 Jul 2005 05:33:45 +0000 (22:33 -0700)

Tutorial: use a bit longer sample filenames.

Darrin Thompson noticed when he was showing off GIT to others
that the use of filenames "a" and "b" in the tutorial example
was unnecessarily confusing, especially with our "patch -p1"
prefix a/ and b/, without giving us any patch. I was very
tempted to change them back to l/ and k/ prefixes, but decided
to restrain myself and update the tutorial instead ;-).

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] support older versions of libcurlJohannes Schindelin Fri, 29 Jul 2005 02:24:13 +0000 (19:24 -0700)

[PATCH] support older versions of libcurl

Some newer features of libcurl are used which are not strictly necessary
for http-pull. Use them only if libcurl is new enough to know about them.

[jc: I just reworked #ifdef sprinkled all over the code into a
single section that defines a set of macros.]

Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge with gitk.Junio C Hamano Fri, 29 Jul 2005 17:17:37 +0000 (10:17 -0700)

Merge with gitk.

Improve the merge display when the result differs from... Paul Mackerras Fri, 29 Jul 2005 14:23:03 +0000 (09:23 -0500)

Improve the merge display when the result differs from all parents.

Now we see if the result is quite similar to one of the parents, and
if it is, display the result as a diff from that parent. If the result
is similar to more than one parent, pick the one that it's most
similar to.

[PATCH] socklen_t needs to be defined and libssl to... Johannes Schindelin Thu, 28 Jul 2005 14:51:41 +0000 (16:51 +0200)

[PATCH] socklen_t needs to be defined and libssl to be linked on old Mac OS X

On older Mac OS X (10.2.8), no socklen_t is defined, and therefore
daemon.c does not compile. However, Mac OS X 10.4 seems to define
socklen_t differently.

Also, linking fails due to some symbols defined in libssl (not just
libcrypto).

[jc: I am tentatively dropping the socklen_t part of the patch
because I am waiting for confirmation on the server side IPV6
patch from Yoshifuji-san]

Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] support bc version 1.04Johannes Schindelin Thu, 28 Jul 2005 14:48:37 +0000 (16:48 +0200)

[PATCH] support bc version 1.04

Test t6002 unnecessarily fails when bc is a bit older than average.

Signed-off-by: Johannes.Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] remove "-r" option to xargsJohannes Schindelin Thu, 28 Jul 2005 14:48:13 +0000 (16:48 +0200)

[PATCH] remove "-r" option to xargs

git-prune-script still contained that non-portable option.

Signed-off-by: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Signed-off-by: Junio C Hamano <junkio@cox.net>

server-info: do not complain if a tag points at a non... Junio C Hamano Thu, 28 Jul 2005 21:33:17 +0000 (14:33 -0700)

server-info: do not complain if a tag points at a non-commit.

Linux 2.6 tree has one of those tree tags.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Make git-apply --stat less butt-ugly with long... Linus Torvalds Fri, 29 Jul 2005 03:37:23 +0000 (20:37 -0700)

[PATCH] Make git-apply --stat less butt-ugly with long filenames

When git-apply was printing out long filenames, it used to just truncate
them to show the last "max_len" characters of the filename. Which can be
really quite ugly (note the two filenames that have just been silently
truncated from the beginning - it looks even worse when there are lots
of them, like there were in the current v2.6.13-rc4 cris arch update):

Documentation/video4linux/README.saa7134 | 9
Documentation/video4linux/bttv/Cards | 74
umentation/video4linux/hauppauge-wintv-cx88-ir.txt | 54
Documentation/video4linux/lifeview.txt | 42
mentation/video4linux/not-in-cx2388x-datasheet.txt | 41
Documentation/w1/w1.generic | 107

With this patch it now looks like so:

Documentation/video4linux/README.saa7134 | 9
Documentation/video4linux/bttv/Cards | 74
.../video4linux/hauppauge-wintv-cx88-ir.txt | 54
Documentation/video4linux/lifeview.txt | 42
.../video4linux/not-in-cx2388x-datasheet.txt | 41
Documentation/w1/w1.generic | 107

ie we've made it clear with an ellipsis that we've cut off something from
the beginning, and it also tries to do it cleanly at a subdirectory level.

Signed-off-by: Linus "good taste" Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] gitk: Use GIT_DIR where appropriate.Junio C Hamano Thu, 28 Jul 2005 07:28:44 +0000 (00:28 -0700)

[PATCH] gitk: Use GIT_DIR where appropriate.

Some places assumed .git is the GIT_DIR, resulting heads and
tags not showing when it was run like "GIT_DIR=. gitk --all".
This is not a contrived example --- I rely on it to verify
my private copy of git.git repository before pushing it out.

Define a single procedure "gitdir" and use it.

Signed-off-by: Junio C Hamano <junkio@cox.net>
Signed-off-by: Paul Mackerras <paulus@samba.org>

[PATCH] GIT: Listen on IPv6 as well, if available.YOSHIFUJI Hideaki Sat, 23 Jul 2005 08:24:59 +0000 (04:24 -0400)

[PATCH] GIT: Listen on IPv6 as well, if available.

Signed-off-by: Hideaki YOSHIFUJI <yoshfuji@linux-ipv6.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add documentation for git-rename-scriptRyan Anderson Mon, 25 Jul 2005 06:13:11 +0000 (02:13 -0400)

[PATCH] Add documentation for git-rename-script

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add support for directories to git-rename-script.Ryan Anderson Mon, 25 Jul 2005 05:26:47 +0000 (01:26 -0400)

[PATCH] Add support for directories to git-rename-script.

Oh, and in the process, rewrite it in Perl.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Import the --topo-order change and fix the writing... Paul Mackerras Thu, 28 Jul 2005 03:16:51 +0000 (22:16 -0500)

Import the --topo-order change and fix the writing of ~/.gitk.

Display the diffs for a merge in a unified fashion.Paul Mackerras Thu, 28 Jul 2005 03:15:47 +0000 (22:15 -0500)

Display the diffs for a merge in a unified fashion.

Stuff that ended up in the result is shown in bold with a "+" at the
beginning of the line; stuff that didn't is in the normal font with
a "-" at the beginning of the line. The color shows which parent
the stuff was in; red for the first parent, blue for the second, then
green, purple, brown, and the rest are grey. If the result is different
from all of the parents it is shown in black (and bold).

Document --strict flag to the fsck-cache command.Junio C Hamano Thu, 28 Jul 2005 01:55:18 +0000 (18:55 -0700)

Document --strict flag to the fsck-cache command.

Signed-off-by: Junio C Hamano <junkio@cox.net>

git-fsck-cache: be stricter about "tree" objectsLinus Torvalds Wed, 27 Jul 2005 23:08:43 +0000 (16:08 -0700)

git-fsck-cache: be stricter about "tree" objects

In particular, warn about things like zero-padding of the mode bits,
which is a big no-no, since it makes otherwise identical trees have
different representations (and thus different SHA1 numbers).

Also make the warnings more regular.

Signed-off-by: Linus Torvalds <torvalds@osdl.org>

git-convert-cache: fix up mode conversionLinus Torvalds Wed, 27 Jul 2005 22:29:38 +0000 (15:29 -0700)

git-convert-cache: fix up mode conversion

The old mode conversion was not only complex, it also refused to change
the length of a mode, which made it fragile. By moving the mode
conversion around a bit, we can not only simplify it, it also ends up
being more powerful.

Also fix a memory leak that made it impossible to convert huge archives
without tons and tons of memory.

Signed-off-by: Linus Torvalds <torvalds@osdl.org>

git-fsck-cache.c: check commit objects more carefullyLinus Torvalds Wed, 27 Jul 2005 22:16:03 +0000 (15:16 -0700)

git-fsck-cache.c: check commit objects more carefully

We historically used to be very careful in fsck-cache, but when it was
re-written to use "parse_object()" instead of parsing everything by
hand, it lost a bit of the checks. This, together with the previous
commit, should make it do more proper commit object syntax checks.

Also add a "--strict" flag, which warns about the old-style "0664" file
mode bits, which shouldn't exist in modern trees, but that happened
early on in git trees and that the default git-fsck-cache thus silently
accepts.

Signed-off-by: Linus Torvalds <torvalds@osdl.org>

Make "parse_commit()" be a lot more carefulLinus Torvalds Wed, 27 Jul 2005 22:12:48 +0000 (15:12 -0700)

Make "parse_commit()" be a lot more careful

This was brought on by a bad tree of Thomas Gleixner, where some bogus
commit objects weren't warned about properly

Signed-off-by: Linus Torvalds <torvalds@osdl.org>

Tutorial typofix.Linus Torvalds Wed, 27 Jul 2005 03:04:22 +0000 (20:04 -0700)

Tutorial typofix.

Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Typofix: usage strings fix.Junio C Hamano Wed, 27 Jul 2005 07:04:16 +0000 (00:04 -0700)

Typofix: usage strings fix.

The *_usage strings should not start with "usage: ", since the
usage() function gives its own.

Signed-off-by: Junio C Hamano <junkio@cox.net>

git-log: make sure we have some commit to start from.Linus Torvalds Wed, 27 Jul 2005 03:04:22 +0000 (20:04 -0700)

git-log: make sure we have some commit to start from.

When no usable head/tag is specified, git log barfed with
underlying error message from rev-list, which was not helpful.

Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

request-pull: minor tweaks.Junio C Hamano Tue, 26 Jul 2005 18:47:31 +0000 (11:47 -0700)

request-pull: minor tweaks.

- use --verify to make sure rev param is a rev, and barf otherwise.
- make it always output to stdout; no funny business with tee.
- take optional branch head name to specify which branch to summarize.
- show baserev in a human readable way.
- do not depend on diffstat; use git-apply --stat instead.

Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add git-request-pull-script, a short script... Ryan Anderson Tue, 26 Jul 2005 07:30:36 +0000 (03:30 -0400)

[PATCH] Add git-request-pull-script, a short script that generates a summary of pending changes

A short message requesting a pull from the repository is also included.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] git-status-script was missed during the convers... Ryan Anderson Wed, 27 Jul 2005 08:36:08 +0000 (04:36 -0400)

[PATCH] git-status-script was missed during the conversion from N -> A

git-status-script was missed during the conversion from "N" to "A" as
the new-file marker flag.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Deb Packaging fixes: Build against Mozilla libs for... Ryan Anderson Sat, 23 Jul 2005 19:26:32 +0000 (15:26 -0400)

Deb Packaging fixes: Build against Mozilla libs for Debian, conflict with "git"

This patch includes two fixes to the git-core Debian package:

* Conflict with the GNU Interactive Tools package, which _also_
wants to install /usr/bin/git.

* Compile against the unencumbered Mozilla SHA1 code, instead of
the iffy OpenSSL code, as much as possible. This makes it easier to get
the package included for distribution with Debian.

This has been based upon the original patch by Sebastian Kuzminsky
<seb@highlab.com>, but has been fixed up based upon feedback.

Signed-off-by: Ryan Anderson <ryan@michonline.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Fix potential send-pack SIGSEGVLinus Torvalds Wed, 27 Jul 2005 03:04:22 +0000 (20:04 -0700)

Fix potential send-pack SIGSEGV

The check that the source is ahead of the destination incorrectly expects
pop_most_recent_commit() to gracefully handle an empty list.

Fix by just checking the list itself, rather than the return value of the
pop function.

[jc: I did the test script that demonstrated the problem]

Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Name it 0.99.2 v0.99.2Junio C Hamano Wed, 27 Jul 2005 00:21:16 +0000 (17:21 -0700)

Name it 0.99.2

Signed-off-by: Junio C Hamano <junkio@cox.net>

Adjust diff-raw tests to the status letter change.Junio C Hamano Tue, 26 Jul 2005 07:22:43 +0000 (00:22 -0700)

Adjust diff-raw tests to the status letter change.

We use 'A' for added files instead of 'N' to make the it
visually easier to distinguish from 'M' now.

While we are at it, make the test scripts executable. Yes, I
know it does not matter because t/Makefile runs them explicitly
with "sh tXXXX-blah.sh", but being consistent is always better.

Signed-off-by: Junio C Hamano <junkio@cox.net>

diff-raw: Use 'A' instead of 'N' for added files.Junio C Hamano Mon, 25 Jul 2005 21:31:19 +0000 (14:31 -0700)

diff-raw: Use 'A' instead of 'N' for added files.

This actually changes the diff-raw status letter from N to A
for added files.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Use symbolic constants for diff-raw status indicators.Junio C Hamano Mon, 25 Jul 2005 20:05:44 +0000 (13:05 -0700)

Use symbolic constants for diff-raw status indicators.

Both Cogito and StGIT prefer to see 'A' for new files. The
current 'N' is visually harder to distinguish from 'M', which is
used for modified files. Prepare the internals to use symbolic
constants to make the change easier.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Documentation: describe git-ls-files --exclude patterns.Junio C Hamano Sun, 24 Jul 2005 22:47:26 +0000 (15:47 -0700)

Documentation: describe git-ls-files --exclude patterns.

Signed-off-by: Junio C Hamano <junkio@cox.net>

git-ls-files: --exclude mechanism updates.Junio C Hamano Sun, 24 Jul 2005 22:26:09 +0000 (15:26 -0700)

git-ls-files: --exclude mechanism updates.

Add --exclude-per-directory=<name> option that specifies a file
to contain exclude patterns local to that directory and its
subdirectories. Update the exclusion logic to be able to say
"include files that match this more specific pattern, even
though later exclude patterns may match them". Also enhances
that a pattern can contain '/' in which case fnmatch is called
with FNM_PATHNAME flag to match the entire path.

Signed-off-by: Junio C Hamano <junkio@cox.net>

Update the documentation for git-tag-script to reflect... Ryan Anderson Mon, 25 Jul 2005 06:17:16 +0000 (02:17 -0400)

Update the documentation for git-tag-script to reflect current behavior.

[jc: I updated Ryan's patch to mention -a to create an unsigned
tag.]

Signed-off-by: Ryan Anderson <ryan@michonline.com>

git-tag-script updates.Junio C Hamano Mon, 25 Jul 2005 22:18:35 +0000 (15:18 -0700)

git-tag-script updates.

This adds -a (annotate only but not sign) option "A Large Angry
SCM" <gitzilla@gmail.com> sent to the list, after fixing up the
whitespace corruption in the patch, with some of my own fixes.
Namely:

* A new flag '-a' can be used to create an unsigned tag
object;

* The '-f' flag logic did not do the right thing;

* When creating a signed tag, we did not check for GPG failure
as we should;

* Try to use the key for the tagger identity when signing the
tag.

Signed-off-by: Junio C Hamano <junkio@cox.net>