diff options
author | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
---|---|---|
committer | toma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da> | 2009-11-25 17:56:58 +0000 |
commit | bcb704366cb5e333a626c18c308c7e0448a8e69f (patch) | |
tree | f0d6ab7d78ecdd9207cf46536376b44b91a1ca71 /kopete/protocols/testbed/testbedfakeserver.cpp | |
download | tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.tar.gz tdenetwork-bcb704366cb5e333a626c18c308c7e0448a8e69f.zip |
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923
git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdenetwork@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kopete/protocols/testbed/testbedfakeserver.cpp')
-rw-r--r-- | kopete/protocols/testbed/testbedfakeserver.cpp | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/kopete/protocols/testbed/testbedfakeserver.cpp b/kopete/protocols/testbed/testbedfakeserver.cpp new file mode 100644 index 00000000..b1bb3e1e --- /dev/null +++ b/kopete/protocols/testbed/testbedfakeserver.cpp @@ -0,0 +1,64 @@ +/* + testbedfakeserver.cpp - Kopete Testbed Protocol + + Copyright (c) 2003 by Will Stephenson <[email protected]> + Kopete (c) 2002-2003 by the Kopete developers <[email protected]> + + ************************************************************************* + * * + * This library is free software; you can redistribute it and/or * + * modify it under the terms of the GNU General Public * + * License as published by the Free Software Foundation; either * + * version 2 of the License, or (at your option) any later version. * + * * + ************************************************************************* +*/ + +#include "testbedfakeserver.h" +#include <qtimer.h> +#include <kdebug.h> +#include "testbedincomingmessage.h" + + +TestbedFakeServer::TestbedFakeServer() +{ + m_incomingMessages.setAutoDelete( true ); +} + +TestbedFakeServer::~TestbedFakeServer() +{ +} + +void TestbedFakeServer::sendMessage( QString contactId, QString message ) +{ + // see what contact the message is for + // if it's for Echo, respond immediately + kdDebug( 14210 ) << k_funcinfo << "Message for: " << contactId << ", is: " << message << endl; + kdDebug( 14210 ) << "recipient is echo, coming back at you." << endl; + // put the message in a map and start a timer to tell it to deliver itself. + //emit messageReceived( QString::fromLatin1( "echo: " ) + message ); + QString messageId = contactId + QString::fromLatin1(": "); + TestbedIncomingMessage* msg = new TestbedIncomingMessage( this, messageId + message ); + m_incomingMessages.append( msg ); + QTimer::singleShot( 1000, msg, SLOT( deliver() ) ); + + // This removes any delivered messages + purgeMessages(); +} + +void TestbedFakeServer::incomingMessage( QString message ) +{ + emit messageReceived( message ); +} + +void TestbedFakeServer::purgeMessages() +{ + TestbedIncomingMessage* msg; + for ( msg = m_incomingMessages.first(); msg; msg = m_incomingMessages.next() ) + { + if ( msg->delivered() ) + m_incomingMessages.remove(); + } +} + +#include "testbedfakeserver.moc" |