1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95
|
/*
* ccache_list.h -- definitions for CS 2270 linked list package
*
* Mark Peterson 9/91
*
* $Id: ccache_list.h,v 1.6 1995/01/10 16:30:21 hardy Exp $
*
* ----------------------------------------------------------------------
* Copyright (c) 1994, 1995. All rights reserved.
*
* Mic Bowman of Transarc Corporation.
* Peter Danzig of the University of Southern California.
* Darren R. Hardy of the University of Colorado at Boulder.
* Udi Manber of the University of Arizona.
* Michael F. Schwartz of the University of Colorado at Boulder.
*
* This copyright notice applies to all code in Harvest other than
* subsystems developed elsewhere, which contain other copyright notices
* in their source text.
*
* The Harvest software was developed by the Internet Research Task
* Force Research Group on Resource Discovery (IRTF-RD). The Harvest
* software may be used for academic, research, government, and internal
* business purposes without charge. If you wish to sell or distribute
* the Harvest software to commercial clients or partners, you must
* license the software. See
* http://harvest.cs.colorado.edu/harvest/copyright,licensing.html#licensing.
*
* The Harvest software is provided ``as is'', without express or
* implied warranty, and with no support nor obligation to assist in its
* use, correction, modification or enhancement. We assume no liability
* with respect to the infringement of copyrights, trade secrets, or any
* patents, and are not responsible for consequential damages. Proper
* use of the Harvest software is entirely the responsibility of the user.
*
* For those who are using Harvest for non-commercial purposes, you may
* make derivative works, subject to the following constraints:
*
* - You must include the above copyright notice and these accompanying
* paragraphs in all forms of derivative works, and any documentation
* and other materials related to such distribution and use acknowledge
* that the software was developed at the above institutions.
*
* - You must notify IRTF-RD regarding your distribution of the
* derivative work.
*
* - You must clearly notify users that your are distributing a modified
* version and not the original Harvest software.
*
* - Any derivative product is also subject to the restrictions of the
* copyright, including distribution and use limitations.
*
*/
#ifndef _CCACHE_LIST_H_
#define _CCACHE_LIST_H_
typedef struct list_node { /*list node type */
struct list_node *next; /*points to the following node */
struct list_node *previous; /*points to the previous node */
Datum *data; /*stores data record in list */
} List_Node;
typedef struct { /*list header node */
List_Node *first; /*points to the first node */
List_Node *last; /*points to the last node */
unsigned int count;
/*keeps count of the number of nodes in list */
int (*compare) (); /*A compare function */
} Linked_List;
/*
**The list toolkit functions:
*/
Linked_List *list_create(); /*initialize list header block */
void list_destroy(); /*destroy list header block */
List_Node *list_insert(); /*insert a new node in the list */
Datum *list_delete(); /*delete a node from the list */
List_Node *list_find(); /*find a node in the list */
Boolean list_apply(); /*apply a function to each node in the list */
/*Built in Macros */
#define list_first(head) ((head)->first) /*find the first node in the list */
#define list_next(node) ((node)->next) /*find the next node in the list */
#define list_last(head) ((head)->last) /*find the last node in the list */
#define list_previous(node) ((node)->previous)
/*find the previous node in the list */
#define list_getdata(node) ((node)->data) /*get the data from the list */
void list_putdata(); /*modify the data in the node in the list */
#define list_length(head) ((head)->count) /*find the length of the list */
#endif
|