2 * Copyright Geoff Levand <geoff@infradead.org>
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation; version 2 of the License.
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
18 #if defined(HAVE_CONFIG_H)
27 #include <list/list.h>
28 #include <talloc/talloc.h>
34 struct list_item list;
43 ctx = talloc_new(NULL);
45 for (i = 0; i < 5; i++) {
46 struct item *item = talloc(ctx, struct item);
50 list_add_tail(&tester, &item->list);
54 fprintf(stderr, "-- list_for_each_entry --\n");
55 list_for_each_entry(&tester, item, list) {
56 fprintf(stderr, "%d: %d: %p -> %p\n", i++, item->value, item, item->list.next);
60 fprintf(stderr, "-- list_for_each_entry_safe --\n");
61 list_for_each_entry_safe(&tester, item, tmp, list) {
62 fprintf(stderr, "pos: %d: %d: %p -> %p\n", i++, item->value, item, item->list.next);
63 fprintf(stderr, "tmp: %p -> %p\n", tmp, (tmp ? tmp->list.next : NULL));
64 list_remove(&item->list);
67 /* we should see that the list is empty */
69 fprintf(stderr, "-- list_for_each_entry(empty) --\n");
70 list_for_each_entry(&tester, item, list) {
71 fprintf(stderr, "%d: %d: %p -> %p\n", i++, item->value, item, item->list.next);
75 fprintf(stderr, "Error: list should be empty\n");
80 fprintf(stderr, "-- list_for_each_entry_safe(empty) --\n");
81 list_for_each_entry_safe(&tester, item, tmp, list) {
82 fprintf(stderr, "%d: %d: %p -> %p\n", i++, item->value, item, item->list.next);
86 fprintf(stderr, "Error: list should be empty\n");
89 fprintf(stderr, "-- done --\n");