154 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			154 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | /* | ||
|  | #Sov Mil Order of Malta:   15:  28:  EU:   41.90:   -12.43:    -1.0:  1A: | ||
|  |     #1A; | ||
|  | #Spratly Islands:          26:  50:  AS:    9.88:  -114.23:    -8.0:  1S: | ||
|  |     #1S,9M0,BV9S; | ||
|  | #Monaco:                   14:  27:  EU:   43.73:    -7.40:    -1.0:  3A: | ||
|  |     #3A; | ||
|  | #Heard Island:             39:  68:  AF:  -53.08:   -73.50:    -5.0:  VK0H: | ||
|  |     #=VK0IR; | ||
|  | #Macquarie Island:         30:  60:  OC:  -54.60:  -158.88:   -10.0:  VK0M: | ||
|  |     #=VK0KEV; | ||
|  | #Cocos-Keeling:            29:  54:  OC:  -12.15:   -96.82:    -6.5:  VK9C: | ||
|  |     #AX9C,AX9Y,VH9C,VH9Y,VI9C,VI9Y,VJ9C,VJ9Y,VK9C,VK9Y,VL9C,VL9Y,VM9C,VM9Y, | ||
|  |     #VN9C,VN9Y,VZ9C,VZ9Y,=VK9AA; | ||
|  | */ | ||
|  | 
 | ||
|  | 
 | ||
|  | #include "countrydat.h" | ||
|  | #include <QFile> | ||
|  | #include <QTextStream> | ||
|  | 
 | ||
|  | 
 | ||
|  | void CountryDat::init(const QString filename) | ||
|  | { | ||
|  |     _filename = filename; | ||
|  |     _data.clear(); | ||
|  | } | ||
|  | 
 | ||
|  | QString CountryDat::_extractName(const QString line) const | ||
|  | { | ||
|  |     int s1 = line.indexOf(':'); | ||
|  |     if (s1>=0) | ||
|  |     { | ||
|  |         QString name = line.mid(0,s1); | ||
|  |         return name; | ||
|  |     } | ||
|  |     return ""; | ||
|  | } | ||
|  | 
 | ||
|  | void CountryDat::_removeBrackets(QString &line, const QString a, const QString b) const | ||
|  | { | ||
|  |     int s1 = line.indexOf(a); | ||
|  |     while (s1 >= 0) | ||
|  |     { | ||
|  |       int s2 = line.indexOf(b); | ||
|  |       line = line.mid(0,s1) + line.mid(s2+1,-1); | ||
|  |       s1 = line.indexOf(a); | ||
|  |     } | ||
|  | }     | ||
|  | 
 | ||
|  | QStringList CountryDat::_extractPrefix(QString &line, bool &more) const | ||
|  | { | ||
|  |     line = line.remove(" \n"); | ||
|  |     line = line.replace(" ",""); | ||
|  | 
 | ||
|  |     _removeBrackets(line,"(",")"); | ||
|  |     _removeBrackets(line,"[","]"); | ||
|  |     _removeBrackets(line,"<",">"); | ||
|  |     _removeBrackets(line,"~","~"); | ||
|  | 
 | ||
|  |     int s1 = line.indexOf(';'); | ||
|  |     more = true; | ||
|  |     if (s1 >= 0) | ||
|  |     { | ||
|  |       line = line.mid(0,s1); | ||
|  |       more = false; | ||
|  |     } | ||
|  | 
 | ||
|  |     QStringList r = line.split(','); | ||
|  | 
 | ||
|  |     return r; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | void CountryDat::load() | ||
|  | { | ||
|  |     _data.clear(); | ||
|  |     _countryNames.clear(); //used by countriesWorked | ||
|  |    | ||
|  |     QFile inputFile(_filename); | ||
|  |     if (inputFile.open(QIODevice::ReadOnly)) | ||
|  |     { | ||
|  |        QTextStream in(&inputFile); | ||
|  |        while ( !in.atEnd() ) | ||
|  |        { | ||
|  |           QString line1 = in.readLine(); | ||
|  |           if ( !in.atEnd() ) | ||
|  |           { | ||
|  |             QString line2 = in.readLine(); | ||
|  |                | ||
|  |             QString name = _extractName(line1); | ||
|  |             if (name.length()>0) | ||
|  |             { | ||
|  |                 _countryNames << name; | ||
|  |                 bool more = true; | ||
|  |                 QStringList prefixs; | ||
|  |                 while (more) | ||
|  |                 { | ||
|  |                     QStringList p = _extractPrefix(line2,more); | ||
|  |                     prefixs += p; | ||
|  |                     if (more) | ||
|  |                         line2 = in.readLine(); | ||
|  |                 } | ||
|  | 
 | ||
|  |                 QString p; | ||
|  |                 foreach(p,prefixs) | ||
|  |                 { | ||
|  |                     if (p.length() > 0) | ||
|  |                         _data.insert(p,name); | ||
|  |                 } | ||
|  |             } | ||
|  |           } | ||
|  |        } | ||
|  |     inputFile.close(); | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | // return country name else "" | ||
|  | QString CountryDat::find(QString call) const | ||
|  | { | ||
|  |   call = call.toUpper (); | ||
|  | 
 | ||
|  |   // check for exact match first | ||
|  |   if (_data.contains ("=" + call)) | ||
|  |     { | ||
|  |       return fixup (_data.value ("=" + call), call); | ||
|  |     } | ||
|  | 
 | ||
|  |   auto prefix = call; | ||
|  |   while (prefix.size () >= 1) | ||
|  |     { | ||
|  |       if (_data.contains (prefix)) | ||
|  |         { | ||
|  |           return fixup (_data.value (prefix), call); | ||
|  |         } | ||
|  |       prefix = prefix.left (prefix.size () - 1); | ||
|  |     } | ||
|  |   return QString {}; | ||
|  | } | ||
|  | 
 | ||
|  | QString CountryDat::fixup (QString country, QString const& call) const | ||
|  | { | ||
|  |   // | ||
|  |   // deal with special rules that cty.dat does not cope with | ||
|  |   // | ||
|  | 
 | ||
|  |   // KG4 2x1 and 2x3 calls that map to Gitmo are mainland US not Gitmo | ||
|  |   if (call.startsWith ("KG4") && call.size () != 5) | ||
|  |     { | ||
|  |       country.replace ("Guantanamo Bay", "United States"); | ||
|  |     } | ||
|  |   return country; | ||
|  | } |