|
Packit |
f2ed7b |
/*
|
|
Packit |
f2ed7b |
* Copyright (C) 2006, 2008 Red Hat
|
|
Packit |
f2ed7b |
* see file 'COPYING' for use and warranty information
|
|
Packit |
f2ed7b |
*
|
|
Packit |
f2ed7b |
* This program is free software; you can redistribute it and/or
|
|
Packit |
f2ed7b |
* modify it under the terms of the GNU General Public License as
|
|
Packit |
f2ed7b |
* published by the Free Software Foundation; either version 2 of
|
|
Packit |
f2ed7b |
* the License, or (at your option) any later version.
|
|
Packit |
f2ed7b |
*
|
|
Packit |
f2ed7b |
* This program is distributed in the hope that it will be useful,
|
|
Packit |
f2ed7b |
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
Packit |
f2ed7b |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
Packit |
f2ed7b |
* GNU General Public License for more details.
|
|
Packit |
f2ed7b |
.*
|
|
Packit |
f2ed7b |
* You should have received a copy of the GNU General Public License
|
|
Packit |
f2ed7b |
* along with this program; if not, write to the Free Software
|
|
Packit |
f2ed7b |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
|
Packit |
f2ed7b |
* 02111-1307 USA
|
|
Packit |
f2ed7b |
*
|
|
Packit |
f2ed7b |
* Authors:
|
|
Packit |
f2ed7b |
* Dan Walsh <dwalsh@redhat.com>
|
|
Packit |
f2ed7b |
*
|
|
Packit |
f2ed7b |
*/
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
#include <string.h>
|
|
Packit |
f2ed7b |
#include <stdio.h>
|
|
Packit |
f2ed7b |
#include <stdlib.h>
|
|
Packit |
f2ed7b |
#include "stringslist.h"
|
|
Packit |
f2ed7b |
#include "restorecond.h"
|
|
Packit |
f2ed7b |
#include <fnmatch.h>
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
/* Sorted lists */
|
|
Packit |
f2ed7b |
void strings_list_add(struct stringsList **list, const char *string)
|
|
Packit |
f2ed7b |
{
|
|
Packit |
f2ed7b |
struct stringsList *ptr = *list;
|
|
Packit |
f2ed7b |
struct stringsList *prev = NULL;
|
|
Packit |
f2ed7b |
struct stringsList *newptr = NULL;
|
|
Packit |
f2ed7b |
while (ptr) {
|
|
Packit |
f2ed7b |
int cmp = strcmp(string, ptr->string);
|
|
Packit |
f2ed7b |
if (cmp < 0)
|
|
Packit |
f2ed7b |
break; /* Not on list break out to add */
|
|
Packit |
f2ed7b |
if (cmp == 0)
|
|
Packit |
f2ed7b |
return; /* Already on list */
|
|
Packit |
f2ed7b |
prev = ptr;
|
|
Packit |
f2ed7b |
ptr = ptr->next;
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
newptr = calloc(1, sizeof(struct stringsList));
|
|
Packit |
f2ed7b |
if (!newptr)
|
|
Packit |
f2ed7b |
exitApp("Out of Memory");
|
|
Packit |
f2ed7b |
newptr->string = strdup(string);
|
|
Packit |
f2ed7b |
newptr->next = ptr;
|
|
Packit |
f2ed7b |
if (prev)
|
|
Packit |
f2ed7b |
prev->next = newptr;
|
|
Packit |
f2ed7b |
else
|
|
Packit |
f2ed7b |
*list = newptr;
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
int strings_list_find(struct stringsList *ptr, const char *string, int *exact)
|
|
Packit |
f2ed7b |
{
|
|
Packit |
f2ed7b |
while (ptr) {
|
|
Packit |
f2ed7b |
*exact = strcmp(ptr->string, string) == 0;
|
|
Packit |
f2ed7b |
int cmp = fnmatch(ptr->string, string, 0);
|
|
Packit |
f2ed7b |
if (cmp == 0)
|
|
Packit |
f2ed7b |
return 0; /* Match found */
|
|
Packit |
f2ed7b |
ptr = ptr->next;
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
return -1;
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
void strings_list_free(struct stringsList *ptr)
|
|
Packit |
f2ed7b |
{
|
|
Packit |
f2ed7b |
struct stringsList *prev = NULL;
|
|
Packit |
f2ed7b |
while (ptr) {
|
|
Packit |
f2ed7b |
free(ptr->string);
|
|
Packit |
f2ed7b |
prev = ptr;
|
|
Packit |
f2ed7b |
ptr = ptr->next;
|
|
Packit |
f2ed7b |
free(prev);
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
int strings_list_diff(struct stringsList *from, struct stringsList *to)
|
|
Packit |
f2ed7b |
{
|
|
Packit |
f2ed7b |
while (from != NULL && to != NULL) {
|
|
Packit |
f2ed7b |
if (strcmp(from->string, to->string) != 0)
|
|
Packit |
f2ed7b |
return 1;
|
|
Packit |
f2ed7b |
from = from->next;
|
|
Packit |
f2ed7b |
to = to->next;
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
if (from != NULL || to != NULL)
|
|
Packit |
f2ed7b |
return 1;
|
|
Packit |
f2ed7b |
return 0;
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
void strings_list_print(struct stringsList *ptr)
|
|
Packit |
f2ed7b |
{
|
|
Packit |
f2ed7b |
while (ptr) {
|
|
Packit |
f2ed7b |
printf("%s\n", ptr->string);
|
|
Packit |
f2ed7b |
ptr = ptr->next;
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
#ifdef TEST
|
|
Packit |
f2ed7b |
void exitApp(const char *msg)
|
|
Packit |
f2ed7b |
{
|
|
Packit |
f2ed7b |
perror(msg);
|
|
Packit |
f2ed7b |
exit(-1);
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
|
|
Packit |
f2ed7b |
int main(int argc, char **argv)
|
|
Packit |
f2ed7b |
{
|
|
Packit |
f2ed7b |
struct stringsList *list = NULL;
|
|
Packit |
f2ed7b |
struct stringsList *list1 = NULL;
|
|
Packit |
f2ed7b |
strings_list_add(&list, "/etc/resolv.conf");
|
|
Packit |
f2ed7b |
strings_list_add(&list, "/etc/walsh");
|
|
Packit |
f2ed7b |
strings_list_add(&list, "/etc/mtab");
|
|
Packit |
f2ed7b |
strings_list_add(&list, "/etc/walsh");
|
|
Packit |
f2ed7b |
if (strings_list_diff(list, list) != 0)
|
|
Packit |
f2ed7b |
printf("strings_list_diff test1 bug\n");
|
|
Packit |
f2ed7b |
strings_list_add(&list1, "/etc/walsh");
|
|
Packit |
f2ed7b |
if (strings_list_diff(list, list1) == 0)
|
|
Packit |
f2ed7b |
printf("strings_list_diff test2 bug\n");
|
|
Packit |
f2ed7b |
strings_list_add(&list1, "/etc/walsh");
|
|
Packit |
f2ed7b |
strings_list_add(&list1, "/etc/walsh/*");
|
|
Packit |
f2ed7b |
strings_list_add(&list1, "/etc/resolv.conf");
|
|
Packit |
f2ed7b |
strings_list_add(&list1, "/etc/mtab1");
|
|
Packit |
f2ed7b |
if (strings_list_diff(list, list1) == 0)
|
|
Packit |
f2ed7b |
printf("strings_list_diff test3 bug\n");
|
|
Packit |
f2ed7b |
printf("strings list\n");
|
|
Packit |
f2ed7b |
strings_list_print(list);
|
|
Packit |
f2ed7b |
printf("strings list1\n");
|
|
Packit |
f2ed7b |
strings_list_find(list1, "/etc/walsh/dan");
|
|
Packit |
f2ed7b |
strings_list_print(list1);
|
|
Packit |
f2ed7b |
strings_list_free(list);
|
|
Packit |
f2ed7b |
strings_list_free(list1);
|
|
Packit |
f2ed7b |
}
|
|
Packit |
f2ed7b |
#endif
|