Skip to content

Commit

Permalink
Refactor http.h USE_CURL_MULTI fill_active_slots().
Browse files Browse the repository at this point in the history
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>
  • Loading branch information
Daniel Barkalow authored and Junio C Hamano committed Sep 19, 2007
1 parent 077d6f7 commit 45c1741
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 39 deletions.
23 changes: 7 additions & 16 deletions http-fetch.c
Original file line number Diff line number Diff line change
Expand Up @@ -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

Expand Down
23 changes: 6 additions & 17 deletions http-push.c
Original file line number Diff line number Diff line change
Expand Up @@ -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

Expand Down
24 changes: 24 additions & 0 deletions http.c
Original file line number Diff line number Diff line change
Expand Up @@ -372,18 +372,42 @@ 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) {
active_requests--;
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;
Expand Down
9 changes: 3 additions & 6 deletions http.h
Original file line number Diff line number Diff line change
Expand Up @@ -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);
Expand All @@ -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
Expand All @@ -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 */

0 comments on commit 45c1741

Please sign in to comment.