From: Hans-Peter Nilsson Date: Fri, 29 Nov 2002 22:41:04 +0000 (+0000) Subject: cpplib.c (_cpp_test_assertion): Default *value to 0. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=2402645b4d554a5dc8f61fb88d33d716c7198c61;p=gcc.git cpplib.c (_cpp_test_assertion): Default *value to 0. * cpplib.c (_cpp_test_assertion): Default *value to 0. * cppexp.c (num_part_mul): Initialize result.unsignedp, to 1. From-SVN: r59648 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 409703d74cb..dc5a79a26d9 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2002-11-29 Hans-Peter Nilsson + + * cpplib.c (_cpp_test_assertion): Default *value to 0. + + * cppexp.c (num_part_mul): Initialize result.unsignedp, to 1. + 2002-11-29 Ulrich Weigand * config/s390/t-crtstuff: New target makefile fragment. diff --git a/gcc/cppexp.c b/gcc/cppexp.c index d4ea2fc1854..7f576f211e4 100644 --- a/gcc/cppexp.c +++ b/gcc/cppexp.c @@ -1446,6 +1446,7 @@ num_part_mul (lhs, rhs) result.high += HIGH_PART (middle[0]); result.high += HIGH_PART (middle[1]); + result.unsignedp = 1; return result; } diff --git a/gcc/cpplib.c b/gcc/cpplib.c index 7092cc002f8..f8a702d8c1a 100644 --- a/gcc/cpplib.c +++ b/gcc/cpplib.c @@ -1689,7 +1689,7 @@ find_answer (node, candidate) /* Test an assertion within a preprocessor conditional. Returns nonzero on failure, zero on success. On success, the result of - the test is written into VALUE. */ + the test is written into VALUE, otherwise the value 0. */ int _cpp_test_assertion (pfile, value) cpp_reader *pfile; @@ -1699,6 +1699,11 @@ _cpp_test_assertion (pfile, value) cpp_hashnode *node; node = parse_assertion (pfile, &answer, T_IF); + + /* For recovery, an erroneous assertion expression is handled as a + failing assertion. */ + *value = 0; + if (node) *value = (node->type == NT_ASSERTION && (answer == 0 || *find_answer (node, answer) != 0));