⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 ospf_linked_list.c

📁 vxworks下ospf协议栈
💻 C
📖 第 1 页 / 共 2 页
字号:
/* ospf_linked_list.c - OSPF linked list *//* Copyright 2003 Wind River Systems, Inc. */#include "copyright_wrs.h"/*modification history--------------------01c,02jun03,ram Changed native memory usage to OSPF memory partition01b,02jun03,agi added static keyword in front of local functions01a,30may03,agi create (ported from RWOS)*//* includes */#include "stdio.h"#include "stdlib.h"#include <vxWorks.h>#include "ospf.h"#include "ospf_container_functions.h"#include "ospf_linked_list_structures.h"/******************************************************************************/static void linked_list_set_container_function_pointers (LINKED_LIST_CONTAINER* p_linked_list);static void linked_list_set_iterator_function_pointers (LINKED_LIST_ITERATOR* p_linked_list_iterator);static bool linked_list_add_node_to_sorted_list (LINKED_LIST_CONTAINER* p_linked_list, LINKED_LIST_NODE* p_node);static void linked_list_determine_position (LINKED_LIST_CONTAINER* p_linked_list, LINKED_LIST_NODE* p_node,	LINKED_LIST_NODE** pp_previous_node, LINKED_LIST_NODE** pp_next_node);static void linked_list_free_iterator_local (OSPF_CONTAINER_ITERATOR* p_iterator);static OSPF_CONTAINER_ITERATOR linked_list_create_iterator_local (OSPF_CONTAINER* p_rw_container);/******************************************************************************/OSPF_CONTAINER* ospf_list_create (FP_OSPF_CONTAINER_ITEM_COMPARE fp_compare){    LINKED_LIST_CONTAINER* p_linked_list;    p_linked_list = (LINKED_LIST_CONTAINER*) buffer_malloc (        sizeof (LINKED_LIST_CONTAINER));	if (p_linked_list == NULL)		{		return ((OSPF_CONTAINER*) NULL);		}			p_linked_list->p_first_node = NULL;	p_linked_list->p_last_node = NULL;	if (fp_compare != NULL)		{		p_linked_list->fp_compare = fp_compare;		}	else		{		p_linked_list->fp_compare = NULL;		}	linked_list_set_container_function_pointers (p_linked_list);#if defined (__LOCAL_ITERATOR__)    p_linked_list->mp_linked_list_iterator = buffer_malloc (        sizeof (LINKED_LIST_ITERATOR));	if (p_linked_list->mp_linked_list_iterator == NULL)		{		table_free ((void *)p_linked_list);		return (NULL);		}	p_linked_list->mp_linked_list_iterator->p_linked_list = p_linked_list;	p_linked_list->mp_linked_list_iterator->p_node = NULL;	linked_list_set_iterator_function_pointers (p_linked_list->mp_linked_list_iterator);#endif /*__LOCAL_ITERATOR__*/	return ((OSPF_CONTAINER*)p_linked_list);		}/************************************************************************************/static bool linked_list_is_at_end (OSPF_CONTAINER_ITERATOR* p_iterator){	if (p_iterator == NULL)		{		return (true);		}	if (((LINKED_LIST_ITERATOR*)p_iterator)->p_linked_list == NULL)		{		return (true);		}	if (((LINKED_LIST_ITERATOR*)p_iterator)->p_node == NULL)		{		return (true);		}	else		{		return (false);		}}/************************************************************************************/static void linked_list_goto_front (OSPF_CONTAINER_ITERATOR* p_iterator){	if (p_iterator == NULL)		{		return;		}	if (((LINKED_LIST_ITERATOR*)p_iterator)->p_linked_list == NULL)		{		return;		}	((LINKED_LIST_ITERATOR*)p_iterator)->p_node = ((LINKED_LIST_ITERATOR*)p_iterator)->p_linked_list->p_first_node;}/************************************************************************************/static void linked_list_goto_end (OSPF_CONTAINER_ITERATOR* p_iterator){	if (p_iterator == NULL)		{		return;		}	if (((LINKED_LIST_ITERATOR*)p_iterator)->p_linked_list == NULL)		{		return;		}	((LINKED_LIST_ITERATOR*)p_iterator)->p_node = ((LINKED_LIST_ITERATOR*)p_iterator)->p_linked_list->p_last_node;}/************************************************************************************/static OSPF_CONTAINER_ITERATOR linked_list_create_iterator (OSPF_CONTAINER* p_rw_container){	LINKED_LIST_ITERATOR* p_linked_list_iterator;#if defined (__LOCAL_ITERATOR__)	p_linked_list_iterator = NULL;	p_linked_list_iterator = ((LINKED_LIST_CONTAINER*) p_rw_container)->mp_linked_list_iterator;	linked_list_goto_front ((OSPF_CONTAINER_ITERATOR*) p_linked_list_iterator);#else 	p_linked_list_iterator = buffer_malloc (sizeof (LINKED_LIST_ITERATOR));	if (p_linked_list_iterator == NULL)		{		return ((OSPF_CONTAINER_ITERATOR) NULL);		}	p_linked_list_iterator->p_linked_list = (LINKED_LIST_CONTAINER*) p_rw_container;	p_linked_list_iterator->p_node = NULL;	linked_list_set_iterator_function_pointers (p_linked_list_iterator);#endif	return ((OSPF_CONTAINER_ITERATOR) p_linked_list_iterator);}/************************************************************************************/static void linked_list_free_container (OSPF_CONTAINER* p_linked_list){	LINKED_LIST_NODE* p_node;	LINKED_LIST_NODE* p_next_node;#if defined (__LOCAL_ITERATOR__)	LINKED_LIST_ITERATOR* p_linked_list_iterator;#endif	if (p_linked_list == NULL)		{		return;		}	p_node = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node;	while (p_node != NULL) 		{		p_next_node = p_node->p_next;		table_free (p_node);		p_node = p_next_node;				}#if defined (__LOCAL_ITERATOR__)		p_linked_list_iterator = NULL;	p_linked_list_iterator = (LINKED_LIST_ITERATOR*)((LINKED_LIST_CONTAINER*)p_linked_list)->mp_linked_list_iterator;	if (p_linked_list_iterator != NULL)		{		table_free (p_linked_list_iterator);		p_linked_list_iterator = NULL;		}#endif	table_free ((LINKED_LIST_CONTAINER*)p_linked_list);	p_linked_list = NULL;}/************************************************************************************/static bool linked_list_add_at_front (OSPF_CONTAINER* p_linked_list, const OSPF_CONTAINER_ITEM* p_item){	LINKED_LIST_NODE* p_node;	LINKED_LIST_NODE* p_next_node;	bool return_value;	if (p_linked_list == NULL)		{		return (false);		}	if (p_item == NULL)		{		return (false);		}			p_node = (LINKED_LIST_NODE*) buffer_malloc (sizeof (LINKED_LIST_NODE));	if (p_node == NULL)		{		return (false);		}			p_node->p_next = NULL;	p_node->p_previous = NULL;	p_node->p_data = (void*) p_item;	if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node == NULL)		{		((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node = p_node;		((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node = p_node;		p_node->p_previous = NULL;		p_node->p_next = NULL;		return (true);		}	else		{		if (((LINKED_LIST_CONTAINER*)p_linked_list)->fp_compare != NULL)			{			return_value = linked_list_add_node_to_sorted_list (p_linked_list, p_node);			if (return_value == false)				{				table_free (p_node);				p_node = NULL;				}			}		else			{			p_next_node = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node;			p_node->p_next = p_next_node;			p_node->p_previous = NULL;			p_next_node->p_previous = p_node;			((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node = p_node;			return_value = true;			}		return (return_value);		}}/************************************************************************************/static void linked_list_remove_from_front (OSPF_CONTAINER* p_linked_list){	LINKED_LIST_NODE* p_node_to_remove;	if (p_linked_list == NULL)		{		return;		}			if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node == NULL)		{		return;		}	if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node == ((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node)		{		p_node_to_remove = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node;		((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node = NULL;		((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node = NULL;		table_free (p_node_to_remove);				p_node_to_remove = NULL;		return;		}			p_node_to_remove = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node;	((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node = p_node_to_remove->p_next;	((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node->p_previous = NULL;	table_free (p_node_to_remove);	p_node_to_remove = NULL;}/************************************************************************************/static bool linked_list_add_at_back (OSPF_CONTAINER* p_linked_list, const OSPF_CONTAINER_ITEM* p_item){	LINKED_LIST_NODE* p_node;	LINKED_LIST_NODE* p_previous_node;	bool return_value;	if (p_linked_list == NULL)		{		return (false);		}			if (p_item == NULL)		{		return (false);		}			p_node = (LINKED_LIST_NODE*) buffer_malloc (sizeof (LINKED_LIST_NODE));	if (p_node == NULL)		{		return (false);		}			p_node->p_next = NULL;	p_node->p_previous = NULL;	p_node->p_data = (void*) p_item;	if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node == NULL)		{		((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node = p_node;		((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node = p_node;			p_node->p_next = NULL;		p_node->p_previous = NULL;		return (true);		}	else		{		if (((LINKED_LIST_CONTAINER*)p_linked_list)->fp_compare != NULL)			{			return_value = linked_list_add_node_to_sorted_list (p_linked_list, p_node);			if (return_value == false)				{				table_free (p_node);								p_node = NULL;				}			}		else			{			p_previous_node = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node;			p_node->p_next = NULL;			p_node->p_previous = p_previous_node;			p_previous_node->p_next = p_node;			((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node = p_node;			return_value = true;			}		return (return_value);		}}/************************************************************************************/static void linked_list_remove_from_back (OSPF_CONTAINER* p_linked_list){	LINKED_LIST_NODE* p_node_to_remove;	p_linked_list = (LINKED_LIST_CONTAINER*) p_linked_list;	if (p_linked_list == NULL)		{		return;		}	if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node == NULL)		{		return;		}			if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node == ((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node)		{		p_node_to_remove = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node;		((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node = NULL;		((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node = NULL;		table_free (p_node_to_remove);		p_node_to_remove = NULL;		return;		}			p_node_to_remove = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node;		((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node = p_node_to_remove->p_previous;	((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node->p_next = NULL;		table_free (p_node_to_remove);	p_node_to_remove = NULL;}/************************************************************************************/static UINT linked_list_get_number_of_nodes (const OSPF_CONTAINER* p_linked_list){	UINT number_of_nodes;	LINKED_LIST_NODE* p_node;	p_node = ((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node;	number_of_nodes = 0;	while (p_node !=  NULL)		{		++ number_of_nodes;		p_node = p_node->p_next;		}	return (number_of_nodes);}/************************************************************************************/static OSPF_CONTAINER_ITEM* linked_list_get_item_at_front (const OSPF_CONTAINER* p_linked_list){	if (p_linked_list == NULL)		{		return (NULL);		}	if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node == NULL)		{		return (NULL);		}	return (((LINKED_LIST_CONTAINER*)p_linked_list)->p_first_node->p_data);}/************************************************************************************/static OSPF_CONTAINER_ITEM* linked_list_get_item_at_back (const OSPF_CONTAINER* p_linked_list){	if (p_linked_list == NULL)		{		return (NULL);		}	if (((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node == NULL)		{		return (NULL);		}	return (((LINKED_LIST_CONTAINER*)p_linked_list)->p_last_node->p_data);}/************************************************************************************/static void linked_list_set_container_function_pointers (LINKED_LIST_CONTAINER* p_linked_list){	if (p_linked_list != NULL)		{		p_linked_list->function.create_iterator = linked_list_create_iterator;		p_linked_list->function.free_container = linked_list_free_container;		p_linked_list->function.add_at_front = linked_list_add_at_front;		p_linked_list->function.remove_from_front = linked_list_remove_from_front;		p_linked_list->function.add_at_back = linked_list_add_at_back;		p_linked_list->function.remove_from_back = linked_list_remove_from_back;		p_linked_list->function.get_container_size = linked_list_get_number_of_nodes;		p_linked_list->function.get_item_at_front = linked_list_get_item_at_front;		p_linked_list->function.get_item_at_back = linked_list_get_item_at_back;		}}/************************************************************************************/static OSPF_CONTAINER_ITERATOR linked_list_create_iterator_local (OSPF_CONTAINER* p_rw_container){	LINKED_LIST_ITERATOR* p_linked_list_iterator;	p_linked_list_iterator = buffer_malloc (sizeof (LINKED_LIST_ITERATOR));	if (p_linked_list_iterator == NULL)		{		return ((OSPF_CONTAINER_ITERATOR) NULL);		}	p_linked_list_iterator->p_linked_list = (LINKED_LIST_CONTAINER*) p_rw_container;	p_linked_list_iterator->p_node = NULL;	linked_list_set_iterator_function_pointers (p_linked_list_iterator);	return ((OSPF_CONTAINER_ITERATOR) p_linked_list_iterator);}/************************************************************************************/static OSPF_CONTAINER_ITEM* linked_list_get_item_at_iterator (OSPF_CONTAINER_ITERATOR* p_iterator){	if (p_iterator == NULL)		{		return ((OSPF_CONTAINER_ITEM*)NULL);		}	if (((LINKED_LIST_ITERATOR*)p_iterator)->p_linked_list == NULL)		{		return ((OSPF_CONTAINER_ITEM*)NULL);		}	if (((LINKED_LIST_ITERATOR*)p_iterator)->p_node == NULL)		{		return ((OSPF_CONTAINER_ITEM*)NULL);		}	return ((OSPF_CONTAINER_ITEM*)(((LINKED_LIST_ITERATOR*)p_iterator)->p_node->p_data));		}/************************************************************************************/static bool linked_list_find_item_in_range (OSPF_CONTAINER_ITERATOR* p_iterator_start, OSPF_CONTAINER_ITERATOR* p_iterator_end,	FP_OSPF_CONTAINER_ITEM_CRITERIA_MATCHER fp_criteria_matcher, OSPF_CONTAINER_CRITERIA* p_criteria,	OSPF_CONTAINER_ITERATOR* p_matched_item_iterator){	LINKED_LIST_ITERATOR* p_first_iterator;	LINKED_LIST_ITERATOR* p_last_iterator;	LINKED_LIST_NODE* p_node;	LINKED_LIST_NODE* p_last_node;	bool item_found;	if (fp_criteria_matcher == NULL)		{		return (false);		}	if (p_criteria == NULL)		{		return (false);		}	if (p_matched_item_iterator == NULL)		{		return (false);		}			p_first_iterator = (LINKED_LIST_ITERATOR*) p_iterator_start;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -