1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/src/string_list.c Fri Dec 28 15:44:28 2012 +0100 1.3 @@ -0,0 +1,58 @@ 1.4 +/* 1.5 + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER. 1.6 + * Copyright 2011 Mike Becker. All rights reserved. 1.7 + * 1.8 + * Redistribution and use in source and binary forms, with or without 1.9 + * modification, are permitted provided that the following conditions are met: 1.10 + * 1.11 + * 1. Redistributions of source code must retain the above copyright 1.12 + * notice, this list of conditions and the following disclaimer. 1.13 + * 1.14 + * 2. Redistributions in binary form must reproduce the above copyright 1.15 + * notice, this list of conditions and the following disclaimer in the 1.16 + * documentation and/or other materials provided with the distribution. 1.17 + * 1.18 + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" 1.19 + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 1.20 + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 1.21 + * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE 1.22 + * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 1.23 + * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 1.24 + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 1.25 + * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, 1.26 + * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 1.27 + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 1.28 + * 1.29 + * string_list.c 1.30 + * 1.31 + * Created on: 15.09.2011 1.32 + * Author: Mike 1.33 + */ 1.34 + 1.35 +#include "string_list.h" 1.36 + 1.37 +string_list_t* new_string_list_t() { 1.38 + string_list_t* stringList = malloc(sizeof(string_list_t)); 1.39 + stringList->count = 0; 1.40 + stringList->items = NULL; 1.41 + 1.42 + return stringList; 1.43 +} 1.44 + 1.45 +void destroy_string_list_t(string_list_t* list) { 1.46 + if (list->items != NULL) { 1.47 + free(list->items); 1.48 + } 1.49 + free(list); 1.50 +} 1.51 + 1.52 +void add_string(string_list_t* list, char* item) { 1.53 + char** reallocated_list = 1.54 + realloc(list->items, sizeof(char*) * (list->count + 1)); 1.55 + if (reallocated_list != NULL) { 1.56 + list->items = reallocated_list; 1.57 + list->items[list->count] = item; 1.58 + list->count++; 1.59 + } 1.60 +} 1.61 +