summaryrefslogtreecommitdiff
path: root/util/list.c
diff options
context:
space:
mode:
Diffstat (limited to 'util/list.c')
-rw-r--r--util/list.c118
1 files changed, 118 insertions, 0 deletions
diff --git a/util/list.c b/util/list.c
new file mode 100644
index 0000000..c27f695
--- /dev/null
+++ b/util/list.c
@@ -0,0 +1,118 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+/* GMime
+ * Copyright (C) 2000-2012 Jeffrey Stedfast
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public License
+ * as published by the Free Software Foundation; either version 2.1
+ * of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free
+ * Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
+ * 02110-1301, USA.
+ */
+
+
+#ifdef HAVE_CONFIG_H
+#include <config.h>
+#endif
+
+#include "list.h"
+
+void
+list_init (List *list)
+{
+ list->head = (ListNode *) &list->tail;
+ list->tail = NULL;
+ list->tailpred = (ListNode *) &list->head;
+}
+
+int
+list_is_empty (List *list)
+{
+ return list->head == (ListNode *) &list->tail;
+}
+
+int
+list_length (List *list)
+{
+ ListNode *node;
+ int n = 0;
+
+ node = list->head;
+ while (node->next) {
+ node = node->next;
+ n++;
+ }
+
+ return n;
+}
+
+ListNode *
+list_unlink_head (List *list)
+{
+ ListNode *n, *nn;
+
+ n = list->head;
+ nn = n->next;
+ if (nn) {
+ nn->prev = n->prev;
+ list->head = nn;
+ return n;
+ }
+
+ return NULL;
+}
+
+ListNode *
+list_unlink_tail (List *list)
+{
+ ListNode *n, *np;
+
+ n = list->tailpred;
+ np = n->prev;
+ if (np) {
+ np->next = n->next;
+ list->tailpred = np;
+ return n;
+ }
+
+ return NULL;
+}
+
+ListNode *
+list_prepend (List *list, ListNode *node)
+{
+ node->next = list->head;
+ node->prev = (ListNode *) &list->head;
+ list->head->prev = node;
+ list->head = node;
+
+ return node;
+}
+
+ListNode *
+list_append (List *list, ListNode *node)
+{
+ node->next = (ListNode *) &list->tail;
+ node->prev = list->tailpred;
+ list->tailpred->next = node;
+ list->tailpred = node;
+
+ return node;
+}
+
+ListNode *
+list_unlink (ListNode *node)
+{
+ node->next->prev = node->prev;
+ node->prev->next = node->next;
+
+ return node;
+}