* gcc.dg/cpp/avoidpaste1.c: Test case.
authorNeil Booth <neil@daikokuya.demon.co.uk>
Sun, 28 Jan 2001 11:27:22 +0000 (11:27 +0000)
committerNeil Booth <neil@gcc.gnu.org>
Sun, 28 Jan 2001 11:27:22 +0000 (11:27 +0000)
From-SVN: r39319

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

index edd52229b3ce9e31b5d3bed99ed96c58d9411237..d5e7c9e88a875776b0904ab14c766a9c873b2000 100644 (file)
@@ -1,3 +1,7 @@
+2001-01-28  Neil Booth  <neil@daikokuya.demon.co.uk>
+
+        * gcc.dg/cpp/avoidpaste1.c: Test case.
+
 2001-01-28  Jakub Jelinek  <jakub@redhat.com>
 
        * g++.old-deja/g++.other/inline18.C: New test.
diff --git a/gcc/testsuite/gcc.dg/cpp/avoidpaste1.c b/gcc/testsuite/gcc.dg/cpp/avoidpaste1.c
new file mode 100644 (file)
index 0000000..54233e8
--- /dev/null
@@ -0,0 +1,32 @@
+/* Copyright (C) 2000 Free Software Foundation, Inc.  */
+
+/* { dg-do preprocess } */
+
+/* This tests that we avoid accidental pasting only before and after
+   macros and arguments, and not when the tokens are already pasted
+   in the souce file (e.g. "::" in a C source file).
+
+   Neil Booth, 28 Jan 2001.  */
+
+#define f(x) x
+#define g
+
+/* This should preprocess as
+
+:: : : : : :^:
+: : : .. . 0
+
+It relies on the fact that even preprocessing C we bother to separate
+the colons of C++'s :: operator.  If we confine this behaviour to C++
+in future, this test needs to change.  */
+
+:: :g: :f(): :f(^):
+:f(:): .. .__INCLUDE_LEVEL__   /* Check builtins, too.  */
+
+/*
+   { dg-final { if ![file exists avoidpaste1.i] { return }                } }
+   { dg-final { if { [grep avoidpaste1.i ":: : : : : :\\^:"] != "" } \{   } }
+   { dg-final { if { [grep avoidpaste1.i ": : : \\\.\\\. \\\. 0"] != "" } \{  } }
+   { dg-final { return \} \}                                              } }
+   { dg-final { fail "avoidpaste1.c: paste avoidance"                     } }
+*/