1999-05-03 07:29:11 +00:00
|
|
|
struct A
|
|
|
|
{
|
|
|
|
virtual void foo();
|
|
|
|
virtual void bar();
|
|
|
|
};
|
|
|
|
|
|
|
|
void A::foo() { } // keep
|
2000-04-12 12:55:06 +00:00
|
|
|
void A::bar() { } // lose
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
struct B : public A
|
|
|
|
{
|
|
|
|
virtual void foo();
|
|
|
|
};
|
|
|
|
|
|
|
|
void B::foo() { } // keep
|
|
|
|
|
2003-04-30 12:07:19 +00:00
|
|
|
void _start() __asm__("_start"); // keep
|
|
|
|
void start() __asm__("start"); // some toolchains use this name.
|
1999-05-03 07:29:11 +00:00
|
|
|
|
|
|
|
A a; // keep
|
|
|
|
B b;
|
|
|
|
A *getme() { return &a; } // keep
|
|
|
|
|
|
|
|
void _start()
|
|
|
|
{
|
|
|
|
getme()->foo();
|
2000-04-12 12:55:06 +00: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 07:29:11 +00:00
|
|
|
}
|
|
|
|
|
2003-04-30 12:07:19 +00:00
|
|
|
void start ()
|
|
|
|
{
|
|
|
|
_start ();
|
|
|
|
}
|
|
|
|
|
1999-05-03 07:29:11 +00: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() { }
|