Bump versions to 1.5.2 in a couple places.
[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 (const 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 (!from) {
68     return NULL;
69   }
70
71   if (NULL != (to = malloc(sizeof(TR_NAME)))) {
72     to->len = from->len;
73     if (NULL != (to->buf = malloc(to->len+1))) {
74       strncpy(to->buf, from->buf, from->len);
75       to->buf[to->len] = 0;     /* NULL terminate for debugging printf()s */
76     }
77   }
78   return to;
79 }
80
81 int tr_name_cmp(TR_NAME *one, TR_NAME *two)
82 {
83   if (one->len != two->len)
84     return 1;
85   else {
86     /* lengths equal */
87     return strncmp(one->buf, two->buf, one->len);
88   }
89 }
90
91 void tr_name_strlcat(char *dest, const TR_NAME *src, size_t len)
92 {
93   size_t used_len;
94   if (src->len >= len)
95     used_len = len-1;
96   else used_len = src->len;
97   if (used_len > 0)
98     strncat(dest, src->buf, used_len);
99   else dest[0] = '\0';
100 }
101
102   
103 char * tr_name_strdup(TR_NAME *src)
104 {
105   char *s = calloc(src->len+1, 1);
106   if (s) {
107     memcpy(s, src->buf, src->len);
108     s[src->len] = '\0';
109   }
110   return s;
111 }
112
113