/*
* Copyright (C) 2023 Barry
*
* This file is part of Barry's Little Objects in C Library (libBLOC).
*
* libBLOC is free software: you can redistribute it and/or modify it under the
* terms of the GNU General Public License as published by the Free Software
* Foundation, either version 3 of the License, or (at your option) any later
* version.
*
* libBLOC is distributed in the hope that it will be useful, but WITHOUT ANY
* WARRANTY; without even the implied warranty of MERCHANTIBILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
* details.
*
* You should have received a copy of the GNU General Public License along with
* libBLOC. If not, see .
*/
#include
#include
#include "../assert.h"
#include "list.h"
/* Remove an object from a list */
void
list_remove(List *list, void *obj)
{
ASSERT(list);
ASSERT(obj);
ASSERT(obj_verify(obj));
if (!list->header.start)
return;
if (list->type && list->type != obj_type(obj))
return;
obj_lock(list);
/* Search for object */
struct IterableEntry *entry;
for (entry = list->header.start; entry; entry = entry->next) {
if (entry->obj == obj)
break;
}
if (!entry) {
obj_unlock(list);
return;
}
/* Unlink */
if (list->header.start == entry)
list->header.start = entry->next;
if (list->header.end == entry)
list->header.end = entry->prev;
if (entry->prev)
entry->prev->next = entry->next;
if (entry->next)
entry->next->prev = entry->prev;
obj_put(entry->obj);
list->header.entries--;
free(entry);
obj_unlock(list);
}