diff options
author | Nathan Sidwell <nathan@acm.org> | 1999-06-14 03:16:37 +0000 |
---|---|---|
committer | Nathan Sidwell <nathan@gcc.gnu.org> | 1999-06-14 03:16:37 +0000 |
commit | e4b593c532bdaa69aac38e89843cdbb5ad9455c9 (patch) | |
tree | 1c1cba77337e81a71c537c95d4b75dcc6a6b4bee /gcc | |
parent | 7747ddb3f4732bd17e91045a43c5de925af1fe04 (diff) | |
download | gcc-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/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/testsuite/g++.old-deja/g++.other/bitfld3.C | 34 |
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; +} |