gitweb.git
Honor extractor's umask in git-tar-tree.Junio C Hamano Sat, 1 Oct 2005 19:01:07 +0000 (12:01 -0700)

Honor extractor's umask in git-tar-tree.

The archive generated with git-tar-tree had 0755 and 0644 mode bits.
This inconvenienced the extractor with umask 002 by robbing g+w bit
unconditionally. Just write it out with loose permissions bits and
let the umask of the extractor do its job.

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

Honor user's umask.Junio C Hamano Sat, 1 Oct 2005 18:58:43 +0000 (11:58 -0700)

Honor user's umask.

Fix the last two holdouts that forced mode bits stricter than the user's umask.
Noticed by Wolfgang Denk and fixed by Linus.

[jc: applied the same fix to mailsplit just for the sake of consistency.]

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

[PATCH] Flag empty patches as errorsLinus Torvalds Sat, 1 Oct 2005 06:25:23 +0000 (23:25 -0700)

[PATCH] Flag empty patches as errors

A patch that contains no actual diff, and that doesn't change any
meta-data is bad. It shouldn't be a patch at all, and git-apply shouldn't
just accept it.

This caused a corrupted patch to be silently applied as an empty change in
the kernel, because the corruption ended up making the patch look empty.

An example of such a patch is one that contains the patch header, but
where the initial fragment header (the "@@ -nr,.." line) is missing,
causing us to not parse any fragments.

The real "patch" program will also flag such patches as bad, with the
message

patch: **** Only garbage was found in the patch input.

and we should do likewise.

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

Consolidate null_sha1[].Junio C Hamano Fri, 30 Sep 2005 21:02:47 +0000 (14:02 -0700)

Consolidate null_sha1[].

Signed-off-by: Junio C Hamano <junio@twinsun.com>

Still installing the old command names.Junio C Hamano Fri, 30 Sep 2005 07:27:11 +0000 (00:27 -0700)

Still installing the old command names.

After seeing Jeff's guide, I changed my mind about the
big-rename transition plan. Even if Porcelains are kept up to
date, those web documents that describes older world order would
live longer and people will stumble across them via google
searches. And who knows how many mirrored copies there are.

The backward compatible symbolic links *will* be removed before
1.0. But that will not happen in 0.99.8.

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

Tell which packfile is corrupt when we die.Junio C Hamano Fri, 30 Sep 2005 07:09:04 +0000 (00:09 -0700)

Tell which packfile is corrupt when we die.

The core part detected and died upon seeing a corrupted packfile, but
did not help the user by telling which packfile is corrupt and how.

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

[PATCH] Make logerror() and loginfo() staticPavel Roskin Thu, 29 Sep 2005 20:53:14 +0000 (16:53 -0400)

[PATCH] Make logerror() and loginfo() static

Make logerror() and loginfo() static

logerror() and loginfo() in daemon.c are never declared and never called
from other files, therefore they should be declared static. Found by
sparse.

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

[PATCH] Old curl does not know about CURLOPT_SSLKEYJohannes Schindelin Thu, 29 Sep 2005 16:19:50 +0000 (18:19 +0200)

[PATCH] Old curl does not know about CURLOPT_SSLKEY

... so try to set it only in later versions.

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

Use git-merge in git-pull (second try).Junio C Hamano Mon, 26 Sep 2005 02:43:51 +0000 (19:43 -0700)

Use git-merge in git-pull (second try).

This again makes git-pull to use git-merge, so that different merge
strategy can be specified from the command line. Without explicit
strategy parameter, it defaults to git-merge-resolve if only one
remote is pulled, and git-merge-octopus otherwise, to keep the
default behaviour of the command the same as the original.

Also this brings another usability measure: -n flag from the command
line, if given, is passed to git-merge to prevent it from running the
diffstat at the end of the merge.

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

Use git-update-ref in scripts.Junio C Hamano Wed, 28 Sep 2005 01:14:27 +0000 (18:14 -0700)

Use git-update-ref in scripts.

This uses the git-update-ref command in scripts for safer updates.
Also places where we used to read HEAD ref by using "cat" were fixed
to use git-rev-parse. This will matter when we start using symbolic
references.

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

[PATCH] Make some needlessly global stuff staticPeter Hagervall Wed, 28 Sep 2005 12:04:54 +0000 (14:04 +0200)

[PATCH] Make some needlessly global stuff static

Insert 'static' where appropriate.

Signed-off-by: Peter Hagervall <hager@cs.umu.se>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Support for more CURL SSL settings via environm... Nick Hengeveld Tue, 27 Sep 2005 17:45:27 +0000 (10:45 -0700)

[PATCH] Support for more CURL SSL settings via environment variables

Added support for additional CURL SSL settings via environment variables.
Client certificate/key files can be specified as well as alternate CA
information.

Signed-off-by: Nick Hengeveld <nickh@reactrix.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Add new programs to .gitignore.Tom Prince Tue, 27 Sep 2005 07:06:05 +0000 (01:06 -0600)

[PATCH] Add new programs to .gitignore.

Signed-off-by: Tom Prince <tom.prince@ualberta.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Fastpath the normal case by not checking that index... Junio C Hamano Wed, 28 Sep 2005 23:29:11 +0000 (16:29 -0700)

Fastpath the normal case by not checking that index matches HEAD.

The merge strategy would check this itself and typically does it
by using git-read-tree -m -u 3-way merge.

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

Fix default pull not to do an unintended Octopus.Junio C Hamano Mon, 26 Sep 2005 05:54:23 +0000 (22:54 -0700)

Fix default pull not to do an unintended Octopus.

The refspecs specified in the .git/remotes/<remote> on the "Pull: "
lines are for fetching multiple heads in one go, but most of the time
making an Octopus out of them is not what is wanted. Make git-fetch
leave the marker in .git/FETCH_HEAD file so that later stages can
tell which heads are for merging and which are not.

Tom Prince made me realize how stupid the original behaviour was.

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

Update the case table in t/t1000.Junio C Hamano Wed, 28 Sep 2005 19:56:18 +0000 (12:56 -0700)

Update the case table in t/t1000.

It still talked about "the proposed alternative semantics" but we have
used those alternative semantics for quite some time. Update them to
avoid confusion.

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

Merge master.kernel.org:/home/hpa/git/daemonJunio C Hamano Wed, 28 Sep 2005 00:05:41 +0000 (17:05 -0700)

Merge master.kernel.org:/home/hpa/git/daemon

git-commit: use update-index --stdin, instead of xargs.Junio C Hamano Tue, 27 Sep 2005 01:13:53 +0000 (18:13 -0700)

git-commit: use update-index --stdin, instead of xargs.

Now update-index supports '-z --stdin', we do not have to rely on
platform xargs to support -0 option.

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

update-index: document --stdin and -zJunio C Hamano Tue, 27 Sep 2005 01:13:32 +0000 (18:13 -0700)

update-index: document --stdin and -z

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

update-index: --stdin and -zJunio C Hamano Tue, 27 Sep 2005 01:13:08 +0000 (18:13 -0700)

update-index: --stdin and -z

The new option --stdin reads list of paths to be updated from the
standard input. As usual, -z means the paths are terminated with NUL
characters, as opposed to LF without that option.

This is useful to use git-diff-files -z and git-ls-files -z when the
platform xargs does not support -0 option, and obviously saves one
process even when xargs can take -0.

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

COPTS -> CFLAGSH. Peter Anvin Tue, 27 Sep 2005 16:02:24 +0000 (09:02 -0700)

COPTS -> CFLAGS

Parallelize the buildH. Peter Anvin Tue, 27 Sep 2005 16:01:08 +0000 (09:01 -0700)

Parallelize the build

Merge ... git+ssh://kernel.org/pub/scm/git/git.gitH. Peter Anvin Tue, 27 Sep 2005 15:50:08 +0000 (08:50 -0700)

Merge ... git+ssh://kernel.org/pub/scm/git/git.git

Restore chdir(".git")H. Peter Anvin Tue, 27 Sep 2005 15:49:40 +0000 (08:49 -0700)

Restore chdir(".git")

[PATCH] Return CURL error message when object transfer... Nick Hengeveld Mon, 26 Sep 2005 17:52:11 +0000 (10:52 -0700)

[PATCH] Return CURL error message when object transfer fails

Return CURL error message when object transfer fails

[jc: added similar curl_errorstr errors to places where we
use curl_easy_perform() to run fetch that _must_ succeed.]

Signed-off-by: Nick Hengeveld <nickh@reactrix.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Implement --recover for git-*-fetchDaniel Barkalow Tue, 27 Sep 2005 01:38:08 +0000 (21:38 -0400)

[PATCH] Implement --recover for git-*-fetch

With the --recover option, we verify that we have absolutely
everything reachable from the target, not assuming that things
reachable from refs will be complete.

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

[PATCH] Provide access to git_dir through get_git_dir().Sven Verdoolaege Mon, 26 Sep 2005 20:54:01 +0000 (22:54 +0200)

[PATCH] Provide access to git_dir through get_git_dir().

Signed-off-by: Sven Verdoolaege <skimo@kotnet.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Make the test more shell generic and fix missin... Peter Eriksen Sat, 24 Sep 2005 19:50:29 +0000 (21:50 +0200)

[PATCH] Make the test more shell generic and fix missing Solaris find option

This is from Peter Eriksen, but further fixed.

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

Really require tk 8.4 (RPM)Junio C Hamano Tue, 27 Sep 2005 07:15:45 +0000 (00:15 -0700)

Really require tk 8.4 (RPM)

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

Support a modicum of path validation, and allow an... H. Peter Anvin Tue, 27 Sep 2005 02:10:55 +0000 (19:10 -0700)

Support a modicum of path validation, and allow an export all trees option.

Require tk 8.4 (RPM)Junio C Hamano Tue, 27 Sep 2005 01:29:26 +0000 (18:29 -0700)

Require tk 8.4 (RPM)
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge http://www.kernel.org/pub/scm/gitk/gitkJunio C Hamano Tue, 27 Sep 2005 01:23:47 +0000 (18:23 -0700)

Merge http://www.kernel.org/pub/scm/gitk/gitk

git-fetch: send informational output to >&2 consistently.Junio C Hamano Mon, 26 Sep 2005 02:49:49 +0000 (19:49 -0700)

git-fetch: send informational output to >&2 consistently.

Only the "Fetching ... using http" was leaking to stdout.

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

Give default merge message after failed automerge.Junio C Hamano Sun, 25 Sep 2005 07:12:06 +0000 (00:12 -0700)

Give default merge message after failed automerge.

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

Do not require clean tree when reverting and cherry... Junio C Hamano Sun, 25 Sep 2005 05:52:32 +0000 (22:52 -0700)

Do not require clean tree when reverting and cherry-picking.

My stupidity deserved to be yelled at by Linus ... there is no reason
to require the working tree to be clean when merging -- the only
requirements are index to match HEAD commit and the paths involved in
merge are up to date in the working tree. Revert and cherry-pick are
just specialized forms of merge, and the requirements should be the
same.

Remove the 'general purpose routine to make sure tree is clean' from
git-sh-setup, to prevent me from getting tempted again.

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

Fix overzealous cleanliness check in git-mergeJunio C Hamano Fri, 23 Sep 2005 07:43:04 +0000 (00:43 -0700)

Fix overzealous cleanliness check in git-merge

Being able to try multiple strategies and automatically picking one
that seems to give less conflicting result may or may not much sense
in practice. At least that should not force normal use case to
additionally require the working tree to be fully clean. As Linus
shouted, local changes do not matter unless they interfere with the
merge.

This commit changes git-merge not to require a clean working tree.
Only when we will iterate through more than one merge strategies,
local changes are stashed away before trying the first merge, and
restored before second and later merges are attempted.

The index file must be in sync with HEAD in any case -- otherwise the
merge result would contain changes since HEAD that was done locally
and registered in the index. This check is already enforced by
three-way read-tree existing merge strategies use, but is done here as
a safeguard as well.

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

git-clone: check out "master" by default.Junio C Hamano Tue, 27 Sep 2005 00:17:09 +0000 (17:17 -0700)

git-clone: check out "master" by default.

And with -n flag you can tell it not to.

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

Use "$@" rather than "${1+$@}" when invoking wish.Paul Mackerras Tue, 27 Sep 2005 00:29:41 +0000 (10:29 +1000)

Use "$@" rather than "${1+$@}" when invoking wish.

Plug a small race in update-ref.c.Junio C Hamano Sun, 25 Sep 2005 23:28:51 +0000 (16:28 -0700)

Plug a small race in update-ref.c.

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

Change wish8.4 back to wishPaul Mackerras Mon, 26 Sep 2005 00:22:43 +0000 (10:22 +1000)

Change wish8.4 back to wish

Checking in the change from wish to wish8.4 was a mistake; I had
changed it for a test but forgot to change it back before checking
in a patch.

[PATCH] Add "git-update-ref" to update the HEAD (or... Linus Torvalds Sun, 25 Sep 2005 18:43:05 +0000 (11:43 -0700)

[PATCH] Add "git-update-ref" to update the HEAD (or other) ref

This is a careful version of the script stuff that currently just
blindly writes HEAD with a new value.

You can use

git-update-ref HEAD <newhead>

or

git-update-ref HEAD <newhead> <oldhead>

where the latter version verifies that the old value of HEAD matches
oldhead.

It basically allows a "ref" file to be a symbolic pointer to another ref
file by starting with the four-byte header sequence of "ref:".

More importantly, it allows the update of a ref file to follow these
symbolic pointers, whether they are symlinks or these "regular file
symbolic refs".

NOTE! It follows _real_ symlinks only if they start with "refs/":
otherwise it will just try to read them and update them as a regular file
(ie it will allow the filesystem to follow them, but will overwrite such a
symlink to somewhere else with a regular filename).

In general, using

git-update-ref HEAD "$head"

should be a _lot_ safer than doing

echo "$head" > "$GIT_DIR/HEAD"

both from a symlink following standpoint _and_ an error checking
standpoint. The "refs/" rule for symlinks means that symlinks that point
to "outside" the tree are safe: they'll be followed for reading but not
for writing (so we'll never write through a ref symlink to some other
tree, if you have copied a whole archive by creating a symlink tree).

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

[PATCH] More descriptive messages for conflict cases... Fredrik Kuivinen Sun, 25 Sep 2005 14:49:02 +0000 (16:49 +0200)

[PATCH] More descriptive messages for conflict cases in merges

The merge strategies can give more descriptive error messages for
conflict cases if they are given the actual branch names instead of
the SHA1s.

Signed-off-by: Fredrik Kuivinen <freku045@student.liu.se>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] recursive-merge: Don't print a stack trace... Fredrik Kuivinen Sun, 25 Sep 2005 14:48:24 +0000 (16:48 +0200)

[PATCH] recursive-merge: Don't print a stack trace when read-tree fails.

If the working tree is dirty read-tree will fail, and we don't want an
ugly stack trace in that case. Also make sure we don't print stack
traces when we use 'die'.

Signed-off-by: Fredrik Kuivinen <freku045@student.liu.se>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Diff: --name-status output format.Junio C Hamano Wed, 21 Sep 2005 07:20:06 +0000 (00:20 -0700)

Diff: --name-status output format.

The new output format shows only the status letter and paths.

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

Diff: -l<num> to limit rename/copy detection.Junio C Hamano Wed, 21 Sep 2005 07:18:27 +0000 (00:18 -0700)

Diff: -l<num> to limit rename/copy detection.

When many paths are modified, rename detection takes a lot of time.
The new option -l<num> can be used to disable rename detection when
more than <num> paths are possibly created as renames.

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

Diff clean-up.Junio C Hamano Wed, 21 Sep 2005 07:00:47 +0000 (00:00 -0700)

Diff clean-up.

This is a long overdue clean-up to the code for parsing and passing
diff options. It also tightens some constness issues.

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

Merge branch 'fixes'Junio C Hamano Sun, 25 Sep 2005 06:50:36 +0000 (23:50 -0700)

Merge branch 'fixes'

Clean generated files a bit more.Junio C Hamano Sun, 25 Sep 2005 06:48:29 +0000 (23:48 -0700)

Clean generated files a bit more.

Now we conditionally compile things in compat/, so we should remove
object files there. Python execution can leave *.pyc and *.pyo, which
need to be cleaned as well.

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

Stop installing the backward compatible symlinks.Junio C Hamano Sun, 25 Sep 2005 06:42:34 +0000 (23:42 -0700)

Stop installing the backward compatible symlinks.

Also cmd-renames.sh can now be used to remove the backward compatible
symlinks -- this is not used by default in any way.

As discussed on the list with Pasky, git-ssh-push and git-ssh-pull will
keep calling each other for a while longer.

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

show-branch: fix commit naming breakage.Junio C Hamano Sun, 25 Sep 2005 06:33:02 +0000 (23:33 -0700)

show-branch: fix commit naming breakage.

It was ignoring the generation number of the commit when naming 2nd
and later parents, showing "(linus^n)^2" for any <n> incorrectly as
"linus^2".

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

[PATCH] Finish documenting trivial merge rulesDaniel Barkalow Sun, 25 Sep 2005 03:50:04 +0000 (23:50 -0400)

[PATCH] Finish documenting trivial merge rules

Fix missing symbol explanations, a few incorrect cases, and add
two-way merge rules.

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

git-grep: fix 'git grep -e $pattern' handlingJunio C Hamano Sat, 24 Sep 2005 22:09:48 +0000 (15:09 -0700)

git-grep: fix 'git grep -e $pattern' handling

People typically say 'grep -e $pattern' because $pattern has a leading
dash which would be mistaken as a grep flag. Make sure we pass -e in
front of $pattern when we invoke grep.

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

Remove use of 'xargs -0' from git-reset.Junio C Hamano Sat, 24 Sep 2005 22:02:35 +0000 (15:02 -0700)

Remove use of 'xargs -0' from git-reset.

Even without the trouble it causes to people without GNU xargs,
it was not really necessary to print from Perl and then remove it
outside. Just unlink it inside Perl.

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

Use 0.99.7.GIT as version between 0.99.7 and 0.99.8Junio C Hamano Sat, 24 Sep 2005 21:58:57 +0000 (14:58 -0700)

Use 0.99.7.GIT as version between 0.99.7 and 0.99.8

Pasky taught me how he does his versioning for ELinks. This will sort
after 0.99.7 and interim fixes 0.99.7a, and before 0.99.8.

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

Solaris: give a bit more built-in defaults.Junio C Hamano Fri, 23 Sep 2005 17:41:40 +0000 (10:41 -0700)

Solaris: give a bit more built-in defaults.

Taking the make command line Peter Eriksen uses, give defaults
to SHELL_PATH, TAR, CURLDIR, NO_STRCASESTR, and INSTALL.

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

[PATCH] CURLDIR in MakefilePatrick Mauritz Mon, 19 Sep 2005 14:11:19 +0000 (16:11 +0200)

[PATCH] CURLDIR in Makefile

Support systems that do not install curl headers and libraries
in /usr/{include,lib}.

Signed-off-by: Patrick Mauritz <oxygene@studentenbude.ath.cx>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] Rename daemon.c's lognotice() to loginfo()Petr Baudis Sat, 24 Sep 2005 14:13:03 +0000 (16:13 +0200)

[PATCH] Rename daemon.c's lognotice() to loginfo()

The syslog code logs with severity LOG_INFO in the loginfo() function, so make
things less confusing.

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

[PATCH] git-daemon --syslog to log through syslogPetr Baudis Sat, 24 Sep 2005 14:13:01 +0000 (16:13 +0200)

[PATCH] git-daemon --syslog to log through syslog

Well, this makes it even more clear that we need the packet reader and
friends to use the daemon logging code. :/ Therefore, we at least indicate
in the "Disconnect" log message if the child process exitted with an error
code or not.

Idea by Linus.

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

[PATCH] Update git-daemon documentation wrt. the -... Petr Baudis Sat, 24 Sep 2005 14:12:58 +0000 (16:12 +0200)

[PATCH] Update git-daemon documentation wrt. the --verbose parameter

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

Really ignore generated distribution material.Junio C Hamano Sat, 24 Sep 2005 18:19:07 +0000 (11:19 -0700)

Really ignore generated distribution material.
Signed-off-by: Junio C Hamano <junkio@cox.net>

daemon.c: pid_t is not int.Junio C Hamano Sat, 24 Sep 2005 06:26:55 +0000 (23:26 -0700)

daemon.c: pid_t is not int.

Reported by Morten Welinder <mwelinder@gmail.com>.

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

Merge 'fixes' branch.Junio C Hamano Sat, 24 Sep 2005 01:46:34 +0000 (18:46 -0700)

Merge 'fixes' branch.

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

Further clarify licensing status of compat/subprocess.py.Junio C Hamano Sat, 24 Sep 2005 01:43:53 +0000 (18:43 -0700)

Further clarify licensing status of compat/subprocess.py.

PSF license explicitly states the files in Python distribution is
compatible with GPL, and upstream clarified the licensing terms by
shortening its file header. This version is a verbatim copy from
release24-maint branch form Python CVS.

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

[PATCH] rsh.c unterminated stringH. Peter Anvin Fri, 23 Sep 2005 23:30:50 +0000 (16:30 -0700)

[PATCH] rsh.c unterminated string

The change I made to rsh.c would leave the string unterminated under
certain conditions, which unfortunately always applied! This patch
fixes this. For some reason this never bit on i386 or ppc, but bit me
on x86-64.

Fix situation where the buffer was not properly null-terminated.

Signed-off-by: H. Peter Anvin <hpa@zytor.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

[PATCH] git-local-fetch: Avoid confusing error messages... Sergey Vlasov Fri, 23 Sep 2005 12:28:38 +0000 (16:28 +0400)

[PATCH] git-local-fetch: Avoid confusing error messages on packed repositories

If the source repository was packed, and git-local-fetch needed to
fetch a pack file, it spewed a misleading error message about not
being able to find the unpacked object. Fixed by adding the
warn_if_not_exists argument to copy_file(), which controls printing
of error messages in case the source file does not exist.

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

[PATCH] Fix "git-local-fetch -s" with packed source... Sergey Vlasov Fri, 23 Sep 2005 12:28:33 +0000 (16:28 +0400)

[PATCH] Fix "git-local-fetch -s" with packed source repository

"git-local-fetch -s" did not work with a packed repository, because
symlink() happily created a link to a non-existing object file,
therefore fetch_file() always returned success, and fetch_pack() was
not called. Fixed by calling stat() before symlink() to ensure the
file really exists.

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

[PATCH] git-local-fetch: Avoid calling close(-1)Sergey Vlasov Fri, 23 Sep 2005 12:28:28 +0000 (16:28 +0400)

[PATCH] git-local-fetch: Avoid calling close(-1)

After open() failure, copy_file() called close(ifd) with ifd == -1
(harmless, but causes Valgrind noise). The same thing was possible
for the destination file descriptor.

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

[PATCH] git-local-fetch: Fix error checking and leak... Sergey Vlasov Fri, 23 Sep 2005 12:28:23 +0000 (16:28 +0400)

[PATCH] git-local-fetch: Fix error checking and leak in setup_indices()

setup_indices() did not check the return value of opendir(), and
did not have a corresponding closedir() call.

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

[PATCH] fetch.c: Plug memory leak in process_tree()Sergey Vlasov Fri, 23 Sep 2005 12:28:18 +0000 (16:28 +0400)

[PATCH] fetch.c: Plug memory leak in process_tree()

When freeing a tree entry, must free its name too.

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

[PATCH] fetch.c: Do not build object ref listsSergey Vlasov Fri, 23 Sep 2005 12:28:13 +0000 (16:28 +0400)

[PATCH] fetch.c: Do not build object ref lists

The fetch code does not need object ref lists; by disabling them we
can save some time and memory.

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

[PATCH] document command to show diff of a commitRobert Watson Fri, 23 Sep 2005 10:06:04 +0000 (11:06 +0100)

[PATCH] document command to show diff of a commit

Document the best way to show the change introduced by a
commit, based on the suggestion by Linus on the list.

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

Ignore a bit more generated files.Junio C Hamano Fri, 23 Sep 2005 21:02:57 +0000 (14:02 -0700)

Ignore a bit more generated files.
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge branch 'fixes'Junio C Hamano Fri, 23 Sep 2005 07:53:43 +0000 (00:53 -0700)

Merge branch 'fixes'

Make 'git diff --cached' synonymous to 'git diff -... Junio C Hamano Fri, 23 Sep 2005 07:53:02 +0000 (00:53 -0700)

Make 'git diff --cached' synonymous to 'git diff --cached HEAD'.

When making changes to different files (i.e. dirty working tree) and
committing logically separate changes in groups, often it is necessary
to run 'git diff --cached HEAD' to make sure that the changes being
committed makes sense. Saying 'git diff --cached' by mistake gives
rather uninformative error message from git-diff-files complaining it
does not understand --cached flag.

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

[PATCH] fetch.c: Remove call to parse_object() from... Sergey Vlasov Wed, 21 Sep 2005 16:34:29 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove call to parse_object() from process()

The call to parse_object() in process() is not actually needed - if
the object type is unknown, parse_object() will be called by loop();
if the type is known, the object will be parsed by the appropriate
process_*() function.

After this change blobs which exist locally are no longer parsed,
which gives about 2x CPU usage improvement; the downside is that there
will be no warnings for existing corrupted blobs, but detecting such
corruption is the job of git-fsck-objects, not the fetch programs.
Newly fetched objects are still checked for corruption in http-fetch.c
and ssh-fetch.c (local-fetch.c does not seem to do it, but the removed
parse_object() call would not be reached for new objects anyway).

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

[PATCH] fetch.c: Clean up object flag definitionsSergey Vlasov Wed, 21 Sep 2005 16:34:24 +0000 (20:34 +0400)

[PATCH] fetch.c: Clean up object flag definitions

Remove holes left after deleting flags, and use shifts to emphasize
that flags are single bits.

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

[PATCH] fetch.c: Remove redundant test of TO_SCAN in... Sergey Vlasov Wed, 21 Sep 2005 16:34:19 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove redundant test of TO_SCAN in process()

If the SEEN flag was not set, the TO_SCAN flag cannot be set,
therefore testing it is pointless.

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

[PATCH] fetch.c: Remove some duplicated code in process()Sergey Vlasov Wed, 21 Sep 2005 16:34:14 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove some duplicated code in process()

It does not matter if we call prefetch() or set the TO_SCAN flag before
or after adding the object to process_queue. However, doing it before
object_list_insert() allows us to kill 3 lines of duplicated code.

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

[PATCH] fetch.c: Remove redundant TO_FETCH flagSergey Vlasov Wed, 21 Sep 2005 16:34:09 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove redundant TO_FETCH flag

The TO_FETCH flag also became redundant after adding the SEEN flag -
it was set and checked in process() to prevent adding the same object
to process_queue multiple times, but now SEEN guards against this.

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

[PATCH] fetch.c: Remove redundant SCANNED flagSergey Vlasov Wed, 21 Sep 2005 16:34:04 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove redundant SCANNED flag

After adding the SEEN flag, the SCANNED flag became obviously
redundant - each object can get into process_queue through process()
only once, and therefore multiple calls to process_object() for the
same object are not possible.

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

[PATCH] fetch.c: Make process() look at each object... Sergey Vlasov Wed, 21 Sep 2005 16:33:59 +0000 (20:33 +0400)

[PATCH] fetch.c: Make process() look at each object only once

The process() function is very often called multiple times for the
same object (because lots of trees refer to the same blobs), but did
not have a fast check for this, therefore a lot of useless calls to
has_sha1_file() and parse_object() were made before discovering that
nothing needs to be done.

This patch adds the SEEN flag which is used in process() to make it
look at each object only once. When testing git-local-fetch on the
repository of GIT, this gives a 14x improvement in CPU usage (mainly
because the redundant calls to parse_object() are now avoided -
parse_object() always unpacks and parses the object data, even if it
was already parsed before).

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

[PATCH] fetch.c: Remove useless lookup_object_type... Sergey Vlasov Wed, 21 Sep 2005 16:33:54 +0000 (20:33 +0400)

[PATCH] fetch.c: Remove useless lookup_object_type() call in process()

In all places where process() is called except the one in pull() (which
is executed only once) the pointer to the object is already available,
so pass it as the argument to process() instead of sha1 and avoid an
unneeded call to lookup_object_type().

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

Do not give alarming error message from rsync in fetch... Junio C Hamano Tue, 20 Sep 2005 06:52:33 +0000 (23:52 -0700)

Do not give alarming error message from rsync in fetch and clone.

When we check the optional objects/info/alternates file at the remote
repository, we forgot to really squelch error message from rsync.

Not having that file is not a crime.

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

[PATCH] Retitle 'inspecting what happened' section.Jon Loeliger Thu, 22 Sep 2005 15:51:57 +0000 (10:51 -0500)

[PATCH] Retitle 'inspecting what happened' section.

In the tutorial, there is a section entitled "Checking it out"
that shows how to use diff log and whatchanged to insect some
of the repository state.

As the phrase "checkout" ususally carries some baggage WRT
other revision control mechanism, I suggest that we re-title
this section something like "Inspecting Changes".

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

Prettyprint octopus merge message.Junio C Hamano Thu, 22 Sep 2005 07:55:22 +0000 (00:55 -0700)

Prettyprint octopus merge message.

Including the current branch in the list of heads being merged
was not a good idea, so drop it. And shorten the message by
grouping branches and tags together to form a single line.

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

[PATCH] Verbose git-daemon loggingPetr Baudis Thu, 22 Sep 2005 09:25:28 +0000 (11:25 +0200)

[PATCH] Verbose git-daemon logging

This patch makes git-daemon --verbose log some useful things on stderr -
in particular connects, disconnects and upload requests, and in such a
way to be able to trace a particular session. Some more errors are now
also logged (even when --verbose is not passed). It is still not perfect
since messages produced by the non-daemon-specific code are obviously
not formatted properly.

[jc: With minor fix up in the log line truncation, and
use of write(2) as suggested by Linus.]

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

Retire diff-helper.Junio C Hamano Wed, 21 Sep 2005 06:24:39 +0000 (23:24 -0700)

Retire diff-helper.

The textual diff generation with built-in '-p' in diff-* brothers has
proven to be useful enough that git-diff-helper outlived its usefulness.

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

Retire rev-tree.Junio C Hamano Sat, 17 Sep 2005 05:30:55 +0000 (22:30 -0700)

Retire rev-tree.

Some old scripts might still use git-rev-tree, but it really is
clearly inferior in every way to git-rev-list that such scripts should
be fixed anyway. Fixing them should be pretty easy.

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

Retire git-export.Junio C Hamano Sat, 17 Sep 2005 05:21:36 +0000 (22:21 -0700)

Retire git-export.

git-export was done as a concept example on how easy it is to export
the git data to something else. It's much less powerful than any
number of trivial one-liner scripts now, and real exporters would not
ever use git-export.

It's obviously much less powerful than "git-whatchanged", or just
about any combination of git-rev-list + git-diff-tree.

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

[PATCH] Fix strange timezone handlingLinus Torvalds Wed, 21 Sep 2005 22:50:28 +0000 (15:50 -0700)

[PATCH] Fix strange timezone handling

We generate the ASCII representation of our internal date representation
("seconds since 1970, UTC + timezone information") in two different
places.

One of them uses the stupid and obvious way to make sure that it gets the
sexagecimal representation right for negative timezones even if they might
not be exact hours, and the other one depends on the modulus operator
always matching the sign of argument.

Hey, the clever one works. And C90 even specifies that behaviour. But I
had to think about it for a while when I was re-visiting this area, and
even if I didn't have to, it's kind of strange to have two different ways
to print out the same data format.

So use a common helper for this. And select the stupid and straighforward
way.

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

[PATCH] Add new keybindingsRobert Suetterlin Thu, 22 Sep 2005 00:07:36 +0000 (10:07 +1000)

[PATCH] Add new keybindings

This adds several new keybindings to allow history and selectline
navigation. I basically added Opera-like history traversal, as well
as left-right-cursor history traversal and vi-like motion commands.

Signed-off-by: Robert Suetterlin <robert@mpe.mpg.de>
Signed-off-by: Paul Mackerras <paulus@samba.org>

Revert "Use git-merge instead of git-resolve in git... Junio C Hamano Wed, 21 Sep 2005 21:01:56 +0000 (14:01 -0700)

Revert "Use git-merge instead of git-resolve in git-pull."

This reverts f887564ab72e107bcdee3ba83c91e2bb4ae13ca7 commit.

Revert "Make Octopus merge message a bit nicer."Junio C Hamano Wed, 21 Sep 2005 20:59:54 +0000 (13:59 -0700)

Revert "Make Octopus merge message a bit nicer."

This reverts 63f1aa6c72c46928f1b6959437aed4becbc42ff3 commit.

[PATCH] fetch.c: Remove call to parse_object() from... Sergey Vlasov Wed, 21 Sep 2005 16:34:29 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove call to parse_object() from process()

The call to parse_object() in process() is not actually needed - if
the object type is unknown, parse_object() will be called by loop();
if the type is known, the object will be parsed by the appropriate
process_*() function.

After this change blobs which exist locally are no longer parsed,
which gives about 2x CPU usage improvement; the downside is that there
will be no warnings for existing corrupted blobs, but detecting such
corruption is the job of git-fsck-objects, not the fetch programs.
Newly fetched objects are still checked for corruption in http-fetch.c
and ssh-fetch.c (local-fetch.c does not seem to do it, but the removed
parse_object() call would not be reached for new objects anyway).

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

[PATCH] fetch.c: Clean up object flag definitionsSergey Vlasov Wed, 21 Sep 2005 16:34:24 +0000 (20:34 +0400)

[PATCH] fetch.c: Clean up object flag definitions

Remove holes left after deleting flags, and use shifts to emphasize
that flags are single bits.

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

[PATCH] fetch.c: Remove redundant test of TO_SCAN in... Sergey Vlasov Wed, 21 Sep 2005 16:34:19 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove redundant test of TO_SCAN in process()

If the SEEN flag was not set, the TO_SCAN flag cannot be set,
therefore testing it is pointless.

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

[PATCH] fetch.c: Remove some duplicated code in process()Sergey Vlasov Wed, 21 Sep 2005 16:34:14 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove some duplicated code in process()

It does not matter if we call prefetch() or set the TO_SCAN flag before
or after adding the object to process_queue. However, doing it before
object_list_insert() allows us to kill 3 lines of duplicated code.

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

[PATCH] fetch.c: Remove redundant TO_FETCH flagSergey Vlasov Wed, 21 Sep 2005 16:34:09 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove redundant TO_FETCH flag

The TO_FETCH flag also became redundant after adding the SEEN flag -
it was set and checked in process() to prevent adding the same object
to process_queue multiple times, but now SEEN guards against this.

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

[PATCH] fetch.c: Remove redundant SCANNED flagSergey Vlasov Wed, 21 Sep 2005 16:34:04 +0000 (20:34 +0400)

[PATCH] fetch.c: Remove redundant SCANNED flag

After adding the SEEN flag, the SCANNED flag became obviously
redundant - each object can get into process_queue through process()
only once, and therefore multiple calls to process_object() for the
same object are not possible.

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

[PATCH] fetch.c: Make process() look at each object... Sergey Vlasov Wed, 21 Sep 2005 16:33:59 +0000 (20:33 +0400)

[PATCH] fetch.c: Make process() look at each object only once

The process() function is very often called multiple times for the
same object (because lots of trees refer to the same blobs), but did
not have a fast check for this, therefore a lot of useless calls to
has_sha1_file() and parse_object() were made before discovering that
nothing needs to be done.

This patch adds the SEEN flag which is used in process() to make it
look at each object only once. When testing git-local-fetch on the
repository of GIT, this gives a 14x improvement in CPU usage (mainly
because the redundant calls to parse_object() are now avoided -
parse_object() always unpacks and parses the object data, even if it
was already parsed before).

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