+Fri Mar 24 11:47:42 1995 Ian Lance Taylor <ian@cygnus.com>
+
+ * strings.c: Include "bfd.h" before other headers. Include
+ "sysdep.h".
+ * bucomm.c (print_arelt_descr): Cast st_uid and st_gid to long,
+ and print them with %ld.
+
+Fri Mar 10 13:09:42 1995 Ian Lance Taylor <ian@cygnus.com>
+
+ * objcopy.c (strip_options): Add --keep-symbol.
+ (copy_options): Likewise.
+ (copy_usage): Mention --keep-symbol and -K.
+ (strip_usage): Likewise.
+ (keep_symbols): New static variable.
+ (is_strip_symbol): Adjust the return value according to
+ keep_symbols.
+ (strip_main): Handle -K. For -N, check that -K was not given.
+ (copy_main): Likewise.
+ * binutils.texi, objcopy.1, strip.1: Document -K.
+
+Mon Mar 6 13:33:47 1995 Stan Shebs <shebs@andros.cygnus.com>
+
+ * objcopy.c (copy_archive): Check result of mkdir.
+ (copy_main): Cast an xmalloc result.
+
+ * objdump.c (usage): Break long format string into shorter ones.
+
Mon Mar 6 13:46:12 1995 Ian Lance Taylor <ian@cygnus.com>
* bucomm.c (list_supported_targets): New function.
/* bucomm.c -- Bin Utils COMmon code.
- Copyright (C) 1991 Free Software Foundation, Inc.
+ Copyright (C) 1991, 92, 93, 94 Free Software Foundation, Inc.
This file is part of GNU Binutils.
#include "bfd.h"
#include "sysdep.h"
+#include "libiberty.h"
#include "bucomm.h"
-#ifdef __STDC__
+#ifdef ANSI_PROTOTYPES
#include <stdarg.h>
#else
#include <varargs.h>
#endif
char *target = NULL; /* default as late as possible */
-
-/* Yes, this is what atexit is for, but that isn't guaranteed yet.
- And yes, I know this isn't as good, but it does what is needed just fine. */
-void (*exit_handler) ();
-
-
+\f
/* Error reporting */
char *program_name;
bfd_nonfatal (string)
CONST char *string;
{
- CONST char *errmsg = bfd_errmsg (bfd_error);
+ CONST char *errmsg = bfd_errmsg (bfd_get_error ());
if (string)
fprintf (stderr, "%s: %s: %s\n", program_name, string, errmsg);
CONST char *string;
{
bfd_nonfatal (string);
-
- if (NULL != exit_handler)
- (*exit_handler) ();
- exit (1);
+ xexit (1);
}
-#ifdef __STDC__
+#ifdef ANSI_PROTOTYPES
void
fatal (const char *format, ...)
{
vfprintf (stderr, format, args);
va_end (args);
putc ('\n', stderr);
- if (NULL != exit_handler)
- (*exit_handler) ();
- exit (1);
+ xexit (1);
}
#else
void
vfprintf (stderr, Format, args);
va_end (args);
putc ('\n', stderr);
- if (NULL != exit_handler)
- (*exit_handler) ();
- exit (1);
+ xexit (1);
}
#endif
+
+/* After a false return from bfd_check_format_matches with
+ bfd_get_error () == bfd_error_file_ambiguously_recognized, print the possible
+ matching targets. */
+
+void
+list_matching_formats (p)
+ char **p;
+{
+ fprintf(stderr, "%s: Matching formats:", program_name);
+ while (*p)
+ fprintf(stderr, " %s", *p++);
+ fprintf(stderr, "\n");
+}
+
+/* List the supported targets. */
+
+void
+list_supported_targets (name, f)
+ const char *name;
+ FILE *f;
+{
+ extern bfd_target *bfd_target_vector[];
+ int t;
+
+ if (name == NULL)
+ fprintf (f, "Supported targets:");
+ else
+ fprintf (f, "%s: supported targets:", name);
+ for (t = 0; bfd_target_vector[t] != NULL; t++)
+ fprintf (f, " %s", bfd_target_vector[t]->name);
+ fprintf (f, "\n");
+}
\f
/* Display the archive header for an element as if it were an ls -l listing:
mode_string (buf.st_mode, modebuf);
modebuf[10] = '\0';
/* POSIX 1003.2/D11 says to skip first character (entry type). */
- fprintf (file, "%s %d/%d %6ld %s ", modebuf + 1,
- buf.st_uid, buf.st_gid, buf.st_size, timebuf);
+ fprintf (file, "%s %ld/%ld %6ld %s ", modebuf + 1,
+ (long) buf.st_uid, (long) buf.st_gid,
+ (long) buf.st_size, timebuf);
}
}
- fprintf (file, "%s\n", abfd->filename);
+ fprintf (file, "%s\n", bfd_get_filename (abfd));
}