1999-05-03 15:29:11 +08:00
|
|
|
struct A
|
|
|
|
{
|
|
|
|
virtual void foo();
|
|
|
|
virtual void bar();
|
|
|
|
};
|
|
|
|
|
|
|
|
void A::foo() { } // keep
|
2000-04-12 20:55:06 +08:00
|
|
|
void A::bar() { } // lose
|
1999-05-03 15:29:11 +08:00
|
|
|
|
|
|
|
struct B : public A
|
|
|
|
{
|
|
|
|
virtual void foo();
|
|
|
|
};
|
|
|
|
|
|
|
|
void B::foo() { } // keep
|
|
|
|
|
|
|
|
void _start() __asm__("_start"); // keep
|
|
|
|
|
|
|
|
A a; // keep
|
|
|
|
B b;
|
|
|
|
A *getme() { return &a; } // keep
|
|
|
|
|
|
|
|
void _start()
|
|
|
|
{
|
|
|
|
getme()->foo();
|
2000-04-12 20:55:06 +08:00
|
|
|
#ifdef __GNUC__
|
|
|
|
#if (__GNUC__ == 2 && __GNUC_MINOR__ < 96)
|
|
|
|
// gcc-2.95.2 gets this test wrong, and loses B::foo().
|
|
|
|
// Cheat. After all, we aren't trying to test the compiler here.
|
|
|
|
b.foo();
|
|
|
|
#endif
|
|
|
|
#endif
|
1999-05-03 15:29:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
// In addition, keep A's virtual table.
|
|
|
|
|
|
|
|
// We'll wind up keeping `b' and thus B's virtual table because
|
|
|
|
// `a' and `b' are both referenced from the constructor function.
|
|
|
|
|
|
|
|
extern "C" void __main() { }
|