Browse Source

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>
maint
Daniel Barkalow 17 years ago committed by Junio C Hamano
parent
commit
45c1741235
  1. 23
      http-fetch.c
  2. 23
      http-push.c
  3. 24
      http.c
  4. 9
      http.h

23
http-fetch.c

@ -317,30 +317,21 @@ static void release_object_request(struct object_request *obj_req) @@ -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);
}
obj_req = obj_req->next;
}

while (slot != NULL) {
if (!slot->in_use && slot->curl != NULL) {
curl_easy_cleanup(slot->curl);
slot->curl = NULL;
return 1;
}
}
slot = slot->next;
}
return 0;
}
#endif


23
http-push.c

@ -795,38 +795,27 @@ static void finish_request(struct transfer_request *request) @@ -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);
}
request = next;
}

while (slot != NULL) {
if (!slot->in_use && slot->curl != NULL) {
curl_easy_cleanup(slot->curl);
slot->curl = NULL;
return 1;
}
slot = slot->next;
}
return 0;
}
#endif


24
http.c

@ -372,6 +372,7 @@ int start_active_slot(struct active_request_slot *slot) @@ -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) @@ -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

@ -71,6 +71,9 @@ extern void release_active_slot(struct active_request_slot *slot); @@ -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); @@ -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; @@ -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 */

Loading…
Cancel
Save