Add a flag to asection, linker_has_input, and use it to reliably
[deliverable/binutils-gdb.git] / bfd / stab-syms.c
index 209c8a4796c9c97cbb07d44643c9376bbd2b4c8c..a685e31eb81879716044e2b94e6cb727dc5bd9ab 100644 (file)
@@ -1,5 +1,6 @@
 /* Table of stab names for the BFD library.
 /* Table of stab names for the BFD library.
-   Copyright (C) 1990-1991 Free Software Foundation, Inc.
+   Copyright 1990, 1991, 1992, 1994, 1995, 1996, 2000
+   Free Software Foundation, Inc.
    Written by Cygnus Support.
 
 This file is part of BFD, the Binary File Descriptor library.
    Written by Cygnus Support.
 
 This file is part of BFD, the Binary File Descriptor library.
@@ -16,44 +17,42 @@ GNU General Public License for more details.
 
 You should have received a copy of the GNU General Public License
 along with this program; if not, write to the Free Software
 
 You should have received a copy of the GNU General Public License
 along with this program; if not, write to the Free Software
-Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
+Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 
 #include "bfd.h"
 
 
 #include "bfd.h"
 
-#define ARCH_SIZE 32 /* Value doesn't matter. */
+#define ARCH_SIZE 32           /* Value doesn't matter.  */
 #include "libaout.h"
 #include "libaout.h"
-#include "aout64.h"
+#include "aout/aout64.h"
 
 
-/* Create a table of debugging stab-codes and corresponding names.  */
-
-#define __define_name(CODE, STRING) {(int)CODE, STRING},
+/* Ignore duplicate stab codes; just return the string for the first
+   one.  */
 #define __define_stab(NAME, CODE, STRING) __define_name(CODE, STRING)
 #define __define_stab(NAME, CODE, STRING) __define_name(CODE, STRING)
-struct {short code; char string[10];} aout_stab_names[]
-  = {
-#include "stab.def"
+#define __define_stab_duplicate(NAME, CODE, STRING)
 
 /* These are not really stab symbols, but it is
    convenient to have them here for the sake of nm.
    For completeness, we could also add N_TEXT etc, but those
 
 /* These are not really stab symbols, but it is
    convenient to have them here for the sake of nm.
    For completeness, we could also add N_TEXT etc, but those
-   are never needed, since nm treats those specially. */
-__define_name (N_SETA, "SETA") /* Absolute set element symbol */
-__define_name (N_SETT, "SETT") /* Text set element symbol */
-__define_name (N_SETD, "SETD") /* Data set element symbol */
-__define_name (N_SETB, "SETB") /* Bss set element symbol */
-__define_name (N_SETV, "SETV")  /* Pointer to set vector in data area. */
-__define_name (N_INDR, "INDR")
-__define_name (N_WARNING, "WARNING")
-    };
-#undef __define_stab
-#undef GNU_EXTRA_STABS
-
-char *
-DEFUN(aout_stab_name,(code),
-int code)
+   are never needed, since nm treats those specially.  */
+#define EXTRA_SYMBOLS \
+  __define_name (N_SETA, "SETA")/* Absolute set element symbol */ \
+  __define_name (N_SETT, "SETT")/* Text set element symbol */ \
+  __define_name (N_SETD, "SETD")/* Data set element symbol */ \
+  __define_name (N_SETB, "SETB")/* Bss set element symbol */ \
+  __define_name (N_SETV, "SETV")/* Pointer to set vector in data area.  */ \
+  __define_name (N_INDR, "INDR") \
+  __define_name (N_WARNING, "WARNING")
+
+const char *
+bfd_get_stab_name (code)
+     int code;
 {
 {
-  register int i = sizeof(aout_stab_names) / sizeof(aout_stab_names[0]);
-  while (--i >= 0)
-    if (aout_stab_names[i].code == code)
-      return aout_stab_names[i].string;
-  return 0;
+  switch (code)
+    {
+#define __define_name(val, str) case val: return str;
+#include "aout/stab.def"
+      EXTRA_SYMBOLS
+    }
+
+  return (const char *) 0;
 }
 }
This page took 0.02349 seconds and 4 git commands to generate.