]> gcc.gnu.org Git - gcc.git/commitdiff
_Pragma1.c: Update.
authorNeil Booth <neilb@earthling.net>
Wed, 15 Nov 2000 19:23:41 +0000 (19:23 +0000)
committerNeil Booth <neil@gcc.gnu.org>
Wed, 15 Nov 2000 19:23:41 +0000 (19:23 +0000)
        * gcc.dg/cpp/_Pragma1.c: Update.
        * gcc.dg/cpp/_Pragma2.c: New test.

From-SVN: r37486

gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/cpp/_Pragma1.c
gcc/testsuite/gcc.dg/cpp/_Pragma2.c [new file with mode: 0644]

index 6a01b9243a1d371781ec1493ce7c34111ce04db4..1ff1fac31e79f3925a85b048001811f656ca1cba 100644 (file)
@@ -1,3 +1,8 @@
+2000-11-15  Neil Booth  <neilb@earthling.net>
+
+        gcc.dg/cpp/_Pragma1.c: Update.
+        gcc.dg/cpp/_Pragma2.c: New test.
+
 2000-11-15  Nathan Sidwell  <nathan@codesourcery.com>
 
        * g++.old-deja/g++.other/anon5.C: New test.
index 8759b0a08245c98b680c89857f2d833c0e1d82c1..0f211a9858b48a4cda97627561d78fffd3452bd4 100644 (file)
@@ -13,12 +13,10 @@ p1                          /* { dg-error "poisoned" } */
 _Pragma ("GCC poison p2")
 p2                             /* { dg-error "poisoned" } */
 
-/* I can see no reason it cannot appear in a directive.  Check we
-   enter the conditional.  Putting the _Pragma at EOL also catches
-   nasties like not saving current lexer state properly.  Also test
-   that wide strings are OK.  */
-#if 1 _Pragma (L"GCC poison p3")
-p3                             /* { dg-error "poisoned" } */
+/* Don't interpret _Pragmas in directives.  The standard is not clear
+   on this, but I think this makes most sense.  */
+#if 1 _Pragma (L"GCC poison p3") /* { dg-error "missing binary operator" } */
+p3
 #endif
 
 #define M1 _Pragma ("GCC poison p4")
@@ -29,10 +27,10 @@ p4                          /* No problem; not yet poisoned.  */
 M1 p4                          /* { dg-error "poisoned" } */
 M2 (GCC poison p5) p5          /* { dg-error "poisoned" } */
 
-/* Look, ma!  These things even nest.  */
+/* Not interpreting _Pragma in directives means they don't nest.  */
 _Pragma ("_Pragma (\"GCC poison p6\") GCC poison p7")
-p6                             /* { dg-error "poisoned" } */
-p7                             /* { dg-error "poisoned" } */
+p6
+p7
 
 /* Check we ignore them in false conditionals.  */
 #if 0
diff --git a/gcc/testsuite/gcc.dg/cpp/_Pragma2.c b/gcc/testsuite/gcc.dg/cpp/_Pragma2.c
new file mode 100644 (file)
index 0000000..24c4457
--- /dev/null
@@ -0,0 +1,13 @@
+/* Copyright (C) 2000 Free Software Foundation, Inc.  */
+
+/* { dg-do preprocess } */
+
+/* Don't allow directives in a _Pragma string. */
+
+/* Contributed by Neil Booth 14 Nov 2000.  */
+
+_Pragma("#define test")
+
+#ifdef test
+#error Do not allow directives in _Pragma strings
+#endif
This page took 0.073656 seconds and 5 git commands to generate.