Added Q Object macros.
This commit is contained in:
parent
2aea4f96f5
commit
87e9d4aa8b
|
@ -8,7 +8,7 @@ bool Competitor::setCompetitor(const QJsonObject &competitor) {
|
||||||
throw invalid_argument("Not a competitor object.");
|
throw invalid_argument("Not a competitor object.");
|
||||||
}
|
}
|
||||||
|
|
||||||
this->code = competitor["code"].toString();
|
this->code = competitor["code"].toInt();
|
||||||
this->name = competitor["name"].toString();
|
this->name = competitor["name"].toString();
|
||||||
this->noc = competitor["noc"].toString();
|
this->noc = competitor["noc"].toString();
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -5,13 +5,26 @@
|
||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QMap>
|
#include <QMap>
|
||||||
#include <QJsonObject>
|
#include <QJsonObject>
|
||||||
|
#include <QAbstractListModel>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
class Competitor {
|
class Competitor {
|
||||||
|
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
Q_PROPERTY(int code READ code)
|
||||||
|
Q_PROPERTY(QString name READ name)
|
||||||
|
Q_PROPERTY(QString noc READ noc)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
Competitor() {
|
||||||
|
this->code = 0;
|
||||||
|
this->name = "na";
|
||||||
|
this->noc = "---";
|
||||||
|
}
|
||||||
|
|
||||||
Competitor(const Competitor &competitor) {
|
Competitor(const Competitor &competitor) {
|
||||||
this->code = competitor.code;
|
this->code = competitor.code;
|
||||||
this->name = competitor.name;
|
this->name = competitor.name;
|
||||||
|
@ -22,14 +35,14 @@ public:
|
||||||
setCompetitor(competitor);
|
setCompetitor(competitor);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString getCode() { return this->code; }
|
int getCode() { return this->code; }
|
||||||
QString getName() { return this->name; }
|
QString getName() { return this->name; }
|
||||||
QString getNOC() { return this->noc; }
|
QString getNOC() { return this->noc; }
|
||||||
|
|
||||||
bool setCompetitor(const QJsonObject &competitor);
|
bool setCompetitor(const QJsonObject &competitor);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QString code;
|
int code;
|
||||||
QString name;
|
QString name;
|
||||||
QString noc;
|
QString noc;
|
||||||
|
|
||||||
|
|
|
@ -1,15 +1,46 @@
|
||||||
|
|
||||||
#include "CompetitorWithResults.h"
|
#include "CompetitorWithResults.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Replaces/sets the results of a competitor.
|
||||||
|
*
|
||||||
|
* @param results The results of the competitor.
|
||||||
|
* @return True, if successful.
|
||||||
|
*/
|
||||||
bool CompetitorWithResults::setResults(const QJsonObject &results) {
|
bool CompetitorWithResults::setResults(const QJsonObject &results) {
|
||||||
if (!results.contains("mark")
|
if (!results.contains("mark")
|
||||||
|| !results.contains("medalType")) {
|
|| !results.contains("medalType")) {
|
||||||
throw invalid_argument("Results object of competitor is incomplete.");
|
throw invalid_argument("Results object of competitor is incomplete.");
|
||||||
}
|
}
|
||||||
|
|
||||||
this->results = {
|
this->mark = results["mark"].toString();
|
||||||
{QString("mark"), results["mark"].toString()},
|
this->medalType = results["medalType"].toString();
|
||||||
{QString("medalType"), results["medalType"].toString()}
|
|
||||||
};
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Static compare method, which can compare the result times or points of two CompetitorsWithResult.
|
||||||
|
* Returns true, if the left competitor (lComp) got a real lesser score than the right competitor (rComp).
|
||||||
|
*
|
||||||
|
* @param lComp First competitor to compare.
|
||||||
|
* @param rComp Second competitor to compare.
|
||||||
|
* @return True, if the second competitor got a higher score.
|
||||||
|
*/
|
||||||
|
bool CompetitorWithResults::compare(CompetitorWithResults lComp, CompetitorWithResults rComp) {
|
||||||
|
QString l = lComp.getMark();
|
||||||
|
QString r = rComp.getMark();
|
||||||
|
|
||||||
|
// check if values are numerical (-> not time values)
|
||||||
|
if (!l.contains(":") || !r.contains(":")) {
|
||||||
|
return l.toFloat() < r.toFloat();
|
||||||
|
}
|
||||||
|
|
||||||
|
// compare time values if not numerical
|
||||||
|
QString lTime(""), rTime("");
|
||||||
|
|
||||||
|
for (QChar c : l) if (c.isDigit()) lTime.append(c);
|
||||||
|
for (QChar c : r) if (c.isDigit()) rTime.append(c);
|
||||||
|
|
||||||
|
return lTime.compare(rTime) < 0;
|
||||||
|
}
|
||||||
|
|
|
@ -6,11 +6,27 @@
|
||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QMap>
|
#include <QMap>
|
||||||
#include <QJsonObject>
|
#include <QJsonObject>
|
||||||
|
#include <QAbstractListModel>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
class CompetitorWithResults : public Competitor {
|
class CompetitorWithResults : public Competitor {
|
||||||
|
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
Q_PROPERTY(QString mark READ mark)
|
||||||
|
Q_PROPERTY(QString medalType READ medalType)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
CompetitorWithResults() : Competitor() {
|
||||||
|
this->mark = "-";
|
||||||
|
this->medalType = "-";
|
||||||
|
}
|
||||||
|
|
||||||
|
CompetitorWithResults(const CompetitorWithResults &competitor) : Competitor(competitor) {
|
||||||
|
this->mark = competitor.mark;
|
||||||
|
this->medalType = competitor.medalType;
|
||||||
|
}
|
||||||
|
|
||||||
CompetitorWithResults(const QJsonObject &competitor) : Competitor(competitor) {
|
CompetitorWithResults(const QJsonObject &competitor) : Competitor(competitor) {
|
||||||
if (!competitor.contains("results")) throw invalid_argument("Competitor does not contain results.");
|
if (!competitor.contains("results")) throw invalid_argument("Competitor does not contain results.");
|
||||||
QJsonObject results = competitor["results"].toObject();
|
QJsonObject results = competitor["results"].toObject();
|
||||||
|
@ -19,8 +35,14 @@ public:
|
||||||
|
|
||||||
bool setResults(const QJsonObject &results);
|
bool setResults(const QJsonObject &results);
|
||||||
|
|
||||||
|
QString getMark() { return this->mark; }
|
||||||
|
QString getMedalType() { return this->medalType; }
|
||||||
|
|
||||||
|
static bool compare(CompetitorWithResults lComp, CompetitorWithResults rComp);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QMap<QString, QString> results;
|
QString mark;
|
||||||
|
QString medalType;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,12 @@
|
||||||
|
|
||||||
#include "MedalWinner.h"
|
#include "MedalWinner.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Replaces/sets the won medals of a competitor.
|
||||||
|
*
|
||||||
|
* @param medals The won medals with their amount.
|
||||||
|
* @return True, if successful.
|
||||||
|
*/
|
||||||
bool MedalWinner::setMedals(const QJsonObject &medals) {
|
bool MedalWinner::setMedals(const QJsonObject &medals) {
|
||||||
if (!medals.contains("ME_GOLD")
|
if (!medals.contains("ME_GOLD")
|
||||||
|| !medals.contains("ME_SILVER")
|
|| !medals.contains("ME_SILVER")
|
||||||
|
@ -8,11 +14,27 @@ bool MedalWinner::setMedals(const QJsonObject &medals) {
|
||||||
throw invalid_argument("Medal object of competitor is incomplete.");
|
throw invalid_argument("Medal object of competitor is incomplete.");
|
||||||
}
|
}
|
||||||
|
|
||||||
this->wonMedals = {
|
this->gold = medals["ME_GOLD"].toInt();
|
||||||
{QString("ME_GOLD"), medals["ME_GOLD"].toString()},
|
this->silver = medals["ME_SILVER"].toInt();
|
||||||
{QString("ME_SILVER"), medals["ME_SILVER"].toString()},
|
this->bronze = medals["ME_BRONZE"].toInt();
|
||||||
{QString("ME_BRONZE"), medals["ME_BRONZE"].toString()}
|
|
||||||
};
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Static compare method, which can compare the amount of medals of two MedalWinners.
|
||||||
|
* Gold has the highest priority, then silver and finally bronze.
|
||||||
|
*
|
||||||
|
* @param lComp First competitor to compare.
|
||||||
|
* @param rComp Second competitor to compare.
|
||||||
|
* @return True, if the second competitor got more or higher medals.
|
||||||
|
*/
|
||||||
|
bool MedalWinner::compare(MedalWinner lComp, MedalWinner rComp) {
|
||||||
|
// create difference between medal amounts
|
||||||
|
int gold = lComp.getGold() - rComp.getGold();
|
||||||
|
int silver = lComp.getSilver() - rComp.getSilver();
|
||||||
|
int bronze = lComp.getBronze() - rComp.getBronze();
|
||||||
|
|
||||||
|
// compare medal differences
|
||||||
|
return gold < 0 || (gold == 0 && (silver < 0 || (silver == 0 && bronze < 0)));
|
||||||
|
}
|
||||||
|
|
|
@ -7,27 +7,43 @@
|
||||||
#include <QJsonObject>
|
#include <QJsonObject>
|
||||||
#include <stdexcept>
|
#include <stdexcept>
|
||||||
|
|
||||||
|
#include <QAbstractListModel>
|
||||||
|
|
||||||
class MedalWinner : public Competitor {
|
class MedalWinner : public Competitor {
|
||||||
|
Q_OBJECT
|
||||||
|
|
||||||
|
Q_PROPERTY(int gold READ gold)
|
||||||
|
Q_PROPERTY(int silver READ silver)
|
||||||
|
Q_PROPERTY(int bronze READ bronze)
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
MedalWinner() : Competitor() {
|
||||||
|
this->gold = 0;
|
||||||
|
this->silver = 0;
|
||||||
|
this->bronze = 0;
|
||||||
|
}
|
||||||
|
|
||||||
MedalWinner(const MedalWinner &medalWinner) : Competitor(medalWinner) {
|
MedalWinner(const MedalWinner &medalWinner) : Competitor(medalWinner) {
|
||||||
this->wonMedals = {
|
this->gold = medalWinner.gold;
|
||||||
{QString("ME_GOLD"), medalWinner.wonMedals.value("ME_GOLD")},
|
this->silver = medalWinner.silver;
|
||||||
{QString("ME_SILVER"), medalWinner.wonMedals.value("ME_SILVER")},
|
this->bronze = medalWinner.bronze;
|
||||||
{QString("ME_BRONZE"), medalWinner.wonMedals.value("ME_BRONZE")}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
MedalWinner(const QJsonObject &competitor) : Competitor(competitor) {
|
MedalWinner(const QJsonObject &competitor) : Competitor(competitor) {
|
||||||
if (competitor.contains("medals")) throw invalid_argument("Competitor has no medals.");
|
if (!competitor.contains("medals")) throw invalid_argument("Competitor has no medals.");
|
||||||
QJsonObject medals = competitor["medals"].toObject();
|
QJsonObject medals = competitor["medals"].toObject();
|
||||||
setMedals(medals);
|
setMedals(medals);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool setMedals(const QJsonObject &medals);
|
bool setMedals(const QJsonObject &medals);
|
||||||
|
int getGold() { return gold; }
|
||||||
|
int getSilver() { return silver; }
|
||||||
|
int getBronze() { return bronze; }
|
||||||
|
|
||||||
|
static bool compare(MedalWinner lComp, MedalWinner rComp);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QMap<QString, QString> wonMedals;
|
int gold, silver, bronze;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue