send-pack can send a pack with loose ends to the server.  receive-pack
before 6d4bb38 (fetch: verify we have everything we need before
updating our ref - 2011-09-01) does not detect this and keeps the pack
anyway, which corrupts the repository, at least from fsck point of

send-pack will learn to safely push from a shallow repository later.

Signed-off-by: Nguyễn Thái Ngọc Duy <>
 builtin/send-pack.c | 3 +++
 1 file changed, 3 insertions(+)

diff --git a/builtin/send-pack.c b/builtin/send-pack.c
index 4482f16..51121f2 100644
--- a/builtin/send-pack.c
+++ b/builtin/send-pack.c
@@ -207,6 +207,9 @@ int cmd_send_pack(int argc, const char **argv, const char 
            (send_all && args.send_mirror))
+       if (is_repository_shallow())
+               die("attempt to push from a shallow repository");
        if (remote_name) {
                remote = remote_get(remote_name);
                if (!remote_has_url(remote, dest)) {

To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to
More majordomo info at

Reply via email to