* hppah-tdep.c (skip_trampoline_code): Use new macros for
[deliverable/binutils-gdb.git] / gdb / partial-stab.h
CommitLineData
7e258d18 1/* Shared code to pre-read a stab (dbx-style), when building a psymtab.
c2e4669f
JG
2 Copyright 1986, 1987, 1988, 1989, 1990, 1991, 1992 Free Software Foundation,
3 Inc.
7e258d18
PB
4
5This file is part of GDB.
6
7This program is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
9the Free Software Foundation; either version 2 of the License, or
10(at your option) any later version.
11
12This program is distributed in the hope that it will be useful,
13but WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15GNU General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with this program; if not, write to the Free Software
19Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
20
21/* The following need to be defined:
22 SET_NAMESTRING() --Set namestring to name of symbol.
23 CUR_SYMBOL_TYPE --Type code of current symbol.
24 CUR_SYMBOL_VALUE --Value field of current symbol. May be adjusted here.
25 */
26
7e258d18
PB
27/* End of macro definitions, now let's handle them symbols! */
28
29 switch (CUR_SYMBOL_TYPE)
30 {
31 char *p;
32 /*
33 * Standard, external, non-debugger, symbols
34 */
35
7e258d18
PB
36 case N_TEXT | N_EXT:
37 case N_NBTEXT | N_EXT:
2670f34d
JG
38 CUR_SYMBOL_VALUE += ANOFFSET (section_offsets, SECT_OFF_TEXT);
39 goto record_it;
40
41 case N_DATA | N_EXT:
7e258d18 42 case N_NBDATA | N_EXT:
2670f34d
JG
43 CUR_SYMBOL_VALUE += ANOFFSET (section_offsets, SECT_OFF_DATA);
44 goto record_it;
45
46 case N_BSS | N_EXT:
7e258d18 47 case N_NBBSS | N_EXT:
2670f34d
JG
48 case N_SETV | N_EXT: /* FIXME, is this in BSS? */
49 CUR_SYMBOL_VALUE += ANOFFSET (section_offsets, SECT_OFF_BSS);
50 goto record_it;
51
7e258d18 52 case N_ABS | N_EXT:
2670f34d 53 record_it:
aab77d5f 54#ifdef DBXREAD_ONLY
7e258d18
PB
55 SET_NAMESTRING();
56
57 bss_ext_symbol:
1ab3bf1b
JG
58 record_minimal_symbol (namestring, CUR_SYMBOL_VALUE,
59 CUR_SYMBOL_TYPE, objfile); /* Always */
aab77d5f 60#endif /* DBXREAD_ONLY */
7e258d18
PB
61 continue;
62
63 /* Standard, local, non-debugger, symbols */
64
65 case N_NBTEXT:
66
67 /* We need to be able to deal with both N_FN or N_TEXT,
68 because we have no way of knowing whether the sys-supplied ld
69 or GNU ld was used to make the executable. Sequents throw
70 in another wrinkle -- they renumbered N_FN. */
71
72 case N_FN:
73 case N_FN_SEQ:
74 case N_TEXT:
aab77d5f 75#ifdef DBXREAD_ONLY
2670f34d 76 CUR_SYMBOL_VALUE += ANOFFSET (section_offsets, SECT_OFF_TEXT);
7e258d18
PB
77 SET_NAMESTRING();
78 if ((namestring[0] == '-' && namestring[1] == 'l')
79 || (namestring [(nsl = strlen (namestring)) - 1] == 'o'
7da1e27d 80 && namestring [nsl - 2] == '.')
e0ba1d14 81#ifdef GDB_TARGET_IS_HPPA
7da1e27d 82 /* some cooperation from gcc to get around ld stupidity */
2e4964ad 83 || (namestring[0] == 'e' && STREQ (namestring, "end_file."))
7da1e27d
SG
84#endif
85 )
7e258d18 86 {
e0ba1d14 87#ifndef GDB_TARGET_IS_HPPA
5e2e79f8 88 if (objfile -> ei.entry_point < CUR_SYMBOL_VALUE &&
2670f34d 89 objfile -> ei.entry_point >= last_o_file_start)
7e258d18 90 {
5e2e79f8
FF
91 objfile -> ei.entry_file_lowpc = last_o_file_start;
92 objfile -> ei.entry_file_highpc = CUR_SYMBOL_VALUE;
7e258d18 93 }
7da1e27d 94#endif
7e258d18
PB
95 if (past_first_source_file && pst
96 /* The gould NP1 uses low values for .o and -l symbols
97 which are not the address. */
369172bb 98 && CUR_SYMBOL_VALUE >= pst->textlow)
7e258d18
PB
99 {
100 END_PSYMTAB (pst, psymtab_include_list, includes_used,
101 symnum * symbol_size, CUR_SYMBOL_VALUE,
102 dependency_list, dependencies_used);
103 pst = (struct partial_symtab *) 0;
104 includes_used = 0;
105 dependencies_used = 0;
106 }
107 else
108 past_first_source_file = 1;
109 last_o_file_start = CUR_SYMBOL_VALUE;
110 }
aab77d5f 111#endif /* DBXREAD_ONLY */
7e258d18
PB
112 continue;
113
114 case N_DATA:
aab77d5f 115#ifdef DBXREAD_ONLY
2670f34d 116 CUR_SYMBOL_VALUE += ANOFFSET (section_offsets, SECT_OFF_DATA);
7e258d18
PB
117 SET_NAMESTRING ();
118 /* Check for __DYNAMIC, which is used by Sun shared libraries.
119 Record it even if it's local, not global, so we can find it.
de9bef49
JG
120 FIXME: this might want to check for _DYNAMIC and the current
121 symbol_leading_char. */
2e4964ad 122 if (namestring[8] == 'C' && STREQ ("__DYNAMIC", namestring))
de9bef49
JG
123 goto record_it;
124
125 /* Same with virtual function tables, both global and static. */
126 {
127 char *tempstring = namestring;
128 if (tempstring[0] == bfd_get_symbol_leading_char (objfile->obfd))
129 tempstring++;
130 if (VTBL_PREFIX_P ((tempstring)))
131 goto record_it;
132 }
aab77d5f 133#endif /* DBXREAD_ONLY */
7e258d18
PB
134 continue;
135
136 case N_UNDF | N_EXT:
aab77d5f 137#ifdef DBXREAD_ONLY
7e258d18
PB
138 if (CUR_SYMBOL_VALUE != 0) {
139 /* This is a "Fortran COMMON" symbol. See if the target
140 environment knows where it has been relocated to. */
141
142 CORE_ADDR reladdr;
143
144 SET_NAMESTRING();
145 if (target_lookup_symbol (namestring, &reladdr)) {
146 continue; /* Error in lookup; ignore symbol for now. */
147 }
148 CUR_SYMBOL_TYPE ^= (N_BSS^N_UNDF); /* Define it as a bss-symbol */
149 CUR_SYMBOL_VALUE = reladdr;
150 goto bss_ext_symbol;
151 }
aab77d5f 152#endif /* DBXREAD_ONLY */
7e258d18 153 continue; /* Just undefined, not COMMON */
7e258d18 154
9342ecb9
JG
155 case N_UNDF:
156#ifdef DBXREAD_ONLY
157 if (processing_acc_compilation && bufp->n_strx == 1) {
bcbf9559
JG
158 /* Deal with relative offsets in the string table
159 used in ELF+STAB under Solaris. If we want to use the
160 n_strx field, which contains the name of the file,
161 we must adjust file_string_table_offset *before* calling
162 SET_NAMESTRING(). */
9342ecb9
JG
163 past_first_source_file = 1;
164 file_string_table_offset = next_file_string_table_offset;
165 next_file_string_table_offset =
166 file_string_table_offset + bufp->n_value;
167 if (next_file_string_table_offset < file_string_table_offset)
168 error ("string table offset backs up at %d", symnum);
169 /* FIXME -- replace error() with complaint. */
170 continue;
171 }
172#endif /* DBXREAD_ONLY */
173 continue;
174
7e258d18
PB
175 /* Lots of symbol types we can just ignore. */
176
7e258d18
PB
177 case N_ABS:
178 case N_BSS:
179 case N_NBDATA:
180 case N_NBBSS:
181 continue;
182
183 /* Keep going . . .*/
184
185 /*
186 * Special symbol types for GNU
187 */
188 case N_INDR:
189 case N_INDR | N_EXT:
190 case N_SETA:
191 case N_SETA | N_EXT:
192 case N_SETT:
193 case N_SETT | N_EXT:
194 case N_SETD:
195 case N_SETD | N_EXT:
196 case N_SETB:
197 case N_SETB | N_EXT:
198 case N_SETV:
199 continue;
200
201 /*
202 * Debugger symbols
203 */
204
205 case N_SO: {
206 unsigned long valu = CUR_SYMBOL_VALUE;
cdaa27e9
SG
207 static int prev_so_symnum = -10;
208 static int first_so_symnum;
c72af089 209 char *p;
7e258d18 210
cdaa27e9
SG
211 past_first_source_file = 1;
212
213 if (prev_so_symnum != symnum - 1)
214 { /* Here if prev stab wasn't N_SO */
215 first_so_symnum = symnum;
216
217 if (pst)
218 {
219 END_PSYMTAB (pst, psymtab_include_list, includes_used,
220 symnum * symbol_size, valu,
221 dependency_list, dependencies_used);
222 pst = (struct partial_symtab *) 0;
223 includes_used = 0;
224 dependencies_used = 0;
225 }
226 }
227
228 prev_so_symnum = symnum;
229
7e258d18
PB
230 /* End the current partial symtab and start a new one */
231
232 SET_NAMESTRING();
233
2670f34d 234 valu += ANOFFSET (section_offsets, SECT_OFF_TEXT);
7e258d18 235
c72af089
SG
236 /* Some compilers (including gcc) emit a pair of initial N_SOs.
237 The first one is a directory name; the second the file name.
238 If pst exists, is empty, and has a filename ending in '/',
239 we assume the previous N_SO was a directory name. */
240
323227fe 241 p = strrchr (namestring, '/');
c72af089 242 if (p && *(p+1) == '\000')
cdaa27e9 243 continue; /* Simply ignore directory name SOs */
c72af089
SG
244
245 /* Some other compilers (C++ ones in particular) emit useless
cdaa27e9
SG
246 SOs for non-existant .c files. We ignore all subsequent SOs that
247 immediately follow the first. */
248
249 if (!pst)
250 pst = START_PSYMTAB (objfile, section_offsets,
251 namestring, valu,
252 first_so_symnum * symbol_size,
253 objfile -> global_psymbols.next,
254 objfile -> static_psymbols.next);
7e258d18
PB
255 continue;
256 }
257
7e258d18 258 case N_BINCL:
aab77d5f 259#ifdef DBXREAD_ONLY
7e258d18
PB
260 /* Add this bincl to the bincl_list for future EXCLs. No
261 need to save the string; it'll be around until
262 read_dbx_symtab function returns */
263
264 SET_NAMESTRING();
265
266 add_bincl_to_list (pst, namestring, CUR_SYMBOL_VALUE);
267
268 /* Mark down an include file in the current psymtab */
269
270 psymtab_include_list[includes_used++] = namestring;
271 if (includes_used >= includes_allocated)
272 {
273 char **orig = psymtab_include_list;
274
275 psymtab_include_list = (char **)
276 alloca ((includes_allocated *= 2) *
277 sizeof (char *));
be772100
JG
278 memcpy ((PTR)psymtab_include_list, (PTR)orig,
279 includes_used * sizeof (char *));
7e258d18
PB
280 }
281
aab77d5f 282#endif /* DBXREAD_ONLY */
7e258d18 283 continue;
7e258d18
PB
284
285 case N_SOL:
286 /* Mark down an include file in the current psymtab */
287
288 SET_NAMESTRING();
289
290 /* In C++, one may expect the same filename to come round many
291 times, when code is coming alternately from the main file
292 and from inline functions in other files. So I check to see
293 if this is a file we've seen before -- either the main
294 source file, or a previously included file.
295
296 This seems to be a lot of time to be spending on N_SOL, but
297 things like "break c-exp.y:435" need to work (I
298 suppose the psymtab_include_list could be hashed or put
299 in a binary tree, if profiling shows this is a major hog). */
2e4964ad 300 if (pst && STREQ (namestring, pst->filename))
7e258d18
PB
301 continue;
302 {
303 register int i;
304 for (i = 0; i < includes_used; i++)
2e4964ad 305 if (STREQ (namestring, psymtab_include_list[i]))
7e258d18
PB
306 {
307 i = -1;
308 break;
309 }
310 if (i == -1)
311 continue;
312 }
313
314 psymtab_include_list[includes_used++] = namestring;
315 if (includes_used >= includes_allocated)
316 {
317 char **orig = psymtab_include_list;
318
319 psymtab_include_list = (char **)
320 alloca ((includes_allocated *= 2) *
321 sizeof (char *));
be772100
JG
322 memcpy ((PTR)psymtab_include_list, (PTR)orig,
323 includes_used * sizeof (char *));
7e258d18
PB
324 }
325 continue;
aab77d5f 326
7e258d18
PB
327 case N_LSYM: /* Typedef or automatic variable. */
328 case N_STSYM: /* Data seg var -- static */
329 case N_LCSYM: /* BSS " */
2670f34d 330 case N_ROSYM: /* Read-only data seg var -- static. */
7e258d18
PB
331 case N_NBSTS: /* Gould nobase. */
332 case N_NBLCS: /* symbols. */
333
334 SET_NAMESTRING();
335
336 p = (char *) strchr (namestring, ':');
337
338 /* Skip if there is no :. */
339 if (!p) continue;
340
341 switch (p[1])
342 {
343 case 'T':
bcbf9559 344 if (p != namestring) /* a name is there, not just :T... */
7e258d18 345 {
7e258d18 346 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
bcbf9559 347 STRUCT_NAMESPACE, LOC_TYPEDEF,
2e4964ad
FF
348 objfile->static_psymbols,
349 CUR_SYMBOL_VALUE,
350 psymtab_language, objfile);
bcbf9559
JG
351 if (p[2] == 't')
352 {
353 /* Also a typedef with the same name. */
354 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
355 VAR_NAMESPACE, LOC_TYPEDEF,
2e4964ad
FF
356 objfile->static_psymbols,
357 CUR_SYMBOL_VALUE, psymtab_language,
358 objfile);
bcbf9559
JG
359 p += 1;
360 }
7e258d18
PB
361 }
362 goto check_enum;
363 case 't':
bcbf9559
JG
364 if (p != namestring) /* a name is there, not just :T... */
365 {
366 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
367 VAR_NAMESPACE, LOC_TYPEDEF,
2e4964ad
FF
368 objfile->static_psymbols,
369 CUR_SYMBOL_VALUE,
370 psymtab_language, objfile);
bcbf9559 371 }
7e258d18 372 check_enum:
7e258d18
PB
373 /* If this is an enumerated type, we need to
374 add all the enum constants to the partial symbol
375 table. This does not cover enums without names, e.g.
376 "enum {a, b} c;" in C, but fortunately those are
377 rare. There is no way for GDB to find those from the
378 enum type without spending too much time on it. Thus
379 to solve this problem, the compiler needs to put out separate
380 constant symbols ('c' N_LSYMS) for enum constants in
381 enums without names, or put out a dummy type. */
382
383 /* We are looking for something of the form
384 <name> ":" ("t" | "T") [<number> "="] "e"
385 {<constant> ":" <value> ","} ";". */
386
387 /* Skip over the colon and the 't' or 'T'. */
388 p += 2;
389 /* This type may be given a number. Also, numbers can come
390 in pairs like (0,26). Skip over it. */
391 while ((*p >= '0' && *p <= '9')
392 || *p == '(' || *p == ',' || *p == ')'
393 || *p == '=')
394 p++;
395
396 if (*p++ == 'e')
397 {
398 /* We have found an enumerated type. */
399 /* According to comments in read_enum_type
400 a comma could end it instead of a semicolon.
401 I don't know where that happens.
402 Accept either. */
403 while (*p && *p != ';' && *p != ',')
404 {
405 char *q;
406
407 /* Check for and handle cretinous dbx symbol name
408 continuation! */
409 if (*p == '\\')
410 p = next_symbol_text ();
411
412 /* Point to the character after the name
413 of the enum constant. */
414 for (q = p; *q && *q != ':'; q++)
415 ;
416 /* Note that the value doesn't matter for
417 enum constants in psymtabs, just in symtabs. */
418 ADD_PSYMBOL_TO_LIST (p, q - p,
419 VAR_NAMESPACE, LOC_CONST,
2e4964ad
FF
420 objfile->static_psymbols, 0,
421 psymtab_language, objfile);
7e258d18
PB
422 /* Point past the name. */
423 p = q;
424 /* Skip over the value. */
425 while (*p && *p != ',')
426 p++;
427 /* Advance past the comma. */
428 if (*p)
429 p++;
430 }
431 }
7e258d18
PB
432 continue;
433 case 'c':
434 /* Constant, e.g. from "const" in Pascal. */
435 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
436 VAR_NAMESPACE, LOC_CONST,
2e4964ad
FF
437 objfile->static_psymbols, CUR_SYMBOL_VALUE,
438 psymtab_language, objfile);
7e258d18
PB
439 continue;
440 default:
441 /* Skip if the thing following the : is
442 not a letter (which indicates declaration of a local
443 variable, which we aren't interested in). */
444 continue;
445 }
446
447 case N_FUN:
448 case N_GSYM: /* Global (extern) variable; can be
2670f34d 449 data or bss (sigh FIXME). */
7e258d18
PB
450
451 /* Following may probably be ignored; I'll leave them here
452 for now (until I do Pascal and Modula 2 extensions). */
453
454 case N_PC: /* I may or may not need this; I
455 suspect not. */
456 case N_M2C: /* I suspect that I can ignore this here. */
457 case N_SCOPE: /* Same. */
458
459 SET_NAMESTRING();
460
461 p = (char *) strchr (namestring, ':');
462 if (!p)
463 continue; /* Not a debugging symbol. */
464
465
466
467 /* Main processing section for debugging symbols which
468 the initial read through the symbol tables needs to worry
469 about. If we reach this point, the symbol which we are
470 considering is definitely one we are interested in.
471 p must also contain the (valid) index into the namestring
472 which indicates the debugging type symbol. */
473
474 switch (p[1])
475 {
476 case 'c':
477 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
478 VAR_NAMESPACE, LOC_CONST,
2e4964ad
FF
479 objfile->static_psymbols, CUR_SYMBOL_VALUE,
480 psymtab_language, objfile);
7e258d18
PB
481 continue;
482 case 'S':
2670f34d 483 CUR_SYMBOL_VALUE += ANOFFSET (section_offsets, SECT_OFF_DATA);
7e258d18 484 ADD_PSYMBOL_ADDR_TO_LIST (namestring, p - namestring,
2e4964ad
FF
485 VAR_NAMESPACE, LOC_STATIC,
486 objfile->static_psymbols,
487 CUR_SYMBOL_VALUE,
488 psymtab_language, objfile);
7e258d18
PB
489 continue;
490 case 'G':
2670f34d 491 CUR_SYMBOL_VALUE += ANOFFSET (section_offsets, SECT_OFF_DATA);
7e258d18
PB
492 /* The addresses in these entries are reported to be
493 wrong. See the code that reads 'G's for symtabs. */
494 ADD_PSYMBOL_ADDR_TO_LIST (namestring, p - namestring,
2e4964ad
FF
495 VAR_NAMESPACE, LOC_STATIC,
496 objfile->global_psymbols,
497 CUR_SYMBOL_VALUE,
498 psymtab_language, objfile);
7e258d18
PB
499 continue;
500
501 case 't':
502 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
503 VAR_NAMESPACE, LOC_TYPEDEF,
2e4964ad
FF
504 objfile->static_psymbols, CUR_SYMBOL_VALUE,
505 psymtab_language, objfile);
7e258d18
PB
506 continue;
507
508 case 'f':
9342ecb9
JG
509#ifdef DBXREAD_ONLY
510 /* Kludges for ELF/STABS with Sun ACC */
511 last_function_name = namestring;
fef84cc4 512 if (pst && pst->textlow == 0)
9342ecb9
JG
513 pst->textlow = CUR_SYMBOL_VALUE;
514#if 0
515 if (startup_file_end == 0)
516 startup_file_end = CUR_SYMBOL_VALUE;
517#endif
518 /* End kludge. */
519#endif /* DBXREAD_ONLY */
7e258d18
PB
520 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
521 VAR_NAMESPACE, LOC_BLOCK,
2e4964ad
FF
522 objfile->static_psymbols, CUR_SYMBOL_VALUE,
523 psymtab_language, objfile);
7e258d18
PB
524 continue;
525
526 /* Global functions were ignored here, but now they
527 are put into the global psymtab like one would expect.
528 They're also in the misc fn vector...
529 FIXME, why did it used to ignore these? That broke
530 "i fun" on these functions. */
531 case 'F':
9342ecb9
JG
532#ifdef DBXREAD_ONLY
533 /* Kludges for ELF/STABS with Sun ACC */
534 last_function_name = namestring;
fef84cc4 535 if (pst && pst->textlow == 0)
9342ecb9
JG
536 pst->textlow = CUR_SYMBOL_VALUE;
537#if 0
538 if (startup_file_end == 0)
539 startup_file_end = CUR_SYMBOL_VALUE;
540#endif
541 /* End kludge. */
542#endif /* DBXREAD_ONLY */
7e258d18
PB
543 ADD_PSYMBOL_TO_LIST (namestring, p - namestring,
544 VAR_NAMESPACE, LOC_BLOCK,
2e4964ad
FF
545 objfile->global_psymbols, CUR_SYMBOL_VALUE,
546 psymtab_language, objfile);
7e258d18
PB
547 continue;
548
549 /* Two things show up here (hopefully); static symbols of
550 local scope (static used inside braces) or extensions
551 of structure symbols. We can ignore both. */
552 case 'V':
553 case '(':
554 case '0':
555 case '1':
556 case '2':
557 case '3':
558 case '4':
559 case '5':
560 case '6':
561 case '7':
562 case '8':
563 case '9':
564 continue;
565
566 default:
567 /* Unexpected symbol. Ignore it; perhaps it is an extension
568 that we don't know about.
569
570 Someone says sun cc puts out symbols like
571 /foo/baz/maclib::/usr/local/bin/maclib,
572 which would get here with a symbol type of ':'. */
573 continue;
574 }
575
7e258d18 576 case N_EXCL:
aab77d5f 577#ifdef DBXREAD_ONLY
7e258d18
PB
578
579 SET_NAMESTRING();
580
581 /* Find the corresponding bincl and mark that psymtab on the
582 psymtab dependency list */
583 {
584 struct partial_symtab *needed_pst =
585 find_corresponding_bincl_psymtab (namestring, CUR_SYMBOL_VALUE);
586
587 /* If this include file was defined earlier in this file,
588 leave it alone. */
589 if (needed_pst == pst) continue;
590
591 if (needed_pst)
592 {
593 int i;
594 int found = 0;
595
596 for (i = 0; i < dependencies_used; i++)
597 if (dependency_list[i] == needed_pst)
598 {
599 found = 1;
600 break;
601 }
602
603 /* If it's already in the list, skip the rest. */
604 if (found) continue;
605
606 dependency_list[dependencies_used++] = needed_pst;
607 if (dependencies_used >= dependencies_allocated)
608 {
609 struct partial_symtab **orig = dependency_list;
610 dependency_list =
611 (struct partial_symtab **)
612 alloca ((dependencies_allocated *= 2)
613 * sizeof (struct partial_symtab *));
be772100 614 memcpy ((PTR)dependency_list, (PTR)orig,
7e258d18
PB
615 (dependencies_used
616 * sizeof (struct partial_symtab *)));
617#ifdef DEBUG_INFO
618 fprintf (stderr, "Had to reallocate dependency list.\n");
619 fprintf (stderr, "New dependencies allocated: %d\n",
620 dependencies_allocated);
621#endif
622 }
623 }
624 else
625 error ("Invalid symbol data: \"repeated\" header file not previously seen, at symtab pos %d.",
626 symnum);
627 }
aab77d5f 628#endif /* DBXREAD_ONLY */
7e258d18 629 continue;
7e258d18
PB
630
631 case N_RBRAC:
632#ifdef HANDLE_RBRAC
633 HANDLE_RBRAC(CUR_SYMBOL_VALUE);
aab77d5f 634 continue;
7e258d18
PB
635#endif
636 case N_EINCL:
637 case N_DSLINE:
638 case N_BSLINE:
639 case N_SSYM: /* Claim: Structure or union element.
640 Hopefully, I can ignore this. */
641 case N_ENTRY: /* Alternate entry point; can ignore. */
642 case N_MAIN: /* Can definitely ignore this. */
643 case N_CATCH: /* These are GNU C++ extensions */
644 case N_EHDECL: /* that can safely be ignored here. */
645 case N_LENG:
646 case N_BCOMM:
647 case N_ECOMM:
648 case N_ECOML:
649 case N_FNAME:
650 case N_SLINE:
651 case N_RSYM:
652 case N_PSYM:
653 case N_LBRAC:
654 case N_NSYMS: /* Ultrix 4.0: symbol count */
655 case N_DEFD: /* GNU Modula-2 */
9342ecb9 656
4c7c6bab 657 case N_OBJ: /* useless types from Solaris */
9342ecb9 658 case N_OPT:
4c7c6bab 659 case N_ENDM:
7e258d18
PB
660 /* These symbols aren't interesting; don't worry about them */
661
662 continue;
663
664 default:
7e258d18
PB
665 /* If we haven't found it yet, ignore it. It's probably some
666 new type we don't know about yet. */
51b80b00
FF
667 complain (&unknown_symtype_complaint,
668 local_hex_string (CUR_SYMBOL_TYPE));
7e258d18
PB
669 continue;
670 }
This page took 0.091102 seconds and 4 git commands to generate.