diff options
Diffstat (limited to 'src/pr_list.h')
-rw-r--r-- | src/pr_list.h | 85 |
1 files changed, 85 insertions, 0 deletions
diff --git a/src/pr_list.h b/src/pr_list.h new file mode 100644 index 0000000..7c430ae --- /dev/null +++ b/src/pr_list.h @@ -0,0 +1,85 @@ +/*-------------------------------------------------------------------- + * procenv - generic list handling header. + * + * Copyright 2012-2015 James Hunt <jamesodhunt@ubuntu.com>. + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program 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 General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + *-------------------------------------------------------------------- + */ + +#ifndef _PROCENV_LIST +#define _PROCENV_LIST + +#ifdef HAVE_CONFIG_H +# include <config.h> +#endif /* HAVE_CONFIG_H */ + +#include <stdio.h> +#include <stdlib.h> + +/* Double-linked list structure with no terminal node - a list of a + * single item has next and prev pointers pointing "back round" to + * itself. + */ +typedef struct list { + void *data; + struct list *next; + struct list *prev; +} PRList; + +typedef void (*PRListVisitor) (PRList *entry); + +typedef int (*PRListCmp) (PRList *a, PRList *b); + +PRList *pr_list_new (void *data); + +PRList *pr_list_append (PRList *list, PRList *entry); +PRList *pr_list_append_str (PRList *list, const char *str); +PRList *pr_list_appendn_str (PRList *list, const char *str, size_t len); + +PRList *pr_list_prepend (PRList *list, PRList *entry); +PRList *pr_list_prepend_str (PRList *list, const char *str); +PRList *pr_list_prependn_str (PRList *list, const char *str, size_t len); + +PRList *pr_list_prepend_str_sorted(PRList *list, PRList *entry); +PRList *pr_list_prepend_sorted(PRList *list, PRList *entry, PRListCmp cmp); + +PRList *pr_list_append_str_sorted(PRList *list, PRList *entry); +PRList *pr_list_append_sorted(PRList *list, PRList *entry, PRListCmp cmp); + +PRList *pr_list_remove (PRList *entry); + +void pr_list_foreach_visit (PRList *list, PRListVisitor visitor); +void pr_list_foreach_rev_visit (PRList *list, PRListVisitor visitor); + +void pr_list_visitor_str (PRList *entry); + +#define PR_LIST_FOREACH(list, iter) \ + for (PRList *iter = (list)->next; iter != (list); iter = iter->next) + +#define PR_LIST_FOREACH_SAFE(list, iter) \ + for (PRList *iter = (list)->next, *tmp = iter->next; \ + iter != (list); \ + iter = tmp, tmp = iter->next) + +#define PR_LIST_FOREACH_REV(list, iter) \ + for (PRList *iter = (list)->prev; iter != (list); iter = iter->prev) + +#define PR_LIST_FOREACH_STR(list) \ + pr_list_foreach_visit (list, pr_list_visitor_str) + +#define PR_LIST_FOREACH_REV_STR(list) \ + pr_list_foreach_rev_visit (list, pr_list_visitor_str) + +#endif /* _PROCENV_LIST */ |