fetch: add --unshallow for turning shallow repo into complete one
authorNguyễn Thái Ngọc Duy <pclouds@gmail.com>
Fri, 11 Jan 2013 09:05:46 +0000 (16:05 +0700)
committerJunio C Hamano <gitster@pobox.com>
Fri, 11 Jan 2013 17:09:30 +0000 (09:09 -0800)
commit4dcb167fc3536db0e78c50f239cd3a19afd383fa
treebce14f1a6fc52523022a0cd324659ef3e4e7801e
parent15999998fbda60552742275570947431b57108ae
fetch: add --unshallow for turning shallow repo into complete one

The user can do --depth=2147483647 (*) for restoring complete repo
now. But it's hard to remember. Any other numbers larger than the
longest commit chain in the repository would also do, but some
guessing may be involved. Make easy-to-remember --unshallow an alias
for --depth=2147483647.

Make upload-pack recognize this special number as infinite depth. The
effect is essentially the same as before, except that upload-pack is
more efficient because it does not have to traverse to the bottom
anymore.

The chance of a user actually wanting exactly 2147483647 commits
depth, not infinite, on a repository with a history that long, is
probably too small to consider. The client can learn to add or
subtract one commit to avoid the special treatment when that actually
happens.

(*) This is the largest positive number a 32-bit signed integer can
    contain. JGit and older C Git store depth as "int" so both are OK
    with this number. Dulwich does not support shallow clone.

Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Documentation/fetch-options.txt
Documentation/git-fetch-pack.txt
Documentation/technical/shallow.txt
builtin/fetch.c
commit.h
t/t5500-fetch-pack.sh
upload-pack.c