summaryrefslogtreecommitdiff
path: root/gcc/testsuite/g++.old-deja/g++.jason/tempparse.C
diff options
context:
space:
mode:
authorYamaArashi <shadow962@live.com>2016-01-06 01:47:28 -0800
committerYamaArashi <shadow962@live.com>2016-01-06 01:47:28 -0800
commitbe8b04496302184c6e8f04d6179f9c3afc50aeb6 (patch)
tree726e2468c0c07add773c0dbd86ab6386844259ae /gcc/testsuite/g++.old-deja/g++.jason/tempparse.C
initial commit
Diffstat (limited to 'gcc/testsuite/g++.old-deja/g++.jason/tempparse.C')
-rwxr-xr-xgcc/testsuite/g++.old-deja/g++.jason/tempparse.C29
1 files changed, 29 insertions, 0 deletions
diff --git a/gcc/testsuite/g++.old-deja/g++.jason/tempparse.C b/gcc/testsuite/g++.old-deja/g++.jason/tempparse.C
new file mode 100755
index 0000000..68f67ad
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.jason/tempparse.C
@@ -0,0 +1,29 @@
+/*
+ PRMS Id: 3631
+ Bug is: g++ mangles template class names in a way that it won't accept,
+ and then tries to feed them to itself.
+*/
+// Build don't link:
+
+template<class T>
+struct A {
+ A();
+};
+
+template<class T>
+struct B : A<T> {
+ B();
+}; // gets bogus error - B<C<char>>
+
+template<class T>
+struct C {
+ C();
+};
+
+template<class T>
+struct D {
+ D();
+ B<C<T> > p_f;
+};
+
+typedef D<char> Dummy;