mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-05 00:41:19 -05:00
6507fedec3
FT4 -> <mode:4>MFSK <submode:3>FT4 When reading ADIF records <mode:3>FT4 is acceptable as well.
120 lines
4.7 KiB
C++
120 lines
4.7 KiB
C++
#include "logbook.h"
|
|
|
|
#include <QDateTime>
|
|
#include "Configuration.hpp"
|
|
#include "AD1CCty.hpp"
|
|
|
|
#include "moc_logbook.cpp"
|
|
|
|
LogBook::LogBook (Configuration const * configuration)
|
|
: config_ {configuration}
|
|
{
|
|
connect (&worked_before_, &WorkedBefore::finished_loading, this, &LogBook::finished_loading);
|
|
}
|
|
|
|
void LogBook::match (QString const& call, QString const& mode, QString const& grid,
|
|
AD1CCty::Record const& looked_up,
|
|
bool& callB4,
|
|
bool& countryB4,
|
|
bool& gridB4,
|
|
bool& continentB4,
|
|
bool& CQZoneB4,
|
|
bool& ITUZoneB4,
|
|
QString const& band) const
|
|
{
|
|
if (call.length() > 0)
|
|
{
|
|
auto const& mode_to_check = (config_ && !config_->highlight_by_mode ()) ? QString {} : mode;
|
|
callB4 = worked_before_.call_worked (call, mode_to_check, band);
|
|
gridB4 = worked_before_.grid_worked(grid, mode_to_check, band);
|
|
auto const& countryName = looked_up.entity_name;
|
|
if (countryName.size ())
|
|
{
|
|
countryB4 = worked_before_.country_worked (countryName, mode_to_check, band);
|
|
continentB4 = worked_before_.continent_worked (looked_up.continent, mode_to_check, band);
|
|
CQZoneB4 = worked_before_.CQ_zone_worked (looked_up.CQ_zone, mode_to_check, band);
|
|
ITUZoneB4 = worked_before_.ITU_zone_worked (looked_up.ITU_zone, mode_to_check, band);
|
|
}
|
|
else
|
|
{
|
|
countryB4 = true; // we don't want to flag unknown entities
|
|
continentB4 = true;
|
|
CQZoneB4 = true;
|
|
ITUZoneB4 = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
bool LogBook::add (QString const& call
|
|
, QString const& grid
|
|
, QString const& band
|
|
, QString const& mode
|
|
, QByteArray const& ADIF_record)
|
|
{
|
|
return worked_before_.add (call, grid, band, mode, ADIF_record);
|
|
}
|
|
|
|
void LogBook::rescan ()
|
|
{
|
|
worked_before_.reload ();
|
|
}
|
|
|
|
QByteArray LogBook::QSOToADIF (QString const& hisCall, QString const& hisGrid, QString const& mode,
|
|
QString const& rptSent, QString const& rptRcvd, QDateTime const& dateTimeOn,
|
|
QDateTime const& dateTimeOff, QString const& band, QString const& comments,
|
|
QString const& name, QString const& strDialFreq, QString const& myCall,
|
|
QString const& myGrid, QString const& txPower, QString const& operator_call,
|
|
QString const& xSent, QString const& xRcvd)
|
|
{
|
|
QString t;
|
|
t = "<call:" + QString::number(hisCall.length()) + ">" + hisCall;
|
|
t += " <gridsquare:" + QString::number(hisGrid.length()) + ">" + hisGrid;
|
|
if (mode != "FT4")
|
|
{
|
|
t += " <mode:" + QString::number(mode.length()) + ">" + mode;
|
|
}
|
|
else
|
|
{
|
|
t += " <mode:4>MFSK <submode:" + QString::number(mode.length()) + ">" + mode;
|
|
}
|
|
t += " <rst_sent:" + QString::number(rptSent.length()) + ">" + rptSent;
|
|
t += " <rst_rcvd:" + QString::number(rptRcvd.length()) + ">" + rptRcvd;
|
|
t += " <qso_date:8>" + dateTimeOn.date().toString("yyyyMMdd");
|
|
t += " <time_on:6>" + dateTimeOn.time().toString("hhmmss");
|
|
t += " <qso_date_off:8>" + dateTimeOff.date().toString("yyyyMMdd");
|
|
t += " <time_off:6>" + dateTimeOff.time().toString("hhmmss");
|
|
t += " <band:" + QString::number(band.length()) + ">" + band;
|
|
t += " <freq:" + QString::number(strDialFreq.length()) + ">" + strDialFreq;
|
|
t += " <station_callsign:" + QString::number(myCall.length()) + ">" + myCall;
|
|
t += " <my_gridsquare:" + QString::number(myGrid.length()) + ">" + myGrid;
|
|
if(txPower!="") t += " <tx_pwr:" + QString::number(txPower.length()) + ">" + txPower;
|
|
if(comments!="") t += " <comment:" + QString::number(comments.length()) + ">" + comments;
|
|
if(name!="") t += " <name:" + QString::number(name.length()) + ">" + name;
|
|
if(operator_call!="") t+=" <operator:" + QString::number(operator_call.length()) + ">" + operator_call;
|
|
if (xSent.size ())
|
|
{
|
|
auto words = xSent.split (' ', QString::SkipEmptyParts);
|
|
if (words.size () > 1)
|
|
{
|
|
bool ok;
|
|
auto sn = words.back ().toUInt (&ok);
|
|
if (ok && sn)
|
|
{
|
|
// assume last word is a serial if there are at least
|
|
// two words and if it is positive numeric
|
|
t += " <STX:" + QString::number (words.back ().size ()) + '>' + words.back ();
|
|
}
|
|
}
|
|
}
|
|
if (xRcvd.size ()) {
|
|
QString t1="";
|
|
if(xRcvd.split(" ").size()==2) t1=xRcvd.split(" ").at(1);
|
|
if(t1.toInt()>0) {
|
|
t += " <SRX:" + QString::number(t1.length()) + ">" + t1;
|
|
} else {
|
|
t += " <STATE:" + QString::number(t1.length()) + ">" + t1;
|
|
}
|
|
}
|
|
return t.toLatin1();
|
|
}
|