/* * 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); }