Files
clang-p2996/lldb/test/API/lang/cpp/virtual-functions/main.cpp
Jordan Rupprecht 99451b4453 [lldb][test] Remove symlink for API tests.
Summary: Moves lldbsuite tests to lldb/test/API.

This is a largely mechanical change, moved with the following steps:

```
rm lldb/test/API/testcases
mkdir -p lldb/test/API/{test_runner/test,tools/lldb-{server,vscode}}
mv lldb/packages/Python/lldbsuite/test/test_runner/test lldb/test/API/test_runner
for d in $(find lldb/packages/Python/lldbsuite/test/* -maxdepth 0 -type d | egrep -v "make|plugins|test_runner|tools"); do mv $d lldb/test/API; done
for d in $(find lldb/packages/Python/lldbsuite/test/tools/lldb-vscode -maxdepth 1 -mindepth 1 | grep -v ".py"); do mv $d lldb/test/API/tools/lldb-vscode; done
for d in $(find lldb/packages/Python/lldbsuite/test/tools/lldb-server -maxdepth 1 -mindepth 1 | egrep -v "gdbremote_testcase.py|lldbgdbserverutils.py|socket_packet_pump.py"); do mv $d lldb/test/API/tools/lldb-server; done
```

lldb/packages/Python/lldbsuite/__init__.py and lldb/test/API/lit.cfg.py were also updated with the new directory structure.

Reviewers: labath, JDevlieghere

Tags: #lldb

Differential Revision: https://reviews.llvm.org/D71151
2020-02-11 10:03:53 -08:00

71 lines
2.3 KiB
C++

// Tests virtual function calls. As virtual destructors influence
// vtables this tests also needs to cover all combinations of
// virtual destructors in the derived/base class.
struct BaseWithVirtDtor {
virtual ~BaseWithVirtDtor() {}
virtual int foo() { return 1; }
};
struct BaseWithoutVirtDtor {
virtual int foo() { return 2; }
};
struct DerivedWithVirtDtor : BaseWithVirtDtor {
virtual ~DerivedWithVirtDtor() {}
virtual int foo() { return 3; }
};
struct DerivedWithoutVirtDtor : BaseWithoutVirtDtor {
virtual int foo() { return 4; }
};
struct DerivedWithBaseVirtDtor : BaseWithVirtDtor {
virtual int foo() { return 5; }
};
struct DerivedWithVirtDtorButNoBaseDtor : BaseWithoutVirtDtor {
virtual ~DerivedWithVirtDtorButNoBaseDtor() {}
virtual int foo() { return 6; }
};
struct DerivedWithOverload : BaseWithVirtDtor {
virtual ~DerivedWithOverload() {}
virtual int foo(int i) { return 7; }
};
struct DerivedWithOverloadAndUsing : BaseWithVirtDtor {
virtual ~DerivedWithOverloadAndUsing() {}
using BaseWithVirtDtor::foo;
virtual int foo(int i) { return 8; }
};
int main() {
// Declare base classes.
BaseWithVirtDtor base_with_dtor;
BaseWithoutVirtDtor base_without_dtor;
// Declare all the derived classes.
DerivedWithVirtDtor derived_with_dtor;
DerivedWithoutVirtDtor derived_without_dtor;
DerivedWithBaseVirtDtor derived_with_base_dtor;
DerivedWithVirtDtorButNoBaseDtor derived_with_dtor_but_no_base_dtor;
DerivedWithOverload derived_with_overload;
DerivedWithOverloadAndUsing derived_with_overload_and_using;
// The previous classes as their base class type.
BaseWithVirtDtor &derived_with_dtor_as_base = derived_with_dtor;
BaseWithoutVirtDtor &derived_without_as_base = derived_without_dtor;
BaseWithVirtDtor &derived_with_base_dtor_as_base = derived_with_base_dtor;
BaseWithoutVirtDtor &derived_with_dtor_but_no_base_dtor_as_base = derived_with_dtor_but_no_base_dtor;
// Call functions so that they are compiled.
int i = base_with_dtor.foo() + base_without_dtor.foo() +
derived_with_dtor.foo() + derived_without_dtor.foo() +
derived_with_base_dtor.foo() + derived_with_overload.foo(1)
+ derived_with_overload_and_using.foo(2)
+ derived_with_overload_and_using.foo();
return i; // break here
}