00757d440ecf22d35d73521b1092d5e8c76bd46c
[trust_router.git] / common / tr_name.c
1 /*
2  * Copyright (c) 2012, JANET(UK)
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * 1. Redistributions of source code must retain the above copyright
10  *    notice, this list of conditions and the following disclaimer.
11  *
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  *
16  * 3. Neither the name of JANET(UK) nor the names of its contributors
17  *    may be used to endorse or promote products derived from this software
18  *    without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
23  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
24  * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
25  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
27  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
29  * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
31  * OF THE POSSIBILITY OF SUCH DAMAGE.
32  *
33  */
34
35 #include <stdlib.h>
36 #include <string.h>
37
38 #include <trust_router/tr_name.h>
39
40 void tr_free_name (TR_NAME *name)
41 {
42   if (name->buf) {
43     free (name->buf);
44     name->buf = NULL;
45   }
46   
47   free(name);
48 }
49
50 TR_NAME *tr_new_name (char *name) 
51 {
52   TR_NAME *new;
53
54   if (new = malloc(sizeof(TR_NAME))) { 
55     new->len = strlen(name);
56     if (new->buf = malloc((new->len)+1)) {
57       strcpy(new->buf, name);
58     }
59   }
60   return new;
61 }
62
63 TR_NAME *tr_dup_name (TR_NAME *from) 
64 {
65   TR_NAME *to;
66
67   if (to = malloc(sizeof(TR_NAME))) {
68     to->len = from->len;
69     if (to->buf = malloc(to->len+1)) {
70       strncpy(to->buf, from->buf, from->len);
71       to->buf[to->len] = 0;     /* NULL terminate for debugging printf()s */
72     }
73   }
74
75   return to;
76 }
77
78 int tr_name_cmp(TR_NAME *one, TR_NAME *two)
79 {
80   if (one->len != two->len)
81     return 1;
82   else 
83     /* TBD -- should really do a length-based comparison */
84     return strcmp(one->buf, two->buf);
85 }
86
87 void tr_name_strlcat(char *dest, const TR_NAME *src, size_t len)
88 {
89   size_t used_len;
90   if (src->len >= len)
91     used_len = len-1;
92   else used_len = src->len;
93   if (used_len > 0)
94     strncat(dest, src->buf, used_len);
95   else dest[0] = '\0';
96 }
97
98   
99 char * tr_name_strdup(TR_NAME *src)
100 {
101   char *s = calloc(src->len+1, 1);
102   if (s) {
103     memcpy(s, src->buf, src->len);
104     s[src->len] = '\0';
105   }
106   return s;
107 }
108
109