diff options
author | Yang Tse <yangsita@gmail.com> | 2007-10-02 02:18:01 +0000 |
---|---|---|
committer | Yang Tse <yangsita@gmail.com> | 2007-10-02 02:18:01 +0000 |
commit | 343d6f221fea91aa47cd1e8a3ed9d7c462fc6f7f (patch) | |
tree | d54d1d5e112590d96e42aae433c94c98cd80c697 /ares_llist.h | |
parent | e4eb2d0e1d36937ff1dab2c9e2a00295c3bb5539 (diff) | |
download | c-ares-343d6f221fea91aa47cd1e8a3ed9d7c462fc6f7f.tar.gz c-ares-343d6f221fea91aa47cd1e8a3ed9d7c462fc6f7f.tar.bz2 c-ares-343d6f221fea91aa47cd1e8a3ed9d7c462fc6f7f.zip |
Avoid inline C99ism, and move c-ares routines for managing doubly-linked lists.
Diffstat (limited to 'ares_llist.h')
-rw-r--r-- | ares_llist.h | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/ares_llist.h b/ares_llist.h new file mode 100644 index 0000000..d20af7e --- /dev/null +++ b/ares_llist.h @@ -0,0 +1,43 @@ +#ifndef __ARES_LLIST_H +#define __ARES_LLIST_H + +/* $Id$ */ + +/* Copyright 1998 by the Massachusetts Institute of Technology. + * + * Permission to use, copy, modify, and distribute this + * software and its documentation for any purpose and without + * fee is hereby granted, provided that the above copyright + * notice appear in all copies and that both that copyright + * notice and this permission notice appear in supporting + * documentation, and that the name of M.I.T. not be used in + * advertising or publicity pertaining to distribution of the + * software without specific, written prior permission. + * M.I.T. makes no representations about the suitability of + * this software for any purpose. It is provided "as is" + * without express or implied warranty. + */ + + +/* Node definition for circular, doubly-linked list */ +struct list_node { + struct list_node *prev; + struct list_node *next; + void* data; +}; + +void ares__init_list_head(struct list_node* head); + +void ares__init_list_node(struct list_node* node, void* d); + +int ares__is_list_empty(struct list_node* head); + +void ares__insert_in_list(struct list_node* new_node, + struct list_node* old_node); + +void ares__remove_from_list(struct list_node* node); + +void ares__swap_lists(struct list_node* head_a, + struct list_node* head_b); + +#endif /* __ARES_LLIST_H */ |