// { dg-do run }
// PRMS Id: 6000
// Bug: g++ gets confused trying to build up a reference to a cast.
class String {
protected:
char *cp;
public:
String(char *incp);
String(const String &constStringRef);
virtual void virtualFn1(void) const {;}
};
String::String(char *incp)
{
cp = incp;
}
String::String(const String &constStringRef)
{
// Right here, do an 'info args', and look at the virtual function table
// pointer: typically junk! Calling the function through that table could
// do anything, since we're really leaping off into the void. This example
// goes down with 'SIGBUS', but I've seen 'SIGSEGV' too, and 'SIGILL' is
// possible.
cp = constStringRef.cp;
constStringRef.virtualFn1();
}
void foofun(String string)
{
;
}
class Class1 {
public:
Class1(const String & constStringRef);
};
Class1 :: Class1 (const String & constStringRef)
{
// If instead of calling the function 'foofun()' here, we just assign
// 'constStringRef' to a local variable, then the vptr is typically == 0!
foofun(String(constStringRef));
}
int main(void)
{
Class1 *class1 = new Class1((char*) "Hi!");
}