gitweb.git
Merge branch 'mc/sendmail'Junio C Hamano Wed, 28 Feb 2007 06:23:40 +0000 (22:23 -0800)

Merge branch 'mc/sendmail'

* mc/sendmail:
git-send-email: abort/usage on bad option

Merge branch 'js/diff-ni' (early part)Junio C Hamano Wed, 28 Feb 2007 06:18:22 +0000 (22:18 -0800)

Merge branch 'js/diff-ni' (early part)

* 'js/diff-ni' (early part):
diff --no-index: also imitate the exit status of diff(1)
Fix typo: do not show name1 when name2 fails
Teach git-diff-files the new option `--no-index`
run_diff_{files,index}(): update calling convention.
update-index: do not die too early in a read-only repository.
git-status: do not be totally useless in a read-only repository.

Merge branch 'maint'Junio C Hamano Wed, 28 Feb 2007 06:15:42 +0000 (22:15 -0800)

Merge branch 'maint'

* maint:
builtin-fmt-merge-msg: fix bugs in --file option
index-pack: Loop over pread until data loading is complete.
blameview: Fix the browse behavior in blameview
Fix minor typos/grammar in user-manual.txt
Correct ordering in git-cvsimport's option documentation
git-show: Reject native ref
Fix git-show man page formatting in the EXAMPLES section

builtin-fmt-merge-msg: fix bugs in --file optionMichael Coleman Wed, 28 Feb 2007 05:44:42 +0000 (23:44 -0600)

builtin-fmt-merge-msg: fix bugs in --file option

If --file's argument is missing, don't crash. If it cannot be opened,
die with an error message.

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

index-pack: Loop over pread until data loading is complete.Shawn O. Pearce Wed, 28 Feb 2007 04:47:19 +0000 (23:47 -0500)

index-pack: Loop over pread until data loading is complete.

A filesystem might not be able to completely supply our pread
request in one system call, such as if we are reading data from a
network file system and the requested length is just simply huge.

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

blameview: Fix the browse behavior in blameviewAneesh Kumar Mon, 26 Feb 2007 08:31:57 +0000 (14:01 +0530)

blameview: Fix the browse behavior in blameview

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

git-send-email: abort/usage on bad optionMichael Coleman Wed, 28 Feb 2007 04:47:54 +0000 (22:47 -0600)

git-send-email: abort/usage on bad option

Instead of proceeding, abort and give usage message when a bad option
is seen.

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

Fix minor typos/grammar in user-manual.txtMichael Coleman Wed, 28 Feb 2007 04:13:09 +0000 (22:13 -0600)

Fix minor typos/grammar in user-manual.txt

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

Correct ordering in git-cvsimport's option documentationMichael Poole Wed, 28 Feb 2007 03:27:44 +0000 (22:27 -0500)

Correct ordering in git-cvsimport's option documentation

A pair of commits on January 8th added option documentation (for -a,
-S and -L) in the middle of the documentation for the -A option. This
makes -A's documentation contiguous again.

Signed-off-by: Michael Poole <mdpoole@troilus.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

git-show: Reject native refLinus Torvalds Wed, 28 Feb 2007 00:22:52 +0000 (16:22 -0800)

git-show: Reject native ref

So when we do

git show v1.4.4..v1.5.0

that's an illogical thing to do, since "git show" is defined to be a
non-revision-walking action, which means the range operator be pointless
and wrong. The fact that we happily accept it (and then _only_ show
v1.5.0, which is the positive end of the range) is quite arguably not very
logical.

We should complain, and say that you can only do "no_walk" with positive
refs. Negative object refs really don't make any sense unless you walk
the obejct list (or you're "git diff" and know about ranges explicitly).

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

cvsserver: Make always-binary mode a config file optionAndy Parkins Tue, 27 Feb 2007 13:46:55 +0000 (13:46 +0000)

cvsserver: Make always-binary mode a config file option

The config option gitcvs.allbinary may be set to force all entries to
get the -kb flag.

In the future the gitattributes system will probably be a more
appropriate way of doing this, but that will easily slot in as the
entries lines sent to the CVS client now have their kopts set via the
function kopts_from_path().

In the interim it might be better to not just have a all-or-nothing
approach, but rather detect based on file extension (or file contents?).
That would slot in easily here as well. However, I personally prefer
everything to be binary-safe, so I just switch the switch.

Signed-off-by: Andy Parkins <andyparkins@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

cvsserver: Remove trailing "\n" from commithash in... Andy Parkins Tue, 27 Feb 2007 12:49:09 +0000 (12:49 +0000)

cvsserver: Remove trailing "\n" from commithash in checkin function

The commithash for updating the ref is obtained from a call to
git-commit-tree. However, it was returned (and stored) with the
trailing newline. This meant that the later call to git-update-ref that
was trying to update to $commithash was including the newline in the
parameter - obviously that hash would never exist, and so git-update-ref
would always fail.

The solution is to chomp() the commithash as soon as it is returned by
git-commit-tree.

Signed-off-by: Andy Parkins <andyparkins@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Make 'cvs ci' lockless in git-cvsserver by using git... Junio C Hamano Wed, 21 Feb 2007 05:54:39 +0000 (21:54 -0800)

Make 'cvs ci' lockless in git-cvsserver by using git-update-ref

This makes "ci" codepath lockless by following the usual
"remember the tip, do your thing, then compare and swap at the
end" update pattern using update-ref. Incidentally, by updating
the code that reads where the tip of the head is to use
show-ref, it makes it safe to use in a repository whose refs are
pack-pruned.

I noticed that other parts of the program are not yet pack-refs
safe, but tried to keep the changes to the minimum.

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

Fix git-show man page formatting in the EXAMPLES sectionTheodore Tso Tue, 27 Feb 2007 15:43:28 +0000 (10:43 -0500)

Fix git-show man page formatting in the EXAMPLES section

Fix asciidoc markup so that the man page is properly formatted in the
EXAMPLES section.

Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge branch 'maint'Junio C Hamano Tue, 27 Feb 2007 09:33:52 +0000 (01:33 -0800)

Merge branch 'maint'

* maint:
git-apply: do not fix whitespaces on context lines.
diff --cc: integer overflow given a 2GB-or-larger file
mailinfo: do not get confused with logical lines that are too long.

git-apply: do not fix whitespaces on context lines.Junio C Hamano Tue, 27 Feb 2007 09:31:42 +0000 (01:31 -0800)

git-apply: do not fix whitespaces on context lines.

Internal function apply_line() is called to copy both context lines
and added lines to the output buffer, while possibly fixing the
whitespace breakages depending on --whitespace=strip settings.
However, it did its fix-up on both context lines and added lines.

This resulted in two symptoms:

(1) The number of lines reported to have been fixed up included
these context lines.

(2) However, the lines actually shown were limited to the added
lines that had whitespace breakages.

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

diff --cc: integer overflow given a 2GB-or-larger fileJim Meyering Mon, 26 Feb 2007 23:11:35 +0000 (00:11 +0100)

diff --cc: integer overflow given a 2GB-or-larger file

Few of us use git to compare or even version-control 2GB files,
but when we do, we'll want it to work.

Reading a recent patch, I noticed two lines like this:

int len = st.st_size;

Instead of "int", that should be "size_t". Otherwise, in the
non-symlink case, with 64-bit size_t, if the file's size is 2GB,
the following xmalloc will fail:

result = xmalloc(len + 1);

trying to allocate 2^64 - 2^31 + 1 bytes (assuming sign-extension
in the int-to-size_t promotion). And even if it didn't fail, the
subsequent "result[len] = 0;" would be equivalent to an unpleasant
"result[-2147483648] = 0;"

The other nearby "int"-declared size variable, sz, should also be of
type size_t, for the same reason. If sz ever wraps around and becomes
negative, xread will corrupt memory _before_ the "result" buffer.

Signed-off-by: Jim Meyering <jim@meyering.net>
Signed-off-by: Junio C Hamano <junkio@cox.net>

mailinfo: do not get confused with logical lines that... Linus Torvalds Mon, 26 Feb 2007 19:10:59 +0000 (11:10 -0800)

mailinfo: do not get confused with logical lines that are too long.

It basically considers all the continuation lines to be lines of their
own, and if the total line is bigger than what we can fit in it, we just
truncate the result rather than stop in the middle and then get confused
when we try to parse the "next" line (which is just the remainder of the
first line).

[jc: added test, and tightened boundary a bit per list discussion.]

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

diff --no-index: also imitate the exit status of diff(1)Johannes Schindelin Sun, 25 Feb 2007 22:34:54 +0000 (23:34 +0100)

diff --no-index: also imitate the exit status of diff(1)

diff sets the exit status to 0 when no changes were found, to 1
when changes were found, and 2 means error.

We imitate this to be able to use "git diff" in the test scripts.
(Actually, keeping in line with the rest of git, -1 is returned
on error, which corresponds to an exit status 255).

To find out if the diff is not empty, a member called
"found_changes" was introduced in struct diff_options, which is
set in builtin_diff() and fn_out_consume().

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

Merge branch 'master' into js/diff-niJunio C Hamano Mon, 26 Feb 2007 09:20:42 +0000 (01:20 -0800)

Merge branch 'master' into js/diff-ni

* master: (201 commits)
Documentation: link in 1.5.0.2 material to the top documentation page.
Documentation: document remote.<name>.tagopt
GIT 1.5.0.2
git-remote: support remotes with a dot in the name
Documentation: describe "-f/-t/-m" options to "git-remote add"
diff --cc: fix display of symlink conflicts during a merge.
merge-recursive: fix longstanding bug in merging symlinks
merge-index: fix longstanding bug in merging symlinks
diff --cached: give more sensible error message when HEAD is yet to be created.
Update tests to use test-chmtime
Add test-chmtime: a utility to change mtime on files
Add Release Notes to prepare for 1.5.0.2
Allow arbitrary number of arguments to git-pack-objects
rerere: do not deal with symlinks.
rerere: do not skip two conflicted paths next to each other.
Don't modify CREDITS-FILE if it hasn't changed.
diff-patch: Avoid emitting double-slashes in textual patch.
Reword git-am 3-way fallback failure message.
Limit filename for format-patch
core.legacyheaders: Use the description used in RelNotes-1.5.0
...

Documentation: link in 1.5.0.2 material to the top... Junio C Hamano Mon, 26 Feb 2007 09:16:01 +0000 (01:16 -0800)

Documentation: link in 1.5.0.2 material to the top documentation page.

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

Documentation: document remote.<name>.tagoptAneesh Kumar K.V Sat, 24 Feb 2007 15:32:56 +0000 (21:02 +0530)

Documentation: document remote.<name>.tagopt

Update config.txt with info regarding tagopt option

Signed-off-by: Aneesh Kumar K.V <aneesh.kumar@gmail.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>

Merge branch 'maint'Junio C Hamano Mon, 26 Feb 2007 08:32:19 +0000 (00:32 -0800)

Merge branch 'maint'

* maint:
GIT 1.5.0.2
git-remote: support remotes with a dot in the name
Documentation: describe "-f/-t/-m" options to "git-remote add"
diff --cc: fix display of symlink conflicts during a merge.

GIT 1.5.0.2 v1.5.0.2Junio C Hamano Mon, 26 Feb 2007 07:58:50 +0000 (23:58 -0800)

GIT 1.5.0.2

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

git-remote: support remotes with a dot in the namePavel Roskin Wed, 21 Feb 2007 05:03:36 +0000 (00:03 -0500)

git-remote: support remotes with a dot in the name

[jc: the original from Pavel was limiting the variable names to only
fetch and url, but I loosened it to take valid variable names.]
[jc: cherry-picked from 'master', since people seem to be reinventing
this many times.]

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

Documentation: describe "-f/-t/-m" options to "git... Junio C Hamano Mon, 26 Feb 2007 07:26:11 +0000 (23:26 -0800)

Documentation: describe "-f/-t/-m" options to "git-remote add"

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

diff --cc: fix display of symlink conflicts during... Junio C Hamano Mon, 26 Feb 2007 06:24:47 +0000 (22:24 -0800)

diff --cc: fix display of symlink conflicts during a merge.

"git-diff-files --cc" to show conflicts during merge did not pass
the correct mode information for the working tree down, and showed
bogus combined diff.

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

Merge branch 'maint'Junio C Hamano Mon, 26 Feb 2007 03:10:13 +0000 (19:10 -0800)

Merge branch 'maint'

* maint:
merge-recursive: fix longstanding bug in merging symlinks
merge-index: fix longstanding bug in merging symlinks

Merge branch 'jc/merge-symlink' into maintJunio C Hamano Mon, 26 Feb 2007 03:09:59 +0000 (19:09 -0800)

Merge branch 'jc/merge-symlink' into maint

* jc/merge-symlink:
merge-recursive: fix longstanding bug in merging symlinks
merge-index: fix longstanding bug in merging symlinks

merge-recursive: fix longstanding bug in merging symlinksJunio C Hamano Mon, 26 Feb 2007 02:42:07 +0000 (18:42 -0800)

merge-recursive: fix longstanding bug in merging symlinks

Commit 3af244ca added unlink(2) before running symlink(2) to
update the working tree with the merge result, but it was
unlinking a wrong path. This resulted in loss of the path
pointed by a symlink.

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

merge-index: fix longstanding bug in merging symlinksJunio C Hamano Mon, 26 Feb 2007 02:17:15 +0000 (18:17 -0800)

merge-index: fix longstanding bug in merging symlinks

Ancient commit e2b6a9d0 added code to pass "file modes" from
merge-index to merge-one-file, and then later commit 54dd99a1
wanted to make sure we do not end up creating a nonsense symlink
that points at a path whose name contains conflict markers.

However, nobody noticed that the code in merge-index added by
e2b6a9d0 were stripping the S_IFMT bits and the code in 54dd99a1
was meaningless. This fixes it.

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

Fix typo: do not show name1 when name2 failsJohannes Schindelin Sun, 25 Feb 2007 22:34:31 +0000 (23:34 +0100)

Fix typo: do not show name1 when name2 fails

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

diff --cached: give more sensible error message when... Junio C Hamano Sun, 25 Feb 2007 06:26:33 +0000 (22:26 -0800)

diff --cached: give more sensible error message when HEAD is yet to be created.

It is not like the user said 'diff --cached HEAD', so complaining about
HEAD not being a valid commit, while technically might be correct, is
not very helpful.

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

Update tests to use test-chmtimeEric Wong Sun, 25 Feb 2007 00:59:52 +0000 (16:59 -0800)

Update tests to use test-chmtime

test-lib:
Make sure test-chmtime has been built before starting.

t4200-rerere:
Removed non-portable date dependency and avoid touch
Avoid "test -a" which isn't portable, either

lib-git-svn:
Use test-chmtime instead of Perl one-liner to poke

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

Add test-chmtime: a utility to change mtime on filesEric Wong Sun, 25 Feb 2007 02:18:22 +0000 (18:18 -0800)

Add test-chmtime: a utility to change mtime on files

This is intended to be a portable replacement for our usage
of date(1), touch(1), and Perl one-liners in tests.

Usage: test-chtime (+|=|-|=+|=-)<seconds> <file>..."

'+' increments the mtime on the files by <seconds>
'-' decrements the mtime on the files by <seconds>
'=' sets the mtime on the file to exactly <seconds>
'=+' and '=-' sets the mtime on the file to <seconds> after or
before the current time.

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

Merge branch 'maint'Junio C Hamano Sun, 25 Feb 2007 19:08:47 +0000 (11:08 -0800)

Merge branch 'maint'

* maint:
Add Release Notes to prepare for 1.5.0.2
Allow arbitrary number of arguments to git-pack-objects
rerere: do not deal with symlinks.
rerere: do not skip two conflicted paths next to each other.
Don't modify CREDITS-FILE if it hasn't changed.

Add Release Notes to prepare for 1.5.0.2Junio C Hamano Sun, 25 Feb 2007 18:53:42 +0000 (10:53 -0800)

Add Release Notes to prepare for 1.5.0.2

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

Allow arbitrary number of arguments to git-pack-objectsRoland Dreier Sun, 25 Feb 2007 17:34:27 +0000 (09:34 -0800)

Allow arbitrary number of arguments to git-pack-objects

If a repository ever gets in a situation where there are too many
packs (more than 60 or so), perhaps because of frequent use of
git-fetch -k or incremental git-repack, then it becomes impossible to
fully repack the repository with git-repack -a. That command just
dies with the cryptic message

fatal: too many internal rev-list options

This message comes from git-pack-objects, which is passed one command
line option like --unpacked=pack-<SHA1>.pack for each pack file to be
repacked. However, the current code has a static limit of 64 command
line arguments and just aborts if more arguments are passed to it.

Fix this by dynamically allocating the array of command line
arguments, and doubling the size each time it overflows.

Signed-off-by: Roland Dreier <roland@digitalvampire.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

rerere: do not deal with symlinks.Junio C Hamano Sun, 25 Feb 2007 09:29:43 +0000 (01:29 -0800)

rerere: do not deal with symlinks.

Who would use multi-line symlinks that would benefit from rerere?
Just ignore them.

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

rerere: do not skip two conflicted paths next to each... Junio C Hamano Sun, 25 Feb 2007 09:24:34 +0000 (01:24 -0800)

rerere: do not skip two conflicted paths next to each other.

The code forgot to take the for (;;) loop control into account,
incrementing the index once too many.

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

Merge git://repo.or.cz/git-gui into maintJunio C Hamano Sun, 25 Feb 2007 07:33:12 +0000 (23:33 -0800)

Merge git://repo.or.cz/git-gui into maint

* git://repo.or.cz/git-gui:
Don't modify CREDITS-FILE if it hasn't changed.

Don't modify CREDITS-FILE if it hasn't changed.Junio C Hamano Sun, 25 Feb 2007 07:18:11 +0000 (02:18 -0500)

Don't modify CREDITS-FILE if it hasn't changed.

We should always avoid rewriting a built file during `make install`
if nothing has changed since `make all`. This is to help support
the typical installation process of compiling a package as yourself,
then installing it as root.

Forcing CREDITS-FILE to be always be rebuilt in the Makefile means
that CREDITS-GEN needs to check for a change and only update
CREDITS-FILE if the file content actually differs. After all,
content is king in Git.

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

Evil Merge branch 'jc/status' (early part) into js... Junio C Hamano Sat, 24 Feb 2007 10:20:13 +0000 (02:20 -0800)

Evil Merge branch 'jc/status' (early part) into js/diff-ni

* 'jc/status' (early part):
run_diff_{files,index}(): update calling convention.
update-index: do not die too early in a read-only repository.
git-status: do not be totally useless in a read-only repository.

This is to resolve semantic conflict (which is not textual) that
changes the calling convention of run_diff_files() early.

Merge branch 'js/apply'Junio C Hamano Sat, 24 Feb 2007 10:00:32 +0000 (02:00 -0800)

Merge branch 'js/apply'

* js/apply:
apply: make --verbose a little more useful

Merge branch 'js/no-limit-boundary'Junio C Hamano Sat, 24 Feb 2007 09:47:56 +0000 (01:47 -0800)

Merge branch 'js/no-limit-boundary'

* js/no-limit-boundary:
rev-list --max-age, --max-count: support --boundary

Merge branch 'js/etc-config'Junio C Hamano Sat, 24 Feb 2007 09:43:28 +0000 (01:43 -0800)

Merge branch 'js/etc-config'

* js/etc-config:
Make tests independent of global config files
config: read system-wide defaults from /etc/gitconfig

Merge branch 'maint'Junio C Hamano Sat, 24 Feb 2007 09:42:06 +0000 (01:42 -0800)

Merge branch 'maint'

* maint:
diff-patch: Avoid emitting double-slashes in textual patch.
Reword git-am 3-way fallback failure message.
Limit filename for format-patch
core.legacyheaders: Use the description used in RelNotes-1.5.0
git-show-ref --verify: Fail if called without a reference

Conflicts:

builtin-show-ref.c
diff.c

diff-patch: Avoid emitting double-slashes in textual... Junio C Hamano Fri, 23 Feb 2007 11:44:30 +0000 (03:44 -0800)

diff-patch: Avoid emitting double-slashes in textual patch.

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

Reword git-am 3-way fallback failure message.Junio C Hamano Sat, 24 Feb 2007 09:05:27 +0000 (01:05 -0800)

Reword git-am 3-way fallback failure message.

When the blobs recorded on the index lines in the patch as pre-image
blobs are not found in the repository, "git-am" punted saying
that the index line does not record anything useful. This was not
clear enough -- the index line does have something useful but the
problem was that it was not useful in _that_ repository.

Reword the message as Francis Moreau suggests.

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

Limit filename for format-patchRobin Rosenberg Fri, 23 Feb 2007 22:27:58 +0000 (23:27 +0100)

Limit filename for format-patch

Badly formatted commits may have very long comments. This causes
git-format-patch to fail. To avoid that, truncate the filename
to a value we believe will always work.

Err out if the patch file cannot be created.

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

core.legacyheaders: Use the description used in RelNote... Santi Béjar Fri, 23 Feb 2007 16:03:43 +0000 (17:03 +0100)

core.legacyheaders: Use the description used in RelNotes-1.5.0

It explains what it does and why, and says how to use the new format.

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

git-show-ref --verify: Fail if called without a referenceDmitry V. Levin Fri, 23 Feb 2007 17:12:33 +0000 (20:12 +0300)

git-show-ref --verify: Fail if called without a reference

builtin-show-ref.c (cmd_show_ref): Fail if called with --verify option but
without a reference.

Signed-off-by: Dmitry V. Levin <ldv@altlinux.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>

.mailmap maintenance after pulling from git-svnJunio C Hamano Fri, 23 Feb 2007 11:11:52 +0000 (03:11 -0800)

.mailmap maintenance after pulling from git-svn

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

git-svn: fix some potential bugs with --follow-parentEric Wong Fri, 23 Feb 2007 10:21:59 +0000 (02:21 -0800)

git-svn: fix some potential bugs with --follow-parent

When using do_switch:

We only need to ensure the index is clean and set to that of the
parent tree) we rely on being able to reconstruct full files
with deltas transferred over the network.

When using do_update:

We may safely unlink the index if we are fetching an entire
new tree with do_update. Having an old index (from a
previously deleted/abandoned directory) around can cause
irrelevant files to be mistakenly kept.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: fix reconnections to different paths of svn... Eric Wong Fri, 23 Feb 2007 09:57:40 +0000 (01:57 -0800)

git-svn: fix reconnections to different paths of svn:// repositories

Clearing the pool of the previous SVN::Ra connection we have
seems to to fix mysterious connection dropping errors when
reconnecting to different paths of svn:// repositories hosted by
rubyforge.org.

Note: I'm not sure *why* this fixes things things,
but it does for me.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: fix clone when a target directory has been... Eric Wong Fri, 23 Feb 2007 09:26:26 +0000 (01:26 -0800)

git-svn: fix clone when a target directory has been specified

Several bugs caused this to fail:

* GIT_DIR was set incorrectly after entering the target directory

* Avoid double chdir-ing when clone is called with an explicit path

* create target subdirectory *before* running git-init when using
the multi-init path

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: document --usernameSam Vilain Thu, 22 Feb 2007 23:32:30 +0000 (12:32 +1300)

git-svn: document --username

Also, it turns out that SVN::Ra doesn't attempt to deal with
authentication or pass the username to ssh when doing svn+ssh://
URLs

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: don't consider SVN URL usernames significant... Sam Vilain Thu, 22 Feb 2007 23:32:29 +0000 (12:32 +1300)

git-svn: don't consider SVN URL usernames significant when comparing

http://foo@blah.com/path is the same as http://blah.com/path, so
remove usernames from URLs before storing them in commits, and when
reading them from commits.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: ensure we're at the top-level and can access... Eric Wong Tue, 20 Feb 2007 09:36:30 +0000 (01:36 -0800)

git-svn: ensure we're at the top-level and can access $GIT_DIR

If we are run inside a subdirectory of a working tree, we'll
chdir to the top first before touching anything. This also
prevents the accidental creation of .git directories inside
subdirectories since they need metadata.

Noticed by maio on #git

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: give show-ignore HEAD smarts, like dcommit... Eric Wong Tue, 20 Feb 2007 08:43:19 +0000 (00:43 -0800)

git-svn: give show-ignore HEAD smarts, like dcommit and log

This allows the user to run git-svn show-ignore on there
current HEAD without needing to remember which branch/ref they
branched from with -i. Also, find_by_url should correctly
handle cases where the URL passed to it is not valid.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: allow metadata options to be specified with... Eric Wong Sun, 18 Feb 2007 10:34:09 +0000 (02:34 -0800)

git-svn: allow metadata options to be specified with 'init' and 'clone'

Since the options that affect the way metadata is handled in
git-svn, should be consistently set/unset throughout history
imported by git-svn; it makes sense to allow the user to set
certain options from the command-line that will write to the
config file when initially creating the repository.

Also, fix some formatting issues while we're updating
documentation.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: documentation updatesEric Wong Sun, 18 Feb 2007 10:10:51 +0000 (02:10 -0800)

git-svn: documentation updates

This documents the 'clone' and 'rebase' commands
of git-svn. Additionaly, examples are updated
to use them instead of the lower-level 'init' and
'fetch' commands.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: add test for useSvnsyncPropsEric Wong Sun, 18 Feb 2007 09:30:35 +0000 (01:30 -0800)

git-svn: add test for useSvnsyncProps

These tests are very similar as the ones I used for useSvmProps
and expect the same results because both dumps were generated
from the same original repo.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: fix useSvmProps, hopefully for the last timeEric Wong Sat, 17 Feb 2007 10:53:07 +0000 (02:53 -0800)

git-svn: fix useSvmProps, hopefully for the last time

svm:mirror is not useful at all for us. Parts of the old unit
test were broken and based on my misunderstanding of the
svm:mirror property.

When we read svm:source; make sure we correctly handle the '!'
in it: it is used to separate the path of the repository root
from the virtual path within the repository. We don't need
to make that distinction, honestly!

We also ensure that subdirectories are also mirrored with the
correct URL if we're using useSvmProps.

We have a new test that uses dumped repo that was really
created using SVN::Mirror to avoid ambiguities and
mis-understandings about the svm: properties.

Note: trailing whitespace in the svm.dump file is unfortunately
a reality and required by SVN; so please ignore it when applying
this patch.

Also, ensure that the -R/--remote/--svn-remote flag is always
in effect if explicitly passed via the command-line. This
allows us to track logically different mirrors sharing the
same URL (probably common with SVN::Mirror/SVK users).

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: add support for using svnsync propertiesEric Wong Sat, 17 Feb 2007 03:57:29 +0000 (19:57 -0800)

git-svn: add support for using svnsync properties

This is similar to useSvmProps, but far simpler in
implementation because svnsync retains a 1:1
between revision numbers and relative paths within
the repository

Config keys: svn.useSvnsyncProps
svn-remote.<repo>.useSvnsyncProps

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: allow overriding of the SVN repo root in metadataEric Wong Sat, 17 Feb 2007 03:15:21 +0000 (19:15 -0800)

git-svn: allow overriding of the SVN repo root in metadata

This feature allows users to create repositories from alternate
URLs. For example, an administrator could run git-svn on the
server locally (accessing via file://) but wish to distribute
the repository with a public http:// or svn:// URL in the
metadata so users of it will see the public URL.

Config key: svn-remote.<remote>.rewriteRoot

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: add 'clone' command, an alias for init + fetchEric Wong Sat, 17 Feb 2007 02:45:01 +0000 (18:45 -0800)

git-svn: add 'clone' command, an alias for init + fetch

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: hide the private git-svn 'config' file as... Eric Wong Fri, 16 Feb 2007 12:09:28 +0000 (04:09 -0800)

git-svn: hide the private git-svn 'config' file as '.metadata'

Having it named as 'config' prevents us from tracking a
ref named 'config', which is a huge mistake.

On the non-technical side, the word 'config' implies that
a user can freely modify it; but that's not the case
here.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: fix some issues for people migrating from... Eric Wong Fri, 16 Feb 2007 12:05:33 +0000 (04:05 -0800)

git-svn: fix some issues for people migrating from older versions

* Fixed logic for renaming old .rev_db -> .rev_db.$uuid

* correctly handle manual migrations for those who decide to
start use globbing to handle branches/tags over individual
'fetch' keys

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: add a 'rebase' commandEric Wong Fri, 16 Feb 2007 11:22:40 +0000 (03:22 -0800)

git-svn: add a 'rebase' command

This works similarly to 'svn update' or 'git pull' except that
it preserves linear history with 'git rebase' instead of 'git
merge' for ease of dcommit-ing with git-svn.

While we're at it, put the working_head_info() logic
into its own function and allow --fetch-all/--all for
dcommit and rebase (which will fetch all refs in the
current [svn-remote] instead of just the working one).

Note that the '-a' switch (short for --fetch-all/--all) has been
removed as it conflicts with the non-svn 'git fetch'

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: checkout files on new fetchesEric Wong Fri, 16 Feb 2007 09:45:13 +0000 (01:45 -0800)

git-svn: checkout files on new fetches

On newly-created repositories, 'refs/heads/master' does not
point to anything. This can be confusing to new users; so we
update 'master' to point to the last imported ref after fetching
is done.

Once 'master' is valid; we assume HEAD points to it; and if
the repository is not bare, then checkout the files if the
working tree is clean and unused.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: add support for --stat in the log commandEric Wong Thu, 15 Feb 2007 08:40:42 +0000 (00:40 -0800)

git-svn: add support for --stat in the log command

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: documentation updates for new functionalityEric Wong Thu, 15 Feb 2007 03:34:56 +0000 (19:34 -0800)

git-svn: documentation updates for new functionality

Force the showing of the --minimize flag as an option in the
'migrate' help.

Also, fix the usage function to correctly filter out
the deprecated aliases.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: allow dcommit for those who only fetch from... Eric Wong Thu, 15 Feb 2007 02:47:16 +0000 (18:47 -0800)

git-svn: allow dcommit for those who only fetch from SVM with useSvmProps

This allows users to use SVM (SVN::Mirror) to mirror a remote
repository to use dcommit to commit to the repository that SVM
was mirroring. When dcommit is used in this manner, the automatic
fetch + rebase/reset does not happen; in which case the user will
have to manually invoke svm/svk, run 'git svn fetch', and finally
'git rebase'.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: error checking for invalid [svn-remote ".... Eric Wong Thu, 15 Feb 2007 02:38:46 +0000 (18:38 -0800)

git-svn: error checking for invalid [svn-remote "..."] sections

We don't end up trying to pass an undef URL over to SVN::Ra->new
because it'll segfault.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: remember to check for clean indices on globbed... Eric Wong Thu, 15 Feb 2007 00:29:52 +0000 (16:29 -0800)

git-svn: remember to check for clean indices on globbed refs, too

Also, warn about dirty indices and avoid an unncessary
write-tree call if the index is clean.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: allow --log-window-size to be specified, defau... Eric Wong Thu, 15 Feb 2007 00:04:10 +0000 (16:04 -0800)

git-svn: allow --log-window-size to be specified, default to 100

The newer default value should should lower memory usage for
large fetches and also help with fetching from less reliable
servers. Previously the value was 1000 and memory usage
got a bit high on some repositories and fetching became
less reliable in some cases.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: simplify the (multi-)init methods of fetchingEric Wong Wed, 14 Feb 2007 23:10:44 +0000 (15:10 -0800)

git-svn: simplify the (multi-)init methods of fetching

Also, some changes to avoid creating dead dirs under
.git/svn/. We now create all directories as late as
possible.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: brown paper bag fixesEric Wong Wed, 14 Feb 2007 21:32:21 +0000 (13:32 -0800)

git-svn: brown paper bag fixes

* avoid skipping modification-only changes in fetch
* correctly fetch when we only have branches and tags
to glob from (no fetch keys defined)

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: allow 'init' to act as multi-initEric Wong Wed, 14 Feb 2007 20:27:41 +0000 (12:27 -0800)

git-svn: allow 'init' to act as multi-init

multi-init is now just an alias that requires -T/-t/-b;
all options that 'init' can now accept.

This will hopefully simplify usage and reduce typing.

Also, allow the --shared option in 'init' to take an optional
argument now that 'git-init --shared' supports an optional
argument.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: hopefully make 'fetch' more user-friendlyEric Wong Wed, 14 Feb 2007 10:21:19 +0000 (02:21 -0800)

git-svn: hopefully make 'fetch' more user-friendly

multi-fetch is deprecated, "fetch -a" is easier to type
By default, fetch will fetch everything from its default
[svn-remote]; if fetch [--all|-a] is specified, then it will
fetch from all svn remotes. Refspecs on the command-line
(like git-fetch) are not supported.

Also, enable -r/--revision arguments for fetch so
users can shoot themselves in the foot^W^W^W^W^W
skip some history and do the equivalent of a shallow
clone/fetch they're not interested in.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

t910*: s/repo-config/config/g; poke around possible... Eric Wong Wed, 14 Feb 2007 01:38:58 +0000 (17:38 -0800)

t910*: s/repo-config/config/g; poke around possible race conditions

Some of the repo-config => config renaming missed the git-svn
tests; so I'm just renaming them to be consisten with the
rest of the modern git.

Also, some of the newer tests didn't have 'poke' in them
to workaround race conditions on fast machines. This adds
places where they can _possibly_ occur; but I don't have
fast enough hardware to trigger them.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: usability fixes for the 'git svn log' commandEric Wong Wed, 14 Feb 2007 01:09:40 +0000 (17:09 -0800)

git-svn: usability fixes for the 'git svn log' command

Similar in spirit to the recent dcommit change, we now
look at 'HEAD' by default to look for a GIT_SVN_ID
so the user won't have to pass -i <GIT_SVN_ID> argument.

We are also more tolerant of of people passing bare remote names
as a result (just $GIT_SVN_ID without the -i)

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: include merges when calling rev-list for decommitEric Wong Tue, 13 Feb 2007 23:56:08 +0000 (15:56 -0800)

git-svn: include merges when calling rev-list for decommit

Merge commits can be created when following certain parents,
(most notably 'R' cases) and we definitely don't want to exclude
them.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: make dcommit usable for glob usersEric Wong Tue, 13 Feb 2007 22:22:11 +0000 (14:22 -0800)

git-svn: make dcommit usable for glob users

* dcommit no longer requires the correct -i/GIT_SVN_ID option
passed to it. Since you're committing from HEAD (or another
commit that is a parent of HEAD), you'll be able to find
a commit with metadata information containing the SVN URL
that your HEAD was descended from anyways.

* I don't think dcommit ever worked for people using the
noMetadata option; so I don't think relying on metadata
is an issue.

* useSvmProps users shouldn't commit to SVN::Mirror created
repositories anyways, right?

* Users of globbing should automatically be able to commit
to paths that are not explicitly set in .git/config

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: make test for SVK mirror path importsam@vilain.net Tue, 5 Dec 2006 05:17:38 +0000 (16:17 +1100)

git-svn: make test for SVK mirror path import

A manual test that sets up a repository that looks like an SVK depot,
and then imports it to check that it looks like we mirrored the
'original' source.

There is also a minor modification to the git-svn test library shell
file which sets a variable for the subversion repository's filesystem
path.

[ew: made some of the tests stricter and more thorough]

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: handle multi-init without --trunk, UseSvmProps... Eric Wong Tue, 13 Feb 2007 08:38:02 +0000 (00:38 -0800)

git-svn: handle multi-init without --trunk, UseSvmProps fixes

multi-init did not write a svn-remote.<remote>.url config
entry without a --trunk argument.

Also, The svm:mirror property is used by SVN::Mirror to track
the path of the repository that we are mirroring. We need to
append that to the source (which is (presumably) just the URL of
the repository root).

Lastly, we now look harder for svm:(source|mirror|uuid) properties
in sub and parent directories. Since our relative path could
be tweaked.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: write the highest maxRex out for branches... Eric Wong Tue, 13 Feb 2007 00:03:32 +0000 (16:03 -0800)

git-svn: write the highest maxRex out for branches and tags

Even if nothing touched paths we care about in a fetch;
increment the maxRev like we do with rev_db since
we don't like having to run get_log on revisions we've
seen before.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: use separate, per-repository .rev_db filesEric Wong Mon, 12 Feb 2007 21:25:25 +0000 (13:25 -0800)

git-svn: use separate, per-repository .rev_db files

We need a separate .rev_db file for each repository we're
tracking. This allows us to track the same logical path off
multiple mirrors. We preserve a symlink to the old .rev_db
(no-UUID) if we're (auto-)migrating from an old version to
preserve backwards compatibility.

Also, get rid of the uuid() wrapper since we cache UUID in our
private config, and the SVN::Ra::get_uuid() function memoizes
the return value per-connection.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: extra safety for noMetadata and useSvmProps... Eric Wong Sun, 11 Feb 2007 23:21:24 +0000 (15:21 -0800)

git-svn: extra safety for noMetadata and useSvmProps users

Make sure we flush our userspace buffers and and fsync(2)
.rev_db information to disk if we use these options because
we really don't want to lose this information.

Also, disallow --use-svm-props and --no-metadata from the
command-line because history will be inconsistent if they're
only used occasionally. If a user wants to use these options,
they must be set in the config so they're always on.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: use private $GIT_DIR/svn/config file moreEric Wong Sun, 11 Feb 2007 09:20:26 +0000 (01:20 -0800)

git-svn: use private $GIT_DIR/svn/config file more

Switch max_rev storage over to using it for globbing
branches and tags.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: add support for per-[svn-remote "..."] optionsEric Wong Sun, 11 Feb 2007 08:51:33 +0000 (00:51 -0800)

git-svn: add support for per-[svn-remote "..."] options

Available options are currently:

svn-remote.<remote>.{noMetadata,useSvmProps,followParent}

These boolean switches will override options set globally in
[svn], and even override options set on the command-line (this
should probably change in the future, however).

Note that the noMetadata and useSvmProps options conflict. It's
both technically and logically impossible to use them together.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: add support for SVN::Mirror/svk using revprops... Eric Wong Sun, 11 Feb 2007 04:46:50 +0000 (20:46 -0800)

git-svn: add support for SVN::Mirror/svk using revprops for metadata

Pass --use-svm-props or set the svn.usesvmprops key with git-config
to enable using properties set by SVN::Mirror when it mirrored the
upstream URL.

This is heavily based on work from Sam Vilain:
> From: Sam Vilain <sam@vilain.net>
> Date: Sun, 11 Feb 2007 12:34:45 +1300
> Subject: [PATCH] git-svn: re-map repository URLs and UUIDs on SVK mirror paths
>
> If an SVN revision has a property, "svm:headrev", it is likely that
> the revision was created by SVN::Mirror (a part of SVK). The property
> contains a repository UUID and a revision. We want to make it look
> like we are mirroring the original URL, so introduce a helper function
> that returns the original identity URL and UUID, and use it when
> generating commit messages.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: remove optimized commit stuff for set-treeEric Wong Sat, 10 Feb 2007 21:58:33 +0000 (13:58 -0800)

git-svn: remove optimized commit stuff for set-tree

I may resurrect it for dcommit at some point, but nobody really
uses set-tree anymore and I don't feel like introducing more
complexity into the code at this point.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: correctly handle globs with a right-hand-side... Eric Wong Sat, 10 Feb 2007 21:28:50 +0000 (13:28 -0800)

git-svn: correctly handle globs with a right-hand-side path component

Several bugs were found and fixed while getting this to work:

* Remember the 'R'(eplace) case of actions and treat it like we
would an 'A'(dd) case.

* Fix a small case of follow-parent missing a parent if a
subdirectory was modified in the revision where the parent was
copied.

* dirents returned by get_dir sometimes expire if the data
structure is too big and the pool is destroyed, so we
cache get_dir (along with check_path and get_revprops)
temporarily along with its pool.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: correctly handle the -q flag in SVN::Git:... Eric Wong Fri, 9 Feb 2007 20:23:47 +0000 (12:23 -0800)

git-svn: correctly handle the -q flag in SVN::Git::Fetcher

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: fix buggy regular expression usage in several... Eric Wong Fri, 9 Feb 2007 20:17:57 +0000 (12:17 -0800)

git-svn: fix buggy regular expression usage in several places

I incorrectly used $path/? and $path/* to strip off leading
directories, but places where $path = 'branches/0.17' would
incorrectly strip changes to 'branches/0.17.1' as well.

For globs, we require that our '*' is its own path component
(surrounded by '/' or nothing). Enforce this when --prefix= is
passed to us, too.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: enable follow-parent functionality by defaultEric Wong Fri, 9 Feb 2007 10:45:03 +0000 (02:45 -0800)

git-svn: enable follow-parent functionality by default

--no-follow-parent disables and reverts it back to the old
default behavior of not following parents (if you don't care for
full history).

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: remove some noisy debugging messagesEric Wong Fri, 9 Feb 2007 10:32:48 +0000 (02:32 -0800)

git-svn: remove some noisy debugging messages

We don't need them anymore, all the rough points of
the --follow-parent implementation have been worked out.

The only improvement in the future will probably be
--follow-parent-harder, which will track subdirectories and
follow individual file history (so annotate/blame can be
complete); but that is still a ways off.

Signed-off-by: Eric Wong <normalperson@yhbt.net>

git-svn: remove check_path calls before calling do_updateEric Wong Fri, 9 Feb 2007 10:19:41 +0000 (02:19 -0800)

git-svn: remove check_path calls before calling do_update

These checks were needed before git-svn got smarter about
match_paths() and using path information returned by get_log().
We also have extra checking against fetching revisions
out-of-order these days; so we don't have to worry about that as
much. We also check for tree deletions in match_paths() and
skip those as well.

Signed-off-by: Eric Wong <normalperson@yhbt.net>