diff options
author | Caolán McNamara <caolan.mcnamara@collabora.com> | 2024-04-30 10:00:22 +0100 |
---|---|---|
committer | Caolán McNamara <caolan.mcnamara@collabora.com> | 2024-04-30 13:39:03 +0200 |
commit | a6f52af75780ae28e4dc12f564ce3eb6d9c14b91 (patch) | |
tree | bb92c95f1f0cb945f4119619566d5e03b2ddfa60 /cppu/source/threadpool/current.cxx | |
parent | da3913a70cd133478add296b63d0e7e28c2374bf (diff) |
try to workaround clang crash
Stack dump:
0. Program arguments: clang++ -stdlib=libc++ -fsanitize-blacklist=/src/libreoffice/bin/sanitize-excludelist.txt -DBOOST_SYSTEM_NO_DEPRECATED -DCPPU_ENV=gcc3 -DLINUX -DNDEBUG -DOSL_DEBUG_LEVEL=0 -DUNIX -DUNX -DX86_64 -D_PTHREADS -D_REENTRANT -DCPPU_DLLIMPLEMENTATION -fvisibility=hidden -Wall -Wno-missing-braces -Wendif-labels -Wextra -Wundef -Wunreachable-code -Wshadow -Wunused-macros -Wembedded-directive -finput-charset=UTF-8 -fmessage-length=0 -fno-common -pipe -fstack-protector-strong -Wdeprecated-copy-dtor -Wimplicit-fallthrough -Wunused-exception-parameter -Wrange-loop-analysis -fvisibility-inlines-hidden -fPIC -Wshadow -Woverloaded-virtual -std=c++20 -pthread -O1 -fno-omit-frame-pointer -gline-tables-only -DFUZZING_BUILD_MODE_UNSAFE_FOR_PRODUCTION -fsanitize=address -fsanitize-address-use-after-scope -fsanitize-coverage=trace-pc-guard,indirect-calls,trace-cmp -stdlib=libc++ -fexceptions -DLIBO_INTERNAL_ONLY -c /src/libreoffice/cppu/source/threadpool/current.cxx -o /work/workdir_for_build/CxxObject/cppu/source/threadpool/current.o -MMD -MT /work/workdir_for_build/CxxObject/cppu/source/threadpool/current.o -MP -MF /work/workdir_for_build/Dep/CxxObject/cppu/source/threadpool/current.d_ -I/src/libreoffice/include -I/work/config_build -I/work/workdir_for_build/UnoApiHeadersTarget/udkapi/normal
1. /src/libreoffice/cppu/source/threadpool/current.cxx:77:8: current parser token ';'
2. /src/libreoffice/cppu/source/threadpool/current.cxx:37:1: parsing namespace 'cppu'
3. /src/libreoffice/cppu/source/threadpool/current.cxx:41:1: parsing function body 'cppu::get_type_XCurrentContext'
4. /src/libreoffice/cppu/source/threadpool/current.cxx:41:1: in compound statement ('{}')
#0 0x000000000190f863 llvm::sys::PrintStackTrace(llvm::raw_ostream&, int) (/usr/local/bin/clang-15+0x190f863)
#1 0x000000000190d7ae llvm::sys::RunSignalHandlers() (/usr/local/bin/clang-15+0x190d7ae)
#2 0x000000000190ed0d llvm::sys::CleanupOnSignal(unsigned long) (/usr/local/bin/clang-15+0x190ed0d)
#3 0x0000000001893000 CrashRecoverySignalHandler(int) CrashRecoveryContext.cpp:0:0
#4 0x00007f628aef1420 __restore_rt (/lib/x86_64-linux-gnu/libpthread.so.0+0x14420)
#5 0x00007f628aafc963 (/lib/x86_64-linux-gnu/libc.so.6+0x18b963)
#6 0x000000000186b31b llvm::APInt::APInt(unsigned int, llvm::ArrayRef<unsigned long>) (/usr/local/bin/clang-15+0x186b31b)
#7 0x0000000003d5031a (anonymous namespace)::StmtPrinter::VisitUserDefinedLiteral(clang::UserDefinedLiteral*) StmtPrinter.cpp:0:0
#8 0x0000000003d44e40 clang::Stmt::printPretty(llvm::raw_ostream&, clang::PrinterHelper*, clang::PrintingPolicy const&, unsigned int, llvm::StringRef, clang::ASTContext const*) const (/usr/local/bin/clang-15+0x3d44e40)
Change-Id: I963a7ee431748b21ab587a90208f9cdbb2df2bf9
Reviewed-on: https://gerrit.libreoffice.org/c/core/+/166918
Tested-by: Caolán McNamara <caolan.mcnamara@collabora.com>
Reviewed-by: Caolán McNamara <caolan.mcnamara@collabora.com>
Diffstat (limited to 'cppu/source/threadpool/current.cxx')
-rw-r--r-- | cppu/source/threadpool/current.cxx | 76 |
1 files changed, 39 insertions, 37 deletions
diff --git a/cppu/source/threadpool/current.cxx b/cppu/source/threadpool/current.cxx index aefd85f3d1b0..0e2a3b70196e 100644 --- a/cppu/source/threadpool/current.cxx +++ b/cppu/source/threadpool/current.cxx @@ -37,45 +37,47 @@ using namespace ::com::sun::star::uno; namespace cppu { -static typelib_InterfaceTypeDescription * get_type_XCurrentContext() +static typelib_InterfaceTypeDescription * impl_get_type_XCurrentContext() { - static typelib_InterfaceTypeDescription* s_type_XCurrentContext = []() { - OUString sTypeName(u"com.sun.star.uno.XCurrentContext"_ustr); - typelib_InterfaceTypeDescription* pTD = nullptr; - typelib_TypeDescriptionReference* pMembers[1] = { nullptr }; - OUString sMethodName0(u"com.sun.star.uno.XCurrentContext::getValueByName"_ustr); - typelib_typedescriptionreference_new(&pMembers[0], typelib_TypeClass_INTERFACE_METHOD, - sMethodName0.pData); - typelib_typedescription_newInterface( - &pTD, sTypeName.pData, 0, 0, 0, 0, 0, - *typelib_static_type_getByTypeClass(typelib_TypeClass_INTERFACE), 1, pMembers); - - typelib_typedescription_register(reinterpret_cast<typelib_TypeDescription**>(&pTD)); - typelib_typedescriptionreference_release(pMembers[0]); - - typelib_InterfaceMethodTypeDescription* pMethod = nullptr; - typelib_Parameter_Init aParameters[1]; - OUString sParamName0(u"Name"_ustr); - OUString sParamType0(u"string"_ustr); - aParameters[0].pParamName = sParamName0.pData; - aParameters[0].eTypeClass = typelib_TypeClass_STRING; - aParameters[0].pTypeName = sParamType0.pData; - aParameters[0].bIn = true; - aParameters[0].bOut = false; - rtl_uString* pExceptions[1]; - OUString sExceptionName0(u"com.sun.star.uno.RuntimeException"_ustr); - pExceptions[0] = sExceptionName0.pData; - OUString sReturnType0(u"any"_ustr); - typelib_typedescription_newInterfaceMethod(&pMethod, 3, false, sMethodName0.pData, - typelib_TypeClass_ANY, sReturnType0.pData, 1, - aParameters, 1, pExceptions); - typelib_typedescription_register(reinterpret_cast<typelib_TypeDescription**>(&pMethod)); - typelib_typedescription_release(&pMethod->aBase.aBase); - // another static ref: - ++reinterpret_cast<typelib_TypeDescription*>(pTD)->nStaticRefCount; - return pTD; - }(); + OUString sTypeName(u"com.sun.star.uno.XCurrentContext"_ustr); + typelib_InterfaceTypeDescription* pTD = nullptr; + typelib_TypeDescriptionReference* pMembers[1] = { nullptr }; + OUString sMethodName0(u"com.sun.star.uno.XCurrentContext::getValueByName"_ustr); + typelib_typedescriptionreference_new(&pMembers[0], typelib_TypeClass_INTERFACE_METHOD, + sMethodName0.pData); + typelib_typedescription_newInterface( + &pTD, sTypeName.pData, 0, 0, 0, 0, 0, + *typelib_static_type_getByTypeClass(typelib_TypeClass_INTERFACE), 1, pMembers); + + typelib_typedescription_register(reinterpret_cast<typelib_TypeDescription**>(&pTD)); + typelib_typedescriptionreference_release(pMembers[0]); + + typelib_InterfaceMethodTypeDescription* pMethod = nullptr; + typelib_Parameter_Init aParameters[1]; + OUString sParamName0(u"Name"_ustr); + OUString sParamType0(u"string"_ustr); + aParameters[0].pParamName = sParamName0.pData; + aParameters[0].eTypeClass = typelib_TypeClass_STRING; + aParameters[0].pTypeName = sParamType0.pData; + aParameters[0].bIn = true; + aParameters[0].bOut = false; + rtl_uString* pExceptions[1]; + OUString sExceptionName0(u"com.sun.star.uno.RuntimeException"_ustr); + pExceptions[0] = sExceptionName0.pData; + OUString sReturnType0(u"any"_ustr); + typelib_typedescription_newInterfaceMethod(&pMethod, 3, false, sMethodName0.pData, + typelib_TypeClass_ANY, sReturnType0.pData, 1, + aParameters, 1, pExceptions); + typelib_typedescription_register(reinterpret_cast<typelib_TypeDescription**>(&pMethod)); + typelib_typedescription_release(&pMethod->aBase.aBase); + // another static ref: + ++reinterpret_cast<typelib_TypeDescription*>(pTD)->nStaticRefCount; + return pTD; +} +static typelib_InterfaceTypeDescription * get_type_XCurrentContext() +{ + static typelib_InterfaceTypeDescription* s_type_XCurrentContext = impl_get_type_XCurrentContext(); return s_type_XCurrentContext; } |