diff options
author | Dimitry Andric <dim@FreeBSD.org> | 2015-05-27 18:44:32 +0000 |
---|---|---|
committer | Dimitry Andric <dim@FreeBSD.org> | 2015-05-27 18:44:32 +0000 |
commit | 5a5ac124e1efaf208671f01c46edb15f29ed2a0b (patch) | |
tree | a6140557876943cdd800ee997c9317283394b22c /test/DebugInfo/PDB/Inputs/symbolformat.cpp | |
parent | f03b5bed27d0d2eafd68562ce14f8b5e3f1f0801 (diff) |
Diffstat (limited to 'test/DebugInfo/PDB/Inputs/symbolformat.cpp')
-rw-r--r-- | test/DebugInfo/PDB/Inputs/symbolformat.cpp | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/test/DebugInfo/PDB/Inputs/symbolformat.cpp b/test/DebugInfo/PDB/Inputs/symbolformat.cpp new file mode 100644 index 000000000000..5479b717cd9d --- /dev/null +++ b/test/DebugInfo/PDB/Inputs/symbolformat.cpp @@ -0,0 +1,73 @@ +// Compile with "cl /c /Zi /GR- symbolformat.cpp" +// Compile symbolformat-fpo.cpp (see file for instructions) +// Link with "link symbolformat.obj symbolformat-fpo.obj /debug /nodefaultlib +// /entry:main /out:symbolformat.exe" + +int __cdecl _purecall(void) { return 0; } + +enum TestEnum { + Value, + Value10 = 10 +}; + +enum class TestEnumClass { + Value, + Value10 = 10 +}; + +struct A { + virtual void PureFunc() = 0 {} + virtual void VirtualFunc() {} + void RegularFunc() {} +}; + +struct VirtualBase { +}; + +struct B : public A, protected virtual VirtualBase { + void PureFunc() override {} +}; + +struct MemberTest { + enum NestedEnum { + FirstVal, + SecondVal + }; + + typedef int NestedTypedef; + + NestedEnum m_nested_enum; + NestedTypedef m_typedef; + bool m_bool; + char m_char; + wchar_t m_wchar_t; + int m_int; + unsigned m_unsigned; + long m_long; + unsigned long m_unsigned_long; + __int64 m_int64; + unsigned __int64 m_unsigned_int64; + float m_float; + double m_double; + void (*m_pfn_2_args)(int, double); +}; + +typedef int IntType; +typedef A ClassAType; + +int g_global_int; +void *g_global_pointer = nullptr; + +int main(int argc, char **argv) { + // Force symbol references so the linker generates debug info + B b; + MemberTest members; + auto PureAddr = &B::PureFunc; + auto VirtualAddr = &A::PureFunc; + auto RegularAddr = &A::RegularFunc; + TestEnum Enum = Value; + TestEnumClass EnumClass = TestEnumClass::Value10; + IntType Int = 12; + ClassAType *ClassA = &b; + return 0; +} |