aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/cpplib.c23
-rw-r--r--gcc/testsuite/gcc.dg/cpp-if5.c12
3 files changed, 31 insertions, 9 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 7906c8d..4aac5bb 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2000-06-06 Jakub Jelinek <jakub@redhat.com>
+
+ * cpplib.c (do_ifdef, do_ifndef): Don't segfault if parse_ifdef
+ returned NULL.
+
Wed Jun 7 20:34:33 2000 Denis Chertykov <denisc@overta.ru>
* config/avr/avr.c (asm_output_section_name): output section
diff --git a/gcc/cpplib.c b/gcc/cpplib.c
index 529d1bb..60dfbdd 100644
--- a/gcc/cpplib.c
+++ b/gcc/cpplib.c
@@ -1126,10 +1126,13 @@ do_ifdef (pfile)
{
int def = 0;
const cpp_hashnode *node = parse_ifdef (pfile, dtable[T_IFDEF].name);
- if (node->type == T_POISON)
- cpp_error (pfile, "attempt to use poisoned `%s'", node->name);
- else
- def = (node->type != T_VOID);
+ if (node)
+ {
+ if (node->type == T_POISON)
+ cpp_error (pfile, "attempt to use poisoned `%s'", node->name);
+ else
+ def = (node->type != T_VOID);
+ }
push_conditional (pfile, !def, T_IFDEF, 0);
return 0;
}
@@ -1147,11 +1150,13 @@ do_ifndef (pfile)
start_of_file = pfile->only_seen_white == 2;
cmacro = parse_ifdef (pfile, dtable[T_IFNDEF].name);
- if (cmacro->type == T_POISON)
- cpp_error (pfile, "attempt to use poisoned `%s'", cmacro->name);
- else
- def = (cmacro->type != T_VOID);
-
+ if (cmacro)
+ {
+ if (cmacro->type == T_POISON)
+ cpp_error (pfile, "attempt to use poisoned `%s'", cmacro->name);
+ else
+ def = (cmacro->type != T_VOID);
+ }
push_conditional (pfile, def, T_IFNDEF,
start_of_file ? cmacro : 0);
return 0;
diff --git a/gcc/testsuite/gcc.dg/cpp-if5.c b/gcc/testsuite/gcc.dg/cpp-if5.c
new file mode 100644
index 0000000..2eac73b
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/cpp-if5.c
@@ -0,0 +1,12 @@
+/* Regression test: #ifdef 0 should not crash. Problem noted by
+ Jakub Jelinek <jakub@redhat.com>. */
+/* { dg-do preprocess } */
+
+#ifdef 0 /* { dg-error "with invalid argument" } */
+#error not seen
+#endif
+
+#ifndef 0 /* { dg-error "with invalid argument" } */
+#else
+#error not seen
+#endif