mirror of
https://github.com/swift-project/pilotclient.git
synced 2026-04-12 07:15:34 +08:00
Ref T658, matching script support for flight number and callsign "as set"
This commit is contained in:
committed by
Mat Sutcliffe
parent
bab053a0a2
commit
4e24edcb0a
@@ -178,25 +178,49 @@ namespace BlackMisc
|
|||||||
|
|
||||||
QString CCallsign::getAirlineSuffix() const
|
QString CCallsign::getAirlineSuffix() const
|
||||||
{
|
{
|
||||||
|
QString flightNumber;
|
||||||
|
return this->getAirlineSuffix(flightNumber);
|
||||||
|
}
|
||||||
|
|
||||||
|
QString CCallsign::getAirlineSuffix(QString &flightNumber) const
|
||||||
|
{
|
||||||
|
flightNumber.clear();
|
||||||
if (m_callsign.length() < 3) { return {}; }
|
if (m_callsign.length() < 3) { return {}; }
|
||||||
if (this->isAtcCallsign()) { return {}; }
|
if (this->isAtcCallsign()) { return {}; }
|
||||||
|
|
||||||
thread_local const QRegularExpression regExp("^[A-Z]{3,}");
|
thread_local const QRegularExpression regExp("^[A-Z]{3,}");
|
||||||
QRegularExpressionMatch match = regExp.match(m_callsign);
|
QRegularExpressionMatch match = regExp.match(m_callsign);
|
||||||
if (!match.hasMatch()) { return QString(); }
|
if (!match.hasMatch()) { return {}; }
|
||||||
const QString airline = match.captured(0);
|
const QString airline = match.captured(0);
|
||||||
|
flightNumber = match.captured(1);
|
||||||
|
|
||||||
// hard facts
|
// hard facts
|
||||||
if (airline.length() == 3) { return airline; } // we allow 3 letters
|
if (airline.length() == 3) { return airline; } // we allow 3 letters
|
||||||
if (airline.length() == 4 && airline.startsWith('V')) { return airline; } // we allow virtual 4 letter codes, e.g. VDLD
|
if (airline.length() == 4 && airline.startsWith('V')) { return airline; } // we allow virtual 4 letter codes, e.g. VDLD
|
||||||
|
|
||||||
// some people use callsigns like UPSE123
|
// some people use callsigns like UPSE123
|
||||||
const QString number = match.captured(1);
|
flightNumber = match.captured(1);
|
||||||
if (number.length() >= 3 && airline.length() == 4) { return airline.left(3); }
|
if (flightNumber.length() >= 3 && airline.length() == 4) { return airline.left(3); }
|
||||||
|
|
||||||
return {}; // invalid
|
return {}; // invalid
|
||||||
}
|
}
|
||||||
|
|
||||||
|
QString CCallsign::getFlightNumber() const
|
||||||
|
{
|
||||||
|
if (this->isAtcCallsign()) { return {}; }
|
||||||
|
QString flightNumber;
|
||||||
|
const QString airline = this->getAirlineSuffix(flightNumber);
|
||||||
|
return airline.isEmpty() ? QString() : flightNumber;
|
||||||
|
}
|
||||||
|
|
||||||
|
int CCallsign::getFlightNumberInt() const
|
||||||
|
{
|
||||||
|
if (this->isAtcCallsign()) { return -1; }
|
||||||
|
bool ok;
|
||||||
|
const int fn = this->getFlightNumber().toInt(&ok);
|
||||||
|
return ok ? fn : -1;
|
||||||
|
}
|
||||||
|
|
||||||
bool CCallsign::hasSuffix() const
|
bool CCallsign::hasSuffix() const
|
||||||
{
|
{
|
||||||
return this->getStringAsSet().contains('_');
|
return this->getStringAsSet().contains('_');
|
||||||
|
|||||||
@@ -107,8 +107,16 @@ namespace BlackMisc
|
|||||||
//! Get the callsign suffix ("TWR", "ATIS" ...) if any ("_" is removed)
|
//! Get the callsign suffix ("TWR", "ATIS" ...) if any ("_" is removed)
|
||||||
QString getSuffix() const;
|
QString getSuffix() const;
|
||||||
|
|
||||||
//! Airline suffix (e.g. DLH1234 -> DLH) if applicable
|
//! Airline suffix (e.g. DLH1234 -> DLH) if applicable @{
|
||||||
QString getAirlineSuffix() const;
|
QString getAirlineSuffix() const;
|
||||||
|
QString getAirlineSuffix(QString &flightNumber) const;
|
||||||
|
// @}
|
||||||
|
|
||||||
|
//! Flight number (e.g. DLH1234 -> 1234) if applicable
|
||||||
|
QString getFlightNumber() const;
|
||||||
|
|
||||||
|
//! Flight number as integer
|
||||||
|
int getFlightNumberInt() const;
|
||||||
|
|
||||||
//! Suffix such as "_TWR"?
|
//! Suffix such as "_TWR"?
|
||||||
bool hasSuffix() const;
|
bool hasSuffix() const;
|
||||||
|
|||||||
@@ -15,21 +15,19 @@ namespace BlackMisc
|
|||||||
{
|
{
|
||||||
namespace Simulation
|
namespace Simulation
|
||||||
{
|
{
|
||||||
MSInOutValues::MSInOutValues(
|
MSInOutValues::MSInOutValues(const CCallsign &cs,
|
||||||
const QString &cs,
|
const CAircraftIcaoCode aircraftIcao,
|
||||||
const CAircraftIcaoCode aircraftIcao,
|
const CAirlineIcaoCode airlineIcao,
|
||||||
const CAirlineIcaoCode airlineIcao,
|
const QString &livery, int liveryId) :
|
||||||
const QString &livery, int liveryId) :
|
MSInOutValues(cs.asString(), cs.getStringAsSet(), cs.getFlightNumber(),
|
||||||
MSInOutValues(cs,
|
|
||||||
aircraftIcao.getDesignator(), aircraftIcao.getCombinedType(), aircraftIcao.getDbKey(),
|
aircraftIcao.getDesignator(), aircraftIcao.getCombinedType(), aircraftIcao.getDbKey(),
|
||||||
airlineIcao.getDesignator(), airlineIcao.getVDesignator(), airlineIcao.getDbKey(),
|
airlineIcao.getDesignator(), airlineIcao.getVDesignator(), airlineIcao.getDbKey(),
|
||||||
livery, liveryId)
|
livery, liveryId)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
MSInOutValues::MSInOutValues(
|
MSInOutValues::MSInOutValues(const CCallsign &cs,
|
||||||
const QString &cs,
|
const CAircraftIcaoCode aircraftIcao,
|
||||||
const CAircraftIcaoCode aircraftIcao,
|
const CLivery livery) :
|
||||||
const CLivery livery) :
|
|
||||||
MSInOutValues(cs,
|
MSInOutValues(cs,
|
||||||
aircraftIcao,
|
aircraftIcao,
|
||||||
livery.getAirlineIcaoCode(),
|
livery.getAirlineIcaoCode(),
|
||||||
@@ -37,14 +35,14 @@ namespace BlackMisc
|
|||||||
{ }
|
{ }
|
||||||
|
|
||||||
MSInOutValues::MSInOutValues(const CAircraftModel &model) :
|
MSInOutValues::MSInOutValues(const CAircraftModel &model) :
|
||||||
MSInOutValues(model.getCallsign().asString(), model.getAircraftIcaoCode(), model.getLivery())
|
MSInOutValues(model.getCallsign(), model.getAircraftIcaoCode(), model.getLivery())
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
MSInOutValues::MSInOutValues(const MSInOutValues &sv) :
|
MSInOutValues::MSInOutValues(const MSInOutValues &sv) :
|
||||||
MSInOutValues(sv.m_callsign,
|
MSInOutValues(sv.m_callsign, sv.m_callsignAsSet, sv.m_flightNumber,
|
||||||
sv.getAircraftIcao(), sv.getCombinedType(), sv.getDbAircraftIcaoId(),
|
sv.getAircraftIcao(), sv.getCombinedType(), sv.getDbAircraftIcaoId(),
|
||||||
sv.getAirlineIcao(), sv.getVirtualAirlineIcao(), sv.getDbAirlineIcaoId(),
|
sv.getAirlineIcao(), sv.getVirtualAirlineIcao(), sv.getDbAirlineIcaoId(),
|
||||||
sv.getLivery(), sv.getDbLiveryId(),
|
sv.getLivery(), sv.getDbLiveryId(),
|
||||||
sv.m_logMessage,
|
sv.m_logMessage,
|
||||||
sv.isModified(), sv.isRerun())
|
sv.isModified(), sv.isRerun())
|
||||||
{ }
|
{ }
|
||||||
|
|||||||
@@ -31,6 +31,8 @@ namespace BlackMisc
|
|||||||
|
|
||||||
//! MSNetworkValues properties @{
|
//! MSNetworkValues properties @{
|
||||||
Q_PROPERTY(QString callsign READ getCallsign WRITE setCallsign NOTIFY callsignChanged)
|
Q_PROPERTY(QString callsign READ getCallsign WRITE setCallsign NOTIFY callsignChanged)
|
||||||
|
Q_PROPERTY(QString callsignAsSet READ getCallsignAsSet)
|
||||||
|
Q_PROPERTY(QString flightNumber READ getFlightNumber)
|
||||||
Q_PROPERTY(int dbAircraftIcaoId READ getDbAircraftIcaoId WRITE setDbAircraftIcaoId NOTIFY dbAircraftIcaoIdChanged)
|
Q_PROPERTY(int dbAircraftIcaoId READ getDbAircraftIcaoId WRITE setDbAircraftIcaoId NOTIFY dbAircraftIcaoIdChanged)
|
||||||
Q_PROPERTY(int dbAirlineIcaoId READ getDbAirlineIcaoId WRITE setDbAirlineIcaoId NOTIFY dbAirlineIcaoIdChanged)
|
Q_PROPERTY(int dbAirlineIcaoId READ getDbAirlineIcaoId WRITE setDbAirlineIcaoId NOTIFY dbAirlineIcaoIdChanged)
|
||||||
Q_PROPERTY(int dbLiveryId READ getDbLiveryId WRITE setDbLiveryId NOTIFY dbLiveryIdChanged)
|
Q_PROPERTY(int dbLiveryId READ getDbLiveryId WRITE setDbLiveryId NOTIFY dbLiveryIdChanged)
|
||||||
@@ -57,13 +59,13 @@ namespace BlackMisc
|
|||||||
Q_INVOKABLE MSInOutValues() {}
|
Q_INVOKABLE MSInOutValues() {}
|
||||||
|
|
||||||
//! Ctor
|
//! Ctor
|
||||||
Q_INVOKABLE MSInOutValues(const QString &cs,
|
Q_INVOKABLE MSInOutValues(const QString &cs, const QString &csAsSet, const QString &flightNumber,
|
||||||
const QString &aircraftIcao, const QString &combinedType, int idAircraftIcao,
|
const QString &aircraftIcao, const QString &combinedType, int idAircraftIcao,
|
||||||
const QString &airlineIcao, const QString &virtualAirlineIcao, int idAirlineIcao,
|
const QString &airlineIcao, const QString &virtualAirlineIcao, int idAirlineIcao,
|
||||||
const QString &livery, int liveryId,
|
const QString &livery, int liveryId,
|
||||||
const QString &logMsg = {},
|
const QString &logMsg = {},
|
||||||
bool modified = false, bool rerun = false) :
|
bool modified = false, bool rerun = false) :
|
||||||
m_callsign(cs.trimmed().toUpper()),
|
m_callsign(cs.trimmed().toUpper()), m_callsignAsSet(csAsSet), m_flightNumber(flightNumber),
|
||||||
m_aircraftIcao(aircraftIcao.trimmed().toUpper()), m_combinedType(combinedType.trimmed().toUpper()),
|
m_aircraftIcao(aircraftIcao.trimmed().toUpper()), m_combinedType(combinedType.trimmed().toUpper()),
|
||||||
m_airlineIcao(airlineIcao.trimmed().toUpper()), m_vAirlineIcao(virtualAirlineIcao),
|
m_airlineIcao(airlineIcao.trimmed().toUpper()), m_vAirlineIcao(virtualAirlineIcao),
|
||||||
m_livery(livery.trimmed().toUpper()),
|
m_livery(livery.trimmed().toUpper()),
|
||||||
@@ -73,13 +75,13 @@ namespace BlackMisc
|
|||||||
{}
|
{}
|
||||||
|
|
||||||
//! Ctor
|
//! Ctor
|
||||||
MSInOutValues(const QString &cs,
|
MSInOutValues(const BlackMisc::Aviation::CCallsign &cs,
|
||||||
const BlackMisc::Aviation::CAircraftIcaoCode aircraftIcao,
|
const BlackMisc::Aviation::CAircraftIcaoCode aircraftIcao,
|
||||||
const BlackMisc::Aviation::CAirlineIcaoCode airlineIcao,
|
const BlackMisc::Aviation::CAirlineIcaoCode airlineIcao,
|
||||||
const QString &livery, int liveryId);
|
const QString &livery, int liveryId);
|
||||||
|
|
||||||
//! Ctor
|
//! Ctor
|
||||||
MSInOutValues(const QString &cs,
|
MSInOutValues(const BlackMisc::Aviation::CCallsign &cs,
|
||||||
const BlackMisc::Aviation::CAircraftIcaoCode aircraftIcao,
|
const BlackMisc::Aviation::CAircraftIcaoCode aircraftIcao,
|
||||||
const BlackMisc::Aviation::CLivery livery);
|
const BlackMisc::Aviation::CLivery livery);
|
||||||
|
|
||||||
@@ -89,11 +91,12 @@ namespace BlackMisc
|
|||||||
//! Ctor
|
//! Ctor
|
||||||
MSInOutValues(const MSInOutValues &sv);
|
MSInOutValues(const MSInOutValues &sv);
|
||||||
|
|
||||||
//! Get callsign
|
//! Callsign values @{
|
||||||
const QString &getCallsign() const { return m_callsign; }
|
const QString &getCallsign() const { return m_callsign; }
|
||||||
|
const QString &getCallsignAsSet() const { return m_callsignAsSet; }
|
||||||
//! Set callsign
|
const QString &getFlightNumber() const { return m_flightNumber; }
|
||||||
void setCallsign(const QString &callsign);
|
void setCallsign(const QString &callsign);
|
||||||
|
//! @}
|
||||||
|
|
||||||
//! Values found in DB? @{
|
//! Values found in DB? @{
|
||||||
bool isFoundDbAircraftIcao() const { return m_dbAircraftIcaoId >= 0; }
|
bool isFoundDbAircraftIcao() const { return m_dbAircraftIcaoId >= 0; }
|
||||||
@@ -149,9 +152,6 @@ namespace BlackMisc
|
|||||||
bool hasModifiedAircraftIcaoDesignator() const { return m_modifiedAircraftDesignator; }
|
bool hasModifiedAircraftIcaoDesignator() const { return m_modifiedAircraftDesignator; }
|
||||||
bool hasModifiedAirlineIcaoDesignator() const { return m_modifiedAirlineDesignator; }
|
bool hasModifiedAirlineIcaoDesignator() const { return m_modifiedAirlineDesignator; }
|
||||||
bool hasUnmodifiedDesignators() const { return !this->hasModifiedAirlineIcaoDesignator() && !this->hasModifiedAircraftIcaoDesignator(); }
|
bool hasUnmodifiedDesignators() const { return !this->hasModifiedAirlineIcaoDesignator() && !this->hasModifiedAircraftIcaoDesignator(); }
|
||||||
//! }
|
|
||||||
|
|
||||||
//! Changed values @{
|
|
||||||
bool hasChangedAircraftIcao(const BlackMisc::Aviation::CAircraftIcaoCode &aircraftIcao) const;
|
bool hasChangedAircraftIcao(const BlackMisc::Aviation::CAircraftIcaoCode &aircraftIcao) const;
|
||||||
bool hasChangedAircraftIcaoId(const BlackMisc::Aviation::CAircraftIcaoCode &aircraftIcao) const;
|
bool hasChangedAircraftIcaoId(const BlackMisc::Aviation::CAircraftIcaoCode &aircraftIcao) const;
|
||||||
bool hasChangedAirlineIcao(const BlackMisc::Aviation::CAirlineIcaoCode &airlineIcao) const;
|
bool hasChangedAirlineIcao(const BlackMisc::Aviation::CAirlineIcaoCode &airlineIcao) const;
|
||||||
@@ -193,6 +193,8 @@ namespace BlackMisc
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
QString m_callsign;
|
QString m_callsign;
|
||||||
|
QString m_callsignAsSet;
|
||||||
|
QString m_flightNumber;
|
||||||
QString m_aircraftIcao;
|
QString m_aircraftIcao;
|
||||||
QString m_combinedType;
|
QString m_combinedType;
|
||||||
QString m_airlineIcao;
|
QString m_airlineIcao;
|
||||||
|
|||||||
Reference in New Issue
Block a user