X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=gas%2Foutput-file.c;h=29497e110e4eedd7bbeec2fbf9d4dbd371b38162;hb=219d1afa89d0d53ca93a684cac341f16470f3ca0;hp=08055090e60d9c90acc9114221f1377ef62ec549;hpb=f740e790c79faaedbed56f98844762432cc2d55b;p=deliverable%2Fbinutils-gdb.git diff --git a/gas/output-file.c b/gas/output-file.c index 08055090e6..29497e110e 100644 --- a/gas/output-file.c +++ b/gas/output-file.c @@ -1,12 +1,11 @@ /* output-file.c - Deal with the output file - Copyright 1987, 1990, 1991, 1992, 1993, 1994, 1996, 1998, 1999, 2001 - Free Software Foundation, Inc. + Copyright (C) 1987-2018 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) + the Free Software Foundation; either version 3, or (at your option) any later version. GAS is distributed in the hope that it will be useful, @@ -16,145 +15,59 @@ 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, 59 Temple Place - Suite 330, Boston, MA - 02111-1307, USA. */ - -#include + the Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston, MA + 02110-1301, USA. */ #include "as.h" - #include "output-file.h" -#ifdef BFD_HEADERS -#define USE_BFD -#endif - -#ifdef BFD_ASSEMBLER -#define USE_BFD #ifndef TARGET_MACH #define TARGET_MACH 0 #endif -#endif -#ifdef USE_BFD -#include "bfd.h" bfd *stdoutput; void -output_file_create (name) - char *name; +output_file_create (const char *name) { if (name[0] == '-' && name[1] == '\0') - as_fatal (_("Can't open a bfd on stdout %s "), name); + as_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 (EXIT_FAILURE); + 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); -#ifdef BFD_ASSEMBLER bfd_set_arch_mach (stdoutput, TARGET_ARCH, TARGET_MACH); -#endif if (flag_traditional_format) stdoutput->flags |= BFD_TRADITIONAL_FORMAT; } void -output_file_close (filename) - char *filename; -{ -#ifdef BFD_ASSEMBLER - /* Close the bfd. */ - if (bfd_close (stdoutput) == 0) - { - bfd_perror (filename); - as_perror (_("FATAL: Can't close %s\n"), filename); - exit (EXIT_FAILURE); - } -#else - /* 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 (EXIT_FAILURE); - } -#endif - stdoutput = NULL; /* Trust nobody! */ -} - -#ifndef BFD_ASSEMBLER -void -output_file_append (where, length, filename) - char *where ATTRIBUTE_UNUSED; - long length ATTRIBUTE_UNUSED; - char *filename ATTRIBUTE_UNUSED; -{ - abort (); -} -#endif - -#else - -static FILE *stdoutput; - -void -output_file_create (name) - char *name; +output_file_close (const char *filename) { - if (name[0] == '-' && name[1] == '\0') - { - stdoutput = stdout; - return; - } - - stdoutput = fopen (name, FOPEN_WB); - - /* Some systems don't grok "b" in fopen modes. */ - /* XXX - is this still necessary now that we use FOPEN_WB ? */ - if (stdoutput == NULL) - stdoutput = fopen (name, FOPEN_W); + bfd_boolean res; if (stdoutput == NULL) - { - as_perror (_("FATAL: Can't create %s"), name); - exit (EXIT_FAILURE); - } -} + return; -void -output_file_close (filename) - char *filename; -{ - if (EOF == fclose (stdoutput)) - { - as_perror (_("FATAL: Can't close %s"), filename); - exit (EXIT_FAILURE); - } + /* Close the bfd. */ + if (had_errors ()) + res = bfd_cache_close_all (); + else + res = bfd_close (stdoutput); - /* Trust nobody! */ + /* Prevent an infinite loop - if the close failed we will call as_fatal + which will call xexit() which may call this function again... */ stdoutput = NULL; -} -void -output_file_append (where, length, filename) - char * where; - long length; - 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")); - } - } + if (! res) + as_fatal (_("can't close %s: %s"), filename, + bfd_errmsg (bfd_get_error ())); } - -#endif -