#include "logbook.h" #include #include "Configuration.hpp" #include "AD1CCty.hpp" #include "Multiplier.hpp" #include "logbook/AD1CCty.hpp" #include "models/CabrilloLog.hpp" #include "models/FoxLog.hpp" #include "moc_logbook.cpp" LogBook::LogBook (Configuration const * configuration) : config_ {configuration} , worked_before_ {configuration} { Q_ASSERT (configuration); connect (&worked_before_, &WorkedBefore::finished_loading, this, &LogBook::finished_loading); } LogBook::~LogBook () { } 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 = "" + hisCall; t += " " + hisGrid; if (mode != "FT4") { t += " " + mode; } else { t += " MFSK " + mode; } t += " " + rptSent; t += " " + rptRcvd; t += " " + dateTimeOn.date().toString("yyyyMMdd"); t += " " + dateTimeOn.time().toString("hhmmss"); t += " " + dateTimeOff.date().toString("yyyyMMdd"); t += " " + dateTimeOff.time().toString("hhmmss"); t += " " + band; t += " " + strDialFreq; t += " " + myCall; t += " " + myGrid; if(txPower!="") t += " " + txPower; if(comments!="") t += " " + comments; if(name!="") t += " " + name; if(operator_call!="") t+=" " + operator_call; if (xSent.size ()) { auto words = xSent.split (' ', QString::SkipEmptyParts); if (words.size () > 1) { if (words.back ().toUInt ()) { // assume last word is a serial if there are at least // two words and if it is positive numeric t += " ' + words.back (); } else { if (words.front ().toUInt () && words.front ().size () > 3) // EU VHF contest mode { auto sn_text = words.front ().mid (2); // assume first word is report+serial if there are // at least two words and if the first word less the // first two characters is a positive numeric t += " ' + sn_text; } } } } if (xRcvd.size ()) { auto words = xRcvd.split (' ', QString::SkipEmptyParts); if (words.size () == 2) { if (words.at (1).toUInt ()) { t += " " + words.at (1); } else if (words.at (0).toUInt () && words.at (0).size () > 3) // EU VHF contest exchange { // strip report and set SRX to serial t += " " + words.at (0).mid (2); } else { t += " " + words.at (1); } } } return t.toLatin1(); } CabrilloLog * LogBook::contest_log () { // lazy create of Cabrillo log object instance if (!contest_log_) { contest_log_.reset (new CabrilloLog {config_}); if (!multiplier_) { multiplier_.reset (new Multiplier {countries ()}); } connect (contest_log_.data (), &CabrilloLog::data_changed, [this] () { multiplier_->reload (contest_log_.data ()); }); } return contest_log_.data (); } Multiplier const * LogBook::multiplier () const { // lazy create of Multiplier object instance if (!multiplier_) { multiplier_.reset (new Multiplier {countries ()}); } return multiplier_.data (); } FoxLog * LogBook::fox_log () { // lazy create of Fox log object instance if (!fox_log_) { fox_log_.reset (new FoxLog {config_}); } return fox_log_.data (); }