summaryrefslogtreecommitdiff
path: root/python/modules/IcePy/Communicator.cpp
diff options
context:
space:
mode:
authorMark Spruiell <mes@zeroc.com>2017-03-07 15:25:46 -0800
committerMark Spruiell <mes@zeroc.com>2017-03-07 15:25:46 -0800
commita6cc8dc5ed35ce0f4afcaddcdaad912bc5816556 (patch)
tree94038b3144884505db5c41006d231b5a2ae2ca3e /python/modules/IcePy/Communicator.cpp
parentMissing CSharp Glacier2/application test (diff)
downloadice-a6cc8dc5ed35ce0f4afcaddcdaad912bc5816556.tar.bz2
ice-a6cc8dc5ed35ce0f4afcaddcdaad912bc5816556.tar.xz
ice-a6cc8dc5ed35ce0f4afcaddcdaad912bc5816556.zip
ICE-6845 - add Python support for dispatcher
Diffstat (limited to 'python/modules/IcePy/Communicator.cpp')
-rw-r--r--python/modules/IcePy/Communicator.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/python/modules/IcePy/Communicator.cpp b/python/modules/IcePy/Communicator.cpp
index 63d19e7634d..56ffebabc9c 100644
--- a/python/modules/IcePy/Communicator.cpp
+++ b/python/modules/IcePy/Communicator.cpp
@@ -13,6 +13,7 @@
#include <IceUtil/DisableWarnings.h>
#include <Communicator.h>
#include <BatchRequestInterceptor.h>
+#include <Dispatcher.h>
#include <ImplicitContext.h>
#include <Logger.h>
#include <ObjectAdapter.h>
@@ -59,6 +60,7 @@ struct CommunicatorObject
IceUtil::Monitor<IceUtil::Mutex>* shutdownMonitor;
WaitForShutdownThreadPtr* shutdownThread;
bool shutdown;
+ DispatcherPtr* dispatcher;
};
}
@@ -80,6 +82,7 @@ communicatorNew(PyTypeObject* type, PyObject* /*args*/, PyObject* /*kwds*/)
self->shutdownMonitor = new IceUtil::Monitor<IceUtil::Mutex>;
self->shutdownThread = 0;
self->shutdown = false;
+ self->dispatcher = 0;
return self;
}
@@ -142,6 +145,7 @@ communicatorInit(CommunicatorObject* self, PyObject* args, PyObject* /*kwds*/)
bool hasArgs = argList != 0;
Ice::InitializationData data;
+ DispatcherPtr dispatcherWrapper;
if(initData)
{
@@ -149,6 +153,7 @@ communicatorInit(CommunicatorObject* self, PyObject* args, PyObject* /*kwds*/)
PyObjectHandle logger = PyObject_GetAttrString(initData, STRCAST("logger"));
PyObjectHandle threadHook = PyObject_GetAttrString(initData, STRCAST("threadHook"));
PyObjectHandle batchRequestInterceptor = PyObject_GetAttrString(initData, STRCAST("batchRequestInterceptor"));
+ PyObjectHandle dispatcher = PyObject_GetAttrString(initData, STRCAST("dispatcher"));
PyErr_Clear(); // PyObject_GetAttrString sets an error on failure.
@@ -172,6 +177,12 @@ communicatorInit(CommunicatorObject* self, PyObject* args, PyObject* /*kwds*/)
data.threadHook = new ThreadHook(threadHook.get());
}
+ if(dispatcher.get() && dispatcher.get() != Py_None)
+ {
+ dispatcherWrapper = new Dispatcher(dispatcher.get());
+ data.dispatcher = dispatcherWrapper;
+ }
+
if(batchRequestInterceptor.get() && batchRequestInterceptor.get() != Py_None)
{
data.batchRequestInterceptor = new BatchRequestInterceptor(batchRequestInterceptor.get());
@@ -269,6 +280,12 @@ communicatorInit(CommunicatorObject* self, PyObject* args, PyObject* /*kwds*/)
}
_communicatorMap.insert(CommunicatorMap::value_type(communicator, reinterpret_cast<PyObject*>(self)));
+ if(dispatcherWrapper)
+ {
+ self->dispatcher = new DispatcherPtr(dispatcherWrapper);
+ dispatcherWrapper->setCommunicator(communicator);
+ }
+
return 0;
}
@@ -323,6 +340,11 @@ communicatorDestroy(CommunicatorObject* self)
vfm->destroy();
+ if(self->dispatcher)
+ {
+ (*self->dispatcher)->setCommunicator(0); // Break cyclic reference.
+ }
+
//
// Break cyclic reference between this object and its Python wrapper.
//