gitweb.git
Merge branch 'lt/web'Junio C Hamano Sun, 1 Oct 2006 04:27:51 +0000 (21:27 -0700)

Merge branch 'lt/web'

* lt/web:
gitweb: tree view: hash_base and hash are now context sensitive
gitweb: History: blob and tree are first, then commitdiff, etc
gitweb: Remove redundant "commit" from history
gitweb: Don't use quotemeta on internally generated strings
gitweb: Add snapshot to shortlog
gitweb: Factor out gitweb_have_snapshot()
gitweb: Remove redundant "commit" link from shortlog
gitweb: "alternate" starts with shade (i.e. 1)
gitweb: Add history and blame to git_difftree_body()
gitweb: Remove excessively redundant entries from git_difftree_body
Revert "gitweb: extend blame to show links to diff and previous"
gitweb: Quote filename in HTTP Content-Disposition: header
gitweb: Add git_url subroutine, and use it to quote full URLs
gitweb: Split validate_input into validate_pathname and validate_refname
gitweb: Use "return" instead of "return undef" for some subs
gitweb: Strip trailing slashes from $path in git_get_hash_by_path
gitweb: extend blame to show links to diff and previous
gitweb: Remove redundant "tree" link
gitweb: tree view: eliminate redundant "blob"

git-branch: remove D/F check done by hand.Junio C Hamano Sat, 30 Sep 2006 22:21:28 +0000 (15:21 -0700)

git-branch: remove D/F check done by hand.

Now ref creation codepath in lock_ref_sha1() and friends notices
the directory/file conflict situation, we do not do this by hand
in git-branch anymore.

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

delete_ref(): delete packed refJunio C Hamano Sat, 30 Sep 2006 22:02:00 +0000 (15:02 -0700)

delete_ref(): delete packed ref

This implements deletion of a packed ref. Since it is a very
rare event to delete a ref compared to looking up, creating and
updating, this opts to remove the ref from the packed-ref file
instead of doing any of the filesystem based "negative ref" trick
to optimize the deletion path.

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

lock_ref_sha1(): check D/F conflict with packed ref... Junio C Hamano Sat, 30 Sep 2006 21:19:25 +0000 (14:19 -0700)

lock_ref_sha1(): check D/F conflict with packed ref when creating.

This makes the ref locking codepath to notice if an existing ref
overlaps with the ref we are creating.

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

lock_ref_sha1(): do not sometimes error() and sometimes... Junio C Hamano Sat, 30 Sep 2006 21:14:31 +0000 (14:14 -0700)

lock_ref_sha1(): do not sometimes error() and sometimes die().

This cleans up the error path in the function so it does not
die() itself sometimes while signalling an error with NULL some
other times which was inconsistent and confusing.

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

refs: minor restructuring of cached refs data.Junio C Hamano Sat, 30 Sep 2006 19:37:37 +0000 (12:37 -0700)

refs: minor restructuring of cached refs data.

Once we read packed and loose refs, for_each_ref() and friends
kept using them even after write_ref_sha1() and delete_ref()
changed the refs. This adds invalidate_cached_refs() as a way
to flush the cached information.

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

ref locking: allow 'foo' when 'foo/bar' used to exist... Junio C Hamano Sat, 30 Sep 2006 09:25:30 +0000 (02:25 -0700)

ref locking: allow 'foo' when 'foo/bar' used to exist but not anymore.

It is normal to have .git/refs/heads/foo directory which is
empty after the last branch whose name starts with foo/ is
removed. Make sure we notice this case and allow creation of
branch foo by removing the empty directory.

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

gitweb: tree view: hash_base and hash are now context... Luben Tuikov Fri, 29 Sep 2006 16:57:43 +0000 (09:57 -0700)

gitweb: tree view: hash_base and hash are now context sensitive

In tree view, by default, hash_base is HEAD and hash is the
entry equivalent. Else the user had selected a hash_base or
hash, say by clicking on a revision or commit, in which case
those values are used.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

git-diff -B output fix. v1.4.2.2Junio C Hamano Fri, 29 Sep 2006 09:06:24 +0000 (02:06 -0700)

git-diff -B output fix.

Geert noticed that complete rewrite diff missed the usual a/ and b/
leading paths. Pickaxe says it never worked, ever.

Embarrassing.

Signed-off-by: Junio C Hamano <junkio@cox.net>
(cherry picked from bc1a5807575b2f34538d4158834da6524a4fc1f7 commit)

git-diff/git-apply: make diff output a bit friendlier... Junio C Hamano Fri, 22 Sep 2006 23:17:58 +0000 (16:17 -0700)

git-diff/git-apply: make diff output a bit friendlier to GNU patch (part 1)

Somebody was wondering on #git channel why a git generated diff
does not apply with GNU patch when the filename contains a SP.
It is because GNU patch expects to find TAB (and trailing timestamp)
on ---/+++ (old_name and new_name) lines after the filenames.

The "diff --git" output format was carefully designed to be
compatible with GNU patch where it can, but whitespace
characters were always a pain.

We can make our output a bit more GNU patch friendly by adding an
extra TAB (but not trailing timestamp) to old/new name lines when
the filename as a SP in it. This updates git-apply to prepare
ourselves to accept such a patch, but we still do not generate
output that is patch friendly yet. That change needs to wait
until everybody has this change.

When a filename contains a real tab, "diff --git" format
always c-quotes it as discussed on the list with GNU patch
maintainer previously:

http://marc.theaimsgroup.com/?l=git&m=112927316408690&w=2

so there should be no downside.

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

fetch: Reset remote refs list each time fetch_main... Santi Béjar Fri, 29 Sep 2006 18:05:40 +0000 (20:05 +0200)

fetch: Reset remote refs list each time fetch_main is called

This prevents the fetch of the heads again in the second call of fetch_main.

Signed-off-by: Santi Béjar <sbejar@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Remove -fPIC which was only needed for Git.xsJunio C Hamano Fri, 29 Sep 2006 07:34:51 +0000 (00:34 -0700)

Remove -fPIC which was only needed for Git.xs

The distinction between BASIC_ vs ALL_ is still kept, since it
is not Git.xs specific -- we could face the same issue when we
do other language bindings (e.g. Python).

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

Fix approxidate() to understand 12:34 AM/PM are 00... Linus Torvalds Fri, 29 Sep 2006 19:36:13 +0000 (12:36 -0700)

Fix approxidate() to understand 12:34 AM/PM are 00:34 and 12:34

It just simplifies the whole thing to say

"hour = (hour % 12) + X"

where X is 12 for PM and 0 for AM.

It also fixes the "exact date" parsing, which didn't parse AM at all, and
as such would do the same "12:30 AM" means "12:30 24-hour-format" bug. Of
course, I hope that no exact dates use AM/PM anyway, but since we support
the PM format, let's just get it right.

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

git-diff -B output fix.Junio C Hamano Fri, 29 Sep 2006 09:06:24 +0000 (02:06 -0700)

git-diff -B output fix.

Geert noticed that complete rewrite diff missed the usual a/ and b/
leading paths. Pickaxe says it never worked, ever.

Embarrassing.

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

Make cvsexportcommit remove files.Robin Rosenberg Thu, 28 Sep 2006 23:28:55 +0000 (01:28 +0200)

Make cvsexportcommit remove files.

Signed-off-by: Robin Rosenberg <robin.rosenberg@dewire.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

diff --stat: ensure at least one '-' for deletions... Johannes Schindelin Thu, 28 Sep 2006 15:37:39 +0000 (17:37 +0200)

diff --stat: ensure at least one '-' for deletions, and one '+' for additions

The number of '-' and '+' is still linear. The idea is that
scaled-length := floor(a * length + b) with the following constraints: if
length == 1, scaled-length == 1, and the combined length of plusses
and minusses should not be larger than the width by a small margin. Thus,

a + b == 1

and
a * max_plusses + b + a * max_minusses + b = width + 1

The solution is

a * x + b = ((width - 1) * (x - 1) + max_change - 1)
/ (max_change - 1)

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

diff --stat=width[,name-width]: allow custom diffstat... Linus Torvalds Thu, 28 Sep 2006 22:07:16 +0000 (15:07 -0700)

diff --stat=width[,name-width]: allow custom diffstat output width.

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

gitweb: History: blob and tree are first, then commitdi... Luben Tuikov Fri, 29 Sep 2006 00:21:07 +0000 (17:21 -0700)

gitweb: History: blob and tree are first, then commitdiff, etc

Reorder link display in history to be consistent with other
list displays: log, shortlog, etc. We now display:

blob | commitdiff
blob | commitdiff | diff_to_current

and

tree | commitdiff

Instead of the old history format where "blob" and "tree"
are between "commitdiff" and "diff_to_current" if present/
applicable.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Remove redundant "commit" from historyLuben Tuikov Fri, 29 Sep 2006 00:20:23 +0000 (17:20 -0700)

gitweb: Remove redundant "commit" from history

Remove redundant "commit" from history -- it can be had
by clicking on the title of the commit. This commit
makes visualization consistent with shortlog, log, etc.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

http/ftp: optionally ask curl to not use EPSV commandSasha Khapyorsky Fri, 29 Sep 2006 00:10:44 +0000 (03:10 +0300)

http/ftp: optionally ask curl to not use EPSV command

If http.noEPSV config variable is defined and true, or if
GIT_CURL_FTP_NO_EPSV environment variable is defined, disable using
of EPSV ftp command (PASV will be used instead). This is helpful with
some "poor" ftp servers which does not support EPSV mode.

Signed-off-by: Sasha Khapyorsky <sashak@voltaire.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Don't use quotemeta on internally generated... Luben Tuikov Thu, 28 Sep 2006 23:51:43 +0000 (16:51 -0700)

gitweb: Don't use quotemeta on internally generated strings

Do not use quotemeta on internally generated strings
such as filenames of snapshot, blobs, etc.
quotemeta quotes any characters not matching /A-Za-z_0-9/.
Which means that we get strings like this:

before: linux\-2\.6\.git\-5c2d97cb31fb77981797fec46230ca005b865799\.tar\.gz
after: linux-2.6.git-5c2d97cb31fb77981797fec46230ca005b865799.tar.gz

This patch fixes this.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Add snapshot to shortlogLuben Tuikov Thu, 28 Sep 2006 23:50:09 +0000 (16:50 -0700)

gitweb: Add snapshot to shortlog

Add snapshot to each commit-row of shortlog.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Factor out gitweb_have_snapshot()Luben Tuikov Thu, 28 Sep 2006 23:49:21 +0000 (16:49 -0700)

gitweb: Factor out gitweb_have_snapshot()

Create gitweb_have_snapshot() which returns true
of snapshot is available and enabled, else false.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Remove redundant "commit" link from shortlogLuben Tuikov Thu, 28 Sep 2006 23:48:40 +0000 (16:48 -0700)

gitweb: Remove redundant "commit" link from shortlog

Remove the redundant "commit" link from shortlog.
It can be had by simply clicking on the entry title
of the row.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: "alternate" starts with shade (i.e. 1)Luben Tuikov Thu, 28 Sep 2006 23:47:50 +0000 (16:47 -0700)

gitweb: "alternate" starts with shade (i.e. 1)

When displaying a list of rows (difftree, shortlog, etc),
the first entry is now printed shaded, i.e. alternate is
initialized to 1, as opposed to non-shaded (alternate
initialized to 0).

This solves the problem when there is only one row to
display -- it is displayed shaded to visually indicate that
it is "active", part of a "list", etc.

(Compare this to the trivial case of more than one entry,
where the rows have alternating shade, thus suggesting
being part of a "list" of "active" entries, etc.)

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

git-format-patch: fix bug using -o in subdirectoriesMatthias Lederhofer Thu, 28 Sep 2006 19:55:35 +0000 (21:55 +0200)

git-format-patch: fix bug using -o in subdirectories

This was introduced by me in commit v1.4.2.1-gc08e524.

Signed-off-by: Matthias Lederhofer <matled@gmx.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

do not discard constness in interp_set_entry value... Alex Riesen Thu, 28 Sep 2006 19:12:55 +0000 (21:12 +0200)

do not discard constness in interp_set_entry value argument

Signed-off-by: Alex Riesen <raa.lkml@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Fix approxidate() to understand more extended numbersLinus Torvalds Thu, 28 Sep 2006 19:14:27 +0000 (12:14 -0700)

Fix approxidate() to understand more extended numbers

You can now say "5:35 PM yesterday", and approxidate() gets the right answer.

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

Clean up approxidate() in preparation for fixesLinus Torvalds Thu, 28 Sep 2006 19:12:28 +0000 (12:12 -0700)

Clean up approxidate() in preparation for fixes

Our approxidate cannot handle simple times like "5 PM yesterday", and to
fix that, we will need to add some logic for number handling. This just
splits that out into a function of its own (the same way the _real_ date
parsing works).

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

fix daemon.c compilation for NO_IPV6=1Alex Riesen Thu, 28 Sep 2006 18:48:14 +0000 (20:48 +0200)

fix daemon.c compilation for NO_IPV6=1

Signed-off-by: Alex Riesen <raa.lkml@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

daemon: default to 256 for HOST_NAME_MAX if it is not... Johannes Schindelin Thu, 28 Sep 2006 10:00:35 +0000 (12:00 +0200)

daemon: default to 256 for HOST_NAME_MAX if it is not defined

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

format-patch: use cwd as default output directoryMatthias Lederhofer Fri, 22 Sep 2006 11:12:01 +0000 (13:12 +0200)

format-patch: use cwd as default output directory

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

svnimport: add support for parsing From: lines for... Andy Whitcroft Mon, 25 Sep 2006 11:08:13 +0000 (12:08 +0100)

svnimport: add support for parsing From: lines for author

When commiting a non-signed off contribution you cannot just add
a Signed-off-by: from the author as they did not sign it off.
But if you then commit it, and necessarily sign it off yourself,
the change appears to be yours. In this case it is common to use
the following form:

Commentry

From: originator <email>
Signed-of-by: me <my email>
Now that we have support for parsing Signed-off-by: for author
information it makes sense to handle From: as well. This patch
adds a new -F which will handle From: lines in the comments. It
may be used in combination with -S.

Signed-off-by: Andy Whitcroft <apw@shadowen.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Contributed bash completion support for core Git tools.Junio C Hamano Thu, 28 Sep 2006 09:31:25 +0000 (02:31 -0700)

Contributed bash completion support for core Git tools.

This is a set of bash completion routines for many of the
popular core Git tools. I wrote these routines from scratch
after reading the git-compl and git-compl-lib routines available
from the gitcompletion package at http://gitweb.hawaga.org.uk/
and found those to be lacking in functionality for some commands.
Consequently there may be some similarities but many differences.

Since these are completion routines only for tools shipped with
core Git and since bash is a popular shell on many of the native
core Git platforms (Linux, Mac OS X, Solaris, BSD) including these
routines as part of the stock package would probably be convienent
for many users.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

teach revision walker about --all-match.Junio C Hamano Thu, 28 Sep 2006 00:55:58 +0000 (17:55 -0700)

teach revision walker about --all-match.

This lets you say:

git log --all-match --author=Linus --committer=Junio --grep=rev-list

to limit commits that was written by Linus, committed by me and
the log message contains word "rev-list".

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

grep --all-matchJunio C Hamano Thu, 28 Sep 2006 00:50:52 +0000 (17:50 -0700)

grep --all-match

This lets you say:

git grep --all-match -e A -e B -e C

to find lines that match A or B or C but limit the matches from
the files that have all of A, B and C.

This is different from

git grep -e A --and -e B --and -e C

in that the latter looks for a single line that has all of these
at the same time.

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

Merge branch 'jl/virtual'Junio C Hamano Thu, 28 Sep 2006 06:56:55 +0000 (23:56 -0700)

Merge branch 'jl/virtual'

* jl/virtual:
Removed memory leaks from interpolation table uses.
Cleaned up git-daemon virtual hosting support.

Uncomment test case: git branch c/d should barf if... Christian Couder Thu, 28 Sep 2006 05:02:00 +0000 (07:02 +0200)

Uncomment test case: git branch c/d should barf if branch c exists.

Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

When creating branch c/d check that branch c does not... Christian Couder Thu, 28 Sep 2006 05:00:38 +0000 (07:00 +0200)

When creating branch c/d check that branch c does not already exists.

With packed refs, there may not be a ".git/refs/heads/c" file
when branch c exists. And currently in this case, there is no check
to prevent creation of branch c/d.

This should probably be rewritten in C and done after the ref lock
has been taken to make sure no race exists though.

This is mainly to make all test cases in "t3210-pack-refs.sh" work.

Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Add pack-refs and show-ref test cases.Christian Couder Thu, 28 Sep 2006 04:58:03 +0000 (06:58 +0200)

Add pack-refs and show-ref test cases.

Some of these test cases are from Junio.
One test case is commented out because it doesn't work right now.

Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge branch 'master' into lj/refsJunio C Hamano Thu, 28 Sep 2006 05:23:12 +0000 (22:23 -0700)

Merge branch 'master' into lj/refs

* master: (72 commits)
runstatus: do not recurse into subdirectories if not needed
grep: fix --fixed-strings combined with expression.
grep: free expressions and patterns when done.
Corrected copy-and-paste thinko in ignore executable bit test case.
An illustration of rev-list --parents --pretty=raw
Allow git-checkout when on a non-existant branch.
gitweb: Decode long title for link tooltips
git-svn: Fix fetch --no-ignore-externals with GIT_SVN_NO_LIB=1
Ignore executable bit when adding files if filemode=0.
Remove empty ref directories that prevent creating a ref.
Use const for interpolate arguments
git-archive: update documentation
Deprecate merge-recursive.py
gitweb: fix over-eager application of esc_html().
Allow '(no author)' in git-svn's authors file.
Allow 'svn fetch' on '(no date)' revisions in Subversion.
git-repack: allow git-repack to run in subdirectory
Remove upload-tar and make git-tar-tree a thin wrapper to git-archive
git-tar-tree: Move code for git-archive --format=tar to archive-tar.c
git-tar-tree: Remove duplicate git_config() call
...

Merge branch 'cc/branch-test'Junio C Hamano Thu, 28 Sep 2006 05:17:01 +0000 (22:17 -0700)

Merge branch 'cc/branch-test'

* cc/branch-test:
Remove empty ref directories that prevent creating a ref.

Merge branch 'jc/for-each-ref' into jc/ref-lockingJunio C Hamano Thu, 28 Sep 2006 05:00:54 +0000 (22:00 -0700)

Merge branch 'jc/for-each-ref' into jc/ref-locking

* jc/for-each-ref:
git-for-each-ref: improve the documentation on scripting modes

gitweb: Add history and blame to git_difftree_body()Luben Tuikov Thu, 28 Sep 2006 00:24:49 +0000 (17:24 -0700)

gitweb: Add history and blame to git_difftree_body()

Add blame and history to Deleted files.
Add blame and history to Modified or Type changed files.
Add blame and history to Renamed or Copied files.

This allows us to do
blame->commit->blame->commit->blame->...
instead of
blame->commit->file->blame->commit->file->blame->...
which is longer and easier to get wrong.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge branch 'sp/void'Junio C Hamano Thu, 28 Sep 2006 04:51:29 +0000 (21:51 -0700)

Merge branch 'sp/void'

* sp/void:
Allow git-checkout when on a non-existant branch.

Merge branch 'jc/whitespace'Junio C Hamano Thu, 28 Sep 2006 04:50:42 +0000 (21:50 -0700)

Merge branch 'jc/whitespace'

* jc/whitespace:
git-apply: second war on whitespace.
diff.c: second war on whitespace.

Merge branch 'jc/repack'Junio C Hamano Thu, 28 Sep 2006 04:46:07 +0000 (21:46 -0700)

Merge branch 'jc/repack'

* jc/repack:
git-repack: allow git-repack to run in subdirectory
repack: use only pack-objects, not rev-list.

Merge branch 'jc/deprecate-recursive'Junio C Hamano Thu, 28 Sep 2006 04:41:24 +0000 (21:41 -0700)

Merge branch 'jc/deprecate-recursive'

* jc/deprecate-recursive:
Deprecate merge-recursive.py

runstatus: do not recurse into subdirectories if not... Johannes Schindelin Thu, 28 Sep 2006 00:44:30 +0000 (02:44 +0200)

runstatus: do not recurse into subdirectories if not needed

This speeds up the case when you run git-status, having an untracked
subdirectory containing huge amounts of files.

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

gitweb: Remove excessively redundant entries from git_d... Luben Tuikov Thu, 28 Sep 2006 00:23:25 +0000 (17:23 -0700)

gitweb: Remove excessively redundant entries from git_difftree_body

1) All entries on the left are blobs and clicking on them
leads to blobs. No more diff or blob depending on what
happened (modified or mode changed) to the file -- this goes
to the right, in the "link" column.

2) Remove redundant "blob" from the link column on the right.
This can now be had by clicking on the entry itself.

This reduces and simplifies the code.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Revert "gitweb: extend blame to show links to diff... Luben Tuikov Thu, 28 Sep 2006 00:22:03 +0000 (17:22 -0700)

Revert "gitweb: extend blame to show links to diff and previous"

This concept is very fine, but it makes blame slow
across renames and across branches, so revert it.
There is a better way to do this.

This reverts commit 03d06a8e26f4fbd37800d1e1125c6ecf4c104466.

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

Removed memory leaks from interpolation table uses.Jon Loeliger Wed, 27 Sep 2006 16:16:10 +0000 (11:16 -0500)

Removed memory leaks from interpolation table uses.

Clarified that parse_extra_args()s results in interpolation
table entries. Removed a few trailing whitespace occurrences.

Signed-off-by: Jon Loeliger <jdl@jdl.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Cleaned up git-daemon virtual hosting support.Jon Loeliger Tue, 26 Sep 2006 14:47:43 +0000 (09:47 -0500)

Cleaned up git-daemon virtual hosting support.

Standardized on lowercase hostnames from client.

Added interpolation values for the IP address, port and
canonical hostname of the server as it is contacted and
named by the client and passed in via the extended args.

Added --listen=host_or_ipaddr option suport. Renamed port
variable as "listen_port" correspondingly as well.

Documented mutual exclusivity of --inetd option with
--user, --group, --listen and --port options.

Added compat/inet_pton.c from Paul Vixie as needed.

Small memory leaks need to be cleaned up still.

Signed-off-by: Jon Loeliger <jdl@jdl.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

grep: fix --fixed-strings combined with expression.Junio C Hamano Wed, 27 Sep 2006 23:42:53 +0000 (16:42 -0700)

grep: fix --fixed-strings combined with expression.

"git grep --fixed-strings -e GIT --and -e VERSION .gitignore"
misbehaved because we did not notice this needs to grab lines
that have the given two fixed strings at the same time.

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

grep: free expressions and patterns when done.Junio C Hamano Wed, 27 Sep 2006 23:27:10 +0000 (16:27 -0700)

grep: free expressions and patterns when done.

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

receive-pack: call setup_ident before git_configJunio C Hamano Wed, 27 Sep 2006 20:47:21 +0000 (13:47 -0700)

receive-pack: call setup_ident before git_config

Otherwise we would end up getting values from Gecos which is often not
what people would want.

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

allow delta data reuse even if base object is a preferr... Nicolas Pitre Wed, 27 Sep 2006 19:42:16 +0000 (15:42 -0400)

allow delta data reuse even if base object is a preferred base

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

Corrected copy-and-paste thinko in ignore executable... Shawn Pearce Wed, 27 Sep 2006 15:18:49 +0000 (11:18 -0400)

Corrected copy-and-paste thinko in ignore executable bit test case.

This test should be testing update-index --add, not git-add as the
latter is implemented in terms of the former.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

zap a debug remnantNicolas Pitre Wed, 27 Sep 2006 19:30:21 +0000 (15:30 -0400)

zap a debug remnant

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

An illustration of rev-list --parents --pretty=rawJunio C Hamano Wed, 27 Sep 2006 19:34:37 +0000 (12:34 -0700)

An illustration of rev-list --parents --pretty=raw

This script creates two separate histories, A and B, each of
which does:

(A0, B0): create fileA and subdir/fileB
(A1, B1): modify fileA
(A2, B2): modify subdir/fileB

and then grafts them together to make B0 a child of A2. So
the final history looks like (time flows from top to bottom):

true parent touches subdir?

A0 none yes (creates it)
A1 A0 no
A2 A1 yes
B0 none yes (different from what's in A2)
B1 B0 no
B2 B1 yes

"git rev-list --parents --pretty=raw B2" would give "fake"
parents on the "commit " header lines while "parent " header
lines show the parent as recorded in the commit object (i.e. B0
appears to have A2 as its parent on "commit " header but there
is no "parent A2" header line in it).

When you have path limiters, we simplify history to omit
commits that do not affect the specified paths.

So "git rev-list --parents --pretty=raw B2 subdir" would return
"B2 B0 A2 A0" (because B1 and A1 do not touch the path). When
it does so, the "commit " header lines have "fake" parents
(i.e. B2 appears to have B0 as its parent on "commit " header),
but you can still get the true parents by looking at "parent "
header.

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

diff --stat: color output.Junio C Hamano Wed, 27 Sep 2006 01:59:41 +0000 (18:59 -0700)

diff --stat: color output.

Under --color option, diffstat shows '+' and '-' in the graph
the same color as added and deleted lines.

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

diff --stat: allow custom diffstat output width.Junio C Hamano Wed, 27 Sep 2006 01:53:02 +0000 (18:53 -0700)

diff --stat: allow custom diffstat output width.

This adds two parameters to "diff --stat".

. --stat-width=72 tells that the page should fit on 72-column output.

. --stat-name-width=30 tells that the filename part is limited
to 30 columns.

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

Teach receive-pack about ref-logJunio C Hamano Wed, 27 Sep 2006 09:40:06 +0000 (02:40 -0700)

Teach receive-pack about ref-log

This converts receive-pack to use the standard ref locking code
instead of its own. As a side effect, it automatically records
the "push" event to ref-log if enabled.

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

update a few Porcelain-ish for ref lock safety.Junio C Hamano Wed, 27 Sep 2006 09:06:31 +0000 (02:06 -0700)

update a few Porcelain-ish for ref lock safety.

This updates the use of git-update-ref in git-branch, git-tag
and git-commit to make them safer in a few corner cases as
demonstration.

- git-tag makes sure that the named tag does not exist, allows
you to edit tag message and then creates the tag. If a tag
with the same name was created by somebody else in the
meantime, it used to happily overwrote it. Now it notices
the situation.

- git-branch -d and git-commit (for the initial commit) had the
same issue but with smaller race window, which is plugged
with this.

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

update-ref: -d flag and ref creation safety.Junio C Hamano Wed, 27 Sep 2006 08:58:57 +0000 (01:58 -0700)

update-ref: -d flag and ref creation safety.

This adds -d flag to update-ref to allow safe deletion of ref.
Before deleting it, the command checks if the given <oldvalue>
still matches the value the caller thought the ref contained.

Similarly, it also accepts 0{40} or an empty string as <oldvalue>
to allow safe creation of a new ref.

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

Clean-up lock-ref implementationJunio C Hamano Wed, 27 Sep 2006 08:09:18 +0000 (01:09 -0700)

Clean-up lock-ref implementation

This drops "mustexist" parameter lock_ref_sha1() and lock_any_ref_forupdate()
functions take.

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

Merge branch 'jc/lt-ref2-with-lt-refs' into jc/ref... Junio C Hamano Wed, 27 Sep 2006 07:53:29 +0000 (00:53 -0700)

Merge branch 'jc/lt-ref2-with-lt-refs' into jc/ref-locking

* jc/lt-ref2-with-lt-refs:
Fix show-ref usage for --dereference.
Document git-show-ref [-s|--hash] option.
Add man page for git-show-ref
gitignore: git-show-ref is a generated file.
Use Linus' show ref in "git-branch.sh".
Add [-s|--hash] option to Linus' show-ref.
Teach "git checkout" to use git-show-ref
Add "git show-ref" builtin command

Merge branch 'jc/for-each-ref-with-lt-refs' into jc... Junio C Hamano Wed, 27 Sep 2006 07:53:16 +0000 (00:53 -0700)

Merge branch 'jc/for-each-ref-with-lt-refs' into jc/ref-locking

* jc/for-each-ref-with-lt-refs:
Add git-for-each-ref: helper for language bindings

Allow git-checkout when on a non-existant branch.Shawn Pearce Mon, 25 Sep 2006 05:24:38 +0000 (01:24 -0400)

Allow git-checkout when on a non-existant branch.

I've seen some users get into situtations where their HEAD
symbolic-ref is pointing at a non-existant ref. (Sometimes this
happens during clone when the remote repository lacks a 'master'
branch.) If this happens the user is unable to use git-checkout
to switch branches as there is no prior commit to merge from.

So instead of giving the user low-level errors about how HEAD
can't be resolved and how not a single revision was given change
the type of checkout to be a force and go through with the user's
request anyway.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Quote filename in HTTP Content-Disposition... Jakub Narebski Mon, 25 Sep 2006 23:59:43 +0000 (01:59 +0200)

gitweb: Quote filename in HTTP Content-Disposition: header

Finish work started by commit a2f3db2 (although not documented
in commit message) of quoting using quotemeta the filename in
HTTP -content_disposition header.

Just in case filename contains end of line character.

Also use consistent coding style to compute -content_disposition
parameter.

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Add git_url subroutine, and use it to quote... Jakub Narebski Mon, 25 Sep 2006 23:58:41 +0000 (01:58 +0200)

gitweb: Add git_url subroutine, and use it to quote full URLs

Add git_url subroutine, which does what git_param did before commit
a2f3db2f5de2a3667b0e038aa65e3e097e642e7d, and is used to quote full
URLs, currently only $home_link.

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Split validate_input into validate_pathname... Jakub Narebski Mon, 25 Sep 2006 23:57:02 +0000 (01:57 +0200)

gitweb: Split validate_input into validate_pathname and validate_refname

Split validate_input subroutine into validate_pathname which is used
for $project, $file_name and $file_parent parameters, and
validate_refname which is used for $hash, $hash_base, $hash_parent and
$hash_parent_base parameters. Reintroduce validation of $file_name
and $file_parent parameters, removed in a2f3db2f

validate_pathname in addition to what validate_input did checks also
for doubled slashes and NUL character. It does not check if input is
textual hash, and does not check if all characters are from the
following set: [a-zA-Z0-9_\x80-\xff\ \t\.\/\-\+\#\~\%].

validate_refname first check if the input is textual hash, then checks
if it is valid pathname, then checks for invalid characters (according
to git-check-ref-format manpage). It does not check if all charactes
are from the [a-zA-Z0-9_\x80-\xff\ \t\.\/\-\+\#\~\%] set.

We do not have to validate pathnames we got from git.

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Use "return" instead of "return undef" for... Jakub Narebski Mon, 25 Sep 2006 23:56:17 +0000 (01:56 +0200)

gitweb: Use "return" instead of "return undef" for some subs

Use "return" instead of "return undef" when subroutine can return, or
always return, non-scalar (list) value.

Other places are left as is.

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Strip trailing slashes from $path in git_get_ha... Jakub Narebski Mon, 25 Sep 2006 23:54:24 +0000 (01:54 +0200)

gitweb: Strip trailing slashes from $path in git_get_hash_by_path

It also removes unused local variable $tree

Signed-off-by: Jakub Narebski <jnareb@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

let the GIT native protocol use offsets to delta base... Nicolas Pitre Tue, 26 Sep 2006 15:27:39 +0000 (11:27 -0400)

let the GIT native protocol use offsets to delta base when possible

There is no reason not to always do this when both ends agree.
Therefore a client that can accept offsets to delta base always sends
the "ofs-delta" flag. The server will stream a pack with or without
offset to delta base depending on whether that flag is provided or not
with no additional cost.

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

make pack data reuse compatible with both delta typesNicolas Pitre Sat, 23 Sep 2006 01:25:04 +0000 (21:25 -0400)

make pack data reuse compatible with both delta types

This is the missing part to git-pack-objects allowing it to reuse delta
data to/from any of the two delta types. It can reuse delta from any
type, and it outputs base offsets when --allow-delta-base-offset is
provided and the base is also included in the pack. Otherwise it
outputs base sha1 references just like it always did.

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

make git-pack-objects able to create deltas with offset... Nicolas Pitre Thu, 21 Sep 2006 04:09:44 +0000 (00:09 -0400)

make git-pack-objects able to create deltas with offset to base

This is enabled with --delta-base-offset only, and doesn't work with
pack data reuse yet.

The idea is to allow for the fetch protocol to use an extension flag
to notify the remote end that --delta-base-offset can be used with
git-pack-objects. Eventually git-repack will always provide this flag.

With this, all delta base objects are now pushed before deltas that depend
on them. This is a requirements for OBJ_OFS_DELTA. This is not a
requirement for OBJ_REF_DELTA but always doing so makes the code simpler.

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

teach git-index-pack about deltas with offset to baseNicolas Pitre Thu, 21 Sep 2006 04:08:33 +0000 (00:08 -0400)

teach git-index-pack about deltas with offset to base

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

teach git-unpack-objects about deltas with offset to... Nicolas Pitre Thu, 21 Sep 2006 04:07:39 +0000 (00:07 -0400)

teach git-unpack-objects about deltas with offset to base

For delta resolution to be possible, a list of sha1/offset tuple must
be constructed in memory in order to load the appropriate base object.

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

introduce delta objects with offset to baseNicolas Pitre Thu, 21 Sep 2006 04:06:49 +0000 (00:06 -0400)

introduce delta objects with offset to base

This adds a new object, namely OBJ_OFS_DELTA, renames OBJ_DELTA to
OBJ_REF_DELTA to better make the distinction between those two delta
objects, and adds support for the handling of those new delta objects
in sha1_file.c only.

The OBJ_OFS_DELTA contains a relative offset from the delta object's
position in a pack instead of the 20-byte SHA1 reference to identify
the base object. Since the base is likely to be not so far away, the
relative offset is more likely to have a smaller encoding on average
than an absolute offset. And for those delta objects the base must
always be stored first because there is no way to know the distance of
later objects when streaming a pack. Hence this relative offset is
always meant to be negative.

The offset encoding is slightly denser than the one used for object
size -- credits to <linux@horizon.com> (whoever this is) for bringing
it to my attention.

This allows for pack size reduction between 3.2% (Linux-2.6) to over 5%
(linux-historic). Runtime pack access should be faster too since delta
replay does skip a search in the pack index for each delta in a chain.

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

gitweb: extend blame to show links to diff and previousLuben Tuikov Tue, 26 Sep 2006 23:45:31 +0000 (16:45 -0700)

gitweb: extend blame to show links to diff and previous

git_blame2() now has two more columns, "Prev" and "Diff",
before the "Commit" column, as follows:

Prev Diff Commit Line Data
SHA Diff SHA N ...
...

The "Prev" column shows the SHA of the parent commit,
between which this line changed. Clicking on it shows the
blame of the file as of the parent commit, for that line.

So clicking repeatedly on "Prev" would show you the blame
of that file, from the point of view of the changes
of that particular line whose "Prev" you're clicking on.

The "Diff" column shows "Diff" which is a link to blobdiff
between "Prev" and "Commit" commits _for that line_.

So clicking on "Diff" would show you the blobdiff (HTML)
between the parent commit and this commit which changed
that particular line.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Decode long title for link tooltipsYasushi SHOJI Wed, 27 Sep 2006 03:04:10 +0000 (12:04 +0900)

gitweb: Decode long title for link tooltips

This is a simple one liner to decode long title string in perl's
internal form to utf-8 for link tooltips.

This is not crucial if the commit message is all in ASCII, however, if
you decide to use other encoding, such as UTF-8, tooltips ain't
readable any more.

Signed-off-by: Yasushi SHOJI <yashi@atmark-techno.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Remove redundant "tree" linkLuben Tuikov Tue, 26 Sep 2006 19:45:37 +0000 (12:45 -0700)

gitweb: Remove redundant "tree" link

In "tree" view, remove redundant "tree" link in the tree
listing. It is identical to simply clicking on the tree
entry itself.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

git-svn: Fix fetch --no-ignore-externals with GIT_SVN_N... Sergey Vlasov Tue, 26 Sep 2006 09:42:55 +0000 (13:42 +0400)

git-svn: Fix fetch --no-ignore-externals with GIT_SVN_NO_LIB=1

When using Subversion 1.3.1 without Perl bindings (GIT_SVN_NO_LIB=1),
"git-svn fetch --no-ignore-externals" fails with errors like:

Tree (.../.git/svn/git-svn/tree) is not clean:
X directory_with_external

In this case the 'X' lines in the "svn status" output are not a sign
of unclean tree, and therefore should be ignored.

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

Ignore executable bit when adding files if filemode=0.Shawn Pearce Wed, 27 Sep 2006 05:21:19 +0000 (01:21 -0400)

Ignore executable bit when adding files if filemode=0.

If the user has configured core.filemode=0 then we shouldn't set
the execute bit in the index when adding a new file as the user
has indicated that the local filesystem can't be trusted.

This means that when adding files that should be marked executable
in a repository with core.filemode=0 the user must perform a
'git update-index --chmod=+x' on the file before committing the
addition.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Remove empty ref directories that prevent creating... Christian Couder Tue, 26 Sep 2006 05:23:37 +0000 (07:23 +0200)

Remove empty ref directories that prevent creating a ref.

This patch also adds test cases from Linus and Junio.

Signed-off-by: Christian Couder <chriscool@tuxfamily.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: tree view: eliminate redundant "blob"Luben Tuikov Tue, 26 Sep 2006 05:38:16 +0000 (22:38 -0700)

gitweb: tree view: eliminate redundant "blob"

Binary and non-binary blobs:

The "list" table element of tree view is identical
to the "blob" link part of the link table element.
I.e. clicking on "blob" is identical to clicking on
the entry itself.

Thus, eliminate "blob" from being shown -- the user
can get identical result by simply clicking on the
entry itself.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Use const for interpolate argumentsAlex Riesen Mon, 25 Sep 2006 21:19:00 +0000 (23:19 +0200)

Use const for interpolate arguments

Signed-off-by: Alex Riesen <raa.lkml@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

git-archive: update documentationFranck Bui-Huu Mon, 25 Sep 2006 10:31:52 +0000 (12:31 +0200)

git-archive: update documentation

This patch documents zip backend options.

It also adds git-archive command into the main git manual
page.

Signed-off-by: Franck Bui-Huu <vagabon.xyz@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Deprecate merge-recursive.pyJunio C Hamano Mon, 25 Sep 2006 02:49:47 +0000 (19:49 -0700)

Deprecate merge-recursive.py

This renames merge-recursive written in Python to merge-recursive-old,
and makes merge-recur as a synonym to merge-recursive. We do not remove
merge-recur yet, but we will remove merge-recur and merge-recursive-old
in a few releases down the road.

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

gitweb: fix over-eager application of esc_html().Petr Baudis Sun, 24 Sep 2006 21:57:40 +0000 (14:57 -0700)

gitweb: fix over-eager application of esc_html().

Contents of %diffinfo hash should be quoted upon output but kept
unquoted internally. Later users of this hash expect filenames
to be filenames, not HTML gibberish.

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

Allow '(no author)' in git-svn's authors file.Shawn Pearce Mon, 25 Sep 2006 03:04:55 +0000 (23:04 -0400)

Allow '(no author)' in git-svn's authors file.

When trying to import an SVN revision which has no author the Git
user may desire to relabel '(no author)' to another name and email
address with their svn.authorsfile.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Allow 'svn fetch' on '(no date)' revisions in Subversion.Shawn Pearce Mon, 25 Sep 2006 02:50:15 +0000 (22:50 -0400)

Allow 'svn fetch' on '(no date)' revisions in Subversion.

Added --ignore-nodate to allow 'git svn fetch' to import revisions
from Subversion which have '(no date)' listed as the date of the
revision. By default 'git svn fetch' will crash with an error
when encountering such a revision. The user may restart the fetch
operation by adding --ignore-nodate if they want to continue tracking
that repository.

I'm not entirely sure why a centralized version control system such
as Subversion permits revisions to be created with absolutely no
date/time associated with it but it apparently is possible as one
of the Subversion repositories that I'm tracking with 'git svn'
created such a revision on '(no date)' and by '(no user)'.

Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

git-repack: allow git-repack to run in subdirectoryJeff King Mon, 25 Sep 2006 02:31:11 +0000 (22:31 -0400)

git-repack: allow git-repack to run in subdirectory

Now that we explicitly create all tmpfiles below $GIT_DIR, there's no reason
to care about which directory we're in.

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

Merge branch 'sk/svnimport'Junio C Hamano Mon, 25 Sep 2006 03:00:59 +0000 (20:00 -0700)

Merge branch 'sk/svnimport'

* sk/svnimport:
git-svnimport: Parse log message for Signed-off-by: lines

Merge early parts of branch 'np/pack'Junio C Hamano Mon, 25 Sep 2006 02:58:30 +0000 (19:58 -0700)

Merge early parts of branch 'np/pack'

Remove upload-tar and make git-tar-tree a thin wrapper... Junio C Hamano Sun, 24 Sep 2006 21:42:01 +0000 (14:42 -0700)

Remove upload-tar and make git-tar-tree a thin wrapper to git-archive

The command now issues a big deprecation warning message and runs
git-archive command with appropriate arguments.

git-tar-tree $tree_ish $base always forces $base to be the leading
directory name, so the --prefix parameter passed internally to
git-archive is a slash appended to it, i.e. "--prefix=$base/".

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

git-tar-tree: Move code for git-archive --format=tar... Rene Scharfe Sun, 24 Sep 2006 15:31:10 +0000 (17:31 +0200)

git-tar-tree: Move code for git-archive --format=tar to archive-tar.c

This patch doesn't change any functionality, it only moves code around. It
makes seeing the few remaining lines of git-tar-tree code easier. ;-)

Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx>
Signed-off-by: Junio C Hamano <junkio@cox.net>

git-tar-tree: Remove duplicate git_config() callRene Scharfe Sun, 24 Sep 2006 15:30:44 +0000 (17:30 +0200)

git-tar-tree: Remove duplicate git_config() call

generate_tar() eventually calls write_tar_archive() which does all the
"real" work and which also calls git_config(git_tar_config). We only
need to do this once.

Signed-off-by: Rene Scharfe <rene.scharfe@lsrfire.ath.cx>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge branch 'jc/filter-commit'Junio C Hamano Mon, 25 Sep 2006 02:53:52 +0000 (19:53 -0700)

Merge branch 'jc/filter-commit'

* jc/filter-commit:
git log: Unify header_filter and message_filter into one.
Update grep internal for grepping only in head/body
git-log --author and --committer are not left-anchored by default
rev-list: fix segfault with --{author,committer,grep}
revision traversal: --author, --committer, and --grep.
revision traversal: prepare for commit log match.
builtin-grep: make pieces of it available as library.