Skip to content
  • Jeff King's avatar
    http-walker: complain about non-404 loose object errors · 3680f16f
    Jeff King authored and Junio C Hamano's avatar Junio C Hamano committed
    Since commit 17966c0a
    
     (http: avoid disconnecting on 404s
    for loose objects, 2016-07-11), we turn off curl's
    FAILONERROR option and instead manually deal with failing
    HTTP codes.
    
    However, the logic to do so only recognizes HTTP 404 as a
    failure. This is probably the most common result, but if we
    were to get another code, the curl result remains CURLE_OK,
    and we treat it as success. We still end up detecting the
    failure when we try to zlib-inflate the object (which will
    fail), but instead of reporting the HTTP error, we just
    claim that the object is corrupt.
    
    Instead, let's catch anything in the 300's or above as an
    error (300's are redirects which are not an error at the
    HTTP level, but are an indication that we've explicitly
    disabled redirects, so we should treat them as such; we
    certainly don't have the resulting object content).
    
    Note that we also fill in req->errorstr, which we didn't do
    before. Without FAILONERROR, curl will not have filled this
    in, and it will remain a blank string. This never mattered
    for the 404 case, because in the logic below we hit the
    "missing_target()" branch and print nothing. But for other
    errors, we'd want to say _something_, if only to fill in the
    blank slot in the error message.
    
    Signed-off-by: default avatarJeff King <peff@peff.net>
    Signed-off-by: default avatarJunio C Hamano <gitster@pobox.com>
    3680f16f