gitweb.git
Git.pm: Add config() methodPetr Baudis Mon, 3 Jul 2006 20:47:55 +0000 (22:47 +0200)

Git.pm: Add config() method

This accessor will retrieve value(s) of the given configuration variable.

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

Use $GITPERLLIB instead of $RUNNING_GIT_TESTS and centr... Petr Baudis Mon, 3 Jul 2006 21:16:32 +0000 (23:16 +0200)

Use $GITPERLLIB instead of $RUNNING_GIT_TESTS and centralize @INC munging

This makes the Git perl scripts check $GITPERLLIB instead of
$RUNNING_GIT_TESTS, which makes more sense if you are setting up your shell
environment to use a non-installed Git instance.

It also weeds out the @INC munging from the individual scripts and makes
Makefile add it during the .perl files processing, so that we can change
just a single place when we modify this shared logic. It looks ugly in the
scripts, too. ;-)

And instead of doing arcane things with the @INC array, we just do 'use lib'
instead, which is essentialy the same thing anyway.

I first want to do three separate patches but it turned out that it's quite
a lot neater when bundled together, so I hope it's ok.

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

Make zlib compression level configurable, and change... Joachim B Haga Mon, 3 Jul 2006 20:11:47 +0000 (22:11 +0200)

Make zlib compression level configurable, and change default.

With the change in default, "git add ." on kernel dir is about
twice as fast as before, with only minimal (0.5%) change in
object size. The speed difference is even more noticeable
when committing large files, which is now up to 8 times faster.

The configurability is through setting core.compression = [-1..9]
which maps to the zlib constants; -1 is the default, 0 is no
compression, and 1..9 are various speed/size tradeoffs, 9
being slowest.

Signed-off-by: Joachim B Haga (cjhaga@fys.uio.no)
Acked-by: Linus Torvalds <torvalds@osdl.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge branch 'master' into js/merge-baseJunio C Hamano Mon, 3 Jul 2006 10:14:32 +0000 (03:14 -0700)

Merge branch 'master' into js/merge-base

This is to pull in the object-hash clean-up from the master branch.

revert clear-commit-marks for now.Junio C Hamano Mon, 3 Jul 2006 10:05:20 +0000 (03:05 -0700)

revert clear-commit-marks for now.

Earlier change broke "git describe A B" among other things.
Revert it for now, and clean the commits smudged by
get_merge_bases using clear_object_marks() function. For
complex commit ancestry graph, this is way cheaper as well.

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

get_merge_bases: clean up even when there is no common... Junio C Hamano Mon, 3 Jul 2006 10:02:27 +0000 (03:02 -0700)

get_merge_bases: clean up even when there is no common commit.

Actually in this case we would have traversed a lot of commits, so cleaning
things up is even more important.

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

INSTALL: a tip for running after building but without... Junio C Hamano Mon, 3 Jul 2006 06:54:47 +0000 (23:54 -0700)

INSTALL: a tip for running after building but without installing.

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

Makefile: tighten git-http-{fetch,push} dependenciesJunio C Hamano Mon, 3 Jul 2006 07:53:13 +0000 (00:53 -0700)

Makefile: tighten git-http-{fetch,push} dependencies

Although our "git-%$X:" implicit target had dependency on
$(GITLIBS) which included xdiff/lib.a, git-http-{fetch,push} had
their own building rules and with an obsolete dependency on
$(LIB_FILES). Update the rules to depend on $(GITLIBS), to make
parallel build work correctly.

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

Perly Git: make sure we do test the freshly built one.Junio C Hamano Sun, 2 Jul 2006 23:49:12 +0000 (16:49 -0700)

Perly Git: make sure we do test the freshly built one.

We could BEGIN { push @INC, '@@INSTLIBDIR@@'; } but that is not
a good idea for normal execution. The would prevent a
workaround for a user who is trying to override an old, faulty
Git.pm installed on the system path with a newer version
installed under $HOME/.

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

Git.pm: Don't #define around diePetr Baudis Sun, 2 Jul 2006 20:57:17 +0000 (22:57 +0200)

Git.pm: Don't #define around die

Back in the old days, we called Git's die() from the .xs code, but we had to
hijack Perl's die() for that. Now we don't call Git's die() so no need to do
the hijacking and it silences a compiler warning.

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

Git.xs: older perl do not know const char *Johannes Schindelin Sun, 2 Jul 2006 09:53:03 +0000 (11:53 +0200)

Git.xs: older perl do not know const char *

Both of these casts _should_ be safe, since you do not want to muck around
with the version or the path anyway.

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

Git.pm: Avoid ppport.hPetr Baudis Sat, 1 Jul 2006 23:48:32 +0000 (01:48 +0200)

Git.pm: Avoid ppport.h

This makes us not include ppport.h which seems not to give us anything
real anyway; it is useful for checking for portability warts but since
Devel::PPPort is a portability wart itself, we shouldn't require it
for build. You can check for portability problems by calling make check
in perl/.

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

Git.pm: Remove PerlIO usage from Git.xsPetr Baudis Sat, 1 Jul 2006 23:38:56 +0000 (01:38 +0200)

Git.pm: Remove PerlIO usage from Git.xs

PerlIO_*() is not portable before 5.7.3, according to ppport.h, and it's
more clear what is going on when we do it in the Perl part of the Git module
anyway.

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

Make perl interface a separate packagePavel Roskin Fri, 30 Jun 2006 05:09:28 +0000 (01:09 -0400)

Make perl interface a separate package

Install it as a vendor package. Remove .packlist, perllocal.pod,
Git.bs. Require perl(Error) for building so that our Error.pm is not
installed.

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

Delete manuals if compiling without docsPavel Roskin Fri, 30 Jun 2006 05:09:26 +0000 (01:09 -0400)

Delete manuals if compiling without docs

Otherwise, rpm would complain about unpacked files.

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

Fix probing for already installed Error.pmPavel Roskin Fri, 30 Jun 2006 05:09:23 +0000 (01:09 -0400)

Fix probing for already installed Error.pm

The syntax for 'require' was wrong, and it was always failing, which
resulted in installing our own version of Error.pm anyways.

Now we used to ship our own Error.pm in the same directory, so after
fixing the syntax, 'require' always succeeds, but it does not test if
the platform has Error.pm module installed anymore. So rename the
source we ship to private-Error.pm, and install that as Error.pm when
the platform does not have one already.

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

Git.pm: clean generated files.Junio C Hamano Fri, 30 Jun 2006 07:43:43 +0000 (00:43 -0700)

Git.pm: clean generated files.

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

Perly git: work around buggy make implementations.Junio C Hamano Fri, 30 Jun 2006 00:02:21 +0000 (17:02 -0700)

Perly git: work around buggy make implementations.

FC4 uses gnumake 3.80 whose annoying "Entering directory..."
messages are not silenced with -s alone.

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

Makefile: Set USE_PIC on x86-64Junio C Hamano Thu, 29 Jun 2006 05:08:54 +0000 (22:08 -0700)

Makefile: Set USE_PIC on x86-64

On some platforms, Git.xs refuses to link with the rest of git
unless the latter is compiled with -fPIC, and we have USE_PIC
control in the Makefile for the user to set it. At least we
know x86-64 is such, so set it in the Makefile.

The original suggestion by Marco Roeland conservatively did this
only for Linux x86-64, but let's keep the Makefile simple and if
it breaks somebody let them holler.

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

Perly Git: arrange include path settings properly.Junio C Hamano Wed, 28 Jun 2006 10:17:07 +0000 (03:17 -0700)

Perly Git: arrange include path settings properly.

Before "use Git" takes effect, we would need to set up the Perl
library path to point at the local installation location. So
that instruction needs to be in BEGIN{} block.

Pointed out and fixed by Pavel Roskin.

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

Add possibility to pass CFLAGS and LDFLAGS specific... Dennis Stosberg Mon, 26 Jun 2006 22:23:08 +0000 (00:23 +0200)

Add possibility to pass CFLAGS and LDFLAGS specific to the perl subdir

Signed-off-by: Dennis Stosberg <dennis@stosberg.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Git.pm: Support for perl/ being built by a different... Petr Baudis Sun, 25 Jun 2006 01:47:03 +0000 (03:47 +0200)

Git.pm: Support for perl/ being built by a different compiler

dst_ on #git reported that on Solaris 9, Perl was built by Sun CC
and perl/ is therefore being built with it as well, while the rest
of Git is built with gcc. The problem (the first one visible, anyway)
is that we passed perl/ even various gcc-specific options. This
separates those to a special variable.

This is not really meant for an application yet since it's not clear
if it will alone help anything.

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

Makefile fix for SolarisDennis Stosberg Mon, 26 Jun 2006 22:21:07 +0000 (00:21 +0200)

Makefile fix for Solaris

Solaris' /bin/sh does not support $( )-style command substitution

Signed-off-by: Dennis Stosberg <dennis@stosberg.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

"test" in Solaris' /bin/sh does not support -eDennis Stosberg Mon, 26 Jun 2006 08:27:54 +0000 (10:27 +0200)

"test" in Solaris' /bin/sh does not support -e

Running "make clean" currently fails:
[ ! -e perl/Makefile ] || make -C perl/ clean
/bin/sh: test: argument expected
make: *** [clean] Error 1

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

Git.pm: Fix Git->repository("/somewhere/totally/elsewhere")Petr Baudis Sun, 25 Jun 2006 01:54:28 +0000 (03:54 +0200)

Git.pm: Fix Git->repository("/somewhere/totally/elsewhere")

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

Git.pm: Swap hash_object() parametersPetr Baudis Sun, 25 Jun 2006 01:54:26 +0000 (03:54 +0200)

Git.pm: Swap hash_object() parameters

I'm about to introduce get_object() and it will be better for consistency
if the object type always goes first. And writing 'blob' there explicitly
is not much bother.

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

Git.pm: Try to support ActiveState output pipePetr Baudis Sun, 25 Jun 2006 01:54:23 +0000 (03:54 +0200)

Git.pm: Try to support ActiveState output pipe

The code is stolen from git-annotate and completely untested since
I don't have access to any Microsoft operating system now. Someone
ActiveState-savvy should look at it anyway and try to implement
the input pipe as well, if it is possible at all; also, the implementation
seems to be horribly whitespace-unsafe.

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

Git.pm: tentative fix to test the freshly built Git.pmJunio C Hamano Sun, 25 Jun 2006 02:41:03 +0000 (19:41 -0700)

Git.pm: tentative fix to test the freshly built Git.pm

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

Git.pm: assorted build related fixes.Petr Baudis Sun, 25 Jun 2006 01:35:12 +0000 (18:35 -0700)

Git.pm: assorted build related fixes.

- We passed our own *.a archives as LIBS to the submake that runs
in perl/; separate LIBS and EXTLIBS and pass the latter which
tells what the system libraries are used.

- The quoting of preprocesor symbol definitions passed down to
perl/ submake was loose and we lost double quotes around
include directives. Use *_SQ to quote them properly.

- The installation location of perl/ submake is not
architecture neutral anymore, so use SITEARCH instead of
SITELIB.

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

perl: fix make cleanJunio C Hamano Sat, 24 Jun 2006 12:16:17 +0000 (05:16 -0700)

perl: fix make clean

When perl/Makefile is stale with respect to perl/Makefile.PL, it
prevents "make clean" from completing which is quite irritating.
Fix it by calling subdirectory make clean twice as needed.

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

Perl interface: make testsuite work again.Junio C Hamano Sat, 24 Jun 2006 00:56:11 +0000 (17:56 -0700)

Perl interface: make testsuite work again.

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

Perl interface: add build-time configuration to allow... Junio C Hamano Sat, 24 Jun 2006 00:57:48 +0000 (17:57 -0700)

Perl interface: add build-time configuration to allow building with -fPIC

On x86-64 it seems that Git.xs does not link without compiling
the main git objects with -fPIC.

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

Convert git-mv to use Git.pmPetr Baudis Sat, 24 Jun 2006 02:34:53 +0000 (04:34 +0200)

Convert git-mv to use Git.pm

Fairly straightforward.

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

Git.pm: Add support for subdirectories inside of workin... Petr Baudis Sat, 24 Jun 2006 02:34:51 +0000 (04:34 +0200)

Git.pm: Add support for subdirectories inside of working copies

This patch adds support for subdirectories inside of working copies;
you can specify them in the constructor either as the Directory
option (it will just get autodetected using rev-parse) or explicitly
using the WorkingSubdir option. This makes Git->repository() do the
exact same path setup and repository lookup as the Git porcelain
does.

This patch also introduces repo_path(), wc_path() and wc_subdir()
accessor methods and wc_chdir() mutator.

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

Git.pm: Implement options for the command interfacePetr Baudis Sat, 24 Jun 2006 02:34:49 +0000 (04:34 +0200)

Git.pm: Implement options for the command interface

This gives the user a way to easily pass options to the command routines.
Currently only the STDERR option is implemented and can be used to adjust
what shall be done with error output of the called command (most usefully,
it can be used to silence it).

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

Git.pm: Enhance the command_pipe() mechanismPetr Baudis Sat, 24 Jun 2006 02:34:47 +0000 (04:34 +0200)

Git.pm: Enhance the command_pipe() mechanism

Rename command_pipe() to command_output_pipe(), outsource
the functionality to _command_common_pipe().

Add command_input_pipe().

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

Git.pm: Handle failed commands' outputPetr Baudis Sat, 24 Jun 2006 02:34:44 +0000 (04:34 +0200)

Git.pm: Handle failed commands' output

Currently if an external command returns error exit code, a generic exception
is thrown and there is no chance for the caller to retrieve the command's
output.

This patch introduces a Git::Error::Command exception class which is thrown
in this case and contains both the error code and the captured command output.
You can use the new git_cmd_try statement to fatally catch the exception
while producing a user-friendly message.

It also adds command_close_pipe() for easier checking of exit status of
a command we have just a pipe handle of. It has partial forward dependency
on the next patch, but basically only in the area of documentation.

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

Git.pm: Better error handlingPetr Baudis Sat, 24 Jun 2006 02:34:42 +0000 (04:34 +0200)

Git.pm: Better error handling

So far, errors just killed the whole program and in case of an error
inside of libgit it would be totally uncatchable. This patch makes
Git.pm throw standard Perl exceptions instead. In the future we might
subclass Error to Git::Error or something but for now Error::Simple
is more than enough.

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

Add Error.pm to the distributionPetr Baudis Sat, 24 Jun 2006 02:34:40 +0000 (04:34 +0200)

Add Error.pm to the distribution

I have been thinking about how to do the error reporting the best
way and after scraping various overcomplicated concepts, I have
decided that by far the most elegant way is to throw Error exceptions;
the closest sane alternative is to catch the dies in Git.pm by
enclosing the calls in eval{}s and that's really _quite_ ugly.

The only "small" trouble is that Error.pm turns out sadly not to be
part of the standard distribution, and installation from CPAN is
a bother, especially if you can't install it system-wide. But since
it is very small, I've decided to just bundle it.

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

Git.pm: Implement Git::version()Petr Baudis Sat, 24 Jun 2006 02:34:36 +0000 (04:34 +0200)

Git.pm: Implement Git::version()

Git::version() returns the Git version string.

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

Git.pm: Call external commands using execv_git_cmd()Petr Baudis Sat, 24 Jun 2006 02:34:34 +0000 (04:34 +0200)

Git.pm: Call external commands using execv_git_cmd()

Instead of explicitly using the git wrapper to call external commands,
use the execv_git_cmd() function which will directly call whatever
needs to be called. GitBin option becomes useless so drop it.

This actually means the exec_path() thing I planned to use worthless
internally, but Jakub wants it in anyway and I don't mind, so...

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

Git.pm: Implement Git::exec_path()Petr Baudis Sat, 24 Jun 2006 02:34:31 +0000 (04:34 +0200)

Git.pm: Implement Git::exec_path()

This patch implements Git::exec_path() (as a direct XS call).

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

Introduce Git.pm (v4)Petr Baudis Sat, 24 Jun 2006 02:34:29 +0000 (04:34 +0200)

Introduce Git.pm (v4)

This patch introduces a very basic and barebone Git.pm module
with a sketch of how the generic interface would look like;
most functions are missing, but this should give some good base.
I will continue expanding it.

Most desirable now is more careful error reporting, generic_in() for feeding
input to Git commands and the repository() constructor doing some poking
with git-rev-parse to get the git directory and subdirectory prefix.
Those three are basically the prerequisities for converting git-mv.
I will send them as follow-ups to this patch.

Currently Git.pm just wraps up exec()s of Git commands, but even that
is not trivial to get right and various Git perl scripts do it in
various inconsistent ways. In addition to Git.pm, there is now also
Git.xs which provides barebone Git.xs for directly interfacing with
libgit.a, and as an example providing the hash_object() function using
libgit.

This adds the Git module, integrates it to the build system and as
an example converts the git-fmt-merge-msg.perl script to it (the result
is not very impressive since its advantage is not quite apparent in this
one, but I just picked up the simplest Git user around).

Compared to v3, only very minor things were fixed in this patch (some
whitespaces, a missing export, tiny bug in git-fmt-merge-msg.perl);
at first I wanted to post them as a separate patch but since this
is still only in pu, I decided that it will be cleaner to just resend
the patch.

My current working state is available all the time at

http://pasky.or.cz/~xpasky/git-perl/Git.pm

and an irregularily updated API documentation is at

http://pasky.or.cz/~xpasky/git-perl/Git.html

Many thanks to Jakub Narebski, Junio and others for their feedback.

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

autoconf: Use autoconf to write installation directorie... Jakub Narebski Sun, 2 Jul 2006 23:56:48 +0000 (01:56 +0200)

autoconf: Use autoconf to write installation directories to config.mak.autogen

This is beginning of patch series introducing installation configuration
using autoconf (and no other autotools) to git. The idea is to generate
config.mak.autogen using ./configure (generated from configure.ac by running
autoconf) from config.mak.in, so one can use autoconf as an _alternative_ to
ordinary Makefile, and creating one's own config.mak. Local settings in
config.mak override generated settings in config.mak.autogen

This patch includes minimal configure.ac and config.mak.in, so one can set
installation directories using autoconf generated ./configure script
e.g. ./configure --prefix=/usr

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

Empty author may be presented by svn as an empty string... Robin Rosenberg Sun, 2 Jul 2006 22:21:00 +0000 (00:21 +0200)

Empty author may be presented by svn as an empty string or a null value.

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

commit.c: do not redefine UNINTERESTING bit.Junio C Hamano Sun, 2 Jul 2006 18:34:17 +0000 (11:34 -0700)

commit.c: do not redefine UNINTERESTING bit.

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

instaweb: fix unportable ';' usage in sedEric Wong Sun, 2 Jul 2006 11:56:16 +0000 (04:56 -0700)

instaweb: fix unportable ';' usage in sed

Hint taken from Johannes. I've tested this with sed --posix on
my system with GNU sed and it works fine with and also without
it. Further portability testing/review would be good.

Signed-off-by: Eric Wong <normalperson@yhbt.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Makefile: replace ugly and unportable sed invocationJohannes Schindelin Sun, 2 Jul 2006 09:31:30 +0000 (11:31 +0200)

Makefile: replace ugly and unportable sed invocation

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

Fold get_merge_bases_clean() into get_merge_bases()Rene Scharfe Sun, 2 Jul 2006 09:49:38 +0000 (11:49 +0200)

Fold get_merge_bases_clean() into get_merge_bases()

Change get_merge_bases() to be able to clean up after itself if
needed by adding a cleanup parameter.

We don't need to save the flags and restore them afterwards anymore;
that was a leftover from before the flags were moved out of the
range used in revision.c. clear_commit_marks() sets them to zero,
which is enough.

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

revision.c: fix "dense" under --remove-emptyLinus Torvalds Sun, 2 Jul 2006 17:55:59 +0000 (10:55 -0700)

revision.c: fix "dense" under --remove-empty

It had the wrong test for whether a commit was a merge. What it did was to
say that a non-merge has exactly one parent (which sounds almost right),
but the fact is, initial trees have no parent at all, but they're
obviously not merges.

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

Remove awkward compatibility wartsTimo Hirvonen Sat, 24 Jun 2006 17:28:42 +0000 (20:28 +0300)

Remove awkward compatibility warts

Signed-off-by: Timo Hirvonen <tihirvon@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

--name-only, --name-status, --check and -s are mutually... Timo Hirvonen Sat, 24 Jun 2006 17:26:49 +0000 (20:26 +0300)

--name-only, --name-status, --check and -s are mutually exclusive

Signed-off-by: Timo Hirvonen <tihirvon@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

builtin-diff: turn recursive on when defaulting to... Junio C Hamano Sun, 2 Jul 2006 05:15:40 +0000 (22:15 -0700)

builtin-diff: turn recursive on when defaulting to --patch format.

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

t4013: add "diff" UI program tests.Junio C Hamano Sun, 2 Jul 2006 05:02:17 +0000 (22:02 -0700)

t4013: add "diff" UI program tests.

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

Add git-instaweb, instantly browse the working repo... Eric Wong Sat, 1 Jul 2006 22:14:14 +0000 (15:14 -0700)

Add git-instaweb, instantly browse the working repo with gitweb

I got tired of having to configure gitweb for every repository
I work on. I sometimes prefer gitweb to standard GUIs like gitk
or gitview; so this lets me automatically configure gitweb to
browse my working repository and also opens my browser to it.

Updates from the original patch:

Added Apache/mod_perl2 compatibility if Dennis Stosberg's gitweb
has been applied, too: <20060621130708.Gcbc6e5c@leonov.stosberg.net>

General cleanups in shell code usage.

Signed-off-by: Eric Wong <normalperson@yhbt.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

gitweb: Declare global variables with "our"Dennis Stosberg Wed, 21 Jun 2006 13:07:08 +0000 (15:07 +0200)

gitweb: Declare global variables with "our"

Variables declared with "my" in the file scope cannot be accessed from
subroutines with mod_perl.

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

gitweb: Enable tree (directory) history displayLuben Tuikov Sat, 1 Jul 2006 02:11:18 +0000 (19:11 -0700)

gitweb: Enable tree (directory) history display

This patch allows history display of whole trees/directories a la
"git-rev-list HEAD -- <dir or file>". I find this useful especially
when a project lives in its own subdirectory, as opposed to being all
of the GIT repository (i.e. when a sub-project is merged into a
super-project).

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

gitweb: optimize per-file history generationJunio C Hamano Sat, 1 Jul 2006 01:54:32 +0000 (18:54 -0700)

gitweb: optimize per-file history generation

The rev-list command that is recent enough can filter commits
based on paths they touch, so use it instead of generating the
full list and limiting it by passing it with diff-tree --stdin.

[jc: The patch originally came from Luben Tuikov but the it was
corrupt, but it was short enough to be applied by hand. I
added the --full-history to make the output compatible with the
original while doing so.]

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

gitweb: Declare global variables with "our"Dennis Stosberg Wed, 21 Jun 2006 13:07:08 +0000 (15:07 +0200)

gitweb: Declare global variables with "our"

Variables declared with "my" in the file scope cannot be accessed from
subroutines with mod_perl.

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

gitweb: Enable tree (directory) history displayLuben Tuikov Sat, 1 Jul 2006 02:11:18 +0000 (19:11 -0700)

gitweb: Enable tree (directory) history display

This patch allows history display of whole trees/directories a la
"git-rev-list HEAD -- <dir or file>". I find this useful especially
when a project lives in its own subdirectory, as opposed to being all
of the GIT repository (i.e. when a sub-project is merged into a
super-project).

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

gitweb: optimize per-file history generationJunio C Hamano Sat, 1 Jul 2006 01:54:32 +0000 (18:54 -0700)

gitweb: optimize per-file history generation

The rev-list command that is recent enough can filter commits
based on paths they touch, so use it instead of generating the
full list and limiting it by passing it with diff-tree --stdin.

[jc: The patch originally came from Luben Tuikov but the it was
corrupt, but it was short enough to be applied by hand. I
added the --full-history to make the output compatible with the
original while doing so.]

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

git object hash cleanups v1.4.1Linus Torvalds Fri, 30 Jun 2006 18:20:33 +0000 (11:20 -0700)

git object hash cleanups

This IMNSHO cleans up the object hashing.

The hash expansion is separated out into a function of its own, the hash
array (and size) names are made more obvious, and the code is generally
made to look a bit more like the object-ref hashing.

It also gets rid of "find_object()" returning an index (or negative
position if no object is found), since that is made redundant by the
simplified object rehashing. The basic operation is now "lookup_object()"
which just returns the object itself.

There's an almost unmeasurable speed increase, but more importantly, I
think the end result is more readable.

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

revision.c: --full-history fix.Linus Torvalds Sat, 1 Jul 2006 03:21:59 +0000 (20:21 -0700)

revision.c: --full-history fix.

With history simplification, we still show merges that are required
to make the history _complete_, i.e. say that you had:

a
|
b
/ \
c d
| |

and neither "a" nor "b" actually changed the file, but both "c" and "d"
did: in this case we have to leave "b" around just because otherwise there
would be no way to show the _relationship_, even if "b" itself doesn't
actually change the tree in any way what-so-ever.

It would make sense to make that further simplification if the
"--parents" flag wasn't present. In that case the user is
literally asking for a list of commits and is not interested in
the relationship between them.

This patch also fixes a real bug. Without this patch, the
"--parents --full-history" combination (which you'd get if you
do something like

gitk --full-history Makefile

or similar) will actually _drop_ merges where all children are identical.
That's wrong in the --full-history case, because it means that the graph
ends up missing lots of entries.

In the process, this also should make

git-rev-list --full-history Makefile

give just the _true_ list of all commits that changed Makefile (and
properly ignore merges that were identical in one parent), because now
we're not asking for "--parent", so we don't need the unnecessary merge
commits to keep the history together.

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

Make clear_commit_marks() clean harderRene Scharfe Sat, 1 Jul 2006 23:29:58 +0000 (01:29 +0200)

Make clear_commit_marks() clean harder

Don't care if objects have been parsed or not and don't stop when we
reach a commit that is already clean -- its parents could be dirty.

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

Add '...' operator for revisionsRene Scharfe Sat, 1 Jul 2006 23:29:37 +0000 (01:29 +0200)

Add '...' operator for revisions

'A...B' is a shortcut for 'A B --not $(git-merge-base --all A B)'.
This XOR-like operation is called symmetric difference in set
theory.

The symbol '...' has been chosen because it's rather similar to the
existing '..' operator and the somewhat more natural caret ('^') is
already taken.

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

Add get_merge_bases_clean()Rene Scharfe Sat, 1 Jul 2006 23:29:26 +0000 (01:29 +0200)

Add get_merge_bases_clean()

Add get_merge_bases_clean(), a wrapper for get_merge_bases() that cleans
up after doing its work and make get_merge_bases() NOT clean up.
Single-shot programs like git-merge-base can use the dirty and fast
version.

Also move the object flags used in get_merge_bases() out of the range
defined in revision.h. This fixes the "66ae0c77...ced9456a
89719209...262a6ef7" test of the ... operator which is introduced with
the next patch.

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

Fix errno usage in connect.cPetr Baudis Sat, 1 Jul 2006 21:56:26 +0000 (23:56 +0200)

Fix errno usage in connect.c

errno was used after it could've been modified by a subsequent library call.
Spotted by Morten Welinder.

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

Minor documentation fixup.Robin Rosenberg Sun, 2 Jul 2006 00:07:40 +0000 (02:07 +0200)

Minor documentation fixup.

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

git-svn: allow a local target directory to be specified... Eric Wong Sat, 1 Jul 2006 04:42:53 +0000 (21:42 -0700)

git-svn: allow a local target directory to be specified for init

git-svn init url://to/the/repo local-repo

will create the local-repo dirrectory if doesn't exist yet and
populate it as expected.

Original patch by Luca Barbato, cleaned up and made to work for
the current version of git-svn by me (Eric Wong).

Signed-off-by: Eric Wong <normalperson@yhbt.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

don't load objects needlessly when repackingNicolas Pitre Sat, 1 Jul 2006 02:55:30 +0000 (22:55 -0400)

don't load objects needlessly when repacking

If no delta is attempted on some objects then it is useless to load them
in memory, neither create any delta index for them. The best thing to
do is therefore to load and index them only when really needed.

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

upload-pack.c: <sys/poll.h> includes <ctype.h> on OpenB... Junio C Hamano Fri, 30 Jun 2006 18:30:29 +0000 (11:30 -0700)

upload-pack.c: <sys/poll.h> includes <ctype.h> on OpenBSD 3.8

Merlyn reports that <sys/poll.h> on OpenBSD 3.8 includes <ctype.h>
and having our custom ctype (done in git-compat-util.h which is
included via cache.h) makes upload-pack.c uncompilable. Try to
work it around by including the system headers first.

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

Rename man1 and man7 variables to man1dir and man7dirJakub Narebski Thu, 29 Jun 2006 21:26:54 +0000 (23:26 +0200)

Rename man1 and man7 variables to man1dir and man7dir

This patch renames man1 and man7 variables to man1dir and man7dir,
according to "Makefile Conventions: Variables for Installation
Directories" in make.info of GNU Make.

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

Allow INSTALL, bindir, mandir to be set in main MakefileJakub Narebski Thu, 29 Jun 2006 20:11:25 +0000 (22:11 +0200)

Allow INSTALL, bindir, mandir to be set in main Makefile

Makefiles in subdirectories now use existing value of INSTALL, bindir,
mandir if it is set, allowing those to be set in main Makefile or in
included config.mak. Main Makefile exports variables which it sets.

Accidentally it renames bin to bindir in Documentation/Makefile
(should be bindir from start, but is unused, perhaps to be removed).

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

Abstract out accesses to object hash arrayLinus Torvalds Fri, 30 Jun 2006 04:38:55 +0000 (21:38 -0700)

Abstract out accesses to object hash array

There are a few special places where some programs accessed the object
hash array directly, which bothered me because I wanted to play with some
simple re-organizations.

So this patch makes the object hash array data structures all entirely
local to object.c, and the few users who wanted to look at it now get to
use a function to query how many object index entries there can be, and to
actually access the array.

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

consider previous pack undeltified object state only... Nicolas Pitre Fri, 30 Jun 2006 03:44:52 +0000 (23:44 -0400)

consider previous pack undeltified object state only when reusing delta data

Without this there would never be a chance to improve packing for
previously undeltified objects.

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

Merge branch 'jc/test-3402'Junio C Hamano Fri, 30 Jun 2006 06:47:59 +0000 (23:47 -0700)

Merge branch 'jc/test-3402'

* jc/test-3402:
Racy GIT (part #3)

Do not try futile object pairs when repacking.Linus Torvalds Thu, 29 Jun 2006 21:04:01 +0000 (14:04 -0700)

Do not try futile object pairs when repacking.

In the repacking window, if both objects we are looking at already came
from the same (old) pack-file, don't bother delta'ing them against each
other.

That means that we'll still always check for better deltas for (and
against!) _unpacked_ objects, but assuming incremental repacks, you'll
avoid the delta creation 99% of the time.

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

Racy GIT (part #3)Junio C Hamano Thu, 29 Jun 2006 21:48:22 +0000 (14:48 -0700)

Racy GIT (part #3)

Commit 29e4d3635709778bcc808dbad0477efad82f8d7e fixed the
underlying update-index races but git-commit was not careful
enough to preserve the index file timestamp when copying the
index file. This caused t3402 test to occasionally fail.

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

move get_merge_bases() to core lib.Johannes Schindelin Thu, 29 Jun 2006 13:17:32 +0000 (15:17 +0200)

move get_merge_bases() to core lib.

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

refactor merge_bases() as preparation to libify merge... Johannes Schindelin Thu, 29 Jun 2006 13:16:46 +0000 (15:16 +0200)

refactor merge_bases() as preparation to libify merge-base

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

Merge branch 'jc/diff-test-updates' into th/diffJunio C Hamano Thu, 29 Jun 2006 19:09:22 +0000 (12:09 -0700)

Merge branch 'jc/diff-test-updates' into th/diff

* jc/diff-test-updates:
t4013: note improvements brought by the new output code.

t4013: note improvements brought by the new output... Junio C Hamano Thu, 29 Jun 2006 19:00:12 +0000 (12:00 -0700)

t4013: note improvements brought by the new output code.

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

Merge branch 'jc/diff-test' into jc/diff-test-updatesJunio C Hamano Thu, 29 Jun 2006 18:52:33 +0000 (11:52 -0700)

Merge branch 'jc/diff-test' into jc/diff-test-updates

* jc/diff-test:
t4013: add format-patch tests.

Merge branch 'jc/diff-test' into th/diffJunio C Hamano Thu, 29 Jun 2006 07:30:57 +0000 (00:30 -0700)

Merge branch 'jc/diff-test' into th/diff

* jc/diff-test:
t4013: add format-patch tests.

t4013: add format-patch tests.Junio C Hamano Thu, 29 Jun 2006 07:01:07 +0000 (00:01 -0700)

t4013: add format-patch tests.

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

format-patch: fix diff format option implementationJunio C Hamano Thu, 29 Jun 2006 07:18:52 +0000 (00:18 -0700)

format-patch: fix diff format option implementation

The updates forgot to make the diff go recursive.

Merge branch 'jc/repack'Junio C Hamano Thu, 29 Jun 2006 06:43:48 +0000 (23:43 -0700)

Merge branch 'jc/repack'

* jc/repack:
git-repack: Be careful when updating the same pack as an existing one.

Merge branch 'js/patch'Junio C Hamano Thu, 29 Jun 2006 06:42:40 +0000 (23:42 -0700)

Merge branch 'js/patch'

* js/patch:
diff.c: fix get_patch_id()
t4014: fix test commit labels.
format-patch: use clear_commit_marks() instead of some ad-hockery
t4014: fix for whitespace from "wc -l"
t4014: add format-patch --ignore-if-in-upstream test
format-patch: introduce "--ignore-if-in-upstream"
add diff_flush_patch_id() to calculate the patch id

diff.c: fix get_patch_id()Junio C Hamano Thu, 29 Jun 2006 05:49:42 +0000 (22:49 -0700)

diff.c: fix get_patch_id()

The function internally generated diff to get the patch id but
passed a wrong emit flags to the xdiff layer when it did so.

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

t4014: fix test commit labels.Junio C Hamano Thu, 29 Jun 2006 05:48:34 +0000 (22:48 -0700)

t4014: fix test commit labels.

The commit tag and commit comments used in the test claimed that
the #1 commit was merged upstream where the test actually let the
upstream merge #2 commit. Fix them.

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

Improved three-way blob merging codeLinus Torvalds Thu, 29 Jun 2006 05:06:36 +0000 (22:06 -0700)

Improved three-way blob merging code

This fleshes out the code that generates a three-way merge of a set of
blobs.

It still actually does the three-way merge using an external executable
(ie just calling "merge"), but the interfaces have been cleaned up a lot
and are now fully based on the 'mmfile_t' interface, so if libxdiff were
to ever grow a compatible three-way-merge, it could probably be directly
plugged in.

It also uses the previous XDL_EMIT_COMMON functionality extension to
libxdiff to generate a made-up base file for the merge for the case where
no base file previously existed. This should be equivalent to what we
currently do in git-merge-one-file.sh:

diff -u -La/$orig -Lb/$orig $orig $src2 | git-apply --no-add

except it should be much simpler and can be done using the direct libxdiff
interfaces.

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

Prepare "git-merge-tree" for future workLinus Torvalds Wed, 28 Jun 2006 18:18:27 +0000 (11:18 -0700)

Prepare "git-merge-tree" for future work

This changes how "git-merge-tree" works in two ways:

- instead of printing things out as we walk the trees, we save the
results in memory.
- when we've walked the tree fully, we print out the results in a more
explicit way, describing the data.

This is basically preparatory work for extending the git-merge-tree
functionality in interesting directions.

In particular, git-merge-tree is also how you would create a diff between
two trees _without_ necessarily creating the merge commit itself. In other
words, if you were to just wonder what another branch adds, you should be
able to (eventually) just do

git merge-tree -p $base HEAD $otherbranch

to generate a diff of what the merge would look like. The current merge
tree already basically has all the smarts for this, and the explanation of
the results just means that hopefully somebody else than me could do the
boring work.

(You'd basically be able to do the above diff by just changing the
printout format for the explanation, and making the "changed in both"
first do a three-way merge before it diffs the result).

The other thing that the in-memory format allows is rename detection
(which the current code does not do). That's the basic reason why we don't
want to just explain the differences as we go along - because we want to
be able to look at the _other_ differences to see whether the reason an
entry got deleted in either branch was perhaps because it got added in
another place..

Rename detection should be a fairly trivial pass in between the tree
diffing and the explanation.

In the meantime, this doesn't actually do anything new, it just outputs
the information in a more verbose manner.

For an example merge, commit 5ab2c0a47574c92f92ea3709b23ca35d96319edd in
the git tree works well and shows renames, along with true removals and
additions and files that got changed in both branches. To see that as a
tree merge, do:

git-merge-tree 64e86c57 c5c23745 928e47e3

where the two last ones are the tips that got merged, and the first one is
the merge base.

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

xdiff: generate "anti-diffs" aka what is common to... Linus Torvalds Thu, 29 Jun 2006 04:57:12 +0000 (21:57 -0700)

xdiff: generate "anti-diffs" aka what is common to two files

This fairly trivial patch adds a new XDL_EMIT_xxx flag to tell libxdiff
that we don't want to generate the _diff_ between two files, we want to
see the lines that are _common_ to two files.

So when you set XDL_EMIT_COMMON, xdl_diff() will do everything exactly
like it used to do, but the output records it generates just contain the
lines that aren't part of the diff.

This is for doing things like generating the common base case for a file
that was added in both branches.

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

checkout -m: fix read-tree invocation v1.4.1-rc2Junio C Hamano Wed, 28 Jun 2006 18:47:28 +0000 (11:47 -0700)

checkout -m: fix read-tree invocation

When we updated "read-tree -m -u" to be careful about not
removing untracked working tree files, we broke "checkout -m" to
switch between branches.

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

t/README: start testing porcelainishJunio C Hamano Wed, 28 Jun 2006 18:45:52 +0000 (11:45 -0700)

t/README: start testing porcelainish

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

Merge branch 'jc/diff-test-updates' into th/diffJunio C Hamano Wed, 28 Jun 2006 11:02:46 +0000 (04:02 -0700)

Merge branch 'jc/diff-test-updates' into th/diff

* jc/diff-test-updates:
t4013 test updates for new output code.

combine-diff.c: type sanity.Junio C Hamano Wed, 28 Jun 2006 08:46:41 +0000 (01:46 -0700)

combine-diff.c: type sanity.

In diff_tree_combined(), show_log_first boolean is initialized with
rev->loginfo (pointer to a string); the intention is that if we have
some string to be emitted we would want to remember that fact. Picky
compilers are offended by this, so make the expression a bit type-safer.

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

Save errno in handle_alias()Johannes Schindelin Wed, 28 Jun 2006 10:45:27 +0000 (12:45 +0200)

Save errno in handle_alias()

git.c:main() relies on the value of errno being set by the last attempt to
execute the command. However, if something goes awry in handle_alias(),
that assumption is wrong. So restore errno before returning from
handle_alias().

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

rebase: check for errors from git-commitEric Wong Wed, 28 Jun 2006 10:24:23 +0000 (03:24 -0700)

rebase: check for errors from git-commit

commit does not always succeed, so we'll have to check for
it in the absence of set -e. This fixes a regression
introduced in 9e4bc7dd1bb9d92491c475cec55147fa0b3f954d

Signed-off-by: Eric Wong <normalperson@yhbt.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

cvsimport - cleanup of the multi-indexes handlingMartin Langhoff Wed, 28 Jun 2006 10:13:23 +0000 (22:13 +1200)

cvsimport - cleanup of the multi-indexes handling

Indexes are only needed when we are about preparing to commit. Prime them
inside commit() when we have all the info we need, and remove all the
redundant index setups.

While we are at it, make sure that index handling is correct when opening
new branches, and on initial import.

Signed-off-by: Martin Langhoff <martin@catalyst.net.nz>
Signed-off-by: Junio C Hamano <junkio@cox.net>