aboutsummaryrefslogtreecommitdiff
path: root/gcc/gcc.c
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2010-05-09 14:14:27 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2010-05-09 14:14:27 +0000
commitd6205185769eaf5898405d2883f4ee38a519b4d4 (patch)
tree6add15c7ab1e9064a443e4dd2dbadfcb69479c7e /gcc/gcc.c
parent5588864d54667da6d2b7caf8d55f77e11a2c11ac (diff)
downloadgcc-d6205185769eaf5898405d2883f4ee38a519b4d4.zip
gcc-d6205185769eaf5898405d2883f4ee38a519b4d4.tar.gz
gcc-d6205185769eaf5898405d2883f4ee38a519b4d4.tar.bz2
gcc.c (store_arg): Handle temporary file deletion for joined arguments.
2010-05-09 Richard Guenther <rguenther@suse.de> * gcc.c (store_arg): Handle temporary file deletion for joined arguments. From-SVN: r159201
Diffstat (limited to 'gcc/gcc.c')
-rw-r--r--gcc/gcc.c10
1 files changed, 9 insertions, 1 deletions
diff --git a/gcc/gcc.c b/gcc/gcc.c
index a0083e1..e2644c4 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