зеркало из https://github.com/microsoft/git.git
Refactor http.h USE_CURL_MULTI fill_active_slots().
This removes all of the boilerplate and http-internal stuff from fill_active_slots() and makes it easy to turn into a callback. Signed-off-by: Daniel Barkalow <barkalow@iabervon.org> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Родитель
077d6f72c7
Коммит
45c1741235
23
http-fetch.c
23
http-fetch.c
|
@ -317,30 +317,21 @@ static void release_object_request(struct object_request *obj_req)
|
|||
}
|
||||
|
||||
#ifdef USE_CURL_MULTI
|
||||
void fill_active_slots(void)
|
||||
int fill_active_slot(void)
|
||||
{
|
||||
struct object_request *obj_req = object_queue_head;
|
||||
struct active_request_slot *slot = active_queue_head;
|
||||
int num_transfers;
|
||||
struct object_request *obj_req;
|
||||
|
||||
while (active_requests < max_requests && obj_req != NULL) {
|
||||
for (obj_req = object_queue_head; obj_req; obj_req = obj_req->next) {
|
||||
if (obj_req->state == WAITING) {
|
||||
if (has_sha1_file(obj_req->sha1))
|
||||
obj_req->state = COMPLETE;
|
||||
else
|
||||
else {
|
||||
start_object_request(obj_req);
|
||||
curl_multi_perform(curlm, &num_transfers);
|
||||
return 1;
|
||||
}
|
||||
}
|
||||
obj_req = obj_req->next;
|
||||
}
|
||||
|
||||
while (slot != NULL) {
|
||||
if (!slot->in_use && slot->curl != NULL) {
|
||||
curl_easy_cleanup(slot->curl);
|
||||
slot->curl = NULL;
|
||||
}
|
||||
slot = slot->next;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
23
http-push.c
23
http-push.c
|
@ -795,38 +795,27 @@ static void finish_request(struct transfer_request *request)
|
|||
}
|
||||
|
||||
#ifdef USE_CURL_MULTI
|
||||
void fill_active_slots(void)
|
||||
int fill_active_slot(void)
|
||||
{
|
||||
struct transfer_request *request = request_queue_head;
|
||||
struct transfer_request *next;
|
||||
struct active_request_slot *slot = active_queue_head;
|
||||
int num_transfers;
|
||||
|
||||
if (aborted)
|
||||
return;
|
||||
return 0;
|
||||
|
||||
while (active_requests < max_requests && request != NULL) {
|
||||
next = request->next;
|
||||
for (request = request_queue_head; request; request = request->next) {
|
||||
if (request->state == NEED_FETCH) {
|
||||
start_fetch_loose(request);
|
||||
return 1;
|
||||
} else if (pushing && request->state == NEED_PUSH) {
|
||||
if (remote_dir_exists[request->obj->sha1[0]] == 1) {
|
||||
start_put(request);
|
||||
} else {
|
||||
start_mkcol(request);
|
||||
}
|
||||
curl_multi_perform(curlm, &num_transfers);
|
||||
return 1;
|
||||
}
|
||||
request = next;
|
||||
}
|
||||
|
||||
while (slot != NULL) {
|
||||
if (!slot->in_use && slot->curl != NULL) {
|
||||
curl_easy_cleanup(slot->curl);
|
||||
slot->curl = NULL;
|
||||
}
|
||||
slot = slot->next;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
#endif
|
||||
|
||||
|
|
24
http.c
24
http.c
|
@ -372,6 +372,7 @@ int start_active_slot(struct active_request_slot *slot)
|
|||
{
|
||||
#ifdef USE_CURL_MULTI
|
||||
CURLMcode curlm_result = curl_multi_add_handle(curlm, slot->curl);
|
||||
int num_transfers;
|
||||
|
||||
if (curlm_result != CURLM_OK &&
|
||||
curlm_result != CURLM_CALL_MULTI_PERFORM) {
|
||||
|
@ -379,11 +380,34 @@ int start_active_slot(struct active_request_slot *slot)
|
|||
slot->in_use = 0;
|
||||
return 0;
|
||||
}
|
||||
|
||||
/*
|
||||
* We know there must be something to do, since we just added
|
||||
* something.
|
||||
*/
|
||||
curl_multi_perform(curlm, &num_transfers);
|
||||
#endif
|
||||
return 1;
|
||||
}
|
||||
|
||||
#ifdef USE_CURL_MULTI
|
||||
void fill_active_slots(void)
|
||||
{
|
||||
struct active_request_slot *slot = active_queue_head;
|
||||
|
||||
while (active_requests < max_requests)
|
||||
if (!fill_active_slot())
|
||||
break;
|
||||
|
||||
while (slot != NULL) {
|
||||
if (!slot->in_use && slot->curl != NULL) {
|
||||
curl_easy_cleanup(slot->curl);
|
||||
slot->curl = NULL;
|
||||
}
|
||||
slot = slot->next;
|
||||
}
|
||||
}
|
||||
|
||||
void step_active_slots(void)
|
||||
{
|
||||
int num_transfers;
|
||||
|
|
9
http.h
9
http.h
|
@ -71,6 +71,9 @@ extern void release_active_slot(struct active_request_slot *slot);
|
|||
#ifdef USE_CURL_MULTI
|
||||
extern void fill_active_slots(void);
|
||||
extern void step_active_slots(void);
|
||||
|
||||
/* Provided by the program using http. */
|
||||
extern int fill_active_slot(void);
|
||||
#endif
|
||||
|
||||
extern void http_init(void);
|
||||
|
@ -79,10 +82,6 @@ extern void http_cleanup(void);
|
|||
extern int data_received;
|
||||
extern int active_requests;
|
||||
|
||||
#ifdef USE_CURL_MULTI
|
||||
extern int max_requests;
|
||||
extern CURLM *curlm;
|
||||
#endif
|
||||
#ifndef NO_CURL_EASY_DUPHANDLE
|
||||
extern CURL *curl_default;
|
||||
#endif
|
||||
|
@ -103,6 +102,4 @@ extern long curl_low_speed_time;
|
|||
extern struct curl_slist *pragma_header;
|
||||
extern struct curl_slist *no_range_header;
|
||||
|
||||
extern struct active_request_slot *active_queue_head;
|
||||
|
||||
#endif /* HTTP_H */
|
||||
|
|
Загрузка…
Ссылка в новой задаче