From: rguenth Date: Sun, 9 May 2010 14:14:27 +0000 (+0000) Subject: 2010-05-09 Richard Guenther X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=d9f0ee99c0fe3b26e7330561ceb6679f77ea3769;p=thirdparty%2Fgcc.git 2010-05-09 Richard Guenther * gcc.c (store_arg): Handle temporary file deletion for joined arguments. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@159201 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 3112b80b0135..bd64d9daec07 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2010-05-09 Richard Guenther + + * gcc.c (store_arg): Handle temporary file deletion for + joined arguments. + 2010-05-09 Richard Guenther PR middle-end/44043 diff --git a/gcc/gcc.c b/gcc/gcc.c index a0083e1d0f66..e2644c4a73ec 100644 --- a/gcc/gcc.c +++ b/gcc/gcc.c @@ -2082,7 +2082,15 @@ store_arg (const char *arg, int delete_always, int delete_failure) if (strcmp (arg, "-o") == 0) have_o_argbuf_index = argbuf_index; if (delete_always || delete_failure) - record_temp_file (arg, delete_always, delete_failure); + { + const char *p; + /* If the temporary file we should delete is specified as + part of a joined argument extract the filename. */ + if (arg[0] == '-' + && (p = strrchr (arg, '='))) + arg = p + 1; + record_temp_file (arg, delete_always, delete_failure); + } } /* Load specs from a file name named FILENAME, replacing occurrences of