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