| 
									
										
										
										
											2018-02-08 21:28:33 -05:00
										 |  |  | #include "logbook.h"
 | 
					
						
							|  |  |  | #include <QDebug>
 | 
					
						
							|  |  |  | #include <QFontMetrics>
 | 
					
						
							|  |  |  | #include <QStandardPaths>
 | 
					
						
							|  |  |  | #include <QDir>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-08-06 16:35:46 -04:00
										 |  |  |   auto logFileName = "ft8call_log.adi"; | 
					
						
							| 
									
										
										
										
											2018-02-08 21:28:33 -05:00
										 |  |  |   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); | 
					
						
							| 
									
										
										
										
											2018-03-05 14:49:51 -05:00
										 |  |  | //      qDebug() << "B" << countryName;
 | 
					
						
							| 
									
										
										
										
											2018-02-08 21:28:33 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |       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); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |