diff options
Diffstat (limited to 'bridges/source/cpp_uno/gcc3_linux_powerpc/cpp2uno.cxx')
-rw-r--r-- | bridges/source/cpp_uno/gcc3_linux_powerpc/cpp2uno.cxx | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/bridges/source/cpp_uno/gcc3_linux_powerpc/cpp2uno.cxx b/bridges/source/cpp_uno/gcc3_linux_powerpc/cpp2uno.cxx index 521dccd6dae1..328fb7a17e38 100644 --- a/bridges/source/cpp_uno/gcc3_linux_powerpc/cpp2uno.cxx +++ b/bridges/source/cpp_uno/gcc3_linux_powerpc/cpp2uno.cxx @@ -19,6 +19,7 @@ #include <string.h> +#include <typeinfo> #include <com/sun/star/uno/genfunc.hxx> #include <sal/log.hxx> @@ -702,7 +703,7 @@ void bridges::cpp_uno::shared::VtableFactory::flushCode(unsigned char const * bp __asm__ volatile ("isync" : : : "memory"); } -struct bridges::cpp_uno::shared::VtableFactory::Slot { void * fn; }; +struct bridges::cpp_uno::shared::VtableFactory::Slot { void const * fn; }; bridges::cpp_uno::shared::VtableFactory::Slot * bridges::cpp_uno::shared::VtableFactory::mapBlockToVtable(void * block) @@ -716,6 +717,12 @@ std::size_t bridges::cpp_uno::shared::VtableFactory::getBlockSize( return (slotCount + 2) * sizeof (Slot) + slotCount * codeSnippetSize; } +namespace { +// Some dummy type whose RTTI is used in the synthesized proxy vtables to make uses of dynamic_cast +// on such proxy objects not crash: +struct ProxyRtti {}; +} + bridges::cpp_uno::shared::VtableFactory::Slot * bridges::cpp_uno::shared::VtableFactory::initializeBlock( void * block, sal_Int32 slotCount, sal_Int32, @@ -723,7 +730,7 @@ bridges::cpp_uno::shared::VtableFactory::initializeBlock( { Slot * slots = mapBlockToVtable(block); slots[-2].fn = 0; - slots[-1].fn = 0; + slots[-1].fn = &typeid(ProxyRtti); return slots + slotCount; } |