Merge branch 'jt/fetch-pack-error-reporting'

"git fetch-pack" was not prepared to accept ERR packet that the
upload-pack can send with a human-readable error message.  It
showed the packet contents with ERR prefix, so there was no data
loss, but it was redundant to say "ERR" in an error message.

* jt/fetch-pack-error-reporting:
  fetch-pack: show clearer error message upon ERR
This commit is contained in:
Junio C Hamano 2017-04-23 22:07:53 -07:00
commit d2617eb984
2 changed files with 8 additions and 1 deletions

View File

@ -351,14 +351,19 @@ ACK after 'done' if there is at least one common base and multi_ack or
multi_ack_detailed is enabled. The server always sends NAK after 'done' multi_ack_detailed is enabled. The server always sends NAK after 'done'
if there is no common base found. if there is no common base found.
Instead of 'ACK' or 'NAK', the server may send an error message (for
example, if it does not recognize an object in a 'want' line received
from the client).
Then the server will start sending its packfile data. Then the server will start sending its packfile data.
---- ----
server-response = *ack_multi ack / nak server-response = *ack_multi ack / nak / error-line
ack_multi = PKT-LINE("ACK" SP obj-id ack_status) ack_multi = PKT-LINE("ACK" SP obj-id ack_status)
ack_status = "continue" / "common" / "ready" ack_status = "continue" / "common" / "ready"
ack = PKT-LINE("ACK" SP obj-id) ack = PKT-LINE("ACK" SP obj-id)
nak = PKT-LINE("NAK") nak = PKT-LINE("NAK")
error-line = PKT-LINE("ERR" SP explanation-text)
---- ----
A simple clone may look like this (with no 'have' lines): A simple clone may look like this (with no 'have' lines):

View File

@ -276,6 +276,8 @@ static enum ack_type get_ack(int fd, unsigned char *result_sha1)
return ACK; return ACK;
} }
} }
if (skip_prefix(line, "ERR ", &arg))
die(_("remote error: %s"), arg);
die(_("git fetch-pack: expected ACK/NAK, got '%s'"), line); die(_("git fetch-pack: expected ACK/NAK, got '%s'"), line);
} }