Currently, git PUTs to /repo.git/objects/1a/1a2b...9z_opaquelocktoken:1234-.... On some platforms, ':' isn't allowed in filenames so the PUT fails. This seems to be an (faulty) implementation of the opaquelocktoken URI scheme (http://www.webdav.org/specs/rfc4918.html#RFC2518). PUT now sends the object to the url /repo.git/objects/1a/1a2b...9z , without the trailing '_opaquelocktoken:1234-....', with an additional "If: (<opaquelocktoken:1234-....>)" header. Signed-off-by: Tay Ray Chuan <rctay89@xxxxxxxxx> --- http-push.c | 7 +++++++ 1 files changed, 7 insertions(+), 0 deletions(-) diff --git a/http-push.c b/http-push.c index c9ba07e..4517cf2 100644 --- a/http-push.c +++ b/http-push.c @@ -480,7 +480,9 @@ static void start_put(struct transfer_request *request) { char *hex = sha1_to_hex(request->obj->sha1); struct active_request_slot *slot; + struct curl_slist *dav_headers = NULL; char *posn; + char *if_header; enum object_type type; char hdr[50]; void *unpacked; @@ -535,6 +537,10 @@ static void start_put(struct transfer_request *request) *(posn++) = '_'; strcpy(posn, request->lock->token); + if_header = xmalloc(strlen(request->lock->token) + 25); + sprintf(if_header, "If: <%s>", request->lock->token); + dav_headers = curl_slist_append(dav_headers, if_header); + slot = get_active_slot(); slot->callback_func = process_response; slot->callback_data = request; @@ -546,6 +552,7 @@ static void start_put(struct transfer_request *request) curl_easy_setopt(slot->curl, CURLOPT_UPLOAD, 1); curl_easy_setopt(slot->curl, CURLOPT_PUT, 1); curl_easy_setopt(slot->curl, CURLOPT_NOBODY, 0); + curl_easy_setopt(slot->curl, CURLOPT_HTTPHEADER, dav_headers); curl_easy_setopt(slot->curl, CURLOPT_URL, request->url); if (start_active_slot(slot)) { -- 1.5.6.3 -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html