From: Petr Baudis Date: Thu, 7 Aug 2008 00:06:30 +0000 (+0200) Subject: Fail properly when cloning from invalid HTTP URL X-Git-Tag: v1.6.0-rc3~1^2~11 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=fd35e42683113e367eee0bb8ac956dde3d95edde;p=git.git Fail properly when cloning from invalid HTTP URL Currently, when cloning from invalid HTTP URL, git clone will possibly return curl error, then a confusing message about remote HEAD and then return success and leave an empty repository behind, confusing either the end-user or the automated service calling it (think repo.or.cz). This patch changes the error() calls in get_refs_via_curl() to die()s, akin to the other get_refs_*() functions. Cc: Daniel Barkalow Signed-off-by: Petr Baudis Signed-off-by: Junio C Hamano --- diff --git a/transport.c b/transport.c index 6f549b336..b3e3e61f9 100644 --- a/transport.c +++ b/transport.c @@ -463,17 +463,14 @@ static struct ref *get_refs_via_curl(struct transport *transport) run_active_slot(slot); if (results.curl_result != CURLE_OK) { strbuf_release(&buffer); - if (missing_target(&results)) { - return NULL; - } else { - error("%s", curl_errorstr); - return NULL; - } + if (missing_target(&results)) + die("%s not found: did you run git update-server-info on the server?", refs_url); + else + die("%s download error - %s", refs_url, curl_errorstr); } } else { strbuf_release(&buffer); - error("Unable to start request"); - return NULL; + die("Unable to start HTTP request"); } data = buffer.buf;