From 0acf07023dca6b6d35c347cb28dce44a04363019 Mon Sep 17 00:00:00 2001 From: Jeremy Lainé Date: Fri, 13 Aug 2010 11:23:19 +0000 Subject: * don't initialise random number generator multiple times, breaks randomness * make QXmppStream easier to subclass, e.g. for a server --- src/QXmppStream.cpp | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) (limited to 'src/QXmppStream.cpp') diff --git a/src/QXmppStream.cpp b/src/QXmppStream.cpp index 2edcca6f..bdcd61c3 100644 --- a/src/QXmppStream.cpp +++ b/src/QXmppStream.cpp @@ -57,6 +57,7 @@ #include #include +static bool randomSeeded = false; static const QString capabilitiesNode = "http://code.google.com/p/qxmpp"; static const QByteArray streamRootElementEnd = ""; @@ -102,7 +103,11 @@ QXmppStream::QXmppStream(QSslSocket *socket, QObject *parent) d(new QXmppStreamPrivate) { // Make sure the random number generator is seeded - qsrand(QTime(0,0,0).secsTo(QTime::currentTime())); + if (!randomSeeded) + { + qsrand(QTime(0,0,0).secsTo(QTime::currentTime())); + randomSeeded = true; + } // initialise logger setLogger(QXmppLogger::getLogger()); @@ -807,12 +812,12 @@ void QXmppStream::handleStanza(const QDomElement &nodeRecv) } } -void QXmppStream::sendStartStream() +bool QXmppStream::sendStartStream() { QByteArray data = ""); - sendData(data); + return sendData(data); } bool QXmppStream::sendData(const QByteArray& packet) @@ -1003,9 +1008,9 @@ bool QXmppStream::sendPacket(const QXmppPacket& packet) return sendData(data); } -void QXmppStream::sendEndStream() +bool QXmppStream::sendEndStream() { - sendData(streamRootElementEnd); + return sendData(streamRootElementEnd); } void QXmppStream::pingStart() -- cgit v1.2.3