1*2d543d20SAndroid Build Coastguard Worker /*
2*2d543d20SAndroid Build Coastguard Worker * Copyright (C) 2006, 2008 Red Hat
3*2d543d20SAndroid Build Coastguard Worker * see file 'COPYING' for use and warranty information
4*2d543d20SAndroid Build Coastguard Worker *
5*2d543d20SAndroid Build Coastguard Worker * This program is free software; you can redistribute it and/or
6*2d543d20SAndroid Build Coastguard Worker * modify it under the terms of the GNU General Public License as
7*2d543d20SAndroid Build Coastguard Worker * published by the Free Software Foundation; either version 2 of
8*2d543d20SAndroid Build Coastguard Worker * the License, or (at your option) any later version.
9*2d543d20SAndroid Build Coastguard Worker *
10*2d543d20SAndroid Build Coastguard Worker * This program is distributed in the hope that it will be useful,
11*2d543d20SAndroid Build Coastguard Worker * but WITHOUT ANY WARRANTY; without even the implied warranty of
12*2d543d20SAndroid Build Coastguard Worker * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13*2d543d20SAndroid Build Coastguard Worker * GNU General Public License for more details.
14*2d543d20SAndroid Build Coastguard Worker .*
15*2d543d20SAndroid Build Coastguard Worker * You should have received a copy of the GNU General Public License
16*2d543d20SAndroid Build Coastguard Worker * along with this program; if not, write to the Free Software
17*2d543d20SAndroid Build Coastguard Worker * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18*2d543d20SAndroid Build Coastguard Worker * 02111-1307 USA
19*2d543d20SAndroid Build Coastguard Worker *
20*2d543d20SAndroid Build Coastguard Worker * Authors:
21*2d543d20SAndroid Build Coastguard Worker * Dan Walsh <[email protected]>
22*2d543d20SAndroid Build Coastguard Worker *
23*2d543d20SAndroid Build Coastguard Worker */
24*2d543d20SAndroid Build Coastguard Worker
25*2d543d20SAndroid Build Coastguard Worker #include <string.h>
26*2d543d20SAndroid Build Coastguard Worker #include <stdio.h>
27*2d543d20SAndroid Build Coastguard Worker #include <stdlib.h>
28*2d543d20SAndroid Build Coastguard Worker #include "stringslist.h"
29*2d543d20SAndroid Build Coastguard Worker #include "restorecond.h"
30*2d543d20SAndroid Build Coastguard Worker #include <fnmatch.h>
31*2d543d20SAndroid Build Coastguard Worker
32*2d543d20SAndroid Build Coastguard Worker /* Sorted lists */
strings_list_add(struct stringsList ** list,const char * string)33*2d543d20SAndroid Build Coastguard Worker void strings_list_add(struct stringsList **list, const char *string)
34*2d543d20SAndroid Build Coastguard Worker {
35*2d543d20SAndroid Build Coastguard Worker struct stringsList *ptr = *list;
36*2d543d20SAndroid Build Coastguard Worker struct stringsList *prev = NULL;
37*2d543d20SAndroid Build Coastguard Worker struct stringsList *newptr = NULL;
38*2d543d20SAndroid Build Coastguard Worker while (ptr) {
39*2d543d20SAndroid Build Coastguard Worker int cmp = strcmp(string, ptr->string);
40*2d543d20SAndroid Build Coastguard Worker if (cmp < 0)
41*2d543d20SAndroid Build Coastguard Worker break; /* Not on list break out to add */
42*2d543d20SAndroid Build Coastguard Worker if (cmp == 0)
43*2d543d20SAndroid Build Coastguard Worker return; /* Already on list */
44*2d543d20SAndroid Build Coastguard Worker prev = ptr;
45*2d543d20SAndroid Build Coastguard Worker ptr = ptr->next;
46*2d543d20SAndroid Build Coastguard Worker }
47*2d543d20SAndroid Build Coastguard Worker newptr = calloc(1, sizeof(struct stringsList));
48*2d543d20SAndroid Build Coastguard Worker if (!newptr)
49*2d543d20SAndroid Build Coastguard Worker exitApp("Out of Memory");
50*2d543d20SAndroid Build Coastguard Worker newptr->string = strdup(string);
51*2d543d20SAndroid Build Coastguard Worker if (!newptr->string)
52*2d543d20SAndroid Build Coastguard Worker exitApp("Out of Memory");
53*2d543d20SAndroid Build Coastguard Worker newptr->next = ptr;
54*2d543d20SAndroid Build Coastguard Worker if (prev)
55*2d543d20SAndroid Build Coastguard Worker prev->next = newptr;
56*2d543d20SAndroid Build Coastguard Worker else
57*2d543d20SAndroid Build Coastguard Worker *list = newptr;
58*2d543d20SAndroid Build Coastguard Worker }
59*2d543d20SAndroid Build Coastguard Worker
strings_list_find(struct stringsList * ptr,const char * string,int * exact)60*2d543d20SAndroid Build Coastguard Worker int strings_list_find(struct stringsList *ptr, const char *string, int *exact)
61*2d543d20SAndroid Build Coastguard Worker {
62*2d543d20SAndroid Build Coastguard Worker while (ptr) {
63*2d543d20SAndroid Build Coastguard Worker *exact = strcmp(ptr->string, string) == 0;
64*2d543d20SAndroid Build Coastguard Worker int cmp = fnmatch(ptr->string, string, 0);
65*2d543d20SAndroid Build Coastguard Worker if (cmp == 0)
66*2d543d20SAndroid Build Coastguard Worker return 0; /* Match found */
67*2d543d20SAndroid Build Coastguard Worker ptr = ptr->next;
68*2d543d20SAndroid Build Coastguard Worker }
69*2d543d20SAndroid Build Coastguard Worker return -1;
70*2d543d20SAndroid Build Coastguard Worker }
71*2d543d20SAndroid Build Coastguard Worker
strings_list_free(struct stringsList * ptr)72*2d543d20SAndroid Build Coastguard Worker void strings_list_free(struct stringsList *ptr)
73*2d543d20SAndroid Build Coastguard Worker {
74*2d543d20SAndroid Build Coastguard Worker struct stringsList *prev = NULL;
75*2d543d20SAndroid Build Coastguard Worker while (ptr) {
76*2d543d20SAndroid Build Coastguard Worker free(ptr->string);
77*2d543d20SAndroid Build Coastguard Worker prev = ptr;
78*2d543d20SAndroid Build Coastguard Worker ptr = ptr->next;
79*2d543d20SAndroid Build Coastguard Worker free(prev);
80*2d543d20SAndroid Build Coastguard Worker }
81*2d543d20SAndroid Build Coastguard Worker }
82*2d543d20SAndroid Build Coastguard Worker
strings_list_diff(struct stringsList * from,struct stringsList * to)83*2d543d20SAndroid Build Coastguard Worker int strings_list_diff(struct stringsList *from, struct stringsList *to)
84*2d543d20SAndroid Build Coastguard Worker {
85*2d543d20SAndroid Build Coastguard Worker while (from != NULL && to != NULL) {
86*2d543d20SAndroid Build Coastguard Worker if (strcmp(from->string, to->string) != 0)
87*2d543d20SAndroid Build Coastguard Worker return 1;
88*2d543d20SAndroid Build Coastguard Worker from = from->next;
89*2d543d20SAndroid Build Coastguard Worker to = to->next;
90*2d543d20SAndroid Build Coastguard Worker }
91*2d543d20SAndroid Build Coastguard Worker if (from != NULL || to != NULL)
92*2d543d20SAndroid Build Coastguard Worker return 1;
93*2d543d20SAndroid Build Coastguard Worker return 0;
94*2d543d20SAndroid Build Coastguard Worker }
95*2d543d20SAndroid Build Coastguard Worker
strings_list_print(struct stringsList * ptr)96*2d543d20SAndroid Build Coastguard Worker void strings_list_print(struct stringsList *ptr)
97*2d543d20SAndroid Build Coastguard Worker {
98*2d543d20SAndroid Build Coastguard Worker while (ptr) {
99*2d543d20SAndroid Build Coastguard Worker printf("%s\n", ptr->string);
100*2d543d20SAndroid Build Coastguard Worker ptr = ptr->next;
101*2d543d20SAndroid Build Coastguard Worker }
102*2d543d20SAndroid Build Coastguard Worker }
103*2d543d20SAndroid Build Coastguard Worker
104*2d543d20SAndroid Build Coastguard Worker #ifdef TEST
exitApp(const char * msg)105*2d543d20SAndroid Build Coastguard Worker void exitApp(const char *msg)
106*2d543d20SAndroid Build Coastguard Worker {
107*2d543d20SAndroid Build Coastguard Worker perror(msg);
108*2d543d20SAndroid Build Coastguard Worker exit(-1);
109*2d543d20SAndroid Build Coastguard Worker }
110*2d543d20SAndroid Build Coastguard Worker
main(int argc,char ** argv)111*2d543d20SAndroid Build Coastguard Worker int main(int argc, char **argv)
112*2d543d20SAndroid Build Coastguard Worker {
113*2d543d20SAndroid Build Coastguard Worker struct stringsList *list = NULL;
114*2d543d20SAndroid Build Coastguard Worker struct stringsList *list1 = NULL;
115*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list, "/etc/resolv.conf");
116*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list, "/etc/walsh");
117*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list, "/etc/mtab");
118*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list, "/etc/walsh");
119*2d543d20SAndroid Build Coastguard Worker if (strings_list_diff(list, list) != 0)
120*2d543d20SAndroid Build Coastguard Worker printf("strings_list_diff test1 bug\n");
121*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list1, "/etc/walsh");
122*2d543d20SAndroid Build Coastguard Worker if (strings_list_diff(list, list1) == 0)
123*2d543d20SAndroid Build Coastguard Worker printf("strings_list_diff test2 bug\n");
124*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list1, "/etc/walsh");
125*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list1, "/etc/walsh/*");
126*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list1, "/etc/resolv.conf");
127*2d543d20SAndroid Build Coastguard Worker strings_list_add(&list1, "/etc/mtab1");
128*2d543d20SAndroid Build Coastguard Worker if (strings_list_diff(list, list1) == 0)
129*2d543d20SAndroid Build Coastguard Worker printf("strings_list_diff test3 bug\n");
130*2d543d20SAndroid Build Coastguard Worker printf("strings list\n");
131*2d543d20SAndroid Build Coastguard Worker strings_list_print(list);
132*2d543d20SAndroid Build Coastguard Worker printf("strings list1\n");
133*2d543d20SAndroid Build Coastguard Worker strings_list_find(list1, "/etc/walsh/dan");
134*2d543d20SAndroid Build Coastguard Worker strings_list_print(list1);
135*2d543d20SAndroid Build Coastguard Worker strings_list_free(list);
136*2d543d20SAndroid Build Coastguard Worker strings_list_free(list1);
137*2d543d20SAndroid Build Coastguard Worker }
138*2d543d20SAndroid Build Coastguard Worker #endif
139