mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-05-04 17:30:12 +08:00
Ref T129, SELCAL class improvements
* unify string to also allow strings like AB-FG as input * removed static variables, replaced by "our normal static const &" style
This commit is contained in:
committed by
Mathew Sutcliffe
parent
6fbf601aea
commit
686cb03170
@@ -21,15 +21,21 @@ namespace BlackMisc
|
|||||||
{
|
{
|
||||||
namespace Aviation
|
namespace Aviation
|
||||||
{
|
{
|
||||||
|
|
||||||
QList<CFrequency> CSelcal::frequencyEquivalents = QList<CFrequency>();
|
|
||||||
QStringList CSelcal::allCodePairs = QStringList();
|
|
||||||
|
|
||||||
QString CSelcal::convertToQString(bool /** i18n **/) const
|
QString CSelcal::convertToQString(bool /** i18n **/) const
|
||||||
{
|
{
|
||||||
return m_code;
|
return m_code;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString CSelcal::unifyCode(const QString &selcalCandidate)
|
||||||
|
{
|
||||||
|
QString s;
|
||||||
|
for (QChar c : selcalCandidate)
|
||||||
|
{
|
||||||
|
if (CSelcal::isValidCharacter(c)) { s += c;}
|
||||||
|
}
|
||||||
|
return s.length() == 4 ? s : QString("");
|
||||||
|
}
|
||||||
|
|
||||||
bool CSelcal::equalsString(const QString &code) const
|
bool CSelcal::equalsString(const QString &code) const
|
||||||
{
|
{
|
||||||
if (code.isEmpty()) return false;
|
if (code.isEmpty()) return false;
|
||||||
@@ -75,37 +81,39 @@ namespace BlackMisc
|
|||||||
|
|
||||||
const PhysicalQuantities::CFrequency &CSelcal::audioFrequencyEquivalent(QChar c)
|
const PhysicalQuantities::CFrequency &CSelcal::audioFrequencyEquivalent(QChar c)
|
||||||
{
|
{
|
||||||
if (CSelcal::frequencyEquivalents.isEmpty())
|
|
||||||
{
|
|
||||||
QList<CFrequency> frequencies;
|
|
||||||
frequencies
|
|
||||||
<< CFrequency(312.7, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(346.7, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(384.6, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(426.6, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(473.2, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(524.8, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(582.1, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(645.7, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(716.1, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(794.3, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(881.0, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(977.2, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(1083.9, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(1202.3, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(1333.5, CFrequencyUnit::Hz())
|
|
||||||
<< CFrequency(1479.1, CFrequencyUnit::Hz());
|
|
||||||
CSelcal::frequencyEquivalents = frequencies;
|
|
||||||
}
|
|
||||||
int pos = CSelcal::validCharacters().indexOf(c);
|
int pos = CSelcal::validCharacters().indexOf(c);
|
||||||
Q_ASSERT(pos >= 0);
|
Q_ASSERT(pos >= 0);
|
||||||
Q_ASSERT(CSelcal::frequencyEquivalents.size() > pos);
|
Q_ASSERT(CSelcal::frequencyEquivalents.size() > pos);
|
||||||
return CSelcal::frequencyEquivalents.at(pos);
|
return CSelcal::frequencyEquivalents[pos];
|
||||||
}
|
}
|
||||||
|
|
||||||
const QStringList &CSelcal::codePairs()
|
const QList<CFrequency> &CSelcal::audioFrequencyEquivalents()
|
||||||
{
|
{
|
||||||
if (CSelcal::allCodePairs.isEmpty())
|
static const QList<CFrequency> frequencies(
|
||||||
|
{
|
||||||
|
CFrequency(312.7, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(346.7, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(384.6, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(426.6, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(473.2, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(524.8, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(582.1, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(645.7, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(716.1, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(794.3, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(881.0, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(977.2, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(1083.9, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(1202.3, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(1333.5, CFrequencyUnit::Hz()),
|
||||||
|
CFrequency(1479.1, CFrequencyUnit::Hz())
|
||||||
|
});
|
||||||
|
return frequencies;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace Private
|
||||||
|
{
|
||||||
|
QStringList selcalCodePairs()
|
||||||
{
|
{
|
||||||
QStringList pairs;
|
QStringList pairs;
|
||||||
for (int p1 = 0; p1 < (CSelcal::validCharacters().length() - 1); p1++)
|
for (int p1 = 0; p1 < (CSelcal::validCharacters().length() - 1); p1++)
|
||||||
@@ -117,10 +125,14 @@ namespace BlackMisc
|
|||||||
pairs.append(pair);
|
pairs.append(pair);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
CSelcal::allCodePairs = pairs;
|
return pairs;
|
||||||
}
|
}
|
||||||
return CSelcal::allCodePairs;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const QStringList &CSelcal::codePairs()
|
||||||
|
{
|
||||||
|
static const QStringList allCodePairs = Private::selcalCodePairs();
|
||||||
|
return allCodePairs;
|
||||||
|
}
|
||||||
} // namespace
|
} // namespace
|
||||||
} // namespace
|
} // namespace
|
||||||
|
|||||||
@@ -40,13 +40,10 @@ namespace BlackMisc
|
|||||||
CSelcal() = default;
|
CSelcal() = default;
|
||||||
|
|
||||||
//! Constructor.
|
//! Constructor.
|
||||||
CSelcal(const QString &code) : m_code(code.trimmed().toUpper()) {}
|
CSelcal(const QString &code) : m_code(unifyCode(code)) {}
|
||||||
|
|
||||||
/*!
|
//! Constructor needed to disambiguate implicit conversion from string literal.
|
||||||
* Constructor.
|
CSelcal(const char *code) : m_code(unifyCode(code)) {}
|
||||||
* Needed to disambiguate implicit conversion from string literal.
|
|
||||||
*/
|
|
||||||
CSelcal(const char *code) : m_code(QString(code).trimmed().toUpper()) {}
|
|
||||||
|
|
||||||
//! Is valid?
|
//! Is valid?
|
||||||
bool isValid() const { return isValidCode(m_code); }
|
bool isValid() const { return isValidCode(m_code); }
|
||||||
@@ -76,14 +73,17 @@ namespace BlackMisc
|
|||||||
//! Audio frequency for character
|
//! Audio frequency for character
|
||||||
static const PhysicalQuantities::CFrequency &audioFrequencyEquivalent(QChar c);
|
static const PhysicalQuantities::CFrequency &audioFrequencyEquivalent(QChar c);
|
||||||
|
|
||||||
|
//! All audio frequencies
|
||||||
|
static const QList<PhysicalQuantities::CFrequency> &audioFrequencyEquivalents();
|
||||||
|
|
||||||
//! All valid code pairs: AB, AC, AD ...
|
//! All valid code pairs: AB, AC, AD ...
|
||||||
static const QStringList &codePairs();
|
static const QStringList &codePairs();
|
||||||
|
|
||||||
|
//! Unify SELCAL code by removing illegal characters
|
||||||
|
static QString unifyCode(const QString &selcalCandidate);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QString m_code;
|
QString m_code;
|
||||||
static QList<BlackMisc::PhysicalQuantities::CFrequency> frequencyEquivalents;
|
|
||||||
static QStringList allCodePairs;
|
|
||||||
|
|
||||||
BLACK_METACLASS(
|
BLACK_METACLASS(
|
||||||
CSelcal,
|
CSelcal,
|
||||||
|
|||||||
Reference in New Issue
Block a user