aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorNeil Booth <neilb@earthling.net>2000-08-17 18:01:43 +0000
committerNeil Booth <neil@gcc.gnu.org>2000-08-17 18:01:43 +0000
commit709e9e509cdca723aec76fb1076b2feb1264192b (patch)
tree08a55b2310020143695da9578d6843781f8dda0a /gcc
parente33f6253857ef2e87ad037c0452c09db7a940b8c (diff)
downloadgcc-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/ChangeLog8
-rw-r--r--gcc/cppinit.c9
-rw-r--r--gcc/cpplib.c10
-rw-r--r--gcc/cppmacro.c12
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;
}