summaryrefslogtreecommitdiffstats
path: root/src/shared
diff options
context:
space:
mode:
authorsr2013-02-05 17:28:19 +0100
committersr2013-02-05 17:28:19 +0100
commit6f4fb557610beccb225a6bf3d46c0118b221bd99 (patch)
treefb2c7cb6cd7b09294fa3ca5cb7eef902bddac0e7 /src/shared
parent... (diff)
downloadpvs2-6f4fb557610beccb225a6bf3d46c0118b221bd99.tar.gz
pvs2-6f4fb557610beccb225a6bf3d46c0118b221bd99.tar.xz
pvs2-6f4fb557610beccb225a6bf3d46c0118b221bd99.zip
[SERVER] Implement all four VNC projection modes
Diffstat (limited to 'src/shared')
-rw-r--r--src/shared/networkmessage.cpp6
-rw-r--r--src/shared/networkmessage.h23
2 files changed, 18 insertions, 11 deletions
diff --git a/src/shared/networkmessage.cpp b/src/shared/networkmessage.cpp
index 9a7ba9f..f7972f0 100644
--- a/src/shared/networkmessage.cpp
+++ b/src/shared/networkmessage.cpp
@@ -190,7 +190,7 @@ bool NetworkMessage::parseMessage(char *buffer)
<< ") length > total remaining bytes (" << (_bufferSize - (ptr - buffer)) << ")";
return false;
}
- _fields.insert(QString::fromUtf8(ptr, keyLen), QByteArray(ptr + keyLen, valLen));
+ _fields.insert(QByteArray(ptr, keyLen), QByteArray(ptr + keyLen, valLen));
//qDebug() << "Got " << QString::fromUtf8(ptr, keyLen) << " -> " << QString::fromUtf8(ptr + keyLen, valLen);
ptr += keyLen + valLen;
}
@@ -260,9 +260,9 @@ void NetworkMessage::serializeMessage()
QByteArray buf;
//qDebug() << "Default size: " << buf.capacity();
buf.reserve(_lastBufferSize > 0 ? _lastBufferSize : 200);
- for (QHash<QString, QByteArray>::const_iterator it = _fields.begin(); it != _fields.end(); ++it)
+ for (QHash<QByteArray, QByteArray>::const_iterator it = _fields.begin(); it != _fields.end(); ++it)
{
- const QByteArray &ba = it.key().toUtf8();
+ const QByteArray &ba = it.key();
const QByteArray &val = it.value();
quint16 keyLen = _htons((quint16)ba.size());
quint16 valLen = _htons((quint16)val.size());
diff --git a/src/shared/networkmessage.h b/src/shared/networkmessage.h
index 5a8b2c2..0df51df 100644
--- a/src/shared/networkmessage.h
+++ b/src/shared/networkmessage.h
@@ -13,8 +13,8 @@
class QAbstractSocket;
class QUdpSocket;
-// define qstrings for message ids. this prevents implicit instanciation of the same qstrings over and over again
-#define MSGTYPE(name) static const QString _ ## name ( #name )
+// define QByteArrays for message ids. this prevents implicit instantiation of the same QByteArray over and over again
+#define MSGTYPE(name) static const QByteArray _ ## name ( #name )
MSGTYPE(ID);
MSGTYPE(IMG);
MSGTYPE(LOGIN);
@@ -31,14 +31,21 @@ MSGTYPE(IPLIST);
MSGTYPE(PORT);
MSGTYPE(CERT);
MSGTYPE(CHALLENGE);
+MSGTYPE(ENABLE);
MSGTYPE(ERROR);
+MSGTYPE(TUTOR);
+
+
+static const QByteArray __TRUE("1");
+static const QByteArray __FALSE("0");
+static const inline QByteArray& _BOOL(bool val) { if (val) return __TRUE; return __FALSE; }
class NetworkMessage
{
private:
char *_buffer;
quint32 _bufferSize, _bufferPos, _lastBufferSize;
- QHash<QString, QByteArray> _fields;
+ QHash<QByteArray, QByteArray> _fields;
int _mode; // 0 = none, 1 = reading, 2 = writing, 3 = read complete, 4 = write complete
void allocBuffer();
@@ -56,11 +63,11 @@ public:
void reset() { _fields.clear(); _bufferSize = 0; _mode = 0; }
const bool readComplete() const { return _mode == 3; }
const bool writeComplete() const { return _mode == 4; }
- const bool hasField(const QString& key) const { return _fields.contains(key); }
- const QString getFieldString(const QString& key) const { return QString::fromUtf8(_fields.value(key)); }
- const QByteArray getFieldBytes(const QString& key) const { return _fields.value(key); }
- void setField(const QString& key, const QByteArray& value) { if (_mode == 1 || _mode == 2) qFatal("setField called in bad state."); _fields.insert(key, value); _mode = 0; }
- void setField(const QString& key, const QString& value) { setField(key, value.toUtf8()); }
+ const bool hasField(const QByteArray& key) const { return _fields.contains(key); }
+ const QString getFieldString(const QByteArray& key) const { return QString::fromUtf8(_fields.value(key)); }
+ const QByteArray getFieldBytes(const QByteArray& key) const { return _fields.value(key); }
+ void setField(const QByteArray& key, const QByteArray& value) { if (_mode == 1 || _mode == 2) qFatal("setField called in bad state."); _fields.insert(key, value); _mode = 0; }
+ void setField(const QByteArray& key, const QString& value) { setField(key, value.toUtf8()); }
// Convenience
void buildErrorMessage(const QString& error);
void buildErrorMessage(const char* error);