mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-11-03 21:40:52 -05:00 
			
		
		
		
	73 messages from other QSOs on frequency should now be ignored rather than being processed. Also some long overdue refactoring and tidying of non-idiomatic C++ code in the logbook directory. git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@8047 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
		
			
				
	
	
		
			101 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
#include "logbook.h"
 | 
						|
#include <QDebug>
 | 
						|
#include <QFontMetrics>
 | 
						|
#include <QStandardPaths>
 | 
						|
#include <QDir>
 | 
						|
 | 
						|
namespace
 | 
						|
{
 | 
						|
  auto logFileName = "wsjtx_log.adi";
 | 
						|
  auto countryFileName = "cty.dat";
 | 
						|
}
 | 
						|
 | 
						|
void LogBook::init()
 | 
						|
{
 | 
						|
  QDir dataPath {QStandardPaths::writableLocation (QStandardPaths::DataLocation)};
 | 
						|
  QString countryDataFilename;
 | 
						|
  if (dataPath.exists (countryFileName))
 | 
						|
    {
 | 
						|
      // User override
 | 
						|
      countryDataFilename = dataPath.absoluteFilePath (countryFileName);
 | 
						|
    }
 | 
						|
  else
 | 
						|
    {
 | 
						|
      countryDataFilename = QString {":/"} + countryFileName;
 | 
						|
    }
 | 
						|
 | 
						|
  _countries.init(countryDataFilename);
 | 
						|
  _countries.load();
 | 
						|
 | 
						|
  _worked.init(_countries.getCountryNames());
 | 
						|
 | 
						|
  _log.init(dataPath.absoluteFilePath (logFileName));
 | 
						|
  _log.load();
 | 
						|
 | 
						|
  _setAlreadyWorkedFromLog();
 | 
						|
 | 
						|
  /*
 | 
						|
    int QSOcount = _log.getCount();
 | 
						|
    int count = _worked.getWorkedCount();
 | 
						|
    qDebug() << QSOcount << "QSOs and" << count << "countries worked in file" << logFilename;
 | 
						|
  */
 | 
						|
 | 
						|
  //    QString call = "ok1ct";
 | 
						|
  //    QString countryName;
 | 
						|
  //    bool callWorkedBefore,countryWorkedBefore;
 | 
						|
  //    match(/*in*/call, /*out*/ countryName,callWorkedBefore,countryWorkedBefore);
 | 
						|
  //    qDebug() << countryName;
 | 
						|
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void LogBook::_setAlreadyWorkedFromLog()
 | 
						|
{
 | 
						|
  QList<QString> calls = _log.getCallList();
 | 
						|
  QString c;
 | 
						|
  foreach(c,calls)
 | 
						|
    {
 | 
						|
      QString countryName = _countries.find(c);
 | 
						|
      if (countryName.length() > 0)
 | 
						|
        {
 | 
						|
          _worked.setAsWorked(countryName);
 | 
						|
          //qDebug() << countryName << " worked " << c;
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 | 
						|
 | 
						|
void LogBook::match(/*in*/const QString call,
 | 
						|
                    /*out*/ QString &countryName,
 | 
						|
                    bool &callWorkedBefore,
 | 
						|
                    bool &countryWorkedBefore) const
 | 
						|
{
 | 
						|
  if (call.length() > 0)
 | 
						|
    {
 | 
						|
      QString currentMode = "JT9"; // JT65 == JT9 in ADIF::match()
 | 
						|
      QString currentBand = "";  // match any band
 | 
						|
      callWorkedBefore = _log.match(call,currentBand,currentMode);
 | 
						|
      countryName = _countries.find(call);
 | 
						|
 | 
						|
      if (countryName.length() > 0)  //  country was found
 | 
						|
        countryWorkedBefore = _worked.getHasWorked(countryName);
 | 
						|
      else
 | 
						|
        {
 | 
						|
          countryName = "where?"; //error: prefix not found
 | 
						|
          countryWorkedBefore = false;
 | 
						|
        }
 | 
						|
    }
 | 
						|
  //qDebug() << "Logbook:" << call << ":" << countryName << "Cty B4:" << countryWorkedBefore << "call B4:" << callWorkedBefore;
 | 
						|
}
 | 
						|
 | 
						|
void LogBook::addAsWorked(const QString call, const QString band, const QString mode, const QString date)
 | 
						|
{
 | 
						|
  //qDebug() << "adding " << call << " as worked";
 | 
						|
  _log.add(call,band,mode,date);
 | 
						|
  QString countryName = _countries.find(call);
 | 
						|
  if (countryName.length() > 0)
 | 
						|
    _worked.setAsWorked(countryName);
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
 |