X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/62b8a649fcae500c983215fac2e5202916c0195f..a6f7c725e21a4b6ed064e92b453331837d12f267:/lib/base/message.h?ds=sidebyside diff --git a/lib/base/message.h b/lib/base/message.h index de14db0f..6e9eb07c 100644 --- a/lib/base/message.h +++ b/lib/base/message.h @@ -2,15 +2,19 @@ #define __lib_base_message_h #include +#include +#include #include #include + /** * \brief A generic messagepump. * * You can send and receive messages with this class. Internally a fifo is used, * so you can use them together with a \c eMainloop. */ +#ifndef SWIG class eMessagePump { int fd[2]; @@ -19,6 +23,7 @@ class eMessagePump public: eMessagePump(int mt=0); virtual ~eMessagePump(); +protected: int send(const void *data, int len); int recv(void *data, int len); // blockierend int getInputFD() const; @@ -34,7 +39,7 @@ public: template class eFixedMessagePump: private eMessagePump, public Object { - eSocketNotifier *sn; + ePtr sn; void do_recv(int) { T msg; @@ -49,14 +54,36 @@ public: } eFixedMessagePump(eMainloop *context, int mt): eMessagePump(mt) { - sn=new eSocketNotifier(context, getOutputFD(), eSocketNotifier::Read); + sn=eSocketNotifier::create(context, getOutputFD(), eSocketNotifier::Read); CONNECT(sn->activated, eFixedMessagePump::do_recv); sn->start(); } - ~eFixedMessagePump() + void start() { if (sn) sn->start(); } + void stop() { if (sn) sn->stop(); } +}; +#endif + +class ePythonMessagePump: public eMessagePump, public Object +{ + ePtr sn; + void do_recv(int) { - delete sn; - sn=0; + int msg; + recv(&msg, sizeof(msg)); + /*emit*/ recv_msg(msg); + } +public: + PSignal1 recv_msg; + void send(int msg) + { + eMessagePump::send(&msg, sizeof(msg)); + } + ePythonMessagePump() + :eMessagePump(1) + { + sn=eSocketNotifier::create(eApp, getOutputFD(), eSocketNotifier::Read); + CONNECT(sn->activated, ePythonMessagePump::do_recv); + sn->start(); } void start() { if (sn) sn->start(); } void stop() { if (sn) sn->stop(); }