Blame restorecond/stringslist.c

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