src/stringpair.c
author Roker <roker@pep-project.org>
Fri, 01 Jul 2016 10:59:53 +0200
changeset 786 cd0c6d03e539
parent 302 1d1a2e776631
child 812 786f03e0cae4
permissions -rw-r--r--
clarify which values are okay in stringpair
     1 #include "pEp_internal.h"
     2 
     3 #include <stdlib.h>
     4 #include <assert.h>
     5 #include <string.h>
     6 
     7 #include "stringpair.h"
     8 
     9 DYNAMIC_API stringpair_t * new_stringpair(const char *key, const char *value)
    10 {
    11     stringpair_t *pair = NULL;
    12 
    13     assert(key);
    14     assert(value),
    15 
    16     pair = calloc(1, sizeof(stringpair_t));
    17     assert(pair);
    18     if (pair == NULL)
    19         goto enomem;
    20 
    21     pair->key = strdup(key);
    22     assert(pair->key);
    23     if (pair->key == NULL)
    24         goto enomem;
    25 
    26     pair->value = strdup(value);
    27     assert(pair->value);
    28     if (pair->value == NULL)
    29         goto enomem;
    30 
    31     return pair;
    32 
    33 enomem:
    34     free_stringpair(pair);
    35     return NULL;
    36 }
    37 
    38 DYNAMIC_API void free_stringpair(stringpair_t * pair)
    39 {
    40     if (pair) {
    41         free(pair->key);
    42         free(pair->value);
    43         free(pair);
    44     }
    45 }
    46 
    47 DYNAMIC_API stringpair_t * stringpair_dup(const stringpair_t *src)
    48 {
    49     assert(src);
    50     return new_stringpair(src->key, src->value);
    51 }
    52 
    53 DYNAMIC_API stringpair_list_t *new_stringpair_list(stringpair_t *value)
    54 {
    55     stringpair_list_t *result = calloc(1, sizeof(stringpair_list_t));
    56     assert(result);
    57 
    58     if (result && value)
    59         result->value = value;
    60 
    61     return result;
    62 }
    63 
    64 DYNAMIC_API stringpair_list_t *stringpair_list_dup(
    65         const stringpair_list_t *src
    66     )
    67 {
    68     assert(src);
    69     if (src == NULL)
    70         return NULL;
    71 
    72     stringpair_list_t *dst = new_stringpair_list(src->value);
    73     if (dst == NULL)
    74         return NULL;
    75 
    76     if (src->next) {
    77         dst->next = stringpair_list_dup(src->next);
    78         if (dst->next == NULL) {
    79             free_stringpair_list(dst);
    80             return NULL;
    81         }
    82     }
    83 
    84     return dst;
    85 }
    86 
    87 DYNAMIC_API stringpair_list_t *stringpair_list_add(
    88         stringpair_list_t *stringpair_list,
    89         stringpair_t *value
    90     )
    91 {
    92     assert(value);
    93 
    94     if (stringpair_list == NULL)
    95         return new_stringpair_list(value);
    96 
    97     if (stringpair_list->next)
    98         return stringpair_list_add(stringpair_list->next, value);
    99 
   100     if (stringpair_list->value == NULL) {
   101         assert(stringpair_list->next == NULL);
   102         stringpair_list->value = value;
   103         return stringpair_list;
   104     }
   105 
   106     stringpair_list->next = new_stringpair_list(value);
   107     if (stringpair_list->next == NULL)
   108         return NULL;
   109 
   110     return stringpair_list->next;
   111 }
   112 
   113 DYNAMIC_API stringpair_list_t *stringpair_list_append(
   114         stringpair_list_t *stringpair_list,
   115         stringpair_list_t *second
   116     )
   117 {
   118     assert(stringpair_list);
   119 
   120     if (second == NULL || second->value == NULL)
   121         return stringpair_list;
   122 
   123     stringpair_list_t *_s = stringpair_list;
   124     stringpair_list_t *_s2;
   125     for (_s2 = second; _s2 != NULL; _s2 = _s2->next) {
   126         _s = stringpair_list_add(_s, _s2->value);
   127         if (_s == NULL)
   128             return NULL;
   129     }
   130     return _s;
   131 }
   132 
   133 DYNAMIC_API int stringpair_list_length(
   134         const stringpair_list_t *stringpair_list
   135     )
   136 {
   137     int len = 0;
   138 
   139     const stringpair_list_t *_sl;
   140     for (_sl = stringpair_list; _sl && _sl->value; _sl = _sl->next)
   141         len++;
   142 
   143     return len;
   144 }
   145 
   146 DYNAMIC_API void free_stringpair_list(stringpair_list_t *stringpair_list)
   147 {
   148     if (stringpair_list) {
   149         free_stringpair_list(stringpair_list->next);
   150         free_stringpair(stringpair_list->value);
   151         free(stringpair_list);
   152     }
   153 }
   154 
   155 DYNAMIC_API stringpair_list_t *stringpair_list_find(
   156         stringpair_list_t *stringpair_list,
   157         const char *key
   158     )
   159 {
   160     assert(key);
   161 
   162     stringpair_list_t *_l;
   163     for (_l = stringpair_list; _l; _l = _l->next) {
   164         if (strcoll(key, _l->value->key) == 0)
   165             return _l;
   166     }
   167 
   168     return NULL;
   169 }
   170