Move network and input handling to separate threads.
Add some debugging output.
This commit is contained in:
parent
5e035a4448
commit
daf7213a05
|
@ -25,28 +25,40 @@ ConsoleReader::ConsoleReader ( std::vector<Socket*> *sockets_vector )
|
|||
start();
|
||||
}
|
||||
|
||||
ConsoleReader::~ConsoleReader()
|
||||
{
|
||||
delete discoveryTimer;
|
||||
}
|
||||
|
||||
void ConsoleReader::run()
|
||||
{
|
||||
char command;
|
||||
QThread::sleep(1); // wait until sockets are discovered
|
||||
for ( unsigned i = 0; i < sockets->size(); ++i )
|
||||
{
|
||||
connect((*sockets)[i], &Socket::stateChanged, this, &ConsoleReader::listSockets);
|
||||
}
|
||||
listSockets();
|
||||
|
||||
std::string command;
|
||||
unsigned int number = 0;
|
||||
bool cont = true;
|
||||
|
||||
while ( cont )
|
||||
{
|
||||
std::cin >> command;
|
||||
switch ( command )
|
||||
switch ( command[0] )
|
||||
{
|
||||
case 'd':
|
||||
( *sockets ) [number]->tableData();
|
||||
(*sockets) [number]->tableData();
|
||||
break;
|
||||
case 'n':
|
||||
// std::cout << "Enter new name (max 16 characters)" << std::endl;
|
||||
// string name;
|
||||
// std::cin >> name;
|
||||
( *sockets ) [number]->changeSocketName();
|
||||
{
|
||||
command.erase(0,1);
|
||||
(*sockets) [number]->changeSocketName(QString::fromStdString(command));
|
||||
break;
|
||||
}
|
||||
case 'p':
|
||||
( *sockets ) [number]->toggle();
|
||||
(*sockets) [number]->toggle();
|
||||
break;
|
||||
case 'q':
|
||||
cont = false;
|
||||
|
@ -72,5 +84,5 @@ void ConsoleReader::listSockets()
|
|||
std::cout << "Socket Name: " << (*i)->name.toStdString() << "\t Remote Password: " << (*i)->remotePassword.toStdString() << std::endl;
|
||||
}
|
||||
std::cout << "___________________________________________________________________________\n" << std::endl;
|
||||
std::cout << "d - update table data\nn - change socket name\ns - pick another socket (default is 1)\np - toggle power state\nq - quit" << std::endl;
|
||||
std::cout << "d - update table data\nnName - change socket name to Name (max 16 characters)\ns - pick another socket (default is 1)\np - toggle power state\nq - quit" << std::endl;
|
||||
}
|
||||
|
|
|
@ -27,11 +27,13 @@ class ConsoleReader : public QThread
|
|||
{
|
||||
public:
|
||||
ConsoleReader ( std::vector<Socket*> *sockets_vector );
|
||||
void run ();
|
||||
~ConsoleReader();
|
||||
void run();
|
||||
void listSockets();
|
||||
|
||||
private:
|
||||
std::vector<Socket*> *sockets;
|
||||
QTimer *discoveryTimer;
|
||||
};
|
||||
|
||||
#endif /* CONSOLEREADER_H */
|
||||
|
|
9
main.cpp
9
main.cpp
|
@ -15,7 +15,6 @@
|
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>.*
|
||||
*************************************************************************/
|
||||
|
||||
#include <iostream>
|
||||
#include <vector>
|
||||
|
||||
#include "consolereader.h"
|
||||
|
@ -28,13 +27,7 @@ int main(int argc, char *argv[])
|
|||
std::vector<Socket*> *sockets = new std::vector<Socket*>;
|
||||
Server server(sockets);
|
||||
ConsoleReader *reader = new ConsoleReader(sockets);
|
||||
QThread::sleep(2);
|
||||
server.readPendingDatagrams();
|
||||
|
||||
for ( unsigned i = 0; i < sockets->size(); ++i )
|
||||
{
|
||||
QObject::connect((*sockets)[i], &Socket::stateChanged, reader, &ConsoleReader::listSockets);
|
||||
}
|
||||
|
||||
qWarning() << "event loop";
|
||||
return app.exec();
|
||||
}
|
||||
|
|
14
server.cpp
14
server.cpp
|
@ -15,7 +15,7 @@
|
|||
* along with this program. If not, see <http://www.gnu.org/licenses/>.*
|
||||
*************************************************************************/
|
||||
|
||||
#include <algorithm>
|
||||
#include <QUdpSocket>
|
||||
|
||||
#include "consolereader.h"
|
||||
#include "server.h"
|
||||
|
@ -33,7 +33,9 @@ Server::Server ( std::vector<Socket*> *sockets_vector )
|
|||
udpSocketSend->disconnectFromHost();
|
||||
delete udpSocketSend;
|
||||
|
||||
connect ( udpSocketGet, &QUdpSocket::readyRead, this, &Server::readPendingDatagrams );
|
||||
connect ( udpSocketGet, &QUdpSocket::readyRead, this, &Server::readPendingDatagrams);
|
||||
qWarning() << "starting server";
|
||||
start();
|
||||
}
|
||||
|
||||
Server::~Server()
|
||||
|
@ -41,8 +43,14 @@ Server::~Server()
|
|||
delete udpSocketGet;
|
||||
}
|
||||
|
||||
void Server::run()
|
||||
{
|
||||
readPendingDatagrams();
|
||||
}
|
||||
|
||||
void Server::readPendingDatagrams()
|
||||
{
|
||||
// qWarning () << "reading datagam";
|
||||
while ( udpSocketGet->hasPendingDatagrams() )
|
||||
{
|
||||
QByteArray reply;
|
||||
|
@ -67,12 +75,14 @@ void Server::readPendingDatagrams()
|
|||
}
|
||||
if ( !duplicate )
|
||||
{
|
||||
qWarning() << "Socket found";
|
||||
Socket *socket = new Socket ( sender, reply );
|
||||
sockets->push_back ( socket );
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
// qWarning() << "preparing to parse datagram";
|
||||
QByteArray mac = reply.mid(6,6);
|
||||
for ( std::vector<Socket*>::iterator i = sockets->begin() ; i != sockets->end(); ++i )
|
||||
{
|
||||
|
|
7
server.h
7
server.h
|
@ -18,9 +18,13 @@
|
|||
#ifndef SERVER_H
|
||||
#define SERVER_H
|
||||
|
||||
#include <QThread>
|
||||
|
||||
#include "socket.h"
|
||||
|
||||
class Server : public QObject
|
||||
class QUdpSocket;
|
||||
|
||||
class Server : public QThread
|
||||
{
|
||||
public:
|
||||
Server ( std::vector<Socket*> *sockets_vector );
|
||||
|
@ -28,6 +32,7 @@ public:
|
|||
|
||||
void discoverSockets ();
|
||||
void readPendingDatagrams();
|
||||
void run();
|
||||
|
||||
private:
|
||||
QByteArray discover = QByteArray::fromHex ( "68 64 00 06 71 61" );
|
||||
|
|
43
socket.cpp
43
socket.cpp
File diff suppressed because one or more lines are too long
10
socket.h
10
socket.h
|
@ -21,7 +21,8 @@
|
|||
#include <QByteArray>
|
||||
#include <QHostAddress>
|
||||
#include <QTimer>
|
||||
#include <QUdpSocket>
|
||||
|
||||
class QUdpSocket;
|
||||
|
||||
const QByteArray magicKey = QByteArray::fromHex ( "68 64" ); // recognize datagrams from the socket
|
||||
|
||||
|
@ -37,13 +38,13 @@ public:
|
|||
~Socket();
|
||||
void toggle();
|
||||
void tableData();
|
||||
void changeSocketName ( /*QString name*/ );
|
||||
void changeSocketName ( QString newName );
|
||||
bool parseReply ( QByteArray );
|
||||
|
||||
QHostAddress ip, localIP;
|
||||
QByteArray mac;
|
||||
bool powered;
|
||||
QString name, remotePassword;
|
||||
QByteArray name, remotePassword;
|
||||
|
||||
private:
|
||||
enum Datagram {Subscribe, PowerOff, PowerOn, TableData, SocketData, TimingData, WriteSocketData, MaxCommands};
|
||||
|
@ -55,6 +56,7 @@ private:
|
|||
QByteArray commandID[MaxCommands];
|
||||
QByteArray datagram[MaxCommands];
|
||||
QByteArray rmac; // Reveresed mac
|
||||
QByteArray versionID;
|
||||
QByteArray socketTableNumber, socketTableVersion, timingTableNumber, timingTableVersion;
|
||||
|
||||
const QByteArray twenties = QByteArray::fromHex ( "20 20 20 20 20 20" ); // mac address padding
|
||||
|
@ -63,8 +65,8 @@ private:
|
|||
const QByteArray one = QByteArray::fromHex ( "01" );
|
||||
|
||||
QUdpSocket *udpSocket;
|
||||
|
||||
QTimer *subscribeTimer;
|
||||
bool subscribed;
|
||||
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in New Issue