mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2024-11-22 04:11:16 -05:00
Better detection of allsign from general calls (CQ, QRZ ...)
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@8027 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
parent
84813be7db
commit
388f5d13ab
@ -3,40 +3,14 @@
|
|||||||
#include <QStringList>
|
#include <QStringList>
|
||||||
#include <QRegularExpression>
|
#include <QRegularExpression>
|
||||||
|
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
bool stdmsg_(const char* msg, int len);
|
bool stdmsg_(const char* msg, int len);
|
||||||
}
|
}
|
||||||
|
|
||||||
QString DecodedText::CQersCall()
|
QString DecodedText::CQersCall()
|
||||||
{
|
{
|
||||||
// extract the CQer's call TODO: does this work with all call formats?
|
QRegularExpression callsign_re {R"(\s(CQ|DE|QRZ)(\s?DX|\s([A-Z]{2}|\d{3}))?\s(?<callsign>[A-Z0-9/]{2,})(\s[A-R]{2}[0-9]{2})?)"};
|
||||||
int s1 {0};
|
return callsign_re.match (_string).captured ("callsign");
|
||||||
int position;
|
|
||||||
QString t=_string;
|
|
||||||
if ((position = _string.indexOf (" CQ DX ")) >= 0)
|
|
||||||
{
|
|
||||||
s1 = 7 + position;
|
|
||||||
}
|
|
||||||
else if ((position = _string.indexOf (" CQDX ")) >= 0)
|
|
||||||
{
|
|
||||||
s1 = 6 + position;
|
|
||||||
}
|
|
||||||
else if ((position = _string.indexOf (" CQ ")) >= 0)
|
|
||||||
{
|
|
||||||
s1 = 4 + position;
|
|
||||||
if(_string.mid(s1,3).toInt() > 0 and _string.mid(s1,3).toInt() <= 999) s1 += 4;
|
|
||||||
}
|
|
||||||
else if ((position = _string.indexOf (" DE ")) >= 0)
|
|
||||||
{
|
|
||||||
s1 = 4 + position;
|
|
||||||
}
|
|
||||||
else if ((position = _string.indexOf (" QRZ ")) >= 0)
|
|
||||||
{
|
|
||||||
s1 = 5 + position;
|
|
||||||
}
|
|
||||||
auto s2 = _string.indexOf (" ", s1);
|
|
||||||
return _string.mid (s1, s2 - s1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user