annotate mcabber/utils.c @ 8:4c1affca7aea

[/trunk] Changeset 23 by mikael * Don't crash when receiving a message with more than 50 lines!
author mikael
date Sat, 19 Mar 2005 12:45:11 +0000
parents 4dcabf02f474
children 7eeda3a06b21
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
1 #include <stdio.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
2 #include <string.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
3 #include <stdlib.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
4 #include <ncurses.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
5 #include <stdarg.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
6 #include <time.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
7
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
8 /* Variables globales a UTILS.C */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
9 int DebugEnabled = 0;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
10
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
11 void ut_InitDebug(int level)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
12 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
13 FILE *fp = fopen("/tmp/mcabberlog", "w");
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
14
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
15 DebugEnabled = level;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
16 fprintf(fp, "Debug inicializado...\n"
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
17 "-----------------------------------\n");
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
18 fclose(fp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
19 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
20
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
21 void ut_WriteLog(const char *fmt, ...)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
22 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
23 FILE *fp = NULL;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
24 time_t ahora;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
25 va_list ap;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
26 char *buffer = NULL;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
27
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
28 if (DebugEnabled) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
29 fp = fopen("/tmp/mcabberlog", "a+");
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
30 buffer = (char *) calloc(1, 64);
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
31
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
32 ahora = time(NULL);
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
33 strftime(buffer, 64, "[%H:%M:%S] ", localtime(&ahora));
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
34 fprintf(fp, "%s", buffer);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
35
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
36 va_start(ap, fmt);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
37 vfprintf(fp, fmt, ap);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
38 va_end(ap);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
39
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
40 free(buffer);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
41 fclose(fp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
42 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
43 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
44
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
45 char **ut_SplitMessage(char *message, int *nsubmsgs, unsigned int maxlong)
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
46 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
47 /* BUGs: recorta la palabra si la longitud maxlong es menor que la palabra
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
48 // maxlong = 4
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
49 // message = "peaso bug!"
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
50 // submsgs[0] = "peas"
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
51 // submsgs[1] = "bug!"
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
52 // por lo demas, rula de arte. De todos modos, podrias verificarla ???
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
53 */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
54 char *running;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
55 char *aux;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
56 char *aux2;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
57 char **submsgs;
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
58 char *buffer = (char *) malloc(strlen(message) * 2);
8
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
59 int maxnlines = 50;
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
60 int i = 0;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
61
8
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
62 submsgs = (char **) malloc(maxnlines * sizeof(char *));
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
63
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
64 running = strdup(message);
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
65 aux2 = strdup(message);
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
66
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
67 aux = index(running, '\n'); /* is there a CR? */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
68
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
69 while ((strlen(aux2) > maxlong) || (aux)) {
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
70 memset(buffer, 0, strlen(message) * 2);
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
71 running[maxlong] = '\0'; /* cut at $maxlong chars */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
72
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
73 if (aux != NULL) { /* there is a CR */
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
74 strncpy(buffer, running, strlen(running) - strlen(aux));
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
75 } else {
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
76 aux = rindex(running, ' '); /* look for last blank */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
77 if (aux != NULL) /* hay blanco! */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
78 strncpy(buffer, running, strlen(running) - strlen(aux));
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
79 else
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
80 strcpy(buffer, running); /* se supone que esto es pa evitar el bug explicado arriba, pero no rula */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
81 }
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
82
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
83 submsgs[i] = (char *) malloc(strlen(buffer) + 1); /*reservamos memoria */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
84 strcpy(submsgs[i], buffer); /*copiamos el buffer de arriba */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
85 i++; /*aumentamos numero de mensajillos */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
86 aux2 += strlen(buffer) + 1; /*eliminamos texto particionado */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
87 sprintf(running, "%s", aux2); /*y lo copiamos de nuevo a la string de "curro" */
8
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
88
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
89 // Check if we have allocated enough space
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
90 if (i >= maxnlines) {
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
91 maxnlines += 50;
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
92 submsgs = (char **) realloc(submsgs, maxnlines * sizeof(char *));
4c1affca7aea [/trunk] Changeset 23 by mikael
mikael
parents: 5
diff changeset
93 }
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
94 aux = index(running, '\n'); /* is there is a CR now? */
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
95 }
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
96 /* last part of the message */
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
97 if (strlen(aux2) > 0) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
98 submsgs[i] = (char *) malloc(strlen(aux2) + 1);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
99 strcpy(submsgs[i], aux2);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
100 i++;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
101 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
102 (*nsubmsgs) = i;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
103 free(buffer);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
104 return submsgs;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
105 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
106
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
107 /* Desc: get the rightmost substring
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
108 *
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
109 * In : string, match
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
110 * Out : ptr to substring (or NULL if not found)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
111 *
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
112 * Note: this one has no namespace, cos it belongs to <string.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
113 */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
114 char *ut_strrstr(const char *s1, const char *s2)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
115 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
116 int l = strlen(s2);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
117
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
118 if (l) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
119 const char *s = strchr(s1, '\0') - l;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
120 while (s >= s1) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
121 if (*s == *s2) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
122 int _l = l - 1;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
123 const char *_s = s + 1, *_s2 = s2 + 1;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
124 while (_l) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
125 if (*_s++ != *_s2++) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
126 break;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
127 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
128 _l--;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
129 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
130 if (!_l) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
131 return (char *) s;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
132 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
133 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
134 s--;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
135 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
136 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
137
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
138 return NULL;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
139 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
140
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
141 char *gettag(char *buffer, char *what)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
142 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
143 char *aux;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
144 char *aux2;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
145 char *result = (char *) malloc(1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
146 char *tmp = (char *) malloc(1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
147 memset(result, 0, 1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
148 memset(tmp, 0, 1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
149
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
150 sprintf(tmp, "<%s>", what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
151 aux = strstr(buffer, tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
152 if (aux) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
153 aux += strlen(tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
154 sprintf(tmp, "</%s>", what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
155 aux2 = strstr(aux, tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
156 if (aux2) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
157 strncpy(result, aux, strlen(aux) - strlen(aux2));
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
158 free(tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
159 return result;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
160 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
161 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
162 free(tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
163 free(result);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
164 return "UNKtag";
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
165 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
166
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
167
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
168 char *getattr(char *buffer, char *what)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
169 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
170 char *aux;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
171 char *aux2;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
172 char *result = (char *) malloc(1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
173 memset(result, 0, 1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
174
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
175 aux = strstr(buffer, what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
176 if (aux) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
177 aux += strlen(what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
178 aux2 = strstr(aux, "'");
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
179 if (aux2) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
180 strncpy(result, aux, strlen(aux) - strlen(aux2));
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
181 return result;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
182 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
183 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
184 free(result);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
185 return "UNKattr";
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
186 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
187
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
188 void ut_CenterMessage(char *text, int width, char *output)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
189 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
190 char *blank;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
191 int ntest, nn;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
192
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
193 memset(output, 0, strlen(output));
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
194
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
195 ntest = (width - strlen(text)) / 2;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
196 blank = (char *) malloc(ntest + 1);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
197
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
198 for (nn = 0; nn < ntest; nn++)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
199 blank[nn] = ' ';
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
200 blank[ntest] = '\0';
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
201
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
202 strcpy(output, blank);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
203 strcat(output, text);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
204 strcat(output, blank);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
205
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
206 free(blank);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
207 }