102 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			102 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| #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);
 | |
| //      qDebug() << "B" << countryName;
 | |
| 
 | |
|       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);
 | |
| }
 | |
| 
 | |
| 
 | |
| 
 | 
