1 /*        $NetBSD: str_list.c,v 1.1.1.2 2009/12/02 00:26:32 haad Exp $          */
2 
3 /*
4  * Copyright (C) 2003-2004 Sistina Software, Inc. All rights reserved.
5  * Copyright (C) 2004-2005 Red Hat, Inc. All rights reserved.
6  *
7  * This file is part of LVM2.
8  *
9  * This copyrighted material is made available to anyone wishing to use,
10  * modify, copy, or redistribute it subject to the terms and conditions
11  * of the GNU Lesser General Public License v.2.1.
12  *
13  * You should have received a copy of the GNU Lesser General Public License
14  * along with this program; if not, write to the Free Software Foundation,
15  * Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
16  */
17 
18 #include "lib.h"
19 #include "str_list.h"
20 
str_list_create(struct dm_pool * mem)21 struct dm_list *str_list_create(struct dm_pool *mem)
22 {
23           struct dm_list *sl;
24 
25           if (!(sl = dm_pool_alloc(mem, sizeof(struct dm_list)))) {
26                     log_errno(ENOMEM, "str_list allocation failed");
27                     return NULL;
28           }
29 
30           dm_list_init(sl);
31 
32           return sl;
33 }
34 
str_list_add(struct dm_pool * mem,struct dm_list * sll,const char * str)35 int str_list_add(struct dm_pool *mem, struct dm_list *sll, const char *str)
36 {
37           struct str_list *sln;
38 
39           if (!str)
40                     return_0;
41 
42           /* Already in list? */
43           if (str_list_match_item(sll, str))
44                     return 1;
45 
46           if (!(sln = dm_pool_alloc(mem, sizeof(*sln))))
47                     return_0;
48 
49           sln->str = str;
50           dm_list_add(sll, &sln->list);
51 
52           return 1;
53 }
54 
str_list_del(struct dm_list * sll,const char * str)55 int str_list_del(struct dm_list *sll, const char *str)
56 {
57           struct dm_list *slh, *slht;
58 
59           dm_list_iterate_safe(slh, slht, sll) {
60                     if (!strcmp(str, dm_list_item(slh, struct str_list)->str))
61                                dm_list_del(slh);
62           }
63 
64           return 1;
65 }
66 
str_list_dup(struct dm_pool * mem,struct dm_list * sllnew,const struct dm_list * sllold)67 int str_list_dup(struct dm_pool *mem, struct dm_list *sllnew,
68                      const struct dm_list *sllold)
69 {
70           struct str_list *sl;
71 
72           dm_list_init(sllnew);
73 
74           dm_list_iterate_items(sl, sllold) {
75                     if (!str_list_add(mem, sllnew, dm_pool_strdup(mem, sl->str)))
76                               return_0;
77           }
78 
79           return 1;
80 }
81 
82 /*
83  * Is item on list?
84  */
str_list_match_item(const struct dm_list * sll,const char * str)85 int str_list_match_item(const struct dm_list *sll, const char *str)
86 {
87           struct str_list *sl;
88 
89           dm_list_iterate_items(sl, sll)
90               if (!strcmp(str, sl->str))
91                     return 1;
92 
93           return 0;
94 }
95 
96 /*
97  * Is at least one item on both lists?
98  */
str_list_match_list(const struct dm_list * sll,const struct dm_list * sll2)99 int str_list_match_list(const struct dm_list *sll, const struct dm_list *sll2)
100 {
101           struct str_list *sl;
102 
103           dm_list_iterate_items(sl, sll)
104               if (str_list_match_item(sll2, sl->str))
105                     return 1;
106 
107           return 0;
108 }
109 
110 /*
111  * Do both lists contain the same set of items?
112  */
str_list_lists_equal(const struct dm_list * sll,const struct dm_list * sll2)113 int str_list_lists_equal(const struct dm_list *sll, const struct dm_list *sll2)
114 {
115           struct str_list *sl;
116 
117           if (dm_list_size(sll) != dm_list_size(sll2))
118                     return 0;
119 
120           dm_list_iterate_items(sl, sll)
121               if (!str_list_match_item(sll2, sl->str))
122                     return 0;
123 
124           return 1;
125 }
126