mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-05-06 10:26:03 +08:00
Revised avionics (stringifier) and matrix operations
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 2013 VATSIM Community / authors
|
||||
/* Copyright (C) 2013 VATSIM Community / contributors
|
||||
* This Source Code Form is subject to the terms of the Mozilla Public
|
||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
@@ -21,7 +21,8 @@ public:
|
||||
/*!
|
||||
* \brief Our transponder codes
|
||||
*/
|
||||
enum TransponderMode {
|
||||
enum TransponderMode
|
||||
{
|
||||
StateStandby = 0, // not a real mode, more a state
|
||||
ModeMil1 = 1, ModeMil2 = 2, ModeMil3 = 3, ModeMil4 = 4, ModeMil5 = 5,
|
||||
StateIdent = 10, // not a real mode, more a state
|
||||
@@ -41,9 +42,11 @@ private:
|
||||
* \param transponderMode
|
||||
*/
|
||||
CTransponder(bool validate, const QString &name, qint32 transponderCode, TransponderMode transponderMode) :
|
||||
m_transponderCode(transponderCode), m_transponderMode(transponderMode), CAvionicsBase(name) {
|
||||
m_transponderCode(transponderCode), m_transponderMode(transponderMode), CAvionicsBase(name)
|
||||
{
|
||||
this->validate(validate);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Constructor for validation
|
||||
* \param validate
|
||||
@@ -52,7 +55,8 @@ private:
|
||||
* \param transponderMode
|
||||
*/
|
||||
CTransponder(bool validate, const QString &name, const QString transponderCode, TransponderMode transponderMode) :
|
||||
m_transponderCode(0), m_transponderMode(transponderMode), CAvionicsBase(name) {
|
||||
m_transponderCode(0), m_transponderMode(transponderMode), CAvionicsBase(name)
|
||||
{
|
||||
bool ok = false;
|
||||
this->m_transponderCode = transponderCode.toUInt(&ok);
|
||||
if (!ok)this->m_transponderCode = -1; // will cause assert / exception
|
||||
@@ -64,13 +68,16 @@ protected:
|
||||
* \return
|
||||
*/
|
||||
bool validValues() const;
|
||||
|
||||
/*!
|
||||
* \brief Default value
|
||||
* \return
|
||||
*/
|
||||
virtual bool isDefaultValue() const {
|
||||
virtual bool isDefaultValue() const
|
||||
{
|
||||
return this->m_transponderCode == 0;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Validate values by assert and exception
|
||||
* \param strict
|
||||
@@ -79,22 +86,26 @@ protected:
|
||||
* \return
|
||||
*/
|
||||
bool validate(bool strict = true) const;
|
||||
|
||||
/*!
|
||||
* \brief Meaningful string representation
|
||||
* \return
|
||||
*/
|
||||
virtual QString stringForStreamingOperator() const;
|
||||
virtual QString stringForConverter() const;
|
||||
|
||||
public:
|
||||
/*!
|
||||
* Default constructor
|
||||
*/
|
||||
CTransponder() : CAvionicsBase("default"), m_transponderCode(0), m_transponderMode(StateStandby) {}
|
||||
|
||||
/*!
|
||||
* \brief Copy constructor
|
||||
* \param otherTransponder
|
||||
*/
|
||||
CTransponder(const CTransponder &otherTransponder) : CAvionicsBase(otherTransponder.getName()),
|
||||
m_transponderCode(otherTransponder.m_transponderCode), m_transponderMode(otherTransponder.m_transponderMode) {}
|
||||
|
||||
/*!
|
||||
* \brief Constructor
|
||||
* \param name
|
||||
@@ -102,9 +113,11 @@ public:
|
||||
* \param transponderMode
|
||||
*/
|
||||
CTransponder(const QString &name, qint32 transponderCode, TransponderMode transponderMode) :
|
||||
CAvionicsBase(name), m_transponderCode(transponderCode), m_transponderMode(transponderMode) {
|
||||
CAvionicsBase(name), m_transponderCode(transponderCode), m_transponderMode(transponderMode)
|
||||
{
|
||||
this->validate(true);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Constructor
|
||||
* \param name
|
||||
@@ -112,99 +125,122 @@ public:
|
||||
* \param transponderMode
|
||||
*/
|
||||
CTransponder(const QString &name, const QString &transponderCode, TransponderMode transponderMode) :
|
||||
CAvionicsBase(name), m_transponderCode(0), m_transponderMode(transponderMode) {
|
||||
CAvionicsBase(name), m_transponderCode(0), m_transponderMode(transponderMode)
|
||||
{
|
||||
bool ok = false;
|
||||
this->m_transponderCode = transponderCode.toUInt(&ok);
|
||||
if (!ok)this->m_transponderCode = -1; // will cause assert / exception
|
||||
this->validate(true);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Transponder mode as string
|
||||
* \return
|
||||
* \throws std::range_erros
|
||||
*/
|
||||
QString getModeAsString() const;
|
||||
|
||||
/*!
|
||||
* \brief Transponder mode
|
||||
* \return
|
||||
*/
|
||||
TransponderMode getTransponderMode() const {
|
||||
TransponderMode getTransponderMode() const
|
||||
{
|
||||
return this->m_transponderMode;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Transponder code
|
||||
* \return
|
||||
*/
|
||||
qint32 getTransponderCode() const {
|
||||
qint32 getTransponderCode() const
|
||||
{
|
||||
return this->m_transponderCode;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Transponder code
|
||||
* \return
|
||||
*/
|
||||
QString getTransponderCodeFormatted() const;
|
||||
|
||||
/*!
|
||||
* \brief Set transponder code
|
||||
* \param transponderCode
|
||||
*/
|
||||
void setTransponderCode(qint32 transponderCode) {
|
||||
void setTransponderCode(qint32 transponderCode)
|
||||
{
|
||||
this->m_transponderCode = transponderCode;
|
||||
this->validate(true);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Set transponder mode
|
||||
* \param mode
|
||||
*/
|
||||
void setTransponderMode(TransponderMode mode) {
|
||||
void setTransponderMode(TransponderMode mode)
|
||||
{
|
||||
this->m_transponderMode = mode ;
|
||||
this->validate(true);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Set emergency
|
||||
*/
|
||||
void setEmergency() {
|
||||
void setEmergency()
|
||||
{
|
||||
this->m_transponderCode = 7700;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Set emergency
|
||||
*/
|
||||
void setVFR() {
|
||||
void setVFR()
|
||||
{
|
||||
this->m_transponderCode = 7000;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Set emergency
|
||||
*/
|
||||
void setIFR() {
|
||||
void setIFR()
|
||||
{
|
||||
this->m_transponderCode = 2000;
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief Assigment operator =
|
||||
* \param otherTransponder
|
||||
* \return
|
||||
*/
|
||||
CTransponder &operator =(const CTransponder &otherTransponder) {
|
||||
CTransponder &operator =(const CTransponder &otherTransponder)
|
||||
{
|
||||
CAvionicsBase::operator =(otherTransponder);
|
||||
this->m_transponderMode = otherTransponder.m_transponderMode;
|
||||
this->m_transponderCode = otherTransponder.m_transponderCode;
|
||||
return (*this);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief operator ==
|
||||
* \param otherTransponder
|
||||
* \return
|
||||
*/
|
||||
bool operator ==(const CTransponder &otherTransponder) const {
|
||||
bool operator ==(const CTransponder &otherTransponder) const
|
||||
{
|
||||
return
|
||||
this->m_transponderCode == otherTransponder.m_transponderCode &&
|
||||
this->m_transponderMode == otherTransponder.m_transponderMode &&
|
||||
CAvionicsBase::operator ==(otherTransponder);
|
||||
}
|
||||
|
||||
/*!
|
||||
* \brief operator =!
|
||||
* \param otherSystem
|
||||
* \return
|
||||
*/
|
||||
bool operator !=(const CTransponder &otherSystem) const {
|
||||
bool operator !=(const CTransponder &otherSystem) const
|
||||
{
|
||||
return !((*this) == otherSystem);
|
||||
}
|
||||
|
||||
@@ -217,7 +253,8 @@ public:
|
||||
* \param mode
|
||||
* \return
|
||||
*/
|
||||
static bool tryGetTransponder(CTransponder &transponder, const QString &name, qint32 transponderCode, TransponderMode mode) {
|
||||
static bool tryGetTransponder(CTransponder &transponder, const QString &name, qint32 transponderCode, TransponderMode mode)
|
||||
{
|
||||
transponder = CTransponder(false, name, transponderCode, mode);
|
||||
bool s;
|
||||
if (!(s = transponder.validate(false))) transponder = CTransponder(); // reset to default
|
||||
@@ -232,7 +269,8 @@ public:
|
||||
* \param mode
|
||||
* \return
|
||||
*/
|
||||
static bool tryGetTransponder(CTransponder &transponder, const QString &name, const QString &transponderCode, TransponderMode mode) {
|
||||
static bool tryGetTransponder(CTransponder &transponder, const QString &name, const QString &transponderCode, TransponderMode mode)
|
||||
{
|
||||
transponder = CTransponder(false, name, transponderCode, mode);
|
||||
bool s;
|
||||
if (!(s = transponder.validate(false))) transponder = CTransponder(); // reset to default
|
||||
@@ -244,7 +282,8 @@ public:
|
||||
* \param mode
|
||||
* \return
|
||||
*/
|
||||
static CTransponder getStandardTransponder(qint32 transponderCode, TransponderMode mode) {
|
||||
static CTransponder getStandardTransponder(qint32 transponderCode, TransponderMode mode)
|
||||
{
|
||||
return CTransponder("Transponder", transponderCode, mode);
|
||||
}
|
||||
/*!
|
||||
@@ -254,7 +293,8 @@ public:
|
||||
* \param mode
|
||||
* \return
|
||||
*/
|
||||
static bool tryGetStandardTransponder(CTransponder &transponder, qint32 transponderCode, TransponderMode mode) {
|
||||
static bool tryGetStandardTransponder(CTransponder &transponder, qint32 transponderCode, TransponderMode mode)
|
||||
{
|
||||
return CTransponder::tryGetTransponder(transponder, "Transponder", transponderCode, mode);
|
||||
}
|
||||
|
||||
@@ -265,7 +305,8 @@ public:
|
||||
* \param mode
|
||||
* \return
|
||||
*/
|
||||
static bool tryGetStandardTransponder(CTransponder &transponder, const QString &transponderCode, TransponderMode mode) {
|
||||
static bool tryGetStandardTransponder(CTransponder &transponder, const QString &transponderCode, TransponderMode mode)
|
||||
{
|
||||
return CTransponder::tryGetTransponder(transponder, "Transponder", transponderCode, mode);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user