summaryrefslogtreecommitdiff
path: root/libopie2
authorzecke <zecke>2004-11-03 23:02:13 (UTC)
committer zecke <zecke>2004-11-03 23:02:13 (UTC)
commita6adcd3869b9c9c7548290ea686bc4e78ed62fc3 (patch) (side-by-side diff)
tree0916443be21889c567de40b90de27d34f793484d /libopie2
parent07900eb7986f63e56072b1fb8fe5dbf846c8519d (diff)
downloadopie-a6adcd3869b9c9c7548290ea686bc4e78ed62fc3.zip
opie-a6adcd3869b9c9c7548290ea686bc4e78ed62fc3.tar.gz
opie-a6adcd3869b9c9c7548290ea686bc4e78ed62fc3.tar.bz2
-Create a QPE/System channel (sysMessage:QCopChannel from QPEApplication
can't be used) -'Forward' receiving of messages to the 'systemMessageSignal'
Diffstat (limited to 'libopie2') (more/less context) (ignore whitespace changes)
-rw-r--r--libopie2/opiecore/oapplication.cpp7
-rw-r--r--libopie2/opiecore/oapplication.h11
2 files changed, 18 insertions, 0 deletions
diff --git a/libopie2/opiecore/oapplication.cpp b/libopie2/opiecore/oapplication.cpp
index 0ce61d8..0164957 100644
--- a/libopie2/opiecore/oapplication.cpp
+++ b/libopie2/opiecore/oapplication.cpp
@@ -30,8 +30,11 @@
#include <opie2/oapplication.h>
#include <opie2/oconfig.h>
#include <opie2/odebug.h>
+#include <qcopchannel_qws.h>
+
+
#include <signal.h>
#include <stdio.h>
using namespace Opie::Core;
@@ -100,8 +103,12 @@ void OApplication::init()
d = new Internal::OApplicationPrivate();
if ( !OApplication::_instance )
{
OApplication::_instance = this;
+
+ QCopChannel *chan = new QCopChannel("QPE/System", this, "OApplication System Channel");
+ connect(chan,SIGNAL(received(const QCString&,const QByteArray&)),
+ this,SIGNAL(systemMessageSignal(const QCString&,const QByteArray&)));
/* register SIGSEGV handler to give programs an option
* to exit gracefully, e.g. save or close devices or files.
struct sigaction sa;
diff --git a/libopie2/opiecore/oapplication.h b/libopie2/opiecore/oapplication.h
index d34e6b1..709d73a 100644
--- a/libopie2/opiecore/oapplication.h
+++ b/libopie2/opiecore/oapplication.h
@@ -100,8 +100,19 @@ class OApplication : public QPEApplication
* @param title the title. If not given, resets caption to appname
*/
virtual void setTitle( const QString& title = QString::null ) const;
+ signals:
+
+ /**
+ * Emit signals when messages are received on QPE/System
+ * QCOP Channel.
+ *
+ * @param msg The QCOP Message
+ * @param data The QCOP Data
+ */
+ void systemMessageSignal(const QCString& msg, const QByteArray& data);
+
protected:
void init();
private: