Revised avionics (stringifier) and matrix operations

This commit is contained in:
Klaus Basan
2013-04-19 14:36:30 +02:00
parent 8121babe77
commit 8ffa443a69
18 changed files with 296 additions and 131 deletions

View File

@@ -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);
}