From 41cb7488b9e5998ce1d665bbe10beca0a0f69c1c Mon Sep 17 00:00:00 2001 From: Linus Torvalds Date: Tue, 5 Jul 2005 15:44:09 -0700 Subject: Move "get_ack()" to common git_connect functions git-clone-pack will want it too. Soon. --- connect.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) (limited to 'connect.c') diff --git a/connect.c b/connect.c index 941bf296b0..075683e83c 100644 --- a/connect.c +++ b/connect.c @@ -1,6 +1,25 @@ #include "cache.h" +#include "pkt-line.h" #include +int get_ack(int fd, unsigned char *result_sha1) +{ + static char line[1000]; + int len = packet_read_line(fd, line, sizeof(line)); + + if (!len) + die("git-fetch-pack: expected ACK/NAK, got EOF"); + if (line[len-1] == '\n') + line[--len] = 0; + if (!strcmp(line, "NAK")) + return 0; + if (!strncmp(line, "ACK ", 3)) { + if (!get_sha1_hex(line+4, result_sha1)) + return 1; + } + die("git-fetch_pack: expected ACK/NAK, got '%s'", line); +} + int path_match(const char *path, int nr, char **match) { int i; -- cgit v1.2.3