[Browser] Rework browser for improved stability & clarity

(cherry picked from commits 5c79e7106f, 57353cdfff, 15723adb9a, 01a5196a92, ed75563a94, 3839a2dcfd, 1fd16ba69c, 66283943c5, ba8613a179, 5b8f4f3e92, 35b771b19e, 043eb224e2, 05fac2f67d)
This commit is contained in:
Koncord 2018-08-05 07:20:12 +03:00 committed by David Cernat
parent 6498bcb22b
commit d03722b3f4
19 changed files with 191 additions and 85 deletions

View file

@ -54,6 +54,7 @@ MainWindow::MainWindow(QWidget *parent)
connect(tblServerBrowser, SIGNAL(doubleClicked(QModelIndex)), this, SLOT(play())); connect(tblServerBrowser, SIGNAL(doubleClicked(QModelIndex)), this, SLOT(play()));
connect(cBoxNotFull, SIGNAL(toggled(bool)), this, SLOT(notFullSwitch(bool))); connect(cBoxNotFull, SIGNAL(toggled(bool)), this, SLOT(notFullSwitch(bool)));
connect(cBoxWithPlayers, SIGNAL(toggled(bool)), this, SLOT(havePlayersSwitch(bool))); connect(cBoxWithPlayers, SIGNAL(toggled(bool)), this, SLOT(havePlayersSwitch(bool)));
connect(cBBoxWOPass, SIGNAL(toggled(bool)), this, SLOT(noPasswordSwitch(bool)));
connect(comboLatency, SIGNAL(currentIndexChanged(int)), this, SLOT(maxLatencyChanged(int))); connect(comboLatency, SIGNAL(currentIndexChanged(int)), this, SLOT(maxLatencyChanged(int)));
connect(leGamemode, SIGNAL(textChanged(const QString &)), this, SLOT(gamemodeChanged(const QString &))); connect(leGamemode, SIGNAL(textChanged(const QString &)), this, SLOT(gamemodeChanged(const QString &)));
loadFavorites(); loadFavorites();
@ -65,7 +66,7 @@ MainWindow::~MainWindow()
delete mGameInvoker; delete mGameInvoker;
} }
void MainWindow::addServerAndUpdate(QString addr) void MainWindow::addServerAndUpdate(const QString &addr)
{ {
favorites->insertRow(0); favorites->insertRow(0);
QModelIndex mi = favorites->index(0, ServerData::ADDR); QModelIndex mi = favorites->index(0, ServerData::ADDR);
@ -121,28 +122,26 @@ void MainWindow::play()
if (id < 0) if (id < 0)
return; return;
ServerInfoDialog infoDialog(this);
ServerModel *sm = ((ServerModel*)proxyModel->sourceModel()); ServerModel *sm = ((ServerModel*)proxyModel->sourceModel());
int sourceId = proxyModel->mapToSource(proxyModel->index(id, ServerData::ADDR)).row(); int sourceId = proxyModel->mapToSource(proxyModel->index(id, ServerData::ADDR)).row();
infoDialog.Server(sm->myData[sourceId].addr); ServerInfoDialog infoDialog(sm->myData[sourceId].addr, this);
if (!infoDialog.refresh())
{
queryHelper->refresh();
return;
}
if (!infoDialog.exec()) if (!infoDialog.exec())
return; return;
if (!infoDialog.isUpdated())
return;
QStringList arguments; QStringList arguments;
arguments.append(QLatin1String("--connect=") + sm->myData[sourceId].addr.toLatin1()); arguments.append(QLatin1String("--connect=") + sm->myData[sourceId].addr.toLatin1());
if (sm->myData[sourceId].GetPassword() == 1) if (sm->myData[sourceId].GetPassword() == 1)
{ {
bool ok; bool ok;
QString passw = QInputDialog::getText(this, "Connecting to: " + sm->myData[sourceId].addr, "Password: ", QLineEdit::Password, "", &ok); QString passw = QInputDialog::getText(this, tr("Connecting to: ") + sm->myData[sourceId].addr, tr("Password: "),
QLineEdit::Password, "", &ok);
if (!ok) if (!ok)
return; return;
arguments.append(QLatin1String("--password=") + passw.toLatin1()); arguments.append(QLatin1String("--password=") + passw.toLatin1());
@ -228,6 +227,11 @@ void MainWindow::havePlayersSwitch(bool state)
proxyModel->filterEmptyServers(state); proxyModel->filterEmptyServers(state);
} }
void MainWindow::noPasswordSwitch(bool state)
{
proxyModel->filterPassworded(state);
}
void MainWindow::maxLatencyChanged(int index) void MainWindow::maxLatencyChanged(int index)
{ {
int maxLatency = index * 50; int maxLatency = index * 50;

View file

@ -17,11 +17,11 @@ class MainWindow : public QMainWindow, private Ui::MainWindow
{ {
Q_OBJECT Q_OBJECT
public: public:
explicit MainWindow(QWidget *parent = 0); explicit MainWindow(QWidget *parent = nullptr);
virtual ~MainWindow(); ~MainWindow() override;
protected: protected:
void closeEvent(QCloseEvent * event) Q_DECL_OVERRIDE; void closeEvent(QCloseEvent * event) Q_DECL_OVERRIDE;
void addServerAndUpdate(QString addr); void addServerAndUpdate(const QString &addr);
protected slots: protected slots:
void tabSwitched(int index); void tabSwitched(int index);
void addServer(); void addServer();
@ -31,6 +31,7 @@ protected slots:
void serverSelected(); void serverSelected();
void notFullSwitch(bool state); void notFullSwitch(bool state);
void havePlayersSwitch(bool state); void havePlayersSwitch(bool state);
void noPasswordSwitch(bool state);
void maxLatencyChanged(int index); void maxLatencyChanged(int index);
void gamemodeChanged(const QString &text); void gamemodeChanged(const QString &text);
private: private:

View file

@ -6,6 +6,7 @@
#include "ServerModel.hpp" #include "ServerModel.hpp"
#include <qdebug.h> #include <qdebug.h>
#include <apps/browser/netutils/Utils.hpp>
bool MySortFilterProxyModel::filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const bool MySortFilterProxyModel::filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const
{ {
@ -13,26 +14,49 @@ bool MySortFilterProxyModel::filterAcceptsRow(int sourceRow, const QModelIndex &
QModelIndex pingIndex = sourceModel()->index(sourceRow, ServerData::PING, sourceParent); QModelIndex pingIndex = sourceModel()->index(sourceRow, ServerData::PING, sourceParent);
QModelIndex plIndex = sourceModel()->index(sourceRow, ServerData::PLAYERS, sourceParent); QModelIndex plIndex = sourceModel()->index(sourceRow, ServerData::PLAYERS, sourceParent);
QModelIndex maxPlIndex = sourceModel()->index(sourceRow, ServerData::MAX_PLAYERS, sourceParent); QModelIndex maxPlIndex = sourceModel()->index(sourceRow, ServerData::MAX_PLAYERS, sourceParent);
QModelIndex passwordIndex = sourceModel()->index(sourceRow, ServerData::PASSW, sourceParent);
int ping = sourceModel()->data(pingIndex).toInt(); bool pingOk;
int ping = sourceModel()->data(pingIndex).toInt(&pingOk);
int players = sourceModel()->data(plIndex).toInt(); int players = sourceModel()->data(plIndex).toInt();
int maxPlayers = sourceModel()->data(maxPlIndex).toInt(); int maxPlayers = sourceModel()->data(maxPlIndex).toInt();
if (maxPing > 0 && (ping == -1 || ping > maxPing)) if (maxPing > 0 && (ping == -1 || ping > maxPing || !pingOk))
return false; return false;
if (filterEmpty && players == 0) if (filterEmpty && players == 0)
return false; return false;
if (filterFull && players >= maxPlayers) if (filterFull && players >= maxPlayers)
return false; return false;
if(filterPasswEnabled && sourceModel()->data(passwordIndex).toString() == "Yes")
return false;
return QSortFilterProxyModel::filterAcceptsRow(sourceRow, sourceParent); return QSortFilterProxyModel::filterAcceptsRow(sourceRow, sourceParent);
} }
bool MySortFilterProxyModel::lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const
{
if(sortColumn() == ServerData::PING)
{
bool valid;
int pingright = sourceModel()->data(source_right).toInt(&valid);
pingright = valid ? pingright : PING_UNREACHABLE;
int pingleft = sourceModel()->data(source_left).toInt(&valid);
pingleft = valid ? pingleft : PING_UNREACHABLE;
return pingleft < pingright;
}
else
return QSortFilterProxyModel::lessThan(source_left, source_right);
}
MySortFilterProxyModel::MySortFilterProxyModel(QObject *parent) : QSortFilterProxyModel(parent) MySortFilterProxyModel::MySortFilterProxyModel(QObject *parent) : QSortFilterProxyModel(parent)
{ {
filterEmpty = false; filterEmpty = false;
filterFull = false; filterFull = false;
filterPasswEnabled = false;
maxPing = 0; maxPing = 0;
setSortCaseSensitivity(Qt::CaseSensitivity::CaseInsensitive);
} }
void MySortFilterProxyModel::filterEmptyServers(bool state) void MySortFilterProxyModel::filterEmptyServers(bool state)
@ -52,3 +76,9 @@ void MySortFilterProxyModel::pingLessThan(int maxPing)
this->maxPing = maxPing; this->maxPing = maxPing;
invalidateFilter(); invalidateFilter();
} }
void MySortFilterProxyModel::filterPassworded(bool state)
{
filterPasswEnabled = state;
invalidateFilter();
}

View file

@ -13,13 +13,15 @@ class MySortFilterProxyModel : public QSortFilterProxyModel
Q_OBJECT Q_OBJECT
protected: protected:
bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const Q_DECL_FINAL; bool filterAcceptsRow(int sourceRow, const QModelIndex &sourceParent) const Q_DECL_FINAL;
bool lessThan(const QModelIndex &source_left, const QModelIndex &source_right) const Q_DECL_FINAL;
public: public:
MySortFilterProxyModel(QObject *parent); explicit MySortFilterProxyModel(QObject *parent);
void filterFullServer(bool state); void filterFullServer(bool state);
void filterEmptyServers(bool state); void filterEmptyServers(bool state);
void filterPassworded(bool state);
void pingLessThan(int maxPing); void pingLessThan(int maxPing);
private: private:
bool filterEmpty, filterFull; bool filterEmpty, filterFull, filterPasswEnabled;
int maxPing; int maxPing;
}; };

View file

@ -7,13 +7,19 @@
#include <QDebug> #include <QDebug>
#include "PingUpdater.hpp" #include "PingUpdater.hpp"
void PingHelper::Add(int row, AddrPair addrPair) void PingHelper::Add(int row, const AddrPair &addrPair)
{ {
pingUpdater->addServer(row, addrPair); pingUpdater->addServer(row, addrPair);
if (!pingThread->isRunning()) if (!pingThread->isRunning())
pingThread->start(); pingThread->start();
} }
void PingHelper::Reset()
{
//if (pingThread->isRunning())
Stop();
}
void PingHelper::Stop() void PingHelper::Stop()
{ {
emit pingUpdater->stop(); emit pingUpdater->stop();
@ -35,9 +41,8 @@ PingHelper &PingHelper::Get()
return helper; return helper;
} }
PingHelper::PingHelper() PingHelper::PingHelper() : QObject()
{ {
QObject();
pingThread = new QThread; pingThread = new QThread;
pingUpdater = new PingUpdater; pingUpdater = new PingUpdater;
pingUpdater->moveToThread(pingThread); pingUpdater->moveToThread(pingThread);
@ -48,11 +53,4 @@ PingHelper::PingHelper()
connect(this, SIGNAL(stop()), pingUpdater, SLOT(stop())); connect(this, SIGNAL(stop()), pingUpdater, SLOT(stop()));
//connect(pingUpdater, SIGNAL(finished()), pingUpdater, SLOT(deleteLater())); //connect(pingUpdater, SIGNAL(finished()), pingUpdater, SLOT(deleteLater()));
connect(pingUpdater, SIGNAL(updateModel(int, unsigned)), this, SLOT(update(int, unsigned))); connect(pingUpdater, SIGNAL(updateModel(int, unsigned)), this, SLOT(update(int, unsigned)));
}
PingHelper::~PingHelper()
{
} }

View file

@ -17,17 +17,17 @@ class PingHelper : public QObject
Q_OBJECT Q_OBJECT
public: public:
void Add(int row, AddrPair addrPair); void Reset();
void Add(int row, const AddrPair &addrPair);
void Stop(); void Stop();
void SetModel(QAbstractTableModel *model); void SetModel(QAbstractTableModel *model);
//void UpdateImmedialy(PingUpdater::AddrPair addrPair); //void UpdateImmedialy(PingUpdater::AddrPair addrPair);
static PingHelper &Get(); static PingHelper &Get();
private:
PingHelper();
~PingHelper();
PingHelper(const PingHelper&) = delete; PingHelper(const PingHelper&) = delete;
PingHelper& operator=(const PingHelper&) = delete; PingHelper& operator=(const PingHelper&) = delete;
private:
PingHelper();
signals: signals:
void stop(); void stop();
public slots: public slots:

View file

@ -14,7 +14,7 @@ void PingUpdater::stop()
run = false; run = false;
} }
void PingUpdater::addServer(int row, AddrPair addr) void PingUpdater::addServer(int row, const AddrPair &addr)
{ {
servers.push_back({row, addr}); servers.push_back({row, addr});
run = true; run = true;
@ -42,7 +42,7 @@ void PingUpdater::process()
unsigned ping = PingRakNetServer(server.second.first.toLatin1(), server.second.second); unsigned ping = PingRakNetServer(server.second.first.toLatin1(), server.second.second);
qDebug() << "Pong from" << server.second.first + "|" + QString::number(server.second.second) qDebug() << "Pong from" << server.second.first + "|" + QString::number(server.second.second)
<< ":" << ping << "ms"; << ":" << ping << "ms" << "Sizeof servers: " << servers.size();
emit updateModel(server.first, ping); emit updateModel(server.first, ping);
} }

View file

@ -14,7 +14,7 @@ class PingUpdater : public QObject
{ {
Q_OBJECT Q_OBJECT
public: public:
void addServer(int row, AddrPair addrPair); void addServer(int row, const AddrPair &addrPair);
public slots: public slots:
void stop(); void stop();
void process(); void process();

View file

@ -19,8 +19,8 @@ QueryHelper::QueryHelper(QAbstractItemModel *model)
connect(queryThread, SIGNAL(started()), queryUpdate, SLOT(process())); connect(queryThread, SIGNAL(started()), queryUpdate, SLOT(process()));
connect(queryUpdate, SIGNAL(finished()), queryThread, SLOT(quit())); connect(queryUpdate, SIGNAL(finished()), queryThread, SLOT(quit()));
connect(queryUpdate, &QueryUpdate::finished, [this](){emit finished();}); connect(queryUpdate, &QueryUpdate::finished, [this](){emit finished();});
connect(queryUpdate, SIGNAL(updateModel(QString, unsigned short, QueryData)), connect(queryUpdate, SIGNAL(updateModel(const QString&, unsigned short, const QueryData&)),
this, SLOT(update(QString, unsigned short, QueryData))); this, SLOT(update(const QString&, unsigned short, const QueryData&)));
queryUpdate->moveToThread(queryThread); queryUpdate->moveToThread(queryThread);
} }
@ -29,6 +29,7 @@ void QueryHelper::refresh()
if (!queryThread->isRunning()) if (!queryThread->isRunning())
{ {
_model->removeRows(0, _model->rowCount()); _model->removeRows(0, _model->rowCount());
PingHelper::Get().Stop();
queryThread->start(); queryThread->start();
emit started(); emit started();
} }
@ -39,7 +40,7 @@ void QueryHelper::terminate()
queryThread->terminate(); queryThread->terminate();
} }
void QueryHelper::update(QString addr, unsigned short port, QueryData data) void QueryHelper::update(const QString &addr, unsigned short port, const QueryData& data)
{ {
ServerModel *model = ((ServerModel*)_model); ServerModel *model = ((ServerModel*)_model);
model->insertRow(model->rowCount()); model->insertRow(model->rowCount());
@ -80,7 +81,7 @@ void QueryUpdate::process()
return; return;
} }
for (auto server : data) for (const auto &server : data)
emit updateModel(server.first.ToString(false), server.first.GetPort(), server.second); emit updateModel(server.first.ToString(false), server.first.GetPort(), server.second);
emit finished(); emit finished();
} }

View file

@ -23,7 +23,7 @@ public slots:
void refresh(); void refresh();
void terminate(); void terminate();
private slots: private slots:
void update(QString addr, unsigned short port, QueryData data); void update(const QString &addr, unsigned short port, const QueryData& data);
signals: signals:
void finished(); void finished();
void started(); void started();
@ -38,7 +38,7 @@ class QueryUpdate : public QObject
Q_OBJECT Q_OBJECT
signals: signals:
void finished(); void finished();
void updateModel(QString addr, unsigned short port, QueryData data); void updateModel(const QString &addr, unsigned short port, const QueryData& data);
public slots: public slots:
void process(); void process();
}; };

View file

@ -6,32 +6,65 @@
#include "qdebug.h" #include "qdebug.h"
#include "ServerInfoDialog.hpp" #include "ServerInfoDialog.hpp"
#include <apps/browser/netutils/Utils.hpp>
#include <algorithm> #include <algorithm>
#include <utility>
#include <QThread>
using namespace std; using namespace std;
using namespace RakNet; using namespace RakNet;
ServerInfoDialog::ServerInfoDialog(QWidget *parent): QDialog(parent) ThrWorker::ThrWorker(ServerInfoDialog *dialog, QString addr, unsigned short port): addr(std::move(addr)), port(port), stopped(false)
{
this->dialog = dialog;
}
void ThrWorker::process()
{
stopped = false;
auto newSD = QueryClient::Get().Update(SystemAddress(addr.toUtf8(), port));
if (dialog != nullptr)
dialog->setData(newSD);
stopped = true;
emit finished();
}
ServerInfoDialog::ServerInfoDialog(const QString &addr, QWidget *parent): QDialog(parent)
{ {
setupUi(this); setupUi(this);
connect(btnRefresh, SIGNAL(clicked()), this, SLOT(refresh())); refreshThread = new QThread;
QStringList list = addr.split(':');
worker = new ThrWorker(this, list[0].toLatin1(), list[1].toUShort());
worker->moveToThread(refreshThread);
connect(refreshThread, SIGNAL(started()), worker, SLOT(process()));
connect(worker, SIGNAL(finished()), refreshThread, SLOT(quit()));
connect(refreshThread, SIGNAL(finished()), this, SLOT(refresh()));
connect(btnRefresh, &QPushButton::clicked, [this]{
if (!refreshThread->isRunning())
refreshThread->start();
});
} }
ServerInfoDialog::~ServerInfoDialog() ServerInfoDialog::~ServerInfoDialog()
{ {
worker->dialog = nullptr;
if (!refreshThread->isRunning())
refreshThread->terminate();
} }
void ServerInfoDialog::Server(QString addr) bool ServerInfoDialog::isUpdated()
{ {
this->addr = addr; return sd.first != UNASSIGNED_SYSTEM_ADDRESS;
} }
bool ServerInfoDialog::refresh() void ServerInfoDialog::setData(std::pair<RakNet::SystemAddress, QueryData> &newSD)
{
sd = newSD;
}
void ServerInfoDialog::refresh()
{ {
QStringList list = addr.split(':');
auto sd = QueryClient::Get().Update(SystemAddress(list[0].toLatin1(), list[1].toUShort()));
if (sd.first != UNASSIGNED_SYSTEM_ADDRESS) if (sd.first != UNASSIGNED_SYSTEM_ADDRESS)
{ {
leAddr->setText(sd.first.ToString(true, ':')); leAddr->setText(sd.first.ToString(true, ':'));
@ -41,17 +74,16 @@ bool ServerInfoDialog::refresh()
btnConnect->setDisabled(ping == PING_UNREACHABLE); btnConnect->setDisabled(ping == PING_UNREACHABLE);
listPlayers->clear(); listPlayers->clear();
for (const auto &player : sd.second.players)
for (auto player : sd.second.players)
listPlayers->addItem(QString::fromStdString(player)); listPlayers->addItem(QString::fromStdString(player));
listPlugins->clear(); listPlugins->clear();
for (auto plugin : sd.second.plugins) for (const auto &plugin : sd.second.plugins)
listPlugins->addItem(QString::fromStdString(plugin.name)); listPlugins->addItem(QString::fromStdString(plugin.name));
listRules->clear(); listRules->clear();
const static vector<std::string> defaultRules {"gamemode", "maxPlayers", "name", "passw", "players", "version"}; const static vector<std::string> defaultRules {"gamemode", "maxPlayers", "name", "passw", "players", "version"};
for (auto rule : sd.second.rules) for (auto &rule : sd.second.rules)
{ {
if (::find(defaultRules.begin(), defaultRules.end(), rule.first) != defaultRules.end()) if (::find(defaultRules.begin(), defaultRules.end(), rule.first) != defaultRules.end())
continue; continue;
@ -64,7 +96,12 @@ bool ServerInfoDialog::refresh()
} }
lblPlayers->setText(QString::number(sd.second.players.size()) + " / " + QString::number(sd.second.GetMaxPlayers())); lblPlayers->setText(QString::number(sd.second.players.size()) + " / " + QString::number(sd.second.GetMaxPlayers()));
return true;
} }
return false; }
int ServerInfoDialog::exec()
{
if (!refreshThread->isRunning())
refreshThread->start();
return QDialog::exec();
} }

View file

@ -6,18 +6,45 @@
#define NEWLAUNCHER_SERVERINFODIALOG_HPP #define NEWLAUNCHER_SERVERINFODIALOG_HPP
#include "ui_ServerInfo.h" #include "ui_ServerInfo.h"
#include <apps/browser/netutils/Utils.hpp>
#include <RakNetTypes.h>
#include <components/openmw-mp/Master/MasterData.hpp>
class ThrWorker;
class ServerInfoDialog : public QDialog, public Ui::Dialog class ServerInfoDialog : public QDialog, public Ui::Dialog
{ {
Q_OBJECT Q_OBJECT
public: public:
explicit ServerInfoDialog(QWidget *parent = 0); explicit ServerInfoDialog(const QString &addr, QWidget *parent = nullptr);
virtual ~ServerInfoDialog(); ~ServerInfoDialog() override;
void Server(QString addr); bool isUpdated();
void setData(std::pair<RakNet::SystemAddress, QueryData> &newSD);
public slots: public slots:
bool refresh(); void refresh();
int exec() Q_DECL_OVERRIDE;
private:
QThread *refreshThread;
ThrWorker* worker;
std::pair<RakNet::SystemAddress, QueryData> sd;
};
class ThrWorker: public QObject
{
friend class ServerInfoDialog;
Q_OBJECT
public:
ThrWorker(ServerInfoDialog *dialog, QString addr, unsigned short port);
public slots:
void process();
signals:
void finished();
private: private:
QString addr; QString addr;
unsigned short port;
bool stopped;
ServerInfoDialog *dialog;
}; };

View file

@ -1,16 +1,11 @@
#include <qmessagebox.h> #include <qmessagebox.h>
#include "ServerModel.hpp" #include "ServerModel.hpp"
#include <qdebug.h> #include <qdebug.h>
#include <apps/browser/netutils/Utils.hpp>
ServerModel::ServerModel(QObject *parent) : QAbstractTableModel(parent) ServerModel::ServerModel(QObject *parent) : QAbstractTableModel(parent)
{ {
} }
ServerModel::~ServerModel()
{
}
/*QHash<int, QByteArray> ServerModel::roleNames() const /*QHash<int, QByteArray> ServerModel::roleNames() const
{ {
return roles; return roles;
@ -49,7 +44,7 @@ QVariant ServerModel::data(const QModelIndex &index, int role) const
var = QString(sd.rules.at("name").str.c_str()); var = QString(sd.rules.at("name").str.c_str());
break; break;
case ServerData::PING: case ServerData::PING:
var = sd.ping; var = sd.ping == PING_UNREACHABLE ? QVariant("Unreachable") : sd.ping;
break; break;
case ServerData::MODNAME: case ServerData::MODNAME:
if (sd.rules.at("gamemode").str == "") if (sd.rules.at("gamemode").str == "")
@ -136,7 +131,7 @@ bool ServerModel::setData(const QModelIndex &index, const QVariant &value, int r
sd.SetPassword(value.toBool()); sd.SetPassword(value.toBool());
break; break;
case ServerData::VERSION: case ServerData::VERSION:
sd.SetVersion(value.toString().toLatin1()); sd.SetVersion(value.toString().toUtf8());
ok = !sd.addr.isEmpty(); ok = !sd.addr.isEmpty();
break; break;
case ServerData::PLAYERS: case ServerData::PLAYERS:
@ -146,14 +141,14 @@ bool ServerModel::setData(const QModelIndex &index, const QVariant &value, int r
sd.SetMaxPlayers(value.toInt(&ok)); sd.SetMaxPlayers(value.toInt(&ok));
break; break;
case ServerData::HOSTNAME: case ServerData::HOSTNAME:
sd.SetName(value.toString().toLatin1()); sd.SetName(value.toString().toUtf8());
ok = !sd.addr.isEmpty(); ok = !sd.addr.isEmpty();
break; break;
case ServerData::PING: case ServerData::PING:
sd.ping = value.toInt(&ok); sd.ping = value.toInt(&ok);
break; break;
case ServerData::MODNAME: case ServerData::MODNAME:
sd.SetGameMode(value.toString().toLatin1()); sd.SetGameMode(value.toString().toUtf8());
break; break;
default: default:
return false; return false;
@ -170,9 +165,7 @@ bool ServerModel::insertRows(int position, int count, const QModelIndex &index)
Q_UNUSED(index); Q_UNUSED(index);
beginInsertRows(QModelIndex(), position, position + count - 1); beginInsertRows(QModelIndex(), position, position + count - 1);
for (int row = 0; row < count; ++row) { myData.insert(position, count, {});
myData.insert(position, {});
}
endInsertRows(); endInsertRows();
return true; return true;

View file

@ -29,8 +29,7 @@ class ServerModel: public QAbstractTableModel
{ {
Q_OBJECT Q_OBJECT
public: public:
explicit ServerModel(QObject *parent = 0); explicit ServerModel(QObject *parent = nullptr);
~ServerModel();
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const Q_DECL_FINAL; QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const Q_DECL_FINAL;
int rowCount(const QModelIndex &parent = QModelIndex()) const Q_DECL_FINAL; int rowCount(const QModelIndex &parent = QModelIndex()) const Q_DECL_FINAL;
int columnCount(const QModelIndex &parent) const Q_DECL_FINAL; int columnCount(const QModelIndex &parent) const Q_DECL_FINAL;

View file

@ -30,7 +30,7 @@ QueryClient::~QueryClient()
RakPeerInterface::DestroyInstance(peer); RakPeerInterface::DestroyInstance(peer);
} }
void QueryClient::SetServer(std::string addr, unsigned short port) void QueryClient::SetServer(const string &addr, unsigned short port)
{ {
masterAddr = SystemAddress(addr.c_str(), port); masterAddr = SystemAddress(addr.c_str(), port);
} }
@ -83,7 +83,7 @@ map<SystemAddress, QueryData> QueryClient::Query()
return query; return query;
} }
pair<SystemAddress, QueryData> QueryClient::Update(RakNet::SystemAddress addr) pair<SystemAddress, QueryData> QueryClient::Update(const RakNet::SystemAddress &addr)
{ {
qDebug() << "Locking mutex in QueryClient::Update(RakNet::SystemAddress addr)"; qDebug() << "Locking mutex in QueryClient::Update(RakNet::SystemAddress addr)";
pair<SystemAddress, QueryData> server; pair<SystemAddress, QueryData> server;
@ -179,7 +179,7 @@ ConnectionState QueryClient::Connect()
{ {
ConnectionAttemptResult car = peer->Connect(masterAddr.ToString(false), masterAddr.GetPort(), TES3MP_MASTERSERVER_PASSW, ConnectionAttemptResult car = peer->Connect(masterAddr.ToString(false), masterAddr.GetPort(), TES3MP_MASTERSERVER_PASSW,
strlen(TES3MP_MASTERSERVER_PASSW), 0, 0, 5, 500); strlen(TES3MP_MASTERSERVER_PASSW), nullptr, 0, 5, 500);
while (true) while (true)
{ {

View file

@ -14,16 +14,16 @@
class QueryClient class QueryClient
{ {
private: public:
QueryClient(QueryClient const &) = delete; QueryClient(QueryClient const &) = delete;
QueryClient(QueryClient &&) = delete; QueryClient(QueryClient &&) = delete;
QueryClient &operator=(QueryClient const &) = delete; QueryClient &operator=(QueryClient const &) = delete;
QueryClient &operator=(QueryClient &&) = delete; QueryClient &operator=(QueryClient &&) = delete;
public:
static QueryClient &Get(); static QueryClient &Get();
void SetServer(std::string addr, unsigned short port); void SetServer(const std::string &addr, unsigned short port);
std::map<RakNet::SystemAddress, QueryData> Query(); std::map<RakNet::SystemAddress, QueryData> Query();
std::pair<RakNet::SystemAddress, QueryData> Update(RakNet::SystemAddress addr); std::pair<RakNet::SystemAddress, QueryData> Update(const RakNet::SystemAddress &addr);
int Status(); int Status();
private: private:
RakNet::ConnectionState Connect(); RakNet::ConnectionState Connect();

View file

@ -44,12 +44,16 @@ unsigned int PingRakNetServer(const char *addr, unsigned short port)
break; break;
case ID_CONNECTED_PING: case ID_CONNECTED_PING:
case ID_UNCONNECTED_PONG: case ID_UNCONNECTED_PONG:
{
RakNet::BitStream bsIn(&packet->data[1], packet->length, false); RakNet::BitStream bsIn(&packet->data[1], packet->length, false);
bsIn.Read(time); bsIn.Read(time);
time = now - time; time = now - time;
done = true; done = true;
break; break;
} }
default:
break;
}
peer->DeallocatePacket(packet); peer->DeallocatePacket(packet);
} }
@ -69,9 +73,9 @@ ServerExtendedData getExtendedData(const char *addr, unsigned short port)
sstr << TES3MP_VERSION; sstr << TES3MP_VERSION;
sstr << TES3MP_PROTO_VERSION; sstr << TES3MP_PROTO_VERSION;
std::string msg = ""; std::string msg;
if (peer->Connect(addr, port, sstr.str().c_str(), (int)(sstr.str().size()), 0, 0, 3, 500, 0) != RakNet::CONNECTION_ATTEMPT_STARTED) if (peer->Connect(addr, port, sstr.str().c_str(), (int)(sstr.str().size()), nullptr, 0, 3, 500, 0) != RakNet::CONNECTION_ATTEMPT_STARTED)
msg = "Connection attempt failed.\n"; msg = "Connection attempt failed.\n";
@ -142,14 +146,14 @@ ServerExtendedData getExtendedData(const char *addr, unsigned short port)
{ {
RakNet::RakString str; RakNet::RakString str;
bs.Read(str); bs.Read(str);
data.players.push_back(str.C_String()); data.players.emplace_back(str.C_String());
} }
bs.Read(length); bs.Read(length);
for (size_t i = 0; i < length; i++) for (size_t i = 0; i < length; i++)
{ {
RakNet::RakString str; RakNet::RakString str;
bs.Read(str); bs.Read(str);
data.plugins.push_back(str.C_String()); data.plugins.emplace_back(str.C_String());
} }
done = true; done = true;
} }

View file

@ -166,6 +166,13 @@
</property> </property>
</widget> </widget>
</item> </item>
<item>
<widget class="QCheckBox" name="cBBoxWOPass">
<property name="text">
<string>No password</string>
</property>
</widget>
</item>
<item> <item>
<spacer name="horizontalSpacer"> <spacer name="horizontalSpacer">
<property name="orientation"> <property name="orientation">

View file

@ -207,6 +207,9 @@
</item> </item>
<item> <item>
<widget class="QPushButton" name="btnConnect"> <widget class="QPushButton" name="btnConnect">
<property name="enabled">
<bool>false</bool>
</property>
<property name="text"> <property name="text">
<string>Connect</string> <string>Connect</string>
</property> </property>