src/stringlist.c
author Volker Birk <vb@pep-project.org>
Thu, 31 Mar 2016 14:01:45 +0200
changeset 523 afaf34a57cc6
parent 301 d8b44dc4b0c8
child 825 c5b5500a978d
permissions -rw-r--r--
delete from stringlist
vb@125
     1
#include "pEp_internal.h"
vb@125
     2
vb@98
     3
#include <stdlib.h>
vb@98
     4
#include <string.h>
vb@98
     5
#include <assert.h>
vb@98
     6
vb@98
     7
#include "stringlist.h"
vb@98
     8
vb@98
     9
vb@98
    10
DYNAMIC_API stringlist_t *new_stringlist(const char *value)
vb@98
    11
{
vb@107
    12
    stringlist_t *result = calloc(1, sizeof(stringlist_t));
vb@109
    13
    assert(result);
vb@109
    14
vb@98
    15
    if (result && value) {
vb@98
    16
        result->value = strdup(value);
vb@98
    17
        assert(result->value);
vb@98
    18
        if (result->value == 0) {
vb@98
    19
            free(result);
vb@98
    20
            return NULL;
vb@98
    21
        }
vb@98
    22
    }
vb@109
    23
vb@98
    24
    return result;
vb@98
    25
}
vb@98
    26
vb@98
    27
DYNAMIC_API stringlist_t *stringlist_dup(const stringlist_t *src)
vb@98
    28
{
vb@98
    29
    assert(src);
vb@98
    30
    if (src == NULL)
vb@98
    31
        return NULL;
vb@98
    32
vb@98
    33
    stringlist_t *dst = new_stringlist(src->value);
vb@98
    34
    if (dst == NULL)
vb@98
    35
        return NULL;
vb@98
    36
vb@98
    37
    if (src->next) {
vb@98
    38
        dst->next = stringlist_dup(src->next);
vb@98
    39
        if (dst->next == NULL) {
vb@98
    40
            free_stringlist(dst);
vb@98
    41
            return NULL;
vb@98
    42
        }
vb@98
    43
    }
vb@98
    44
vb@98
    45
    return dst;
vb@98
    46
}
vb@98
    47
vb@113
    48
DYNAMIC_API stringlist_t *stringlist_add(
vb@113
    49
        stringlist_t *stringlist,
vb@113
    50
        const char *value
vb@113
    51
    )
vb@98
    52
{
vb@98
    53
    assert(value);
vb@98
    54
vb@98
    55
    if (stringlist == NULL)
vb@98
    56
        return new_stringlist(value);
vb@98
    57
vb@98
    58
    if (stringlist->next != NULL)
vb@98
    59
        return stringlist_add(stringlist->next, value);
vb@98
    60
    if (stringlist->value == NULL) {
vb@98
    61
        stringlist->value = strdup(value);
vb@98
    62
        assert(stringlist->value);
vb@98
    63
        if (stringlist->value == NULL)
vb@98
    64
            return NULL;
vb@98
    65
        return stringlist;
vb@98
    66
    }
vb@98
    67
vb@98
    68
    stringlist->next = new_stringlist(value);
vb@98
    69
    assert(stringlist->next);
vb@98
    70
    if (stringlist->next == NULL)
vb@98
    71
        return NULL;
vb@98
    72
vb@98
    73
    return stringlist->next;
vb@98
    74
}
vb@98
    75
vb@113
    76
DYNAMIC_API stringlist_t *stringlist_append(
vb@113
    77
        stringlist_t *stringlist,
vb@113
    78
        stringlist_t *second
vb@113
    79
    )
vb@98
    80
{
vb@98
    81
    assert(stringlist);
vb@98
    82
vb@98
    83
    if (second == NULL || second->value == NULL)
vb@98
    84
        return stringlist;
vb@98
    85
vb@98
    86
    stringlist_t *_s = stringlist;
vb@98
    87
    stringlist_t *_s2;
vb@98
    88
    for (_s2 = second; _s2 != NULL; _s2 = _s2->next) {
vb@98
    89
        _s = stringlist_add(_s, _s2->value);
vb@98
    90
        if (_s == NULL)
vb@98
    91
            return NULL;
vb@98
    92
    }
vb@98
    93
    return _s;
vb@98
    94
}
vb@98
    95
vb@98
    96
DYNAMIC_API int stringlist_length(const stringlist_t *stringlist)
vb@98
    97
{
vb@301
    98
    int len = 0;
vb@98
    99
vb@301
   100
    const stringlist_t *_sl;
vb@301
   101
    for (_sl = stringlist; _sl && _sl->value; _sl = _sl->next)
vb@301
   102
        len++;
vb@98
   103
vb@98
   104
    return len;
vb@98
   105
}
vb@98
   106
vb@523
   107
DYNAMIC_API stringlist_t *stringlist_delete(
vb@523
   108
        stringlist_t *stringlist,
vb@523
   109
        const char *value
vb@523
   110
    )
vb@523
   111
{
vb@523
   112
    assert(stringlist);
vb@523
   113
    assert(value);
vb@523
   114
vb@523
   115
    if (stringlist->value == NULL) {
vb@523
   116
        free_stringlist(stringlist);
vb@523
   117
        return NULL;
vb@523
   118
    }
vb@523
   119
vb@523
   120
    if (value == NULL)
vb@523
   121
        return stringlist;
vb@523
   122
vb@523
   123
    stringlist_t *_sl;
vb@523
   124
    stringlist_t *last = NULL;
vb@523
   125
    for (_sl = stringlist; _sl && _sl->value; _sl = _sl->next) {
vb@523
   126
        if (strcmp(_sl->value, value) == 0) {
vb@523
   127
            if (last == NULL)
vb@523
   128
                stringlist = stringlist->next;
vb@523
   129
            else
vb@523
   130
                last->next = _sl->next;
vb@523
   131
            _sl->next = NULL;
vb@523
   132
            free_stringlist(_sl);
vb@523
   133
            break;
vb@523
   134
        }
vb@523
   135
        last = _sl;
vb@523
   136
    }
vb@523
   137
    return stringlist;
vb@523
   138
}
vb@523
   139
vb@98
   140
DYNAMIC_API void free_stringlist(stringlist_t *stringlist)
vb@98
   141
{
vb@98
   142
    if (stringlist) {
vb@98
   143
        free_stringlist(stringlist->next);
vb@98
   144
        free(stringlist->value);
vb@98
   145
        free(stringlist);
vb@98
   146
    }
vb@98
   147
}
vb@98
   148