diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3bd0fb98fe7..71a6e12bf18 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,4 +1,8 @@ - 1999-06-08 Nathan Sidwell +1999-06-14 Nathan Sidwell + + * g++.old-deja/g++.other/bitfld3.C: New test. + +1999-06-08 Nathan Sidwell * 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 00000000000..bbddc7c93ec --- /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 +// Derived from a bug report from Stephan Riess +// 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; +}