aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorNathan Sidwell <nathan@acm.org>1999-06-14 03:16:37 +0000
committerNathan Sidwell <nathan@gcc.gnu.org>1999-06-14 03:16:37 +0000
commite4b593c532bdaa69aac38e89843cdbb5ad9455c9 (patch)
tree1c1cba77337e81a71c537c95d4b75dcc6a6b4bee /gcc
parent7747ddb3f4732bd17e91045a43c5de925af1fe04 (diff)
downloadgcc-e4b593c532bdaa69aac38e89843cdbb5ad9455c9.zip
gcc-e4b593c532bdaa69aac38e89843cdbb5ad9455c9.tar.gz
gcc-e4b593c532bdaa69aac38e89843cdbb5ad9455c9.tar.bz2
* g++.old-deja/g++.other/bitfld3.C: New test.
From-SVN: r27514
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/g++.old-deja/g++.other/bitfld3.C34
2 files changed, 39 insertions, 1 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 3bd0fb9..71a6e12 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,4 +1,8 @@
- 1999-06-08 Nathan Sidwell <nathan@acm.org>
+1999-06-14 Nathan Sidwell <nathan@acm.org>
+
+ * g++.old-deja/g++.other/bitfld3.C: New test.
+
+1999-06-08 Nathan Sidwell <nathan@acm.org>
* g++.old-deja/g++.eh/catch1.C: New test.
diff --git a/gcc/testsuite/g++.old-deja/g++.other/bitfld3.C b/gcc/testsuite/g++.old-deja/g++.other/bitfld3.C
new file mode 100644
index 0000000..bbddc7c
--- /dev/null
+++ b/gcc/testsuite/g++.old-deja/g++.other/bitfld3.C
@@ -0,0 +1,34 @@
+// Build don't link:
+
+// Copyright (C) 1999 Free Software Foundation, Inc.
+// Contributed by Nathan Sidwell 4 Jun 1999 <nathan@acm.org>
+// Derived from a bug report from Stephan Riess <riess@bfw-online.de>
+// http://egcs.cygnus.com/ml/egcs-bugs/1999-06/msg00107.html
+
+// Builtin ops don't always need reference bindings, and we weren't removing
+// them always after doing overload resolution. This caused us to try and take
+// the address of a bitfield.
+
+enum E {one};
+struct A {
+ E m1: 8;
+ E m2: 8;
+ unsigned m3 : 8;
+ unsigned m4 : 8;
+};
+
+int fn (int f)
+{
+ A a;
+ E m1, m2;
+ E e;
+ int i;
+
+ e = f ? m1 : m2;
+ e = f ? a.m1 : a.m2;
+ i = f ? a.m3 : a.m4;
+ (f ? m1 : m2) = e;
+ (f ? a.m1 : a.m2) = e;
+ (f ? a.m3 : a.m4) = i;
+ return 0;
+}