[Libreoffice-commits] core.git: include/vcl toolkit/source vcl/source
Caolán McNamara (via logerrit)
logerrit at kemper.freedesktop.org
Thu Jun 13 13:13:31 UTC 2019
include/vcl/svapp.hxx | 3 +++
toolkit/source/awt/vclxtoolkit.cxx | 2 +-
vcl/source/app/svmain.cxx | 8 +++-----
3 files changed, 7 insertions(+), 6 deletions(-)
New commits:
commit 21f52ffd77f68d345949f212ad7d622502bd21e9
Author: Caolán McNamara <caolanm at redhat.com>
AuthorDate: Thu Jun 13 12:03:20 2019 +0100
Commit: Caolán McNamara <caolanm at redhat.com>
CommitDate: Thu Jun 13 15:12:44 2019 +0200
unopkg gui crashes on shutdown
since...
commit e655dc8bbf010e5ef89c32c2ebde56281b323925
Date: Thu May 9 18:24:18 2019 +0100
unipoll: let InitVCL tolerate double init.
which changed InitVCL to return true if it was
already initialized, tricking toolkit into thinking
it was the first one to call InitVCL
Change-Id: I33552a5e2caca909f8d63fbf5f23b9fbc4c2dfbd
Reviewed-on: https://gerrit.libreoffice.org/73956
Tested-by: Jenkins
Reviewed-by: Caolán McNamara <caolanm at redhat.com>
Tested-by: Caolán McNamara <caolanm at redhat.com>
diff --git a/include/vcl/svapp.hxx b/include/vcl/svapp.hxx
index d89a23e54a13..8fc5d0d46ccb 100644
--- a/include/vcl/svapp.hxx
+++ b/include/vcl/svapp.hxx
@@ -1482,6 +1482,9 @@ public:
VCL_DLLPUBLIC Application* GetpApp();
+// returns true if vcl is already initialized
+VCL_DLLPUBLIC bool IsVCLInit();
+// returns true if vcl successfully initializes or was already initialized
VCL_DLLPUBLIC bool InitVCL();
VCL_DLLPUBLIC void DeInitVCL();
diff --git a/toolkit/source/awt/vclxtoolkit.cxx b/toolkit/source/awt/vclxtoolkit.cxx
index 398b5b77cfc4..e09dee3d242c 100644
--- a/toolkit/source/awt/vclxtoolkit.cxx
+++ b/toolkit/source/awt/vclxtoolkit.cxx
@@ -877,7 +877,7 @@ static void ToolkitWorkerFunction( void* pArgs )
}
VCLXToolkit * pTk = static_cast<VCLXToolkit *>(pArgs);
- bInitedByVCLToolkit = InitVCL();
+ bInitedByVCLToolkit = !IsVCLInit() && InitVCL();
if( bInitedByVCLToolkit )
{
UnoWrapper* pUnoWrapper = new UnoWrapper( pTk );
diff --git a/vcl/source/app/svmain.cxx b/vcl/source/app/svmain.cxx
index 16b83439751b..51e47674b604 100644
--- a/vcl/source/app/svmain.cxx
+++ b/vcl/source/app/svmain.cxx
@@ -112,8 +112,6 @@ using namespace ::com::sun::star;
static bool g_bIsLeanException;
-static bool isInitVCL();
-
static oslSignalAction VCLExceptionSignal_impl( void* /*pData*/, oslSignalInfo* pInfo)
{
static volatile bool bIn = false;
@@ -190,7 +188,7 @@ int ImplSVMain()
int nReturn = EXIT_FAILURE;
- const bool bWasInitVCL = isInitVCL();
+ const bool bWasInitVCL = IsVCLInit();
const bool bInit = bWasInitVCL || InitVCL();
int nRet = 0;
if (!bWasInitVCL && bInit && pSVData->mpDefInst->SVMainHook(&nRet))
@@ -273,7 +271,7 @@ uno::Any SAL_CALL DesktopEnvironmentContext::getValueByName( const OUString& Nam
return retVal;
}
-static bool isInitVCL()
+bool IsVCLInit()
{
ImplSVData* pSVData = ImplGetSVData();
return pExceptionHandler != nullptr &&
@@ -294,7 +292,7 @@ namespace vclmain
bool InitVCL()
{
- if (isInitVCL())
+ if (IsVCLInit())
{
SAL_INFO("vcl.app", "Double initialization of vcl");
return true;
More information about the Libreoffice-commits
mailing list