]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blobdiff - gas/output-file.c
* as.h (as_perror): Delete declaration.
[thirdparty/binutils-gdb.git] / gas / output-file.c
index 940a0c108e4a26fcc1aaef3056daabfb2d62520e..dfbef1f24d3648a2e2b9f8a1a29ed15af36b323b 100644 (file)
 /* output-file.c -  Deal with the output file
-   Copyright (C) 1987, 1990, 1991 Free Software Foundation, Inc.
-   
+   Copyright 1987, 1990, 1991, 1992, 1993, 1994, 1996, 1998, 1999, 2001,
+   2003, 2004, 2005, 2006 Free Software Foundation, Inc.
+
    This file is part of GAS, the GNU Assembler.
-   
+
    GAS is free software; you can redistribute it and/or modify
    it under the terms of the GNU General Public License as published by
    the Free Software Foundation; either version 2, or (at your option)
    any later version.
-   
+
    GAS is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    GNU General Public License for more details.
-   
+
    You should have received a copy of the GNU General Public License
    along with GAS; see the file COPYING.  If not, write to
-   the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
-
-/*
- * Confines all details of emitting object bytes to this module.
- * All O/S specific crocks should live here.
- * What we lose in "efficiency" we gain in modularity.
- * Note we don't need to #include the "as.h" file. No common coupling!
- */
-
-/* note that we do need config info.  xoxorich. */
-
-/* #include "style.h" */
-#include <stdio.h>
+   the Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA
+   02110-1301, USA.  */
 
 #include "as.h"
-
 #include "output-file.h"
-#ifdef BFD_HEADERS
-#include "bfd.h"
-bfd *stdoutput;
-void output_file_create(name)
-char *name;
-{
-       if(name[0]=='-' && name[1]=='\0')  {
-               as_perror("FATAL: Can't open a bfd on stdout %s ", name);
-       }
-       else if ( ! (stdoutput = bfd_openw( name, TARGET_FORMAT )) )
-           {
-                   as_perror ("FATAL: Can't create %s", name);
-                   exit(42);
-           }
-       bfd_set_format(stdoutput, bfd_object);
-}      
-/* output_file_create() */
-
-
-void output_file_close(filename)
-char *filename;
-{
-       /* Close the bfd without getting bfd to write out anything by itself */
-       if ( bfd_close_all_done( stdoutput ) == 0 )
-           {
-                   as_perror ("FATAL: Can't close %s\n", filename);
-                   exit(42);
-           }
-       stdoutput = NULL;               /* Trust nobody! */
-}                              /* output_file_close() */
-
-void output_file_append(where, length, filename)
-char *where;
-long length;
-char *filename;
-{
-       abort(); /* Never do this */
-} 
-
-#else
-
-static FILE *stdoutput;
-
-void output_file_create(name)
-char *name;
-{
-       if(name[0]=='-' && name[1]=='\0')
-           stdoutput=stdout;
-       else if ( ! (stdoutput = fopen( name, "w" )) )
-           {
-                   as_perror ("FATAL: Can't create %s", name);
-                   exit(42);
-           }
-} /* output_file_create() */
 
+#ifndef TARGET_MACH
+#define TARGET_MACH 0
+#endif
 
+bfd *stdoutput;
 
-void output_file_close(filename)
-char *filename;
+void
+output_file_create (char *name)
 {
-       if ( EOF == fclose( stdoutput ) )
-           {
-                   as_perror ("FATAL: Can't close %s", filename);
-                   exit(42);
-           }
-       stdoutput = NULL;               /* Trust nobody! */
-} /* output_file_close() */
-
-void output_file_append(where, length, filename)
-char *where;
-long length;
-char *filename;
+  if (name[0] == '-' && name[1] == '\0')
+    as_fatal (_("can't open a bfd on stdout %s"), name);
+
+  else if (!(stdoutput = bfd_openw (name, TARGET_FORMAT)))
+    {
+      bfd_error_type err = bfd_get_error ();
+
+      if (err == bfd_error_invalid_target)
+       as_fatal (_("selected target format '%s' unknown"), TARGET_FORMAT);
+      else
+       as_fatal (_("can't create %s: %s"), name, bfd_errmsg (err));
+    }
+
+  bfd_set_format (stdoutput, bfd_object);
+  bfd_set_arch_mach (stdoutput, TARGET_ARCH, TARGET_MACH);
+  if (flag_traditional_format)
+    stdoutput->flags |= BFD_TRADITIONAL_FORMAT;
+}
+
+void
+output_file_close (char *filename)
 {
-       
-       for (; length; length--,where++)
-           {
-                   (void)putc(*where,stdoutput);
-                   if(ferror(stdoutput))
-                       /* if ( EOF == (putc( *where, stdoutput )) ) */
-                       {
-                               as_perror("Failed to emit an object byte", filename);
-                               as_fatal("Can't continue");
-                       }
-           }
-} /* output_file_append() */
-
-/* end: output-file.c */
-#endif
+  /* Close the bfd.  */
+  if (!bfd_close (stdoutput))
+    as_fatal (_("can't close %s: %s"), filename,
+             bfd_errmsg (bfd_get_error ()));
+  stdoutput = NULL;            /* Trust nobody!  */
+}