diff options
author | Neil Booth <neilb@earthling.net> | 2000-08-17 18:01:43 +0000 |
---|---|---|
committer | Neil Booth <neil@gcc.gnu.org> | 2000-08-17 18:01:43 +0000 |
commit | 709e9e509cdca723aec76fb1076b2feb1264192b (patch) | |
tree | 08a55b2310020143695da9578d6843781f8dda0a /gcc | |
parent | e33f6253857ef2e87ad037c0452c09db7a940b8c (diff) | |
download | gcc-709e9e509cdca723aec76fb1076b2feb1264192b.zip gcc-709e9e509cdca723aec76fb1076b2feb1264192b.tar.gz gcc-709e9e509cdca723aec76fb1076b2feb1264192b.tar.bz2 |
cppinit.c (cpp_cleanup): Free include dir chains.
* cppinit.c (cpp_cleanup): Free include dir chains.
* cpplib.c (do_undef): Let _cpp_free_definition make the node void.
(do_unassert): Free the assert with _cpp_free_definition.
* cppmacro.c (_cpp_free_definition): Free memory allocated for
assertions. Make the node a T_VOID node.
From-SVN: r35765
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/ChangeLog | 8 | ||||
-rw-r--r-- | gcc/cppinit.c | 9 | ||||
-rw-r--r-- | gcc/cpplib.c | 10 | ||||
-rw-r--r-- | gcc/cppmacro.c | 12 |
4 files changed, 30 insertions, 9 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 072c5ac..9b8739b 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,13 @@ 2000-08-17 Neil Booth <NeilB@earthling.net> + * cppinit.c (cpp_cleanup): Free include dir chains. + * cpplib.c (do_undef): Let _cpp_free_definition make the node void. + (do_unassert): Free the assert with _cpp_free_definition. + * cppmacro.c (_cpp_free_definition): Free memory allocated for + assertions. Make the node a T_VOID node. + +2000-08-17 Neil Booth <NeilB@earthling.net> + * cppinit.c (path_include, append_include_chain): Remove 2nd parameter (struct cpp_pending *). (path_include, initialize_standard_includes, cpp_handle_option): diff --git a/gcc/cppinit.c b/gcc/cppinit.c index 0cb90ab..e91f1be 100644 --- a/gcc/cppinit.c +++ b/gcc/cppinit.c @@ -467,6 +467,8 @@ void cpp_cleanup (pfile) cpp_reader *pfile; { + struct file_name_list *dir, *next; + while (CPP_BUFFER (pfile) != NULL) cpp_pop_buffer (pfile); @@ -480,6 +482,13 @@ cpp_cleanup (pfile) _cpp_cleanup_includes (pfile); _cpp_cleanup_stacks (pfile); _cpp_cleanup_macros (pfile); + + for (dir = CPP_OPTION (pfile, quote_include); dir; dir = next) + { + next = dir->next; + free (dir->name); + free (dir); + } } diff --git a/gcc/cpplib.c b/gcc/cpplib.c index 9daee3e..bc50452 100644 --- a/gcc/cpplib.c +++ b/gcc/cpplib.c @@ -298,7 +298,6 @@ do_undef (pfile) cpp_warning (pfile, "undefining \"%s\"", node->name); _cpp_free_definition (node); - node->type = T_VOID; } } @@ -1369,14 +1368,7 @@ do_unassert (pfile) node->type = T_VOID; } else - { - for (temp = node->value.answers; temp; temp = next) - { - next = temp->next; - FREE_ANSWER (temp); - } - node->type = T_VOID; - } + _cpp_free_definition (node); } if (answer) diff --git a/gcc/cppmacro.c b/gcc/cppmacro.c index ade67d7..3c9ffb9 100644 --- a/gcc/cppmacro.c +++ b/gcc/cppmacro.c @@ -404,6 +404,18 @@ _cpp_free_definition (h) { if (h->type == T_MACRO) free ((PTR) h->value.expansion); + else if (h->type == T_ASSERTION) + { + struct answer *temp, *next; + + for (temp = h->value.answers; temp; temp = next) + { + next = temp->next; + FREE_ANSWER (temp); + } + } + + h->type = T_VOID; h->value.expansion = NULL; } |