2020-06-28 17:43:08 +00:00
|
|
|
#include "webfuse/impl/util/slist.h"
|
2019-04-17 20:51:16 +00:00
|
|
|
#include <stddef.h>
|
|
|
|
|
2020-06-28 17:43:08 +00:00
|
|
|
void wf_impl_slist_init(
|
2019-04-17 20:51:16 +00:00
|
|
|
struct wf_slist * list)
|
|
|
|
{
|
2019-04-26 18:50:57 +00:00
|
|
|
list->head.next = NULL;
|
|
|
|
list->last = &list->head;
|
2019-04-17 20:51:16 +00:00
|
|
|
}
|
|
|
|
|
2020-06-28 17:43:08 +00:00
|
|
|
bool wf_impl_slist_empty(
|
2019-04-17 20:51:16 +00:00
|
|
|
struct wf_slist * list)
|
|
|
|
{
|
2019-04-26 18:50:57 +00:00
|
|
|
return (list->last == &list->head);
|
|
|
|
}
|
|
|
|
|
2020-06-28 17:43:08 +00:00
|
|
|
struct wf_slist_item * wf_impl_slist_first(
|
2019-04-26 18:50:57 +00:00
|
|
|
struct wf_slist * list)
|
|
|
|
{
|
|
|
|
return list->head.next;
|
2019-04-17 20:51:16 +00:00
|
|
|
}
|
|
|
|
|
2020-06-28 17:43:08 +00:00
|
|
|
void wf_impl_slist_append(
|
2019-04-17 20:51:16 +00:00
|
|
|
struct wf_slist * list,
|
|
|
|
struct wf_slist_item * item)
|
|
|
|
{
|
|
|
|
item->next = NULL;
|
2019-04-26 18:50:57 +00:00
|
|
|
list->last->next = item;
|
|
|
|
list->last = item;
|
2019-04-17 20:51:16 +00:00
|
|
|
}
|
|
|
|
|
2020-06-28 17:43:08 +00:00
|
|
|
struct wf_slist_item * wf_impl_slist_remove_first(
|
2019-04-17 20:51:16 +00:00
|
|
|
struct wf_slist * list)
|
|
|
|
{
|
2020-06-28 17:43:08 +00:00
|
|
|
return wf_impl_slist_remove_after(list, &list->head);
|
2019-04-17 20:51:16 +00:00
|
|
|
}
|
|
|
|
|
2020-06-28 17:43:08 +00:00
|
|
|
struct wf_slist_item * wf_impl_slist_remove_after(
|
2019-04-17 20:51:16 +00:00
|
|
|
struct wf_slist * list,
|
|
|
|
struct wf_slist_item * prev)
|
|
|
|
{
|
|
|
|
|
2019-04-26 18:50:57 +00:00
|
|
|
struct wf_slist_item * result = prev->next;
|
|
|
|
|
|
|
|
if (NULL != result)
|
2019-04-17 20:51:16 +00:00
|
|
|
{
|
2019-04-26 18:50:57 +00:00
|
|
|
prev->next = result->next;
|
|
|
|
|
|
|
|
if (list->last == result)
|
2019-04-17 20:51:16 +00:00
|
|
|
{
|
|
|
|
list->last = prev;
|
2019-04-26 18:50:57 +00:00
|
|
|
}
|
2019-04-17 20:51:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
}
|