From: Akim Demaille Date: Tue, 8 May 2012 08:27:34 +0000 (+0200) Subject: command line: fix minor leaks. X-Git-Tag: v2.5.1_rc2~23 X-Git-Url: https://git.saurik.com/bison.git/commitdiff_plain/0b7fba1335c0c3fde1eab89e265cbcecf20885a8 command line: fix minor leaks. * src/getargs.c (getargs): Free pointers before allocating them new content. --- diff --git a/src/getargs.c b/src/getargs.c index 1185e409..3fa2a7af 100644 --- a/src/getargs.c +++ b/src/getargs.c @@ -606,13 +606,19 @@ getargs (int argc, char *argv[]) /* Here, the -d and --defines options are differentiated. */ defines_flag = true; if (optarg) - spec_defines_file = xstrdup (AS_FILE_NAME (optarg)); + { + free (spec_defines_file); + spec_defines_file = xstrdup (AS_FILE_NAME (optarg)); + } break; case 'g': graph_flag = true; if (optarg) - spec_graph_file = xstrdup (AS_FILE_NAME (optarg)); + { + free (spec_graph_file); + spec_graph_file = xstrdup (AS_FILE_NAME (optarg)); + } break; case 'h': @@ -649,7 +655,10 @@ getargs (int argc, char *argv[]) case 'x': xml_flag = true; if (optarg) - spec_xml_file = xstrdup (AS_FILE_NAME (optarg)); + { + free (spec_xml_file); + spec_xml_file = xstrdup (AS_FILE_NAME (optarg)); + } break; case 'y': @@ -669,6 +678,7 @@ getargs (int argc, char *argv[]) exit (EXIT_SUCCESS); case REPORT_FILE_OPTION: + free (spec_verbose_file); spec_verbose_file = xstrdup (AS_FILE_NAME (optarg)); break;