mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-04 08:21:17 -05:00
Better ADIF conformance for ARRL Field Day mode
This change may break N1MM Logger+ integration, notably the CLASS ADIF field is populated which may not be recognized by N1MM Logger+, nor interfaces to it. One exception to ADIF conformance is that the ARRL_SECT field may be populated with the value DX despite it not being a valid ARRL_SECT enumeration value. This is done for consistency with N1MM Logger+ ADIF exports.
This commit is contained in:
parent
c8fd0b0988
commit
91aa591a71
@ -32,7 +32,7 @@ void LogBook::match (QString const& call, QString const& mode, QString const& gr
|
|||||||
bool& ITUZoneB4,
|
bool& ITUZoneB4,
|
||||||
QString const& band) const
|
QString const& band) const
|
||||||
{
|
{
|
||||||
if (call.length() > 0)
|
if (call.size() > 0)
|
||||||
{
|
{
|
||||||
auto const& mode_to_check = (config_ && !config_->highlight_by_mode ()) ? QString {} : mode;
|
auto const& mode_to_check = (config_ && !config_->highlight_by_mode ()) ? QString {} : mode;
|
||||||
callB4 = worked_before_.call_worked (call, mode_to_check, band);
|
callB4 = worked_before_.call_worked (call, mode_to_check, band);
|
||||||
@ -77,30 +77,30 @@ QByteArray LogBook::QSOToADIF (QString const& hisCall, QString const& hisGrid, Q
|
|||||||
QString const& xSent, QString const& xRcvd)
|
QString const& xSent, QString const& xRcvd)
|
||||||
{
|
{
|
||||||
QString t;
|
QString t;
|
||||||
t = "<call:" + QString::number(hisCall.length()) + ">" + hisCall;
|
t = "<call:" + QString::number(hisCall.size()) + ">" + hisCall;
|
||||||
t += " <gridsquare:" + QString::number(hisGrid.length()) + ">" + hisGrid;
|
t += " <gridsquare:" + QString::number(hisGrid.size()) + ">" + hisGrid;
|
||||||
if (mode != "FT4")
|
if (mode != "FT4")
|
||||||
{
|
{
|
||||||
t += " <mode:" + QString::number(mode.length()) + ">" + mode;
|
t += " <mode:" + QString::number(mode.size()) + ">" + mode;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
t += " <mode:4>MFSK <submode:" + QString::number(mode.length()) + ">" + mode;
|
t += " <mode:4>MFSK <submode:" + QString::number(mode.size()) + ">" + mode;
|
||||||
}
|
}
|
||||||
t += " <rst_sent:" + QString::number(rptSent.length()) + ">" + rptSent;
|
t += " <rst_sent:" + QString::number(rptSent.size()) + ">" + rptSent;
|
||||||
t += " <rst_rcvd:" + QString::number(rptRcvd.length()) + ">" + rptRcvd;
|
t += " <rst_rcvd:" + QString::number(rptRcvd.size()) + ">" + rptRcvd;
|
||||||
t += " <qso_date:8>" + dateTimeOn.date().toString("yyyyMMdd");
|
t += " <qso_date:8>" + dateTimeOn.date().toString("yyyyMMdd");
|
||||||
t += " <time_on:6>" + dateTimeOn.time().toString("hhmmss");
|
t += " <time_on:6>" + dateTimeOn.time().toString("hhmmss");
|
||||||
t += " <qso_date_off:8>" + dateTimeOff.date().toString("yyyyMMdd");
|
t += " <qso_date_off:8>" + dateTimeOff.date().toString("yyyyMMdd");
|
||||||
t += " <time_off:6>" + dateTimeOff.time().toString("hhmmss");
|
t += " <time_off:6>" + dateTimeOff.time().toString("hhmmss");
|
||||||
t += " <band:" + QString::number(band.length()) + ">" + band;
|
t += " <band:" + QString::number(band.size()) + ">" + band;
|
||||||
t += " <freq:" + QString::number(strDialFreq.length()) + ">" + strDialFreq;
|
t += " <freq:" + QString::number(strDialFreq.size()) + ">" + strDialFreq;
|
||||||
t += " <station_callsign:" + QString::number(myCall.length()) + ">" + myCall;
|
t += " <station_callsign:" + QString::number(myCall.size()) + ">" + myCall;
|
||||||
t += " <my_gridsquare:" + QString::number(myGrid.length()) + ">" + myGrid;
|
t += " <my_gridsquare:" + QString::number(myGrid.size()) + ">" + myGrid;
|
||||||
if(txPower!="") t += " <tx_pwr:" + QString::number(txPower.length()) + ">" + txPower;
|
if(txPower!="") t += " <tx_pwr:" + QString::number(txPower.size()) + ">" + txPower;
|
||||||
if(comments!="") t += " <comment:" + QString::number(comments.length()) + ">" + comments;
|
if(comments!="") t += " <comment:" + QString::number(comments.size()) + ">" + comments;
|
||||||
if(name!="") t += " <name:" + QString::number(name.length()) + ">" + name;
|
if(name!="") t += " <name:" + QString::number(name.size()) + ">" + name;
|
||||||
if(operator_call!="") t+=" <operator:" + QString::number(operator_call.length()) + ">" + operator_call;
|
if(operator_call!="") t+=" <operator:" + QString::number(operator_call.size()) + ">" + operator_call;
|
||||||
if (xSent.size ())
|
if (xSent.size ())
|
||||||
{
|
{
|
||||||
auto words = xSent.split (' ', QString::SkipEmptyParts);
|
auto words = xSent.split (' ', QString::SkipEmptyParts);
|
||||||
@ -131,16 +131,27 @@ QByteArray LogBook::QSOToADIF (QString const& hisCall, QString const& hisGrid, Q
|
|||||||
{
|
{
|
||||||
if (words.at (1).toUInt ())
|
if (words.at (1).toUInt ())
|
||||||
{
|
{
|
||||||
t += " <srx:" + QString::number (words.at (1).length ()) + ">" + words.at (1);
|
t += " <srx:" + QString::number (words.at (1).size ()) + ">" + words.at (1);
|
||||||
}
|
}
|
||||||
else if (words.at (0).toUInt () && words.at (0).size () > 3) // EU VHF contest exchange
|
else if (words.at (0).toUInt () && words.at (0).size () > 3) // EU VHF contest exchange
|
||||||
{
|
{
|
||||||
// strip report and set SRX to serial
|
// strip report and set SRX to serial
|
||||||
t += " <srx:" + QString::number (words.at (0).mid (2).length ()) + ">" + words.at (0).mid (2);
|
t += " <srx:" + QString::number (words.at (0).mid (2).size ()) + ">" + words.at (0).mid (2);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
t += " <state:" + QString::number (words.at (1).length ()) + ">" + words.at (1);
|
if (Configuration::SpecialOperatingActivity::FIELD_DAY == config_->special_op_id ())
|
||||||
|
{
|
||||||
|
// include DX as an ARRL_SECT value even though it is
|
||||||
|
// not in the ADIF spec ARRL_SECT enumeration, done
|
||||||
|
// because N1MM does the same
|
||||||
|
t += " <contest_id:14>ARRL-FIELD-DAY <class:" + QString::number (words.at (0).size ()) + '>'
|
||||||
|
+ words.at (0) + " <arrl_sect:" + QString::number (words.at (1).size ()) + '>' + words.at (1);
|
||||||
|
}
|
||||||
|
else if (Configuration::SpecialOperatingActivity::RTTY == config_->special_op_id ())
|
||||||
|
{
|
||||||
|
t += " <state:" + QString::number (words.at (1).size ()) + ">" + words.at (1);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -39,7 +39,7 @@ public:
|
|||||||
AD1CCty::Record const&, bool& callB4, bool& countryB4,
|
AD1CCty::Record const&, bool& callB4, bool& countryB4,
|
||||||
bool &gridB4, bool &continentB4, bool& CQZoneB4, bool& ITUZoneB4,
|
bool &gridB4, bool &continentB4, bool& CQZoneB4, bool& ITUZoneB4,
|
||||||
QString const& currentBand = QString {}) const;
|
QString const& currentBand = QString {}) const;
|
||||||
static QByteArray QSOToADIF (QString const& hisCall, QString const& hisGrid, QString const& mode,
|
QByteArray QSOToADIF (QString const& hisCall, QString const& hisGrid, QString const& mode,
|
||||||
QString const& rptSent, QString const& rptRcvd, QDateTime const& dateTimeOn,
|
QString const& rptSent, QString const& rptRcvd, QDateTime const& dateTimeOn,
|
||||||
QDateTime const& dateTimeOff, QString const& band, QString const& comments,
|
QDateTime const& dateTimeOff, QString const& band, QString const& comments,
|
||||||
QString const& name, QString const& strDialFreq, QString const& myCall,
|
QString const& name, QString const& strDialFreq, QString const& myCall,
|
||||||
|
@ -202,7 +202,7 @@ void LogQSO::accept()
|
|||||||
, m_myGrid
|
, m_myGrid
|
||||||
, xsent
|
, xsent
|
||||||
, xrcvd
|
, xrcvd
|
||||||
, LogBook::QSOToADIF (hisCall
|
, m_log->QSOToADIF (hisCall
|
||||||
, hisGrid
|
, hisGrid
|
||||||
, mode
|
, mode
|
||||||
, rptSent
|
, rptSent
|
||||||
|
Loading…
Reference in New Issue
Block a user