annotate mcabber/utils.c @ 5:4dcabf02f474

[/trunk] Changeset 20 by mikael * Correctly split multi-lines messsages * Don't use an 8kB buffer needlessly for wrtiting debug log
author mikael
date Sat, 19 Mar 2005 11:09:36 +0000
parents b3b2332715fb
children 4c1affca7aea
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);
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
59 int i = 0;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
60
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
61 submsgs = (char **) malloc(50 * sizeof(char *)); /* limitamos, a priori, el maximo de lineas devueltas... */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
62
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
63 running = strdup(message);
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
64 aux2 = strdup(message);
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
65
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
66 aux = index(running, '\n'); /* is there a CR? */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
67
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
68 while ((strlen(aux2) > maxlong) || (aux)) {
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
69 memset(buffer, 0, strlen(message) * 2);
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
70 running[maxlong] = '\0'; /* cut at $maxlong chars */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
71
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
72 if (aux != NULL) { /* there is a CR */
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
73 strncpy(buffer, running, strlen(running) - strlen(aux));
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
74 } else {
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
75 aux = rindex(running, ' '); /* look for last blank */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
76 if (aux != NULL) /* hay blanco! */
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
77 strncpy(buffer, running, strlen(running) - strlen(aux));
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
78 else
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
79 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
80 }
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
81
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
82 submsgs[i] = (char *) malloc(strlen(buffer) + 1); /*reservamos memoria */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
83 strcpy(submsgs[i], buffer); /*copiamos el buffer de arriba */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
84 i++; /*aumentamos numero de mensajillos */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
85 aux2 += strlen(buffer) + 1; /*eliminamos texto particionado */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
86 sprintf(running, "%s", aux2); /*y lo copiamos de nuevo a la string de "curro" */
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
87 aux = index(running, '\n'); /* is there is a CR now? */
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
88 }
5
4dcabf02f474 [/trunk] Changeset 20 by mikael
mikael
parents: 0
diff changeset
89 /* last part of the message */
0
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
90 if (strlen(aux2) > 0) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
91 submsgs[i] = (char *) malloc(strlen(aux2) + 1);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
92 strcpy(submsgs[i], aux2);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
93 i++;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
94 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
95 (*nsubmsgs) = i;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
96 free(buffer);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
97 return submsgs;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
98 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
99
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
100 /* Desc: get the rightmost substring
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
101 *
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
102 * In : string, match
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
103 * Out : ptr to substring (or NULL if not found)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
104 *
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
105 * Note: this one has no namespace, cos it belongs to <string.h>
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
106 */
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
107 char *ut_strrstr(const char *s1, const char *s2)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
108 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
109 int l = strlen(s2);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
110
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
111 if (l) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
112 const char *s = strchr(s1, '\0') - l;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
113 while (s >= s1) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
114 if (*s == *s2) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
115 int _l = l - 1;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
116 const char *_s = s + 1, *_s2 = s2 + 1;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
117 while (_l) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
118 if (*_s++ != *_s2++) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
119 break;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
120 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
121 _l--;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
122 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
123 if (!_l) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
124 return (char *) s;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
125 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
126 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
127 s--;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
128 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
129 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
130
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
131 return NULL;
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 char *gettag(char *buffer, char *what)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
135 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
136 char *aux;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
137 char *aux2;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
138 char *result = (char *) malloc(1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
139 char *tmp = (char *) malloc(1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
140 memset(result, 0, 1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
141 memset(tmp, 0, 1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
142
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
143 sprintf(tmp, "<%s>", what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
144 aux = strstr(buffer, tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
145 if (aux) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
146 aux += strlen(tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
147 sprintf(tmp, "</%s>", what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
148 aux2 = strstr(aux, tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
149 if (aux2) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
150 strncpy(result, aux, strlen(aux) - strlen(aux2));
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
151 free(tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
152 return result;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
153 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
154 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
155 free(tmp);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
156 free(result);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
157 return "UNKtag";
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
158 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
159
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
160
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
161 char *getattr(char *buffer, char *what)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
162 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
163 char *aux;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
164 char *aux2;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
165 char *result = (char *) malloc(1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
166 memset(result, 0, 1024);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
167
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
168 aux = strstr(buffer, what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
169 if (aux) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
170 aux += strlen(what);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
171 aux2 = strstr(aux, "'");
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
172 if (aux2) {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
173 strncpy(result, aux, strlen(aux) - strlen(aux2));
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
174 return result;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
175 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
176 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
177 free(result);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
178 return "UNKattr";
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
179 }
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
180
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
181 void ut_CenterMessage(char *text, int width, char *output)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
182 {
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
183 char *blank;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
184 int ntest, nn;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
185
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
186 memset(output, 0, strlen(output));
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
187
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
188 ntest = (width - strlen(text)) / 2;
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
189 blank = (char *) malloc(ntest + 1);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
190
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
191 for (nn = 0; nn < ntest; nn++)
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
192 blank[nn] = ' ';
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
193 blank[ntest] = '\0';
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
194
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
195 strcpy(output, blank);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
196 strcat(output, text);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
197 strcat(output, blank);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
198
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
199 free(blank);
b3b2332715fb Tailorization of /trunk
tailor@frmp8452
parents:
diff changeset
200 }