annotate gcc/ada/adadecode.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /****************************************************************************
kono
parents:
diff changeset
2 * *
kono
parents:
diff changeset
3 * GNAT COMPILER COMPONENTS *
kono
parents:
diff changeset
4 * *
kono
parents:
diff changeset
5 * A D A D E C O D E *
kono
parents:
diff changeset
6 * *
kono
parents:
diff changeset
7 * C Implementation File *
kono
parents:
diff changeset
8 * *
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
9 * Copyright (C) 2001-2018, Free Software Foundation, Inc. *
111
kono
parents:
diff changeset
10 * *
kono
parents:
diff changeset
11 * GNAT is free software; you can redistribute it and/or modify it under *
kono
parents:
diff changeset
12 * terms of the GNU General Public License as published by the Free Soft- *
kono
parents:
diff changeset
13 * ware Foundation; either version 3, or (at your option) any later ver- *
kono
parents:
diff changeset
14 * sion. GNAT is distributed in the hope that it will be useful, but WITH- *
kono
parents:
diff changeset
15 * OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *
kono
parents:
diff changeset
16 * or FITNESS FOR A PARTICULAR PURPOSE. *
kono
parents:
diff changeset
17 * *
kono
parents:
diff changeset
18 * As a special exception under Section 7 of GPL version 3, you are granted *
kono
parents:
diff changeset
19 * additional permissions described in the GCC Runtime Library Exception, *
kono
parents:
diff changeset
20 * version 3.1, as published by the Free Software Foundation. *
kono
parents:
diff changeset
21 * *
kono
parents:
diff changeset
22 * You should have received a copy of the GNU General Public License and *
kono
parents:
diff changeset
23 * a copy of the GCC Runtime Library Exception along with this program; *
kono
parents:
diff changeset
24 * see the files COPYING3 and COPYING.RUNTIME respectively. If not, see *
kono
parents:
diff changeset
25 * <http://www.gnu.org/licenses/>. *
kono
parents:
diff changeset
26 * *
kono
parents:
diff changeset
27 * GNAT was originally developed by the GNAT team at New York University. *
kono
parents:
diff changeset
28 * Extensive contributions were provided by Ada Core Technologies Inc. *
kono
parents:
diff changeset
29 * *
kono
parents:
diff changeset
30 ****************************************************************************/
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 #if defined(IN_RTS)
kono
parents:
diff changeset
34 #include "tconfig.h"
kono
parents:
diff changeset
35 #include "tsystem.h"
kono
parents:
diff changeset
36 #elif defined(IN_GCC)
kono
parents:
diff changeset
37 #include "config.h"
kono
parents:
diff changeset
38 #include "system.h"
kono
parents:
diff changeset
39 #endif
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 #include <string.h>
kono
parents:
diff changeset
42 #include <stdio.h>
kono
parents:
diff changeset
43 #include <ctype.h>
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 #include "adaint.h" /* for a macro version of xstrdup. */
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 #ifndef ISDIGIT
kono
parents:
diff changeset
48 #define ISDIGIT(c) isdigit(c)
kono
parents:
diff changeset
49 #endif
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 #ifndef PARMS
kono
parents:
diff changeset
52 #define PARMS(ARGS) ARGS
kono
parents:
diff changeset
53 #endif
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 #include "adadecode.h"
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 static void add_verbose (const char *, char *);
kono
parents:
diff changeset
58 static int has_prefix (const char *, const char *);
kono
parents:
diff changeset
59 static int has_suffix (const char *, const char *);
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 /* This is a safe version of strcpy that can be used with overlapped
kono
parents:
diff changeset
62 pointers. Does nothing if s2 <= s1. */
kono
parents:
diff changeset
63 static void ostrcpy (char *s1, char *s2);
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 /* Set to nonzero if we have written any verbose info. */
kono
parents:
diff changeset
66 static int verbose_info;
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 /* Add TEXT to end of ADA_NAME, putting a leading " (" or ", ", depending
kono
parents:
diff changeset
69 on VERBOSE_INFO. */
kono
parents:
diff changeset
70
kono
parents:
diff changeset
71 static void add_verbose (const char *text, char *ada_name)
kono
parents:
diff changeset
72 {
kono
parents:
diff changeset
73 strcat (ada_name, verbose_info ? ", " : " (");
kono
parents:
diff changeset
74 strcat (ada_name, text);
kono
parents:
diff changeset
75
kono
parents:
diff changeset
76 verbose_info = 1;
kono
parents:
diff changeset
77 }
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 /* Returns 1 if NAME starts with PREFIX. */
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 static int
kono
parents:
diff changeset
82 has_prefix (const char *name, const char *prefix)
kono
parents:
diff changeset
83 {
kono
parents:
diff changeset
84 return strncmp (name, prefix, strlen (prefix)) == 0;
kono
parents:
diff changeset
85 }
kono
parents:
diff changeset
86
kono
parents:
diff changeset
87 /* Returns 1 if NAME ends with SUFFIX. */
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 static int
kono
parents:
diff changeset
90 has_suffix (const char *name, const char *suffix)
kono
parents:
diff changeset
91 {
kono
parents:
diff changeset
92 int nlen = strlen (name);
kono
parents:
diff changeset
93 int slen = strlen (suffix);
kono
parents:
diff changeset
94
kono
parents:
diff changeset
95 return nlen > slen && strncmp (name + nlen - slen, suffix, slen) == 0;
kono
parents:
diff changeset
96 }
kono
parents:
diff changeset
97
kono
parents:
diff changeset
98 /* Safe overlapped pointers version of strcpy. */
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 static void
kono
parents:
diff changeset
101 ostrcpy (char *s1, char *s2)
kono
parents:
diff changeset
102 {
kono
parents:
diff changeset
103 if (s2 > s1)
kono
parents:
diff changeset
104 {
kono
parents:
diff changeset
105 while (*s2) *s1++ = *s2++;
kono
parents:
diff changeset
106 *s1 = '\0';
kono
parents:
diff changeset
107 }
kono
parents:
diff changeset
108 }
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 /* This function will return the Ada name from the encoded form.
kono
parents:
diff changeset
111 The Ada coding is done in exp_dbug.ads and this is the inverse function.
kono
parents:
diff changeset
112 see exp_dbug.ads for full encoding rules, a short description is added
kono
parents:
diff changeset
113 below. Right now only objects and routines are handled. Ada types are
kono
parents:
diff changeset
114 stripped of their encodings.
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 CODED_NAME is the encoded entity name.
kono
parents:
diff changeset
117
kono
parents:
diff changeset
118 ADA_NAME is a pointer to a buffer, it will receive the Ada name. A safe
kono
parents:
diff changeset
119 size for this buffer is: strlen (coded_name) * 2 + 60. (60 is for the
kono
parents:
diff changeset
120 verbose information).
kono
parents:
diff changeset
121
kono
parents:
diff changeset
122 VERBOSE is nonzero if more information about the entity is to be
kono
parents:
diff changeset
123 added at the end of the Ada name and surrounded by ( and ).
kono
parents:
diff changeset
124
kono
parents:
diff changeset
125 Coded name Ada name verbose info
kono
parents:
diff changeset
126 ---------------------------------------------------------------------
kono
parents:
diff changeset
127 _ada_xyz xyz library level
kono
parents:
diff changeset
128 x__y__z x.y.z
kono
parents:
diff changeset
129 x__yTKB x.y task body
kono
parents:
diff changeset
130 x__yB x.y task body
kono
parents:
diff changeset
131 x__yX x.y body nested
kono
parents:
diff changeset
132 x__yXb x.y body nested
kono
parents:
diff changeset
133 xTK__y x.y in task
kono
parents:
diff changeset
134 x__y$2 x.y overloaded
kono
parents:
diff changeset
135 x__y__3 x.y overloaded
kono
parents:
diff changeset
136 x__Oabs "abs"
kono
parents:
diff changeset
137 x__Oand "and"
kono
parents:
diff changeset
138 x__Omod "mod"
kono
parents:
diff changeset
139 x__Onot "not"
kono
parents:
diff changeset
140 x__Oor "or"
kono
parents:
diff changeset
141 x__Orem "rem"
kono
parents:
diff changeset
142 x__Oxor "xor"
kono
parents:
diff changeset
143 x__Oeq "="
kono
parents:
diff changeset
144 x__One "/="
kono
parents:
diff changeset
145 x__Olt "<"
kono
parents:
diff changeset
146 x__Ole "<="
kono
parents:
diff changeset
147 x__Ogt ">"
kono
parents:
diff changeset
148 x__Oge ">="
kono
parents:
diff changeset
149 x__Oadd "+"
kono
parents:
diff changeset
150 x__Osubtract "-"
kono
parents:
diff changeset
151 x__Oconcat "&"
kono
parents:
diff changeset
152 x__Omultiply "*"
kono
parents:
diff changeset
153 x__Odivide "/"
kono
parents:
diff changeset
154 x__Oexpon "**" */
kono
parents:
diff changeset
155
kono
parents:
diff changeset
156 void
kono
parents:
diff changeset
157 __gnat_decode (const char *coded_name, char *ada_name, int verbose)
kono
parents:
diff changeset
158 {
kono
parents:
diff changeset
159 int lib_subprog = 0;
kono
parents:
diff changeset
160 int overloaded = 0;
kono
parents:
diff changeset
161 int task_body = 0;
kono
parents:
diff changeset
162 int in_task = 0;
kono
parents:
diff changeset
163 int body_nested = 0;
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 /* Deal with empty input early. This allows assuming non-null length
kono
parents:
diff changeset
166 later on, simplifying coding. In principle, it should be our callers
kono
parents:
diff changeset
167 business not to call here for empty inputs. It is easy enough to
kono
parents:
diff changeset
168 allow it, however, and might allow simplifications upstream so is not
kono
parents:
diff changeset
169 a bad thing per se. We need a guard in any case. */
kono
parents:
diff changeset
170
kono
parents:
diff changeset
171 if (*coded_name == '\0')
kono
parents:
diff changeset
172 {
kono
parents:
diff changeset
173 *ada_name = '\0';
kono
parents:
diff changeset
174 return;
kono
parents:
diff changeset
175 }
kono
parents:
diff changeset
176
kono
parents:
diff changeset
177 /* Check for library level subprogram. */
kono
parents:
diff changeset
178 else if (has_prefix (coded_name, "_ada_"))
kono
parents:
diff changeset
179 {
kono
parents:
diff changeset
180 strcpy (ada_name, coded_name + 5);
kono
parents:
diff changeset
181 lib_subprog = 1;
kono
parents:
diff changeset
182 }
kono
parents:
diff changeset
183 else
kono
parents:
diff changeset
184 strcpy (ada_name, coded_name);
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 /* Check for the first triple underscore in the name. This indicates
kono
parents:
diff changeset
187 that the name represents a type with encodings; in this case, we
kono
parents:
diff changeset
188 need to strip the encodings. */
kono
parents:
diff changeset
189 {
kono
parents:
diff changeset
190 char *encodings;
kono
parents:
diff changeset
191
kono
parents:
diff changeset
192 if ((encodings = (char *) strstr (ada_name, "___")) != NULL)
kono
parents:
diff changeset
193 {
kono
parents:
diff changeset
194 *encodings = '\0';
kono
parents:
diff changeset
195 }
kono
parents:
diff changeset
196 }
kono
parents:
diff changeset
197
kono
parents:
diff changeset
198 /* Check for task body. */
kono
parents:
diff changeset
199 if (has_suffix (ada_name, "TKB"))
kono
parents:
diff changeset
200 {
kono
parents:
diff changeset
201 ada_name[strlen (ada_name) - 3] = '\0';
kono
parents:
diff changeset
202 task_body = 1;
kono
parents:
diff changeset
203 }
kono
parents:
diff changeset
204
kono
parents:
diff changeset
205 if (has_suffix (ada_name, "B"))
kono
parents:
diff changeset
206 {
kono
parents:
diff changeset
207 ada_name[strlen (ada_name) - 1] = '\0';
kono
parents:
diff changeset
208 task_body = 1;
kono
parents:
diff changeset
209 }
kono
parents:
diff changeset
210
kono
parents:
diff changeset
211 /* Check for body-nested entity: X[bn] */
kono
parents:
diff changeset
212 if (has_suffix (ada_name, "X"))
kono
parents:
diff changeset
213 {
kono
parents:
diff changeset
214 ada_name[strlen (ada_name) - 1] = '\0';
kono
parents:
diff changeset
215 body_nested = 1;
kono
parents:
diff changeset
216 }
kono
parents:
diff changeset
217
kono
parents:
diff changeset
218 if (has_suffix (ada_name, "Xb"))
kono
parents:
diff changeset
219 {
kono
parents:
diff changeset
220 ada_name[strlen (ada_name) - 2] = '\0';
kono
parents:
diff changeset
221 body_nested = 1;
kono
parents:
diff changeset
222 }
kono
parents:
diff changeset
223
kono
parents:
diff changeset
224 if (has_suffix (ada_name, "Xn"))
kono
parents:
diff changeset
225 {
kono
parents:
diff changeset
226 ada_name[strlen (ada_name) - 2] = '\0';
kono
parents:
diff changeset
227 body_nested = 1;
kono
parents:
diff changeset
228 }
kono
parents:
diff changeset
229
kono
parents:
diff changeset
230 /* Change instance of TK__ (object declared inside a task) to __. */
kono
parents:
diff changeset
231 {
kono
parents:
diff changeset
232 char *tktoken;
kono
parents:
diff changeset
233
kono
parents:
diff changeset
234 while ((tktoken = (char *) strstr (ada_name, "TK__")) != NULL)
kono
parents:
diff changeset
235 {
kono
parents:
diff changeset
236 ostrcpy (tktoken, tktoken + 2);
kono
parents:
diff changeset
237 in_task = 1;
kono
parents:
diff changeset
238 }
kono
parents:
diff changeset
239 }
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 /* Check for overloading: name terminated by $nn or __nn. */
kono
parents:
diff changeset
242 {
kono
parents:
diff changeset
243 int len = strlen (ada_name);
kono
parents:
diff changeset
244 int n_digits = 0;
kono
parents:
diff changeset
245
kono
parents:
diff changeset
246 if (len > 1)
kono
parents:
diff changeset
247 while (ISDIGIT ((int) ada_name[(int) len - 1 - n_digits]))
kono
parents:
diff changeset
248 n_digits++;
kono
parents:
diff changeset
249
kono
parents:
diff changeset
250 /* Check if we have $ or __ before digits. */
kono
parents:
diff changeset
251 if (ada_name[len - 1 - n_digits] == '$')
kono
parents:
diff changeset
252 {
kono
parents:
diff changeset
253 ada_name[len - 1 - n_digits] = '\0';
kono
parents:
diff changeset
254 overloaded = 1;
kono
parents:
diff changeset
255 }
kono
parents:
diff changeset
256 else if (ada_name[len - 1 - n_digits] == '_'
kono
parents:
diff changeset
257 && ada_name[len - 1 - n_digits - 1] == '_')
kono
parents:
diff changeset
258 {
kono
parents:
diff changeset
259 ada_name[len - 1 - n_digits - 1] = '\0';
kono
parents:
diff changeset
260 overloaded = 1;
kono
parents:
diff changeset
261 }
kono
parents:
diff changeset
262 }
kono
parents:
diff changeset
263
kono
parents:
diff changeset
264 /* Check for nested subprogram ending in .nnnn and strip suffix. */
kono
parents:
diff changeset
265 {
kono
parents:
diff changeset
266 int last = strlen (ada_name) - 1;
kono
parents:
diff changeset
267
kono
parents:
diff changeset
268 while (ISDIGIT (ada_name[last]) && last > 0)
kono
parents:
diff changeset
269 {
kono
parents:
diff changeset
270 last--;
kono
parents:
diff changeset
271 }
kono
parents:
diff changeset
272
kono
parents:
diff changeset
273 if (ada_name[last] == '.')
kono
parents:
diff changeset
274 {
kono
parents:
diff changeset
275 ada_name[last] = (char) 0;
kono
parents:
diff changeset
276 }
kono
parents:
diff changeset
277 }
kono
parents:
diff changeset
278
kono
parents:
diff changeset
279 /* Change all "__" to ".". */
kono
parents:
diff changeset
280 {
kono
parents:
diff changeset
281 int len = strlen (ada_name);
kono
parents:
diff changeset
282 int k = 0;
kono
parents:
diff changeset
283
kono
parents:
diff changeset
284 while (k < len)
kono
parents:
diff changeset
285 {
kono
parents:
diff changeset
286 if (ada_name[k] == '_' && ada_name[k+1] == '_')
kono
parents:
diff changeset
287 {
kono
parents:
diff changeset
288 ada_name[k] = '.';
kono
parents:
diff changeset
289 ostrcpy (ada_name + k + 1, ada_name + k + 2);
kono
parents:
diff changeset
290 len = len - 1;
kono
parents:
diff changeset
291 }
kono
parents:
diff changeset
292 k++;
kono
parents:
diff changeset
293 }
kono
parents:
diff changeset
294 }
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 /* Checks for operator name. */
kono
parents:
diff changeset
297 {
kono
parents:
diff changeset
298 const char *trans_table[][2]
kono
parents:
diff changeset
299 = {{"Oabs", "\"abs\""}, {"Oand", "\"and\""}, {"Omod", "\"mod\""},
kono
parents:
diff changeset
300 {"Onot", "\"not\""}, {"Oor", "\"or\""}, {"Orem", "\"rem\""},
kono
parents:
diff changeset
301 {"Oxor", "\"xor\""}, {"Oeq", "\"=\""}, {"One", "\"/=\""},
kono
parents:
diff changeset
302 {"Olt", "\"<\""}, {"Ole", "\"<=\""}, {"Ogt", "\">\""},
kono
parents:
diff changeset
303 {"Oge", "\">=\""}, {"Oadd", "\"+\""}, {"Osubtract", "\"-\""},
kono
parents:
diff changeset
304 {"Oconcat", "\"&\""}, {"Omultiply", "\"*\""}, {"Odivide", "\"/\""},
kono
parents:
diff changeset
305 {"Oexpon", "\"**\""}, {NULL, NULL} };
kono
parents:
diff changeset
306 int k = 0;
kono
parents:
diff changeset
307
kono
parents:
diff changeset
308 while (1)
kono
parents:
diff changeset
309 {
kono
parents:
diff changeset
310 char *optoken;
kono
parents:
diff changeset
311
kono
parents:
diff changeset
312 if ((optoken = (char *) strstr (ada_name, trans_table[k][0])) != NULL)
kono
parents:
diff changeset
313 {
kono
parents:
diff changeset
314 int codedlen = strlen (trans_table[k][0]);
kono
parents:
diff changeset
315 int oplen = strlen (trans_table[k][1]);
kono
parents:
diff changeset
316
kono
parents:
diff changeset
317 if (codedlen > oplen)
kono
parents:
diff changeset
318 /* We shrink the space. */
kono
parents:
diff changeset
319 ostrcpy (optoken, optoken + codedlen - oplen);
kono
parents:
diff changeset
320 else if (oplen > codedlen)
kono
parents:
diff changeset
321 {
kono
parents:
diff changeset
322 /* We need more space. */
kono
parents:
diff changeset
323 int len = strlen (ada_name);
kono
parents:
diff changeset
324 int space = oplen - codedlen;
kono
parents:
diff changeset
325 int num_to_move = &ada_name[len] - optoken;
kono
parents:
diff changeset
326 int t;
kono
parents:
diff changeset
327
kono
parents:
diff changeset
328 for (t = 0; t < num_to_move; t++)
kono
parents:
diff changeset
329 ada_name[len + space - t - 1] = ada_name[len - t - 1];
kono
parents:
diff changeset
330 }
kono
parents:
diff changeset
331
kono
parents:
diff changeset
332 /* Write symbol in the space. */
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
333 memcpy (optoken, trans_table[k][1], oplen);
111
kono
parents:
diff changeset
334 }
kono
parents:
diff changeset
335 else
kono
parents:
diff changeset
336 k++;
kono
parents:
diff changeset
337
kono
parents:
diff changeset
338 /* Check for table's ending. */
kono
parents:
diff changeset
339 if (trans_table[k][0] == NULL)
kono
parents:
diff changeset
340 break;
kono
parents:
diff changeset
341 }
kono
parents:
diff changeset
342 }
kono
parents:
diff changeset
343
kono
parents:
diff changeset
344 /* If verbose mode is on, we add some information to the Ada name. */
kono
parents:
diff changeset
345 if (verbose)
kono
parents:
diff changeset
346 {
kono
parents:
diff changeset
347 if (overloaded)
kono
parents:
diff changeset
348 add_verbose ("overloaded", ada_name);
kono
parents:
diff changeset
349
kono
parents:
diff changeset
350 if (lib_subprog)
kono
parents:
diff changeset
351 add_verbose ("library level", ada_name);
kono
parents:
diff changeset
352
kono
parents:
diff changeset
353 if (body_nested)
kono
parents:
diff changeset
354 add_verbose ("body nested", ada_name);
kono
parents:
diff changeset
355
kono
parents:
diff changeset
356 if (in_task)
kono
parents:
diff changeset
357 add_verbose ("in task", ada_name);
kono
parents:
diff changeset
358
kono
parents:
diff changeset
359 if (task_body)
kono
parents:
diff changeset
360 add_verbose ("task body", ada_name);
kono
parents:
diff changeset
361
kono
parents:
diff changeset
362 if (verbose_info == 1)
kono
parents:
diff changeset
363 strcat (ada_name, ")");
kono
parents:
diff changeset
364 }
kono
parents:
diff changeset
365 }
kono
parents:
diff changeset
366
kono
parents:
diff changeset
367 #ifdef __cplusplus
kono
parents:
diff changeset
368 extern "C" {
kono
parents:
diff changeset
369 #endif
kono
parents:
diff changeset
370
kono
parents:
diff changeset
371 void
kono
parents:
diff changeset
372 get_encoding (const char *coded_name, char *encoding)
kono
parents:
diff changeset
373 {
kono
parents:
diff changeset
374 char * dest_index = encoding;
kono
parents:
diff changeset
375 const char *p;
kono
parents:
diff changeset
376 int found = 0;
kono
parents:
diff changeset
377 int count = 0;
kono
parents:
diff changeset
378
kono
parents:
diff changeset
379 /* The heuristics is the following: we assume that the first triple
kono
parents:
diff changeset
380 underscore in an encoded name indicates the beginning of the
kono
parents:
diff changeset
381 first encoding, and that subsequent triple underscores indicate
kono
parents:
diff changeset
382 the next encodings. We assume that the encodings are always at the
kono
parents:
diff changeset
383 end of encoded names. */
kono
parents:
diff changeset
384
kono
parents:
diff changeset
385 for (p = coded_name; *p != '\0'; p++)
kono
parents:
diff changeset
386 {
kono
parents:
diff changeset
387 if (*p != '_')
kono
parents:
diff changeset
388 count = 0;
kono
parents:
diff changeset
389 else
kono
parents:
diff changeset
390 if (++count == 3)
kono
parents:
diff changeset
391 {
kono
parents:
diff changeset
392 count = 0;
kono
parents:
diff changeset
393
kono
parents:
diff changeset
394 if (found)
kono
parents:
diff changeset
395 {
kono
parents:
diff changeset
396 dest_index = dest_index - 2;
kono
parents:
diff changeset
397 *dest_index++ = ':';
kono
parents:
diff changeset
398 }
kono
parents:
diff changeset
399
kono
parents:
diff changeset
400 p++;
kono
parents:
diff changeset
401 found = 1;
kono
parents:
diff changeset
402 }
kono
parents:
diff changeset
403
kono
parents:
diff changeset
404 if (found)
kono
parents:
diff changeset
405 *dest_index++ = *p;
kono
parents:
diff changeset
406 }
kono
parents:
diff changeset
407
kono
parents:
diff changeset
408 *dest_index = '\0';
kono
parents:
diff changeset
409 }
kono
parents:
diff changeset
410
kono
parents:
diff changeset
411 #ifdef __cplusplus
kono
parents:
diff changeset
412 }
kono
parents:
diff changeset
413 #endif