summaryrefslogtreecommitdiff
path: root/pyuno
diff options
context:
space:
mode:
authorJens-Heiner Rechtien <hr@openoffice.org>2005-02-11 15:40:27 +0000
committerJens-Heiner Rechtien <hr@openoffice.org>2005-02-11 15:40:27 +0000
commit71ff0547fdea4dc7567f7826e68d1f691f11db81 (patch)
tree147c0217587e5203d595b062ff6dc8999b4ccf24 /pyuno
parent207acbdb923bd09cf1f1d0552113dabb33fa33db (diff)
INTEGRATION: CWS pyunofixes1 (1.2.24); FILE MERGED
2005/01/19 23:13:26 jbu 1.2.24.1: #i37468# reduced liklyhood of crashing after main with extra checks
Diffstat (limited to 'pyuno')
-rw-r--r--pyuno/source/module/pyuno_gc.cxx21
1 files changed, 19 insertions, 2 deletions
diff --git a/pyuno/source/module/pyuno_gc.cxx b/pyuno/source/module/pyuno_gc.cxx
index 2d67810c0df4..ced681c696a7 100644
--- a/pyuno/source/module/pyuno_gc.cxx
+++ b/pyuno/source/module/pyuno_gc.cxx
@@ -2,9 +2,9 @@
*
* $RCSfile: pyuno_gc.cxx,v $
*
- * $Revision: 1.2 $
+ * $Revision: 1.3 $
*
- * last change: $Author: hr $ $Date: 2004-02-02 19:30:09 $
+ * last change: $Author: hr $ $Date: 2005-02-11 16:40:27 $
*
* The Contents of this file are made available subject to the terms of
* either of the following licenses
@@ -63,6 +63,16 @@
namespace pyuno
{
+bool g_destructorsOfStaticObjectsHaveBeenCalled;
+class StaticDestructorGuard
+{
+public:
+ ~StaticDestructorGuard()
+ {
+ g_destructorsOfStaticObjectsHaveBeenCalled = true;
+ }
+};
+StaticDestructorGuard guard;
class GCThread : public ::osl::Thread
{
@@ -84,6 +94,9 @@ GCThread::GCThread( PyInterpreterState *interpreter, PyObject * object ) :
void GCThread::run()
{
+ // otherwise we crash here, when main has been left already
+ if( g_destructorsOfStaticObjectsHaveBeenCalled )
+ return;
try
{
PyThreadAttach guard( (PyInterpreterState*)mPyInterpreter );
@@ -117,6 +130,10 @@ void GCThread::onTerminated()
void decreaseRefCount( PyInterpreterState *interpreter, PyObject *object )
{
+ // otherwise we crash in the last after main ...
+ if( g_destructorsOfStaticObjectsHaveBeenCalled )
+ return;
+
// delegate to a new thread, because there does not seem
// to be a method, which tells, whether the global
// interpreter lock is held or not