diff options
author | Neil Booth <neil@daikokuya.demon.co.uk> | 2001-09-30 12:02:22 +0000 |
---|---|---|
committer | Neil Booth <neil@gcc.gnu.org> | 2001-09-30 12:02:22 +0000 |
commit | ab17715d9b958ec3d271866cf2a8f1b4ab7641ec (patch) | |
tree | daf8312a9a08162e7b4f4c64adb93fcb76c51833 | |
parent | 8c3b269309f3b3651362697d48a3ade54bbddb55 (diff) | |
download | gcc-ab17715d9b958ec3d271866cf2a8f1b4ab7641ec.zip gcc-ab17715d9b958ec3d271866cf2a8f1b4ab7641ec.tar.gz gcc-ab17715d9b958ec3d271866cf2a8f1b4ab7641ec.tar.bz2 |
* mi6.c, mi6a.h, mi6b.h, mi6c.h, mi6d.h, mi6e.h: New test.
From-SVN: r45900
-rw-r--r-- | gcc/testsuite/ChangeLog | 4 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/cpp/mi6.c | 44 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/cpp/mi6a.h | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/cpp/mi6b.h | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/cpp/mi6c.h | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/cpp/mi6d.h | 5 | ||||
-rw-r--r-- | gcc/testsuite/gcc.dg/cpp/mi6e.h | 5 |
7 files changed, 73 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 0e8f92e..b4506b4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,9 @@ 2001-09-30 Neil Booth <neil@daikokuya.demon.co.uk> + * mi6.c, mi6a.h, mi6b.h, mi6c.h, mi6d.h, mi6e.h: New test. + +2001-09-30 Neil Booth <neil@daikokuya.demon.co.uk> + * gcc.dg/cpp/redef2.c: Add test. 2001-09-27 Geoffrey Keating <geoffk@redhat.com> diff --git a/gcc/testsuite/gcc.dg/cpp/mi6.c b/gcc/testsuite/gcc.dg/cpp/mi6.c new file mode 100644 index 0000000..8895706 --- /dev/null +++ b/gcc/testsuite/gcc.dg/cpp/mi6.c @@ -0,0 +1,44 @@ +/* Another test case for over-eager multiple include optimization, + where the leading "#if !defined" expression is obtained partially, + or wholly, from macros. Neil Booth, 30 Sep 2001. */ + +/* { dg-do compile } */ +/* { dg-options "" } */ + +/* Each include file should not be subject to MI optimisation, since + macro definitions can change. Each header increments the variable + VAR if it is defined. + + The first set of inclusions gets the headers into CPP's cache, but + does nothing since VAR is not defined. The second set should each + increment VAR, since none of the initial set should have been + flagged as optimizable. */ + +#define EMPTY +#define NOT ! +#define DEFINED defined (macro) +#define IND ! defined (macro) + +#include "mi6a.h" +#include "mi6b.h" +#include "mi6c.h" +#include "mi6d.h" +#include "mi6e.h" + +#define VAR five + +int +main(void) +{ + unsigned int five = 0; + +#include "mi6a.h" +#include "mi6b.h" +#include "mi6c.h" +#include "mi6d.h" +#include "mi6e.h" + + if (five != 5) + abort (); + return 0; +} diff --git a/gcc/testsuite/gcc.dg/cpp/mi6a.h b/gcc/testsuite/gcc.dg/cpp/mi6a.h new file mode 100644 index 0000000..b11021c --- /dev/null +++ b/gcc/testsuite/gcc.dg/cpp/mi6a.h @@ -0,0 +1,5 @@ +#if IND + #ifdef VAR + VAR++; + #endif +#endif diff --git a/gcc/testsuite/gcc.dg/cpp/mi6b.h b/gcc/testsuite/gcc.dg/cpp/mi6b.h new file mode 100644 index 0000000..0d89ddf --- /dev/null +++ b/gcc/testsuite/gcc.dg/cpp/mi6b.h @@ -0,0 +1,5 @@ +#if NOT defined (macro) + #ifdef VAR + VAR++; + #endif +#endif diff --git a/gcc/testsuite/gcc.dg/cpp/mi6c.h b/gcc/testsuite/gcc.dg/cpp/mi6c.h new file mode 100644 index 0000000..d19cb54 --- /dev/null +++ b/gcc/testsuite/gcc.dg/cpp/mi6c.h @@ -0,0 +1,5 @@ +#if !DEFINED + #ifdef VAR + VAR++; + #endif +#endif diff --git a/gcc/testsuite/gcc.dg/cpp/mi6d.h b/gcc/testsuite/gcc.dg/cpp/mi6d.h new file mode 100644 index 0000000..7cb4b6b --- /dev/null +++ b/gcc/testsuite/gcc.dg/cpp/mi6d.h @@ -0,0 +1,5 @@ +#if EMPTY !defined (macro) + #ifdef VAR + VAR++; + #endif +#endif diff --git a/gcc/testsuite/gcc.dg/cpp/mi6e.h b/gcc/testsuite/gcc.dg/cpp/mi6e.h new file mode 100644 index 0000000..e60ca44 --- /dev/null +++ b/gcc/testsuite/gcc.dg/cpp/mi6e.h @@ -0,0 +1,5 @@ +#if !defined (macro) EMPTY + #ifdef VAR + VAR++; + #endif +#endif |