Do a signed compare suitable for sorting TR_NAMEs.
[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 (!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   int len=one->len;
84   int cmp=0;
85
86   if (two->len<one->len)
87     len=two->len; /* len now min(one->len,two->len) */
88
89   cmp=strncmp(one->buf, two->buf, len);
90   if (cmp==0) {
91     if (one->len<two->len)
92       return -1;
93     else if (one->len==two->len)
94       return 0;
95     else
96       return 1;
97   }
98   return cmp;
99 }
100
101 void tr_name_strlcat(char *dest, const TR_NAME *src, size_t len)
102 {
103   size_t used_len;
104   if (src->len >= len)
105     used_len = len-1;
106   else used_len = src->len;
107   if (used_len > 0)
108     strncat(dest, src->buf, used_len);
109   else dest[0] = '\0';
110 }
111
112   
113 char * tr_name_strdup(TR_NAME *src)
114 {
115   char *s = calloc(src->len+1, 1);
116   if (s) {
117     memcpy(s, src->buf, src->len);
118     s[src->len] = '\0';
119   }
120   return s;
121 }
122
123