Blame src/list.c

Packit Service db8df9
/*
Packit Service db8df9
 * Intel(R) Enclosure LED Utilities
Packit Service db8df9
 * Copyright (C) 2009-2018 Intel Corporation.
Packit Service db8df9
 *
Packit Service db8df9
 * This program is free software; you can redistribute it and/or modify it
Packit Service db8df9
 * under the terms and conditions of the GNU General Public License,
Packit Service db8df9
 * version 2, as published by the Free Software Foundation.
Packit Service db8df9
 *
Packit Service db8df9
 * This program is distributed in the hope it will be useful, but WITHOUT
Packit Service db8df9
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
Packit Service db8df9
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
Packit Service db8df9
 * more details.
Packit Service db8df9
 *
Packit Service db8df9
 * You should have received a copy of the GNU General Public License along with
Packit Service db8df9
 * this program; if not, write to the Free Software Foundation, Inc.,
Packit Service db8df9
 * 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
Packit Service db8df9
 *
Packit Service db8df9
 */
Packit Service db8df9
Packit Service db8df9
#include <assert.h>
Packit Service db8df9
Packit Service db8df9
#include "list.h"
Packit Service db8df9
#include "utils.h"
Packit Service db8df9
Packit Service db8df9
void __list_erase(struct list *list, item_free_t free_fn)
Packit Service db8df9
{
Packit Service db8df9
	struct node *node;
Packit Service db8df9
Packit Service db8df9
	list_for_each_node(list, node) {
Packit Service db8df9
		if (free_fn)
Packit Service db8df9
			free_fn(node->item);
Packit Service db8df9
		free(node);
Packit Service db8df9
	}
Packit Service db8df9
	list->head = list->tail = NULL;
Packit Service db8df9
}
Packit Service db8df9
Packit Service db8df9
void __list_remove(struct node *node, item_free_t free_fn)
Packit Service db8df9
{
Packit Service db8df9
	struct list *list = node->list;
Packit Service db8df9
Packit Service db8df9
	if (node->prev)
Packit Service db8df9
		node->prev->next = node->next;
Packit Service db8df9
	else
Packit Service db8df9
		list->head = node->next;
Packit Service db8df9
	if (node->next)
Packit Service db8df9
		node->next->prev = node->prev;
Packit Service db8df9
	else
Packit Service db8df9
		list->tail = node->prev;
Packit Service db8df9
	node->list = NULL;
Packit Service db8df9
	node->next = NULL;
Packit Service db8df9
	node->prev = NULL;
Packit Service db8df9
Packit Service db8df9
	if (free_fn)
Packit Service db8df9
		free_fn(node->item);
Packit Service db8df9
}
Packit Service db8df9
Packit Service db8df9
void list_insert(struct list *list, void *item, struct node *after)
Packit Service db8df9
{
Packit Service db8df9
	struct node *new;
Packit Service db8df9
	struct node **x;
Packit Service db8df9
Packit Service db8df9
	new = malloc(sizeof(struct node));
Packit Service db8df9
	if (!new) {
Packit Service db8df9
		log_error("Failed to allocate memory for list node.");
Packit Service db8df9
		exit(1);
Packit Service db8df9
	}
Packit Service db8df9
Packit Service db8df9
	new->list = list;
Packit Service db8df9
	new->item = item;
Packit Service db8df9
Packit Service db8df9
	if (after) {
Packit Service db8df9
		assert(list == after->list);
Packit Service db8df9
		x = &after->next;
Packit Service db8df9
	} else {
Packit Service db8df9
		x = &list->head;
Packit Service db8df9
	}
Packit Service db8df9
Packit Service db8df9
	if (*x == NULL)
Packit Service db8df9
		list->tail = new;
Packit Service db8df9
	else
Packit Service db8df9
		(*x)->prev = new;
Packit Service db8df9
	new->next = *x;
Packit Service db8df9
	*x = new;
Packit Service db8df9
	new->prev = after;
Packit Service db8df9
}