summaryrefslogtreecommitdiff
path: root/ares_llist.h
diff options
context:
space:
mode:
authorYang Tse <yangsita@gmail.com>2007-10-02 02:18:01 +0000
committerYang Tse <yangsita@gmail.com>2007-10-02 02:18:01 +0000
commit343d6f221fea91aa47cd1e8a3ed9d7c462fc6f7f (patch)
treed54d1d5e112590d96e42aae433c94c98cd80c697 /ares_llist.h
parente4eb2d0e1d36937ff1dab2c9e2a00295c3bb5539 (diff)
downloadc-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.h43
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 */