mirror of
				https://git.proxmox.com/git/libgit2
				synced 2025-10-20 20:57:42 +00:00 
			
		
		
		
	http: move stuff out of negotiate_fetch
Signed-off-by: Carlos Martín Nieto <carlos@cmartin.tk>
This commit is contained in:
		
							parent
							
								
									1636ba5a0d
								
							
						
					
					
						commit
						3313a05a47
					
				| @ -341,52 +341,22 @@ static int http_ls(git_transport *transport, git_headarray *array) | |||||||
| 	return GIT_SUCCESS; | 	return GIT_SUCCESS; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static int http_negotiate_fetch(git_transport *transport, git_repository *repo, git_headarray *wants) | static int setup_walk(git_revwalk **out, git_repository *repo) | ||||||
| { | { | ||||||
| 	transport_http *t = (transport_http *) transport; |  | ||||||
| 	GIT_UNUSED_ARG(list); |  | ||||||
| 	int error; |  | ||||||
| 	unsigned int i; |  | ||||||
| 	char buff[128]; |  | ||||||
| 	gitno_buffer buf; |  | ||||||
| 	git_strarray refs; |  | ||||||
| 	git_revwalk *walk; | 	git_revwalk *walk; | ||||||
|  | 	git_strarray refs; | ||||||
|  | 	unsigned int i; | ||||||
| 	git_reference *ref; | 	git_reference *ref; | ||||||
| 	git_oid oid; | 	int error; | ||||||
| 	const char *prefix = "http://", *url = t->parent.url; |  | ||||||
| 	git_buf request = GIT_BUF_INIT; |  | ||||||
| 
 |  | ||||||
| 	/* TODO: Store url in the transport */ |  | ||||||
| 	if (!git__prefixcmp(url, prefix)) |  | ||||||
| 		url += strlen(prefix); |  | ||||||
| 
 |  | ||||||
| 	error = do_connect(t, t->host, t->port); |  | ||||||
| 	if (error < GIT_SUCCESS) |  | ||||||
| 		return git__rethrow(error, "Faile to connect to host"); |  | ||||||
| 
 |  | ||||||
| 	error = gen_request(&request, url, t->host, "POST", "upload-pack"); |  | ||||||
| 	if (error < GIT_SUCCESS) |  | ||||||
| 		return git__rethrow(error, "Failed to generate request"); |  | ||||||
| 
 |  | ||||||
| 	error =  gitno_send(t->socket, request.ptr, request.size, 0); |  | ||||||
| 	if (error < GIT_SUCCESS) |  | ||||||
| 		return git__rethrow(error, "Failed to send request"); |  | ||||||
| 
 |  | ||||||
| 	error =  git_pkt_send_wants(wants, &t->caps, t->socket, 1); |  | ||||||
| 	if (error < GIT_SUCCESS) |  | ||||||
| 		return git__rethrow(error, "Failed to send wants"); |  | ||||||
| 
 |  | ||||||
| 	gitno_buffer_setup(&buf, buff, sizeof(buff), t->socket); |  | ||||||
| 
 | 
 | ||||||
| 	error = git_reference_listall(&refs, repo, GIT_REF_LISTALL); | 	error = git_reference_listall(&refs, repo, GIT_REF_LISTALL); | ||||||
| 	if (error < GIT_SUCCESS) | 	if (error < GIT_SUCCESS) | ||||||
| 		return git__rethrow(error, "Failed to list references"); | 		return git__rethrow(error, "Failed to list references"); | ||||||
| 
 | 
 | ||||||
| 	error = git_revwalk_new(&walk, repo); | 	error = git_revwalk_new(&walk, repo); | ||||||
| 	if (error < GIT_ERROR) { | 	if (error < GIT_SUCCESS) | ||||||
| 		error = git__rethrow(error, "Failed to list all references"); | 		return git__rethrow(error, "Failed to setup walk"); | ||||||
| 		goto cleanup; | 
 | ||||||
| 	} |  | ||||||
| 	git_revwalk_sorting(walk, GIT_SORT_TIME); | 	git_revwalk_sorting(walk, GIT_SORT_TIME); | ||||||
| 
 | 
 | ||||||
| 	for (i = 0; i < refs.count; ++i) { | 	for (i = 0; i < refs.count; ++i) { | ||||||
| @ -408,8 +378,54 @@ static int http_negotiate_fetch(git_transport *transport, git_repository *repo, | |||||||
| 			goto cleanup; | 			goto cleanup; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	*out = walk; | ||||||
|  | cleanup: | ||||||
| 	git_strarray_free(&refs); | 	git_strarray_free(&refs); | ||||||
| 
 | 
 | ||||||
|  | 	return error; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | static int http_negotiate_fetch(git_transport *transport, git_repository *repo, git_headarray *wants) | ||||||
|  | { | ||||||
|  | 	transport_http *t = (transport_http *) transport; | ||||||
|  | 	GIT_UNUSED_ARG(list); | ||||||
|  | 	int error; | ||||||
|  | 	unsigned int i; | ||||||
|  | 	char buff[128]; | ||||||
|  | 	gitno_buffer buf; | ||||||
|  | 	git_revwalk *walk; | ||||||
|  | 	git_oid oid; | ||||||
|  | 	const char *prefix = "http://", *url = t->parent.url; | ||||||
|  | 	git_buf request = GIT_BUF_INIT; | ||||||
|  | 	gitno_buffer_setup(&buf, buff, sizeof(buff), t->socket); | ||||||
|  | 
 | ||||||
|  | 	/* TODO: Store url in the transport */ | ||||||
|  | 	if (!git__prefixcmp(url, prefix)) | ||||||
|  | 		url += strlen(prefix); | ||||||
|  | 
 | ||||||
|  | 	error = setup_walk(&walk, repo); | ||||||
|  | 	if (error < GIT_SUCCESS) | ||||||
|  | 		return git__rethrow(error, "Failed to setup walk"); | ||||||
|  | 
 | ||||||
|  | 	do { | ||||||
|  | 		error = do_connect(t, t->host, t->port); | ||||||
|  | 		if (error < GIT_SUCCESS) | ||||||
|  | 			return git__rethrow(error, "Failed to connect to host"); | ||||||
|  | 
 | ||||||
|  | 		error = gen_request(&request, url, t->host, "POST", "upload-pack"); | ||||||
|  | 		if (error < GIT_SUCCESS) | ||||||
|  | 			return git__rethrow(error, "Failed to generate request"); | ||||||
|  | 
 | ||||||
|  | 		error =  gitno_send(t->socket, request.ptr, request.size, 0); | ||||||
|  | 		if (error < GIT_SUCCESS) | ||||||
|  | 			return git__rethrow(error, "Failed to send request"); | ||||||
|  | 
 | ||||||
|  | 		error =  git_pkt_send_wants(wants, &t->caps, t->socket, 1); | ||||||
|  | 		if (error < GIT_SUCCESS) | ||||||
|  | 			return git__rethrow(error, "Failed to send wants"); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| 		i = 0; | 		i = 0; | ||||||
| 		while ((error = git_revwalk_next(&oid, walk)) == GIT_SUCCESS) { | 		while ((error = git_revwalk_next(&oid, walk)) == GIT_SUCCESS) { | ||||||
| 			error = git_pkt_send_have(&oid, t->socket, 1); | 			error = git_pkt_send_have(&oid, t->socket, 1); | ||||||
| @ -417,8 +433,10 @@ static int http_negotiate_fetch(git_transport *transport, git_repository *repo, | |||||||
| 				return git__rethrow(error, "Failed to send have"); | 				return git__rethrow(error, "Failed to send have"); | ||||||
| 			i++; | 			i++; | ||||||
| 		} | 		} | ||||||
|  | 		if (error < GIT_SUCCESS || i >= 256) | ||||||
|  | 			break; | ||||||
|  | 	} while(1); | ||||||
| 
 | 
 | ||||||
| cleanup: |  | ||||||
| 	git_revwalk_free(walk); | 	git_revwalk_free(walk); | ||||||
| 	return error; | 	return error; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Carlos Martín Nieto
						Carlos Martín Nieto