mirror of
https://github.com/netsurf-browser/netsurf
synced 2025-01-03 01:34:25 +03:00
Abstract a number of unsafe iterations of object users into a single safe function call
svn path=/trunk/netsurf/; revision=10398
This commit is contained in:
parent
613fa0213a
commit
b56886d0ee
@ -488,6 +488,31 @@ nserror llcache_object_user_destroy(llcache_object_user *user)
|
||||
return NSERROR_OK;
|
||||
}
|
||||
|
||||
/** Iterate the users of an object, calling their callbacks.
|
||||
*
|
||||
* \param object The object to iterate
|
||||
* \param event The event to pass to the callback.
|
||||
* \return NSERROR_OK on success, appropriate error otherwise.
|
||||
*/
|
||||
static nserror llcache_send_event_to_users(llcache_object *object,
|
||||
llcache_event *event)
|
||||
{
|
||||
nserror error = NSERROR_OK;
|
||||
llcache_object_user *user, *next_user;
|
||||
|
||||
user = object->users;
|
||||
while (user != NULL) {
|
||||
next_user = user->next;
|
||||
error = user->handle.cb(&user->handle, event,
|
||||
user->handle.pw);
|
||||
if (error != NSERROR_OK)
|
||||
break;
|
||||
user = next_user;
|
||||
}
|
||||
|
||||
return error;
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve an object from the cache, fetching it if necessary.
|
||||
*
|
||||
@ -1469,9 +1494,7 @@ nserror llcache_post_data_clone(const llcache_post_data *orig,
|
||||
*/
|
||||
nserror llcache_query_handle_response(bool proceed, void *cbpw)
|
||||
{
|
||||
nserror error;
|
||||
llcache_event event;
|
||||
llcache_object_user *user;
|
||||
llcache_object *object = cbpw;
|
||||
|
||||
/* Refetch, using existing fetch parameters, if client allows us to */
|
||||
@ -1483,13 +1506,7 @@ nserror llcache_query_handle_response(bool proceed, void *cbpw)
|
||||
/** \todo More appropriate error message */
|
||||
event.data.msg = messages_get("FetchFailed");
|
||||
|
||||
for (user = object->users; user != NULL; user = user->next) {
|
||||
error = user->handle.cb(&user->handle, &event, user->handle.pw);
|
||||
if (error != NSERROR_OK)
|
||||
return error;
|
||||
}
|
||||
|
||||
return NSERROR_OK;
|
||||
return llcache_send_event_to_users(object, &event);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1506,7 +1523,6 @@ void llcache_fetch_callback(fetch_msg msg, void *p, const void *data,
|
||||
{
|
||||
nserror error = NSERROR_OK;
|
||||
llcache_object *object = p;
|
||||
llcache_object_user *user;
|
||||
llcache_event event;
|
||||
|
||||
#ifdef LLCACHE_TRACE
|
||||
@ -1580,24 +1596,16 @@ void llcache_fetch_callback(fetch_msg msg, void *p, const void *data,
|
||||
event.type = LLCACHE_EVENT_ERROR;
|
||||
event.data.msg = data;
|
||||
|
||||
for (user = object->users; user != NULL; user = user->next) {
|
||||
error = user->handle.cb(&user->handle, &event,
|
||||
user->handle.pw);
|
||||
if (error != NSERROR_OK)
|
||||
break;
|
||||
}
|
||||
error = llcache_send_event_to_users(object, &event);
|
||||
|
||||
break;
|
||||
case FETCH_PROGRESS:
|
||||
/* Progress update */
|
||||
event.type = LLCACHE_EVENT_PROGRESS;
|
||||
event.data.msg = data;
|
||||
|
||||
for (user = object->users; user != NULL; user = user->next) {
|
||||
error = user->handle.cb(&user->handle, &event,
|
||||
user->handle.pw);
|
||||
if (error != NSERROR_OK)
|
||||
break;
|
||||
}
|
||||
error = llcache_send_event_to_users(object, &event);
|
||||
|
||||
break;
|
||||
|
||||
/* Events requiring action */
|
||||
@ -1661,13 +1669,9 @@ nserror llcache_fetch_redirect(llcache_object *object, const char *target,
|
||||
event.type = LLCACHE_EVENT_ERROR;
|
||||
event.data.msg = messages_get("BadRedirect");
|
||||
|
||||
for (user = object->users; user != NULL; user = user->next) {
|
||||
error = user->handle.cb(&user->handle, &event,
|
||||
user->handle.pw);
|
||||
if (error != NSERROR_OK)
|
||||
break;
|
||||
}
|
||||
error = llcache_send_event_to_users(object, &event);
|
||||
|
||||
/** \todo Should this be 'return error' ? */
|
||||
return NSERROR_OK;
|
||||
}
|
||||
#undef REDIRECT_LIMIT
|
||||
@ -2062,7 +2066,6 @@ nserror llcache_fetch_auth(llcache_object *object, const char *realm)
|
||||
error = query_cb(&query, query_cb_pw,
|
||||
llcache_query_handle_response, object);
|
||||
} else {
|
||||
llcache_object_user *user;
|
||||
llcache_event event;
|
||||
|
||||
/* Inform client(s) that object fetch failed */
|
||||
@ -2070,12 +2073,7 @@ nserror llcache_fetch_auth(llcache_object *object, const char *realm)
|
||||
/** \todo More appropriate error message */
|
||||
event.data.msg = messages_get("FetchFailed");
|
||||
|
||||
for (user = object->users; user != NULL; user = user->next) {
|
||||
error = user->handle.cb(&user->handle, &event,
|
||||
user->handle.pw);
|
||||
if (error != NSERROR_OK)
|
||||
break;
|
||||
}
|
||||
error = llcache_send_event_to_users(object, &event);
|
||||
}
|
||||
|
||||
return error;
|
||||
@ -2110,7 +2108,6 @@ nserror llcache_fetch_cert_error(llcache_object *object,
|
||||
error = query_cb(&query, query_cb_pw,
|
||||
llcache_query_handle_response, object);
|
||||
} else {
|
||||
llcache_object_user *user;
|
||||
llcache_event event;
|
||||
|
||||
/* Inform client(s) that object fetch failed */
|
||||
@ -2118,12 +2115,7 @@ nserror llcache_fetch_cert_error(llcache_object *object,
|
||||
/** \todo More appropriate error message */
|
||||
event.data.msg = messages_get("FetchFailed");
|
||||
|
||||
for (user = object->users; user != NULL; user = user->next) {
|
||||
error = user->handle.cb(&user->handle, &event,
|
||||
user->handle.pw);
|
||||
if (error != NSERROR_OK)
|
||||
break;
|
||||
}
|
||||
error = llcache_send_event_to_users(object, &event);
|
||||
}
|
||||
|
||||
return error;
|
||||
|
Loading…
Reference in New Issue
Block a user