diff options
| author | Junio C Hamano <gitster@pobox.com> | 2009-06-13 12:51:09 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2009-06-13 12:51:09 -0700 | 
| commit | fa71e80525d36ecd911bd0aca87ceb515babd1e9 (patch) | |
| tree | ee31b77eb1f90061c0391f7d9582def86e689756 /http-push.c | |
| parent | 95ad2a65fbb9b7f26669fed9906fe9a1a531810b (diff) | |
| parent | 16493eb0d0da26f80286b39c7b6900e261744afa (diff) | |
| download | git-fa71e80525d36ecd911bd0aca87ceb515babd1e9.tar.gz | |
Merge branch 'rc/maint-http-local-slot-fix'
* rc/maint-http-local-slot-fix:
  http*: cleanup slot->local after fclose
Diffstat (limited to 'http-push.c')
| -rw-r--r-- | http-push.c | 6 | 
1 files changed, 6 insertions, 0 deletions
| diff --git a/http-push.c b/http-push.c index a7e28e345f..c25c4f9176 100644 --- a/http-push.c +++ b/http-push.c @@ -724,9 +724,11 @@ static void finish_request(struct transfer_request *request)  	struct stat st;  	struct packed_git *target;  	struct packed_git **lst; +	struct active_request_slot *slot;  	request->curl_result = request->slot->curl_result;  	request->http_code = request->slot->http_code; +	slot = request->slot;  	request->slot = NULL;  	/* Keep locks active */ @@ -823,6 +825,7 @@ static void finish_request(struct transfer_request *request)  			fclose(request->local_stream);  			request->local_stream = NULL; +			slot->local = NULL;  			if (!move_temp_to_file(request->tmpfile,  					       request->filename)) {  				target = (struct packed_git *)request->userData; @@ -1024,17 +1027,20 @@ static int fetch_index(unsigned char *sha1)  		if (results.curl_result != CURLE_OK) {  			free(url);  			fclose(indexfile); +			slot->local = NULL;  			return error("Unable to get pack index %s\n%s", url,  				     curl_errorstr);  		}  	} else {  		free(url);  		fclose(indexfile); +		slot->local = NULL;  		return error("Unable to start request");  	}  	free(url);  	fclose(indexfile); +	slot->local = NULL;  	return move_temp_to_file(tmpfile, filename);  } | 
