mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-25 18:10:21 -04:00 
			
		
		
		
	A second attempt at grouping contest selection radio buttons using hints from Bill. Contest types are now defined in a named enum in the Configuration class, Configuration::SpecialOperatingActivity. Current contest selection is queried using a Configuration class function, m_config.special_op_activity().
This commit is contained in:
		
							parent
							
								
									de327f7840
								
							
						
					
					
						commit
						a9d096941a
					
				| @ -446,13 +446,11 @@ private: | |||||||
|   Q_SLOT void handle_transceiver_failure (QString const& reason); |   Q_SLOT void handle_transceiver_failure (QString const& reason); | ||||||
|   Q_SLOT void on_reset_highlighting_to_defaults_push_button_clicked (bool); |   Q_SLOT void on_reset_highlighting_to_defaults_push_button_clicked (bool); | ||||||
|   Q_SLOT void on_LotW_CSV_fetch_push_button_clicked (bool); |   Q_SLOT void on_LotW_CSV_fetch_push_button_clicked (bool); | ||||||
|   Q_SLOT void on_rbFox_clicked (bool); |  | ||||||
|   Q_SLOT void on_rbHound_clicked (bool); |  | ||||||
|   Q_SLOT void on_cbx2ToneSpacing_clicked(bool); |   Q_SLOT void on_cbx2ToneSpacing_clicked(bool); | ||||||
|   Q_SLOT void on_cbx4ToneSpacing_clicked(bool); |   Q_SLOT void on_cbx4ToneSpacing_clicked(bool); | ||||||
|   Q_SLOT void on_rbFieldDay_toggled(); |   Q_SLOT void on_rbField_Day_toggled(); | ||||||
|   Q_SLOT void on_rbRTTYroundup_toggled(); |   Q_SLOT void on_rbRTTY_Roundup_toggled(); | ||||||
|   Q_SLOT void on_FieldDay_Exchange_textChanged(); |   Q_SLOT void on_Field_Day_Exchange_textChanged(); | ||||||
|   Q_SLOT void on_RTTY_Exchange_textChanged(); |   Q_SLOT void on_RTTY_Exchange_textChanged(); | ||||||
|   Q_SLOT void on_prompt_to_log_check_box_clicked(bool); |   Q_SLOT void on_prompt_to_log_check_box_clicked(bool); | ||||||
|   Q_SLOT void on_cbAutoLog_clicked(bool); |   Q_SLOT void on_cbAutoLog_clicked(bool); | ||||||
| @ -579,8 +577,8 @@ private: | |||||||
|   bool bFox_; |   bool bFox_; | ||||||
|   bool bHound_; |   bool bHound_; | ||||||
|   bool bSpecialOp_; |   bool bSpecialOp_; | ||||||
|   bool bFieldDay_; |   bool bField_Day_; | ||||||
|   bool bRTTYroundup_; |   bool bRTTY_Roundup_; | ||||||
|   bool bNA_VHF_Contest_; |   bool bNA_VHF_Contest_; | ||||||
|   bool bEU_VHF_Contest_; |   bool bEU_VHF_Contest_; | ||||||
|   bool x2ToneSpacing_; |   bool x2ToneSpacing_; | ||||||
| @ -677,8 +675,8 @@ bool Configuration::twoPass() const {return m_->twoPass_;} | |||||||
| bool Configuration::bFox() const {return m_->bFox_;} | bool Configuration::bFox() const {return m_->bFox_;} | ||||||
| bool Configuration::bHound() const {return m_->bHound_;} | bool Configuration::bHound() const {return m_->bHound_;} | ||||||
| bool Configuration::bSpecialOp() const {return m_->bSpecialOp_;} | bool Configuration::bSpecialOp() const {return m_->bSpecialOp_;} | ||||||
| bool Configuration::bFieldDay() const {return m_->bFieldDay_;} | bool Configuration::bField_Day() const {return m_->bField_Day_;} | ||||||
| bool Configuration::bRTTYroundup() const {return m_->bRTTYroundup_;} | bool Configuration::bRTTY_Roundup() const {return m_->bRTTY_Roundup_;} | ||||||
| bool Configuration::bNA_VHF_Contest() const {return m_->bNA_VHF_Contest_;} | bool Configuration::bNA_VHF_Contest() const {return m_->bNA_VHF_Contest_;} | ||||||
| bool Configuration::bEU_VHF_Contest() const {return m_->bEU_VHF_Contest_;} | bool Configuration::bEU_VHF_Contest() const {return m_->bEU_VHF_Contest_;} | ||||||
| bool Configuration::x2ToneSpacing() const {return m_->x2ToneSpacing_;} | bool Configuration::x2ToneSpacing() const {return m_->x2ToneSpacing_;} | ||||||
| @ -822,7 +820,7 @@ QString Configuration::my_grid() const | |||||||
|   return the_grid; |   return the_grid; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QString Configuration::FieldDayExchange() const | QString Configuration::Field_Day_Exchange() const | ||||||
| { | { | ||||||
|   return m_->FD_exchange_; |   return m_->FD_exchange_; | ||||||
| } | } | ||||||
| @ -834,11 +832,16 @@ void Configuration::setEU_VHF_Contest() | |||||||
|   m_->write_settings(); |   m_->write_settings(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| QString Configuration::RTTYExchange() const | QString Configuration::RTTY_Exchange() const | ||||||
| { | { | ||||||
|   return m_->RTTY_exchange_; |   return m_->RTTY_exchange_; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | auto Configuration::special_op_id () const -> SpecialOperatingActivity | ||||||
|  | { | ||||||
|  |   return m_->bSpecialOp_ ? static_cast<SpecialOperatingActivity> (m_->ui_->special_op_activity_button_group->checkedId()) : SpecialOperatingActivity::NONE; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| void Configuration::set_location (QString const& grid_descriptor) | void Configuration::set_location (QString const& grid_descriptor) | ||||||
| { | { | ||||||
|   // change the dynamic grid
 |   // change the dynamic grid
 | ||||||
| @ -989,7 +992,7 @@ Configuration::impl::impl (Configuration * self, QNetworkAccessManager * network | |||||||
|   ui_->callsign_line_edit->setValidator (new CallsignValidator {this}); |   ui_->callsign_line_edit->setValidator (new CallsignValidator {this}); | ||||||
|   ui_->grid_line_edit->setValidator (new MaidenheadLocatorValidator {this}); |   ui_->grid_line_edit->setValidator (new MaidenheadLocatorValidator {this}); | ||||||
|   ui_->add_macro_line_edit->setValidator (new QRegExpValidator {message_alphabet, this}); |   ui_->add_macro_line_edit->setValidator (new QRegExpValidator {message_alphabet, this}); | ||||||
|   ui_->FieldDay_Exchange->setValidator(new ExchangeValidator{this}); |   ui_->Field_Day_Exchange->setValidator(new ExchangeValidator{this}); | ||||||
|   ui_->RTTY_Exchange->setValidator(new ExchangeValidator{this}); |   ui_->RTTY_Exchange->setValidator(new ExchangeValidator{this}); | ||||||
| 
 | 
 | ||||||
|   ui_->udp_server_port_spin_box->setMinimum (1); |   ui_->udp_server_port_spin_box->setMinimum (1); | ||||||
| @ -1030,6 +1033,13 @@ Configuration::impl::impl (Configuration * self, QNetworkAccessManager * network | |||||||
|   ui_->split_mode_button_group->setId (ui_->split_rig_radio_button, TransceiverFactory::split_mode_rig); |   ui_->split_mode_button_group->setId (ui_->split_rig_radio_button, TransceiverFactory::split_mode_rig); | ||||||
|   ui_->split_mode_button_group->setId (ui_->split_emulate_radio_button, TransceiverFactory::split_mode_emulate); |   ui_->split_mode_button_group->setId (ui_->split_emulate_radio_button, TransceiverFactory::split_mode_emulate); | ||||||
| 
 | 
 | ||||||
|  |   ui_->special_op_activity_button_group->setId (ui_->rbNA_VHF_Contest, static_cast<int> (SpecialOperatingActivity::NA_VHF)); | ||||||
|  |   ui_->special_op_activity_button_group->setId (ui_->rbEU_VHF_Contest, static_cast<int> (SpecialOperatingActivity::EU_VHF)); | ||||||
|  |   ui_->special_op_activity_button_group->setId (ui_->rbField_Day, static_cast<int> (SpecialOperatingActivity::FIELD_DAY)); | ||||||
|  |   ui_->special_op_activity_button_group->setId (ui_->rbRTTY_Roundup, static_cast<int> (SpecialOperatingActivity::RTTY)); | ||||||
|  |   ui_->special_op_activity_button_group->setId (ui_->rbFox, static_cast<int> (SpecialOperatingActivity::FOX)); | ||||||
|  |   ui_->special_op_activity_button_group->setId (ui_->rbHound, static_cast<int> (SpecialOperatingActivity::HOUND)); | ||||||
|  | 
 | ||||||
|   //
 |   //
 | ||||||
|   // setup PTT port combo box drop down content
 |   // setup PTT port combo box drop down content
 | ||||||
|   //
 |   //
 | ||||||
| @ -1204,8 +1214,8 @@ void Configuration::impl::initialize_models () | |||||||
|   ui_->rbFox->setChecked(bFox_); |   ui_->rbFox->setChecked(bFox_); | ||||||
|   ui_->rbHound->setChecked(bHound_); |   ui_->rbHound->setChecked(bHound_); | ||||||
|   ui_->gbSpecialOpActivity->setChecked(bSpecialOp_); |   ui_->gbSpecialOpActivity->setChecked(bSpecialOp_); | ||||||
|   ui_->rbFieldDay->setChecked(bFieldDay_); |   ui_->rbField_Day->setChecked(bField_Day_); | ||||||
|   ui_->rbRTTYroundup->setChecked(bRTTYroundup_); |   ui_->rbRTTY_Roundup->setChecked(bRTTY_Roundup_); | ||||||
|   ui_->rbNA_VHF_Contest->setChecked(bNA_VHF_Contest_); |   ui_->rbNA_VHF_Contest->setChecked(bNA_VHF_Contest_); | ||||||
|   ui_->rbEU_VHF_Contest->setChecked(bEU_VHF_Contest_); |   ui_->rbEU_VHF_Contest->setChecked(bEU_VHF_Contest_); | ||||||
|   ui_->cbx2ToneSpacing->setChecked(x2ToneSpacing_); |   ui_->cbx2ToneSpacing->setChecked(x2ToneSpacing_); | ||||||
| @ -1291,9 +1301,9 @@ void Configuration::impl::read_settings () | |||||||
| 
 | 
 | ||||||
|   my_callsign_ = settings_->value ("MyCall", QString {}).toString (); |   my_callsign_ = settings_->value ("MyCall", QString {}).toString (); | ||||||
|   my_grid_ = settings_->value ("MyGrid", QString {}).toString (); |   my_grid_ = settings_->value ("MyGrid", QString {}).toString (); | ||||||
|   FD_exchange_ = settings_->value ("FieldDayExchange",QString {}).toString (); |   FD_exchange_ = settings_->value ("Field_Day_Exchange",QString {}).toString (); | ||||||
|   RTTY_exchange_ = settings_->value ("RTTYExchange",QString {}).toString (); |   RTTY_exchange_ = settings_->value ("RTTY_Exchange",QString {}).toString (); | ||||||
|   ui_->FieldDay_Exchange->setText(FD_exchange_); |   ui_->Field_Day_Exchange->setText(FD_exchange_); | ||||||
|   ui_->RTTY_Exchange->setText(RTTY_exchange_); |   ui_->RTTY_Exchange->setText(RTTY_exchange_); | ||||||
|   if (next_font_.fromString (settings_->value ("Font", QGuiApplication::font ().toString ()).toString ()) |   if (next_font_.fromString (settings_->value ("Font", QGuiApplication::font ().toString ()).toString ()) | ||||||
|       && next_font_ != font_) |       && next_font_ != font_) | ||||||
| @ -1456,8 +1466,8 @@ void Configuration::impl::read_settings () | |||||||
|   bFox_ = settings_->value("Fox",false).toBool (); |   bFox_ = settings_->value("Fox",false).toBool (); | ||||||
|   bHound_ = settings_->value("Hound",false).toBool (); |   bHound_ = settings_->value("Hound",false).toBool (); | ||||||
|   bSpecialOp_ = settings_->value("SpecialOpActivity",false).toBool (); |   bSpecialOp_ = settings_->value("SpecialOpActivity",false).toBool (); | ||||||
|   bFieldDay_ = settings_->value("FieldDay",false).toBool (); |   bField_Day_ = settings_->value("Field_Day",false).toBool (); | ||||||
|   bRTTYroundup_ = settings_->value("RTTYroundup",false).toBool (); |   bRTTY_Roundup_ = settings_->value("RTTY_Roundup",false).toBool (); | ||||||
|   bNA_VHF_Contest_ = settings_->value("NA_VHF_Contest",false).toBool (); |   bNA_VHF_Contest_ = settings_->value("NA_VHF_Contest",false).toBool (); | ||||||
|   bEU_VHF_Contest_ = settings_->value("EU_VHF_Contest",false).toBool (); |   bEU_VHF_Contest_ = settings_->value("EU_VHF_Contest",false).toBool (); | ||||||
|   x2ToneSpacing_ = settings_->value("x2ToneSpacing",false).toBool (); |   x2ToneSpacing_ = settings_->value("x2ToneSpacing",false).toBool (); | ||||||
| @ -1485,8 +1495,8 @@ void Configuration::impl::write_settings () | |||||||
| 
 | 
 | ||||||
|   settings_->setValue ("MyCall", my_callsign_); |   settings_->setValue ("MyCall", my_callsign_); | ||||||
|   settings_->setValue ("MyGrid", my_grid_); |   settings_->setValue ("MyGrid", my_grid_); | ||||||
|   settings_->setValue ("FieldDayExchange", FD_exchange_); |   settings_->setValue ("Field_Day_Exchange", FD_exchange_); | ||||||
|   settings_->setValue ("RTTYExchange", RTTY_exchange_); |   settings_->setValue ("RTTY_Exchange", RTTY_exchange_); | ||||||
|   settings_->setValue ("Font", font_.toString ()); |   settings_->setValue ("Font", font_.toString ()); | ||||||
|   settings_->setValue ("DecodedTextFont", decoded_text_font_.toString ()); |   settings_->setValue ("DecodedTextFont", decoded_text_font_.toString ()); | ||||||
|   settings_->setValue ("IDint", id_interval_); |   settings_->setValue ("IDint", id_interval_); | ||||||
| @ -1567,8 +1577,8 @@ void Configuration::impl::write_settings () | |||||||
|   settings_->setValue ("Fox", bFox_); |   settings_->setValue ("Fox", bFox_); | ||||||
|   settings_->setValue ("Hound", bHound_); |   settings_->setValue ("Hound", bHound_); | ||||||
|   settings_->setValue ("SpecialOpActivity", bSpecialOp_); |   settings_->setValue ("SpecialOpActivity", bSpecialOp_); | ||||||
|   settings_->setValue ("FieldDay", bFieldDay_); |   settings_->setValue ("Field_Day", bField_Day_); | ||||||
|   settings_->setValue ("RTTYroundup", bRTTYroundup_); |   settings_->setValue ("RTTY_Roundup", bRTTY_Roundup_); | ||||||
|   settings_->setValue ("NA_VHF_Contest", bNA_VHF_Contest_); |   settings_->setValue ("NA_VHF_Contest", bNA_VHF_Contest_); | ||||||
|   settings_->setValue ("EU_VHF_Contest", bEU_VHF_Contest_); |   settings_->setValue ("EU_VHF_Contest", bEU_VHF_Contest_); | ||||||
|   settings_->setValue ("x2ToneSpacing", x2ToneSpacing_); |   settings_->setValue ("x2ToneSpacing", x2ToneSpacing_); | ||||||
| @ -1937,7 +1947,7 @@ void Configuration::impl::accept () | |||||||
| 
 | 
 | ||||||
|   my_callsign_ = ui_->callsign_line_edit->text (); |   my_callsign_ = ui_->callsign_line_edit->text (); | ||||||
|   my_grid_ = ui_->grid_line_edit->text (); |   my_grid_ = ui_->grid_line_edit->text (); | ||||||
|   FD_exchange_= ui_->FieldDay_Exchange->text (); |   FD_exchange_= ui_->Field_Day_Exchange->text (); | ||||||
|   RTTY_exchange_= ui_->RTTY_Exchange->text (); |   RTTY_exchange_= ui_->RTTY_Exchange->text (); | ||||||
|   spot_to_psk_reporter_ = ui_->psk_reporter_check_box->isChecked (); |   spot_to_psk_reporter_ = ui_->psk_reporter_check_box->isChecked (); | ||||||
|   id_interval_ = ui_->CW_id_interval_spin_box->value (); |   id_interval_ = ui_->CW_id_interval_spin_box->value (); | ||||||
| @ -1975,8 +1985,8 @@ void Configuration::impl::accept () | |||||||
|   bHound_ = ui_->rbHound->isChecked (); |   bHound_ = ui_->rbHound->isChecked (); | ||||||
| //  if(bFox_ or bHound_) ui_->gbSpecialOpActivity->setChecked(true);     //###
 | //  if(bFox_ or bHound_) ui_->gbSpecialOpActivity->setChecked(true);     //###
 | ||||||
|   bSpecialOp_ = ui_->gbSpecialOpActivity->isChecked (); |   bSpecialOp_ = ui_->gbSpecialOpActivity->isChecked (); | ||||||
|   bFieldDay_ = ui_->rbFieldDay->isChecked (); |   bField_Day_ = ui_->rbField_Day->isChecked (); | ||||||
|   bRTTYroundup_ = ui_->rbRTTYroundup->isChecked (); |   bRTTY_Roundup_ = ui_->rbRTTY_Roundup->isChecked (); | ||||||
|   bNA_VHF_Contest_ = ui_->rbNA_VHF_Contest->isChecked (); |   bNA_VHF_Contest_ = ui_->rbNA_VHF_Contest->isChecked (); | ||||||
|   bEU_VHF_Contest_ = ui_->rbEU_VHF_Contest->isChecked (); |   bEU_VHF_Contest_ = ui_->rbEU_VHF_Contest->isChecked (); | ||||||
|   x2ToneSpacing_ = ui_->cbx2ToneSpacing->isChecked (); |   x2ToneSpacing_ = ui_->cbx2ToneSpacing->isChecked (); | ||||||
| @ -2204,16 +2214,16 @@ void Configuration::impl::on_add_macro_line_edit_editingFinished () | |||||||
|   ui_->add_macro_line_edit->setText (ui_->add_macro_line_edit->text ().toUpper ()); |   ui_->add_macro_line_edit->setText (ui_->add_macro_line_edit->text ().toUpper ()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Configuration::impl::on_FieldDay_Exchange_textChanged() | void Configuration::impl::on_Field_Day_Exchange_textChanged() | ||||||
| { | { | ||||||
|   bool b=ui_->FieldDay_Exchange->hasAcceptableInput() or !ui_->rbFieldDay->isChecked(); |   bool b=ui_->Field_Day_Exchange->hasAcceptableInput() or !ui_->rbField_Day->isChecked(); | ||||||
|   if(b)  ui_->FieldDay_Exchange->setStyleSheet("color: black"); |   if(b)  ui_->Field_Day_Exchange->setStyleSheet("color: black"); | ||||||
|   if(!b) ui_->FieldDay_Exchange->setStyleSheet("color: red"); |   if(!b) ui_->Field_Day_Exchange->setStyleSheet("color: red"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Configuration::impl::on_RTTY_Exchange_textChanged() | void Configuration::impl::on_RTTY_Exchange_textChanged() | ||||||
| { | { | ||||||
|   bool b=ui_->RTTY_Exchange->hasAcceptableInput() or !ui_->rbRTTYroundup->isChecked(); |   bool b=ui_->RTTY_Exchange->hasAcceptableInput() or !ui_->rbRTTY_Roundup->isChecked(); | ||||||
|   if(b)  ui_->RTTY_Exchange->setStyleSheet("color: black"); |   if(b)  ui_->RTTY_Exchange->setStyleSheet("color: black"); | ||||||
|   if(!b) ui_->RTTY_Exchange->setStyleSheet("color: red"); |   if(!b) ui_->RTTY_Exchange->setStyleSheet("color: red"); | ||||||
| } | } | ||||||
| @ -2458,30 +2468,12 @@ void Configuration::impl::on_cbAutoLog_clicked(bool checked) | |||||||
|   if(checked) ui_->prompt_to_log_check_box->setChecked(false); |   if(checked) ui_->prompt_to_log_check_box->setChecked(false); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| //These are not needed because Fox and Hound have been converted to 
 | void Configuration::impl::on_rbField_Day_toggled() | ||||||
| //mutually exclusive radio buttons.
 |  | ||||||
| void Configuration::impl::on_rbFox_clicked (bool checked) |  | ||||||
| { | { | ||||||
|   if(checked) { |   on_Field_Day_Exchange_textChanged(); | ||||||
| //    ui_->rbHound->setChecked (false);
 |  | ||||||
| //    ui_->rbNone->setChecked(true);
 |  | ||||||
|   } |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Configuration::impl::on_rbHound_clicked (bool checked) | void Configuration::impl::on_rbRTTY_Roundup_toggled() | ||||||
| { |  | ||||||
|   if(checked) { |  | ||||||
| //    ui_->rbFox->setChecked (false);
 |  | ||||||
| //    ui_->rbNone->setChecked(true);
 |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void Configuration::impl::on_rbFieldDay_toggled() |  | ||||||
| { |  | ||||||
|   on_FieldDay_Exchange_textChanged(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void Configuration::impl::on_rbRTTYroundup_toggled() |  | ||||||
| { | { | ||||||
|   on_RTTY_Exchange_textChanged(); |   on_RTTY_Exchange_textChanged(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -98,8 +98,8 @@ public: | |||||||
| 
 | 
 | ||||||
|   QString my_callsign () const; |   QString my_callsign () const; | ||||||
|   QString my_grid () const; |   QString my_grid () const; | ||||||
|   QString FieldDayExchange() const; |   QString Field_Day_Exchange() const; | ||||||
|   QString RTTYExchange() const; |   QString RTTY_Exchange() const; | ||||||
|   void setEU_VHF_Contest(); |   void setEU_VHF_Contest(); | ||||||
|   QFont text_font () const; |   QFont text_font () const; | ||||||
|   QFont decoded_text_font () const; |   QFont decoded_text_font () const; | ||||||
| @ -137,8 +137,8 @@ public: | |||||||
|   bool bGenerate77() const; |   bool bGenerate77() const; | ||||||
|   bool bDecode77() const; |   bool bDecode77() const; | ||||||
|   bool bSpecialOp() const; |   bool bSpecialOp() const; | ||||||
|   bool bFieldDay() const; |   bool bField_Day() const; | ||||||
|   bool bRTTYroundup() const; |   bool bRTTY_Roundup() const; | ||||||
|   bool bNA_VHF_Contest() const; |   bool bNA_VHF_Contest() const; | ||||||
|   bool bEU_VHF_Contest() const; |   bool bEU_VHF_Contest() const; | ||||||
|   bool x2ToneSpacing() const; |   bool x2ToneSpacing() const; | ||||||
| @ -178,6 +178,10 @@ public: | |||||||
|   DecodeHighlightingModel const& decode_highlighting () const; |   DecodeHighlightingModel const& decode_highlighting () const; | ||||||
|   bool highlight_by_mode () const; |   bool highlight_by_mode () const; | ||||||
|   |   | ||||||
|  |   enum class SpecialOperatingActivity {NONE, NA_VHF, EU_VHF, FIELD_DAY, RTTY, FOX, HOUND}; | ||||||
|  |   SpecialOperatingActivity special_op_activity () const; | ||||||
|  |   SpecialOperatingActivity special_op_id () const; | ||||||
|  | 
 | ||||||
|   struct CalibrationParams |   struct CalibrationParams | ||||||
|   { |   { | ||||||
|     CalibrationParams () |     CalibrationParams () | ||||||
|  | |||||||
| @ -2453,13 +2453,16 @@ Right click for insert and delete options.</string> | |||||||
|           <item row="1" column="3"> |           <item row="1" column="3"> | ||||||
|            <layout class="QHBoxLayout" name="horizontalLayout_17" stretch="2,1,1"> |            <layout class="QHBoxLayout" name="horizontalLayout_17" stretch="2,1,1"> | ||||||
|             <item> |             <item> | ||||||
|              <widget class="QRadioButton" name="rbFieldDay"> |              <widget class="QRadioButton" name="rbField_Day"> | ||||||
|               <property name="toolTip"> |               <property name="toolTip"> | ||||||
|                <string><html><head/><body><p>ARRL Field Day exchange: number of transmitters, Class, and ARRL/RAC section or &quot;DX&quot;.</p></body></html></string> |                <string><html><head/><body><p>ARRL Field Day exchange: number of transmitters, Class, and ARRL/RAC section or &quot;DX&quot;.</p></body></html></string> | ||||||
|               </property> |               </property> | ||||||
|               <property name="text"> |               <property name="text"> | ||||||
|                <string>ARRL Field Day</string> |                <string>ARRL Field Day</string> | ||||||
|               </property> |               </property> | ||||||
|  |               <attribute name="buttonGroup"> | ||||||
|  |                <string notr="true">special_op_activity_button_group</string> | ||||||
|  |               </attribute> | ||||||
|              </widget> |              </widget> | ||||||
|             </item> |             </item> | ||||||
|             <item> |             <item> | ||||||
| @ -2483,12 +2486,12 @@ Right click for insert and delete options.</string> | |||||||
|                  <string>Exch:</string> |                  <string>Exch:</string> | ||||||
|                 </property> |                 </property> | ||||||
|                 <property name="buddy"> |                 <property name="buddy"> | ||||||
|                  <cstring>FieldDay_Exchange</cstring> |                  <cstring>Field_Day_Exchange</cstring> | ||||||
|                 </property> |                 </property> | ||||||
|                </widget> |                </widget> | ||||||
|               </item> |               </item> | ||||||
|               <item row="0" column="1"> |               <item row="0" column="1"> | ||||||
|                <widget class="QLineEdit" name="FieldDay_Exchange"> |                <widget class="QLineEdit" name="Field_Day_Exchange"> | ||||||
|                 <property name="minimumSize"> |                 <property name="minimumSize"> | ||||||
|                  <size> |                  <size> | ||||||
|                   <width>70</width> |                   <width>70</width> | ||||||
| @ -2513,13 +2516,16 @@ Right click for insert and delete options.</string> | |||||||
|           <item row="2" column="3"> |           <item row="2" column="3"> | ||||||
|            <layout class="QHBoxLayout" name="horizontalLayout_18" stretch="2,1,1"> |            <layout class="QHBoxLayout" name="horizontalLayout_18" stretch="2,1,1"> | ||||||
|             <item> |             <item> | ||||||
|              <widget class="QRadioButton" name="rbRTTYroundup"> |              <widget class="QRadioButton" name="rbRTTY_Roundup"> | ||||||
|               <property name="toolTip"> |               <property name="toolTip"> | ||||||
|                <string><html><head/><body><p>ARRL RTTY Roundup and similar contests.  Exchange is US state, Canadian province, or &quot;DX&quot;.</p></body></html></string> |                <string><html><head/><body><p>ARRL RTTY Roundup and similar contests.  Exchange is US state, Canadian province, or &quot;DX&quot;.</p></body></html></string> | ||||||
|               </property> |               </property> | ||||||
|               <property name="text"> |               <property name="text"> | ||||||
|                <string>ARRL RTTY Roundup</string> |                <string>ARRL RTTY Roundup</string> | ||||||
|               </property> |               </property> | ||||||
|  |               <attribute name="buttonGroup"> | ||||||
|  |                <string notr="true">special_op_activity_button_group</string> | ||||||
|  |               </attribute> | ||||||
|              </widget> |              </widget> | ||||||
|             </item> |             </item> | ||||||
|             <item> |             <item> | ||||||
| @ -2581,6 +2587,9 @@ Right click for insert and delete options.</string> | |||||||
|             <property name="checked"> |             <property name="checked"> | ||||||
|              <bool>false</bool> |              <bool>false</bool> | ||||||
|             </property> |             </property> | ||||||
|  |             <attribute name="buttonGroup"> | ||||||
|  |              <string notr="true">special_op_activity_button_group</string> | ||||||
|  |             </attribute> | ||||||
|            </widget> |            </widget> | ||||||
|           </item> |           </item> | ||||||
|           <item row="2" column="0"> |           <item row="2" column="0"> | ||||||
| @ -2597,6 +2606,9 @@ Right click for insert and delete options.</string> | |||||||
|             <property name="text"> |             <property name="text"> | ||||||
|              <string>EU VHF Contest</string> |              <string>EU VHF Contest</string> | ||||||
|             </property> |             </property> | ||||||
|  |             <attribute name="buttonGroup"> | ||||||
|  |              <string notr="true">special_op_activity_button_group</string> | ||||||
|  |             </attribute> | ||||||
|            </widget> |            </widget> | ||||||
|           </item> |           </item> | ||||||
|           <item row="1" column="0"> |           <item row="1" column="0"> | ||||||
| @ -2613,6 +2625,9 @@ Right click for insert and delete options.</string> | |||||||
|             <property name="text"> |             <property name="text"> | ||||||
|              <string>NA VHF Contest</string> |              <string>NA VHF Contest</string> | ||||||
|             </property> |             </property> | ||||||
|  |             <attribute name="buttonGroup"> | ||||||
|  |              <string notr="true">special_op_activity_button_group</string> | ||||||
|  |             </attribute> | ||||||
|            </widget> |            </widget> | ||||||
|           </item> |           </item> | ||||||
|           <item row="0" column="4" rowspan="3"> |           <item row="0" column="4" rowspan="3"> | ||||||
| @ -2636,6 +2651,9 @@ Right click for insert and delete options.</string> | |||||||
|             <property name="checked"> |             <property name="checked"> | ||||||
|              <bool>true</bool> |              <bool>true</bool> | ||||||
|             </property> |             </property> | ||||||
|  |             <attribute name="buttonGroup"> | ||||||
|  |              <string notr="true">special_op_activity_button_group</string> | ||||||
|  |             </attribute> | ||||||
|            </widget> |            </widget> | ||||||
|           </item> |           </item> | ||||||
|          </layout> |          </layout> | ||||||
| @ -2918,9 +2936,9 @@ Right click for insert and delete options.</string> | |||||||
|   <tabstop>rbFox</tabstop> |   <tabstop>rbFox</tabstop> | ||||||
|   <tabstop>rbNA_VHF_Contest</tabstop> |   <tabstop>rbNA_VHF_Contest</tabstop> | ||||||
|   <tabstop>rbEU_VHF_Contest</tabstop> |   <tabstop>rbEU_VHF_Contest</tabstop> | ||||||
|   <tabstop>rbFieldDay</tabstop> |   <tabstop>rbField_Day</tabstop> | ||||||
|   <tabstop>FieldDay_Exchange</tabstop> |   <tabstop>Field_Day_Exchange</tabstop> | ||||||
|   <tabstop>rbRTTYroundup</tabstop> |   <tabstop>rbRTTY_Roundup</tabstop> | ||||||
|   <tabstop>RTTY_Exchange</tabstop> |   <tabstop>RTTY_Exchange</tabstop> | ||||||
|  </tabstops> |  </tabstops> | ||||||
|  <resources/> |  <resources/> | ||||||
| @ -2991,12 +3009,13 @@ Right click for insert and delete options.</string> | |||||||
|   </connection> |   </connection> | ||||||
|  </connections> |  </connections> | ||||||
|  <buttongroups> |  <buttongroups> | ||||||
|   <buttongroup name="TX_audio_source_button_group"/> |  | ||||||
|   <buttongroup name="split_mode_button_group"/> |  | ||||||
|   <buttongroup name="CAT_stop_bits_button_group"/> |   <buttongroup name="CAT_stop_bits_button_group"/> | ||||||
|  |   <buttongroup name="TX_audio_source_button_group"/> | ||||||
|   <buttongroup name="CAT_data_bits_button_group"/> |   <buttongroup name="CAT_data_bits_button_group"/> | ||||||
|   <buttongroup name="CAT_handshake_button_group"/> |   <buttongroup name="CAT_handshake_button_group"/> | ||||||
|   <buttongroup name="PTT_method_button_group"/> |   <buttongroup name="split_mode_button_group"/> | ||||||
|   <buttongroup name="TX_mode_button_group"/> |   <buttongroup name="TX_mode_button_group"/> | ||||||
|  |   <buttongroup name="PTT_method_button_group"/> | ||||||
|  |   <buttongroup name="special_op_activity_button_group"/> | ||||||
|  </buttongroups> |  </buttongroups> | ||||||
| </ui> | </ui> | ||||||
|  | |||||||
							
								
								
									
										254
									
								
								mainwindow.cpp
									
									
									
									
									
								
							
							
						
						
									
										254
									
								
								mainwindow.cpp
									
									
									
									
									
								
							| @ -165,6 +165,8 @@ int   fast_jh2 {0}; | |||||||
| int narg[15]; | int narg[15]; | ||||||
| QVector<QColor> g_ColorTbl; | QVector<QColor> g_ColorTbl; | ||||||
| 
 | 
 | ||||||
|  | using SpecOp = Configuration::SpecialOperatingActivity; | ||||||
|  | 
 | ||||||
| namespace | namespace | ||||||
| { | { | ||||||
|   Radio::Frequency constexpr default_frequency {14076000}; |   Radio::Frequency constexpr default_frequency {14076000}; | ||||||
| @ -1172,23 +1174,15 @@ void MainWindow::readSettings() | |||||||
|   m_audioThreadPriority = static_cast<QThread::Priority> (m_settings->value ("Audio/ThreadPriority", QThread::HighPriority).toInt () % 8); |   m_audioThreadPriority = static_cast<QThread::Priority> (m_settings->value ("Audio/ThreadPriority", QThread::HighPriority).toInt () % 8); | ||||||
|   m_settings->endGroup (); |   m_settings->endGroup (); | ||||||
| 
 | 
 | ||||||
|   setContestType(); |   checkMSK144ContestType(); | ||||||
|   if(displayMsgAvg) on_actionMessage_averaging_triggered(); |   if(displayMsgAvg) on_actionMessage_averaging_triggered(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::setContestType() | void MainWindow::checkMSK144ContestType() | ||||||
| { | { | ||||||
|   m_nContest=NONE; |  | ||||||
|   if(m_config.bSpecialOp())  |   if(m_config.bSpecialOp())  | ||||||
|     { |     { | ||||||
|       if(m_config.bNA_VHF_Contest()) m_nContest=NA_VHF; |       if(m_mode=="MSK144" && SpecOp::EU_VHF < m_config.special_op_id()) | ||||||
|       if(m_config.bEU_VHF_Contest()) m_nContest=EU_VHF; |  | ||||||
|       if(m_config.bFieldDay()) m_nContest=FIELD_DAY; |  | ||||||
|       if(m_config.bRTTYroundup()) m_nContest=RTTY; |  | ||||||
|       if(m_config.bFox()) m_nContest=FOX; |  | ||||||
|       if(m_config.bHound()) m_nContest=HOUND; |  | ||||||
| 
 |  | ||||||
|       if(m_mode=="MSK144" && m_nContest>EU_VHF) |  | ||||||
|         { |         { | ||||||
|           MessageBox::warning_message (this, tr ("Improper mode"), |           MessageBox::warning_message (this, tr ("Improper mode"), | ||||||
|            "Mode will be changed to FT8. MSK144 not available if Fox, Hound, Field Day, or RTTY contest is selected."); |            "Mode will be changed to FT8. MSK144 not available if Fox, Hound, Field Day, or RTTY contest is selected."); | ||||||
| @ -1536,7 +1530,7 @@ void MainWindow::fastSink(qint64 frames) | |||||||
|   float pxmax = 0; |   float pxmax = 0; | ||||||
|   float rmsNoGain = 0; |   float rmsNoGain = 0; | ||||||
|   int ftol = ui->sbFtol->value (); |   int ftol = ui->sbFtol->value (); | ||||||
|   int nContest=m_nContest; |   int nContest=(int) m_config.special_op_id(); | ||||||
|   hspec_(dec_data.d2,&k,&nutc0,&nTRpDepth,&RxFreq,&ftol,&nContest,&bmsk144, |   hspec_(dec_data.d2,&k,&nutc0,&nTRpDepth,&RxFreq,&ftol,&nContest,&bmsk144, | ||||||
|          &m_bTrain,m_phaseEqCoefficients.constData(),&m_inGain,&dec_data.params.mycall[0], |          &m_bTrain,m_phaseEqCoefficients.constData(),&m_inGain,&dec_data.params.mycall[0], | ||||||
|          &dec_data.params.hiscall[0],&bshmsg,&bswl, |          &dec_data.params.hiscall[0],&bshmsg,&bswl, | ||||||
| @ -1633,9 +1627,9 @@ void MainWindow::on_actionSettings_triggered()               //Setup Dialog | |||||||
|   // things that might change that we need know about
 |   // things that might change that we need know about
 | ||||||
|   auto callsign = m_config.my_callsign (); |   auto callsign = m_config.my_callsign (); | ||||||
|   auto my_grid = m_config.my_grid (); |   auto my_grid = m_config.my_grid (); | ||||||
|   int nContest0=m_nContest; |   SpecOp nContest0=m_config.special_op_id(); | ||||||
|   if (QDialog::Accepted == m_config.exec ()) { |   if (QDialog::Accepted == m_config.exec ()) { | ||||||
|     setContestType(); |     checkMSK144ContestType(); | ||||||
|     if (m_config.my_callsign () != callsign) { |     if (m_config.my_callsign () != callsign) { | ||||||
|       m_baseCall = Radio::base_callsign (m_config.my_callsign ()); |       m_baseCall = Radio::base_callsign (m_config.my_callsign ()); | ||||||
|       morse_(const_cast<char *> (m_config.my_callsign ().toLatin1().constData()), |       morse_(const_cast<char *> (m_config.my_callsign ().toLatin1().constData()), | ||||||
| @ -1701,7 +1695,7 @@ void MainWindow::on_actionSettings_triggered()               //Setup Dialog | |||||||
|       ui->actionEnable_AP_JT65->setVisible(false); |       ui->actionEnable_AP_JT65->setVisible(false); | ||||||
|     } |     } | ||||||
|     m_opCall=m_config.opCall(); |     m_opCall=m_config.opCall(); | ||||||
|     if(m_nContest!=nContest0) ui->tx1->setEnabled(true); |     if(m_config.special_op_id()!=nContest0) ui->tx1->setEnabled(true); | ||||||
|   } |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -1782,7 +1776,8 @@ void MainWindow::auto_tx_mode (bool state) | |||||||
| 
 | 
 | ||||||
| void MainWindow::keyPressEvent (QKeyEvent * e) | void MainWindow::keyPressEvent (QKeyEvent * e) | ||||||
| { | { | ||||||
|   if(FOX==m_nContest) { | 
 | ||||||
|  |   if(SpecOp::FOX == m_config.special_op_id()) { | ||||||
|     switch (e->key()) { |     switch (e->key()) { | ||||||
|       case Qt::Key_Return: |       case Qt::Key_Return: | ||||||
|         doubleClickOnCall2(Qt::KeyboardModifier(Qt::ShiftModifier + Qt::ControlModifier + Qt::AltModifier)); |         doubleClickOnCall2(Qt::KeyboardModifier(Qt::ShiftModifier + Qt::ControlModifier + Qt::AltModifier)); | ||||||
| @ -1797,7 +1792,7 @@ void MainWindow::keyPressEvent (QKeyEvent * e) | |||||||
|     QMainWindow::keyPressEvent (e); |     QMainWindow::keyPressEvent (e); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if(HOUND==m_nContest) { |   if(SpecOp::HOUND == m_config.special_op_id()) { | ||||||
|     switch (e->key()) { |     switch (e->key()) { | ||||||
|       case Qt::Key_Return: |       case Qt::Key_Return: | ||||||
|         auto_tx_mode(true); |         auto_tx_mode(true); | ||||||
| @ -1888,11 +1883,11 @@ void MainWindow::keyPressEvent (QKeyEvent * e) | |||||||
|         return; |         return; | ||||||
|       } |       } | ||||||
|     case Qt::Key_E: |     case Qt::Key_E: | ||||||
|       if((e->modifiers() & Qt::ShiftModifier) and m_nContest<FOX) { |       if((e->modifiers() & Qt::ShiftModifier) and SpecOp::FOX > m_config.special_op_id()) { | ||||||
|           ui->txFirstCheckBox->setChecked(false); |           ui->txFirstCheckBox->setChecked(false); | ||||||
|           return; |           return; | ||||||
|       } |       } | ||||||
|       else if((e->modifiers() & Qt::ControlModifier) and m_nContest<FOX) { |       else if((e->modifiers() & Qt::ControlModifier) and SpecOp::FOX > m_config.special_op_id()) { | ||||||
|           ui->txFirstCheckBox->setChecked(true); |           ui->txFirstCheckBox->setChecked(true); | ||||||
|           return; |           return; | ||||||
|       } |       } | ||||||
| @ -2403,7 +2398,7 @@ void MainWindow::on_actionAstronomical_data_toggled (bool checked) | |||||||
| void MainWindow::on_actionFox_Log_triggered() | void MainWindow::on_actionFox_Log_triggered() | ||||||
| { | { | ||||||
|   on_actionMessage_averaging_triggered(); |   on_actionMessage_averaging_triggered(); | ||||||
|   m_msgAvgWidget->foxLogSetup(m_nContest); |   m_msgAvgWidget->foxLogSetup((int) m_config.special_op_id()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::on_actionColors_triggered() | void MainWindow::on_actionColors_triggered() | ||||||
| @ -2716,8 +2711,8 @@ void MainWindow::decode()                                       //decode() | |||||||
|   dec_data.params.nfa=m_wideGraph->nStartFreq(); |   dec_data.params.nfa=m_wideGraph->nStartFreq(); | ||||||
|   dec_data.params.nfSplit=m_wideGraph->Fmin(); |   dec_data.params.nfSplit=m_wideGraph->Fmin(); | ||||||
|   dec_data.params.nfb=m_wideGraph->Fmax(); |   dec_data.params.nfb=m_wideGraph->Fmax(); | ||||||
|   if(m_mode=="FT8" and m_nContest==HOUND and !ui->cbRxAll->isChecked()) dec_data.params.nfb=1000; |   if(m_mode=="FT8" and SpecOp::HOUND == m_config.special_op_id() and !ui->cbRxAll->isChecked()) dec_data.params.nfb=1000; | ||||||
|   if(m_mode=="FT8" and m_nContest==FOX) dec_data.params.nfqso=200; |   if(m_mode=="FT8" and SpecOp::FOX == m_config.special_op_id() ) dec_data.params.nfqso=200; | ||||||
|   dec_data.params.ntol=ui->sbFtol->value (); |   dec_data.params.ntol=ui->sbFtol->value (); | ||||||
|   if(m_mode=="JT9+JT65" or !m_config.enable_VHF_features()) { |   if(m_mode=="JT9+JT65" or !m_config.enable_VHF_features()) { | ||||||
|     dec_data.params.ntol=20; |     dec_data.params.ntol=20; | ||||||
| @ -2753,7 +2748,7 @@ void MainWindow::decode()                                       //decode() | |||||||
|   dec_data.params.emedelay=0.0; |   dec_data.params.emedelay=0.0; | ||||||
|   if(m_config.decode_at_52s()) dec_data.params.emedelay=2.5; |   if(m_config.decode_at_52s()) dec_data.params.emedelay=2.5; | ||||||
|   dec_data.params.minSync=ui->syncSpinBox->isVisible () ? m_minSync : 0; |   dec_data.params.minSync=ui->syncSpinBox->isVisible () ? m_minSync : 0; | ||||||
|   dec_data.params.nexp_decode=m_nContest; |   dec_data.params.nexp_decode= (int) m_config.special_op_id(); | ||||||
|   if(m_config.single_decode()) dec_data.params.nexp_decode += 32; |   if(m_config.single_decode()) dec_data.params.nexp_decode += 32; | ||||||
|   if(m_config.enable_VHF_features()) dec_data.params.nexp_decode += 64; |   if(m_config.enable_VHF_features()) dec_data.params.nexp_decode += 64; | ||||||
|   dec_data.params.ldecode77 = true; |   dec_data.params.ldecode77 = true; | ||||||
| @ -2893,7 +2888,7 @@ void MainWindow::decodeDone () | |||||||
|   decodeBusy(false); |   decodeBusy(false); | ||||||
|   m_RxLog=0; |   m_RxLog=0; | ||||||
|   m_blankLine=true; |   m_blankLine=true; | ||||||
|   if(m_nContest==FOX) houndCallers(); |   if(SpecOp::FOX == m_config.special_op_id()) houndCallers(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::readFromStdout()                             //readFromStdout
 | void MainWindow::readFromStdout()                             //readFromStdout
 | ||||||
| @ -2947,7 +2942,7 @@ void MainWindow::readFromStdout()                             //readFromStdout | |||||||
|                                      , tr ("Cannot open \"%1\" for append: %2") |                                      , tr ("Cannot open \"%1\" for append: %2") | ||||||
|                                      .arg (f.fileName ()).arg (f.errorString ())); |                                      .arg (f.fileName ()).arg (f.errorString ())); | ||||||
|       } |       } | ||||||
|       if (m_config.insert_blank () && m_blankLine && m_nContest!=FOX) { |       if (m_config.insert_blank () && m_blankLine && SpecOp::FOX != m_config.special_op_id()) { | ||||||
|         QString band; |         QString band; | ||||||
|         if((QDateTime::currentMSecsSinceEpoch() / 1000 - m_secBandChanged) > 4*m_TRperiod/4) { |         if((QDateTime::currentMSecsSinceEpoch() / 1000 - m_secBandChanged) > 4*m_TRperiod/4) { | ||||||
|           band = ' ' + m_config.bands ()->find (m_freqNominal); |           band = ' ' + m_config.bands ()->find (m_freqNominal); | ||||||
| @ -2961,7 +2956,7 @@ void MainWindow::readFromStdout()                             //readFromStdout | |||||||
|       DecodedText decodedtext {QString::fromUtf8(t.constData()) |       DecodedText decodedtext {QString::fromUtf8(t.constData()) | ||||||
|             .remove(QRegularExpression {"\r|\n"}).remove("TU; ")}; |             .remove(QRegularExpression {"\r|\n"}).remove("TU; ")}; | ||||||
| 
 | 
 | ||||||
|       if(m_mode=="FT8" and m_nContest==FOX and |       if(m_mode=="FT8" and SpecOp::FOX == m_config.special_op_id() and | ||||||
|          (decodedtext.string().contains("R+") or decodedtext.string().contains("R-"))) { |          (decodedtext.string().contains("R+") or decodedtext.string().contains("R-"))) { | ||||||
|         auto for_us  = decodedtext.string().contains(" " + m_config.my_callsign() + " ") or |         auto for_us  = decodedtext.string().contains(" " + m_config.my_callsign() + " ") or | ||||||
|             decodedtext.string().contains(" "+m_baseCall) or |             decodedtext.string().contains(" "+m_baseCall) or | ||||||
| @ -2977,7 +2972,7 @@ void MainWindow::readFromStdout()                             //readFromStdout | |||||||
| 
 | 
 | ||||||
| //Left (Band activity) window
 | //Left (Band activity) window
 | ||||||
|       if(!bAvgMsg) { |       if(!bAvgMsg) { | ||||||
|         if(m_mode=="FT8" and m_nContest==FOX) { |         if(m_mode=="FT8" and SpecOp::FOX == m_config.special_op_id()) { | ||||||
|           if(!m_bDisplayedOnce) { |           if(!m_bDisplayedOnce) { | ||||||
|             // This hack sets the font.  Surely there's a better way!
 |             // This hack sets the font.  Surely there's a better way!
 | ||||||
|             DecodedText dt{"."}; |             DecodedText dt{"."}; | ||||||
| @ -3004,15 +2999,15 @@ void MainWindow::readFromStdout()                             //readFromStdout | |||||||
|             || ("DE" == parts[5] && qAbs (ui->RxFreqSpinBox->value () - audioFreq) <= 10); |             || ("DE" == parts[5] && qAbs (ui->RxFreqSpinBox->value () - audioFreq) <= 10); | ||||||
|           if(m_baseCall==m_config.my_callsign() and m_baseCall!=parts[5]) for_us=false; |           if(m_baseCall==m_config.my_callsign() and m_baseCall!=parts[5]) for_us=false; | ||||||
|           if(m_bCallingCQ && !m_bAutoReply && for_us && ui->cbFirst->isChecked() and |           if(m_bCallingCQ && !m_bAutoReply && for_us && ui->cbFirst->isChecked() and | ||||||
|              m_nContest<FOX) { |              SpecOp::FOX > m_config.special_op_id()) { | ||||||
|             m_bDoubleClicked=true; |             m_bDoubleClicked=true; | ||||||
|             m_bAutoReply = true; |             m_bAutoReply = true; | ||||||
|             if(m_nContest!=FOX) processMessage (decodedtext); |             if(SpecOp::FOX != m_config.special_op_id()) processMessage (decodedtext); | ||||||
|             ui->cbFirst->setStyleSheet(""); |             ui->cbFirst->setStyleSheet(""); | ||||||
|           } |           } | ||||||
|           if(m_nContest==FOX and decodedtext.string().contains(" DE ")) for_us=true; //Hound with compound callsign
 |           if(SpecOp::FOX==m_config.special_op_id() and decodedtext.string().contains(" DE ")) for_us=true; //Hound with compound callsign
 | ||||||
|           if(m_nContest==FOX and for_us and (audioFreq<1000)) bDisplayRight=true; |           if(SpecOp::FOX==m_config.special_op_id() and for_us and (audioFreq<1000)) bDisplayRight=true; | ||||||
|           if(m_nContest!=FOX and (for_us or (abs(audioFreq - m_wideGraph->rxFreq()) <= 10))) bDisplayRight=true; |           if(SpecOp::FOX!=m_config.special_op_id() and (for_us or (abs(audioFreq - m_wideGraph->rxFreq()) <= 10))) bDisplayRight=true; | ||||||
|         } |         } | ||||||
|       } else { |       } else { | ||||||
|         if(abs(audioFreq - m_wideGraph->rxFreq()) <= 10) bDisplayRight=true; |         if(abs(audioFreq - m_wideGraph->rxFreq()) <= 10) bDisplayRight=true; | ||||||
| @ -3032,7 +3027,7 @@ void MainWindow::readFromStdout()                             //readFromStdout | |||||||
|         m_QSOText = decodedtext.string ().trimmed (); |         m_QSOText = decodedtext.string ().trimmed (); | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if(m_mode=="FT8" and m_nContest==HOUND) { |       if(m_mode=="FT8" and SpecOp::HOUND==m_config.special_op_id()) { | ||||||
|         if(decodedtext.string().contains(";")) { |         if(decodedtext.string().contains(";")) { | ||||||
|           QStringList w=decodedtext.string().mid(24).split(" ",QString::SkipEmptyParts); |           QStringList w=decodedtext.string().mid(24).split(" ",QString::SkipEmptyParts); | ||||||
|           QString foxCall=w.at(3); |           QString foxCall=w.at(3); | ||||||
| @ -3074,7 +3069,7 @@ void MainWindow::readFromStdout()                             //readFromStdout | |||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
| //### I think this is where we are preventing Hounds from spotting Fox ###
 | //### I think this is where we are preventing Hounds from spotting Fox ###
 | ||||||
|       if(m_mode!="FT8" or (m_nContest != HOUND)) { |       if(m_mode!="FT8" or (SpecOp::HOUND != m_config.special_op_id())) { | ||||||
|         if(m_mode=="FT8" or m_mode=="QRA64" or m_mode=="JT4" or m_mode=="JT65" or m_mode=="JT9") { |         if(m_mode=="FT8" or m_mode=="QRA64" or m_mode=="JT4" or m_mode=="JT65" or m_mode=="JT9") { | ||||||
|           auto_sequence (decodedtext, 25, 50); |           auto_sequence (decodedtext, 25, 50); | ||||||
|         } |         } | ||||||
| @ -3175,7 +3170,7 @@ void MainWindow::auto_sequence (DecodedText const& message, unsigned start_toler | |||||||
|                 // look for type 2 compound call replies on our Tx and Rx offsets
 |                 // look for type 2 compound call replies on our Tx and Rx offsets
 | ||||||
|                 && ((within_tolerance && "DE" == message_words.at (1)) |                 && ((within_tolerance && "DE" == message_words.at (1)) | ||||||
|                     || message_words.at (1).contains (m_baseCall))))) { |                     || message_words.at (1).contains (m_baseCall))))) { | ||||||
|       if(m_nContest!=FOX) processMessage (message); |       if(SpecOp::FOX != m_config.special_op_id()) processMessage (message); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
| } | } | ||||||
| @ -3359,7 +3354,7 @@ void MainWindow::guiUpdate() | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if(m_mode=="FT8" and m_nContest==FOX) { |     if(m_mode=="FT8" and SpecOp::FOX==m_config.special_op_id()) { | ||||||
| // Don't allow Fox mode in any of the default FT8 sub-bands.
 | // Don't allow Fox mode in any of the default FT8 sub-bands.
 | ||||||
|       qint32 ft8Freq[]={1840,3573,7074,10136,14074,18100,21074,24915,28074,50313,70100}; |       qint32 ft8Freq[]={1840,3573,7074,10136,14074,18100,21074,24915,28074,50313,70100}; | ||||||
|       for(int i=0; i<11; i++) { |       for(int i=0; i<11; i++) { | ||||||
| @ -3403,12 +3398,12 @@ void MainWindow::guiUpdate() | |||||||
|       g_iptt = 1; |       g_iptt = 1; | ||||||
|       setRig (); |       setRig (); | ||||||
|       if(m_mode=="FT8") { |       if(m_mode=="FT8") { | ||||||
|         if (m_nContest==FOX) { |         if (SpecOp::FOX == m_config.special_op_id()) { | ||||||
|           if (ui->TxFreqSpinBox->value() > 900) { |           if (ui->TxFreqSpinBox->value() > 900) { | ||||||
|             ui->TxFreqSpinBox->setValue(300); |             ui->TxFreqSpinBox->setValue(300); | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|         else if (m_nContest==HOUND) { |         else if (SpecOp::HOUND == m_config.special_op_id()) { | ||||||
|           if(m_auto && !m_tune) { |           if(m_auto && !m_tune) { | ||||||
|             if (ui->TxFreqSpinBox->value() < 999 && m_ntx != 3) { |             if (ui->TxFreqSpinBox->value() < 999 && m_ntx != 3) { | ||||||
|               int nf = (qrand() % 2000) + 1000;      // Hound randomized range: 1000-3000 Hz
 |               int nf = (qrand() % 2000) + 1000;      // Hound randomized range: 1000-3000 Hz
 | ||||||
| @ -3430,7 +3425,7 @@ void MainWindow::guiUpdate() | |||||||
| 
 | 
 | ||||||
| // If HoldTxFreq is not checked, randomize Fox's Tx Freq
 | // If HoldTxFreq is not checked, randomize Fox's Tx Freq
 | ||||||
| // NB: Maybe this should be done no more than once every 5 minutes or so ?
 | // NB: Maybe this should be done no more than once every 5 minutes or so ?
 | ||||||
|       if(m_mode=="FT8" and m_nContest==FOX and !ui->cbHoldTxFreq->isChecked()) { |       if(m_mode=="FT8" and SpecOp::FOX==m_config.special_op_id() and !ui->cbHoldTxFreq->isChecked()) { | ||||||
|         int fTx = 300.0 + 300.0*double(qrand())/RAND_MAX; |         int fTx = 300.0 + 300.0*double(qrand())/RAND_MAX; | ||||||
|         ui->TxFreqSpinBox->setValue(fTx); |         ui->TxFreqSpinBox->setValue(fTx); | ||||||
|       } |       } | ||||||
| @ -3486,7 +3481,7 @@ void MainWindow::guiUpdate() | |||||||
|       } |       } | ||||||
|       ba=msg2.toLatin1(); |       ba=msg2.toLatin1(); | ||||||
|     } else { |     } else { | ||||||
|       if(m_nContest==HOUND and m_ntx!=3) {   //Hound transmits only Tx1 or Tx3
 |       if(SpecOp::HOUND == m_config.special_op_id() and m_ntx!=3) {   //Hound transmits only Tx1 or Tx3
 | ||||||
|         m_ntx=1; |         m_ntx=1; | ||||||
|         ui->txrb1->setChecked(true); |         ui->txrb1->setChecked(true); | ||||||
|       } |       } | ||||||
| @ -3543,7 +3538,7 @@ void MainWindow::guiUpdate() | |||||||
|             } |             } | ||||||
|           } |           } | ||||||
|           if(m_modeTx=="FT8") { |           if(m_modeTx=="FT8") { | ||||||
|             if(m_nContest==FOX and ui->tabWidget->currentIndex()==2) { |             if(SpecOp::FOX==m_config.special_op_id() and ui->tabWidget->currentIndex()==2) { | ||||||
|               foxTxSequencer(); |               foxTxSequencer(); | ||||||
|             } else { |             } else { | ||||||
|               m_isync=2; |               m_isync=2; | ||||||
| @ -3551,7 +3546,7 @@ void MainWindow::guiUpdate() | |||||||
|               char ft8msgbits[77]; |               char ft8msgbits[77]; | ||||||
|               genft8_(message, &m_i3, &m_n3, &m_isync, msgsent, |               genft8_(message, &m_i3, &m_n3, &m_isync, msgsent, | ||||||
|                       const_cast<char *> (ft8msgbits), const_cast<int *> (itone), 37, 37); |                       const_cast<char *> (ft8msgbits), const_cast<int *> (itone), 37, 37); | ||||||
|               if(m_nContest==FOX) { |               if(SpecOp::FOX == m_config.special_op_id()) { | ||||||
|                 //Fox must generate the full Tx waveform, not just an itone[] array.
 |                 //Fox must generate the full Tx waveform, not just an itone[] array.
 | ||||||
|                 QString fm = QString::fromStdString(message).trimmed(); |                 QString fm = QString::fromStdString(message).trimmed(); | ||||||
|                 foxGenWaveform(0,fm); |                 foxGenWaveform(0,fm); | ||||||
| @ -3564,12 +3559,12 @@ void MainWindow::guiUpdate() | |||||||
|               } |               } | ||||||
|             } |             } | ||||||
|           } |           } | ||||||
|           if(m_nContest==EU_VHF) { |           if(SpecOp::EU_VHF==m_config.special_op_id()) { | ||||||
|             if(m_ntx==2) m_xSent=ui->tx2->text().right(13); |             if(m_ntx==2) m_xSent=ui->tx2->text().right(13); | ||||||
|             if(m_ntx==3) m_xSent=ui->tx3->text().right(13); |             if(m_ntx==3) m_xSent=ui->tx3->text().right(13); | ||||||
|           } |           } | ||||||
| 
 | 
 | ||||||
|           if(m_nContest==FIELD_DAY or m_nContest==RTTY) { |           if(SpecOp::FIELD_DAY==m_config.special_op_id() or SpecOp::RTTY==m_config.special_op_id()) { | ||||||
|             if(m_ntx==2 or m_ntx==3) { |             if(m_ntx==2 or m_ntx==3) { | ||||||
|               QStringList t=ui->tx2->text().split(' ', QString::SkipEmptyParts); |               QStringList t=ui->tx2->text().split(' ', QString::SkipEmptyParts); | ||||||
|               int n=t.size(); |               int n=t.size(); | ||||||
| @ -3704,7 +3699,7 @@ void MainWindow::guiUpdate() | |||||||
|         write_transmit_entry ("ALL.TXT"); |         write_transmit_entry ("ALL.TXT"); | ||||||
|       } |       } | ||||||
| 
 | 
 | ||||||
|       if (m_config.TX_messages () && !m_tune && m_nContest!=FOX) { |       if (m_config.TX_messages () && !m_tune && SpecOp::FOX!=m_config.special_op_id()) { | ||||||
|         ui->decodedTextBrowser2->displayTransmittedText(current_message, m_modeTx, |         ui->decodedTextBrowser2->displayTransmittedText(current_message, m_modeTx, | ||||||
|               ui->TxFreqSpinBox->value(),m_bFastMode); |               ui->TxFreqSpinBox->value(),m_bFastMode); | ||||||
|       } |       } | ||||||
| @ -3738,11 +3733,14 @@ void MainWindow::guiUpdate() | |||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if(m_mode=="FT8" or m_mode=="MSK144") { |   if(m_mode=="FT8" or m_mode=="MSK144") { | ||||||
|     if(ui->txrb1->isEnabled() and (m_nContest==NA_VHF or m_nContest==FIELD_DAY or m_nContest==RTTY)) { |     if(ui->txrb1->isEnabled() and  | ||||||
|  |        (SpecOp::NA_VHF==m_config.special_op_id() or  | ||||||
|  |         SpecOp::FIELD_DAY==m_config.special_op_id() or  | ||||||
|  |         SpecOp::RTTY==m_config.special_op_id()) ) {  | ||||||
|       //We're in a contest-like mode other than EU_VHF: start QSO with Tx2.
 |       //We're in a contest-like mode other than EU_VHF: start QSO with Tx2.
 | ||||||
|       ui->tx1->setEnabled(false); |       ui->tx1->setEnabled(false); | ||||||
|     } |     } | ||||||
|     if(!ui->tx1->isEnabled() and m_nContest==EU_VHF) { |     if(!ui->tx1->isEnabled() and SpecOp::EU_VHF==m_config.special_op_id()) {  | ||||||
|       //We're in EU_VHF mode: start QSO with Tx1.
 |       //We're in EU_VHF mode: start QSO with Tx1.
 | ||||||
|       ui->tx1->setEnabled(true); |       ui->tx1->setEnabled(true); | ||||||
|     } |     } | ||||||
| @ -3750,9 +3748,8 @@ void MainWindow::guiUpdate() | |||||||
| 
 | 
 | ||||||
| //Once per second:
 | //Once per second:
 | ||||||
|   if(nsec != m_sec0) { |   if(nsec != m_sec0) { | ||||||
| //    qDebug() << "OneSec:" << m_nContest << m_msgAvgWidget;
 |  | ||||||
|     if((!m_msgAvgWidget or (m_msgAvgWidget and !m_msgAvgWidget->isVisible())) |     if((!m_msgAvgWidget or (m_msgAvgWidget and !m_msgAvgWidget->isVisible())) | ||||||
|        and (m_nContest>0) and (m_nContest<6)) on_actionFox_Log_triggered(); |        and (SpecOp::NONE < m_config.special_op_id()) and (SpecOp::HOUND > m_config.special_op_id())) on_actionFox_Log_triggered(); | ||||||
|     if(m_freqNominal!=0 and m_freqNominal<50000000 and m_config.enable_VHF_features()) { |     if(m_freqNominal!=0 and m_freqNominal<50000000 and m_config.enable_VHF_features()) { | ||||||
|       if(!m_bVHFwarned) vhfWarning(); |       if(!m_bVHFwarned) vhfWarning(); | ||||||
|     } else { |     } else { | ||||||
| @ -3760,7 +3757,7 @@ void MainWindow::guiUpdate() | |||||||
|     } |     } | ||||||
|     m_currentBand=m_config.bands()->find(m_freqNominal); |     m_currentBand=m_config.bands()->find(m_freqNominal); | ||||||
| 
 | 
 | ||||||
|     if(m_nContest == HOUND) { |     if( SpecOp::HOUND == m_config.special_op_id() ) { | ||||||
|       qint32 tHound=QDateTime::currentMSecsSinceEpoch()/1000 - m_tAutoOn; |       qint32 tHound=QDateTime::currentMSecsSinceEpoch()/1000 - m_tAutoOn; | ||||||
|       //To keep calling Fox, Hound must reactivate Enable Tx at least once every 2 minutes
 |       //To keep calling Fox, Hound must reactivate Enable Tx at least once every 2 minutes
 | ||||||
|       if(tHound >= 120 and m_ntx==1) auto_tx_mode(false); |       if(tHound >= 120 and m_ntx==1) auto_tx_mode(false); | ||||||
| @ -3784,7 +3781,7 @@ void MainWindow::guiUpdate() | |||||||
| 
 | 
 | ||||||
|     if(m_transmitting) { |     if(m_transmitting) { | ||||||
|       char s[42]; |       char s[42]; | ||||||
|       if(m_nContest==FOX and ui->tabWidget->currentIndex()==2) { |       if(SpecOp::FOX==m_config.special_op_id() and ui->tabWidget->currentIndex()==2) { | ||||||
|         sprintf(s,"Tx:  %d Slots",foxcom_.nslots); |         sprintf(s,"Tx:  %d Slots",foxcom_.nslots); | ||||||
|       } else { |       } else { | ||||||
|         sprintf(s,"Tx: %s",msgsent); |         sprintf(s,"Tx: %s",msgsent); | ||||||
| @ -3806,7 +3803,7 @@ void MainWindow::guiUpdate() | |||||||
|         } else { |         } else { | ||||||
|           s[40]=0; |           s[40]=0; | ||||||
|           QString t{QString::fromLatin1(s)}; |           QString t{QString::fromLatin1(s)}; | ||||||
|           if(m_nContest==FOX and ui->tabWidget->currentIndex()==2 and foxcom_.nslots==1) { |           if(SpecOp::FOX==m_config.special_op_id() and ui->tabWidget->currentIndex()==2 and foxcom_.nslots==1) { | ||||||
|               t=m_fm1.trimmed(); |               t=m_fm1.trimmed(); | ||||||
|           } |           } | ||||||
|           tx_status_label.setText(t.trimmed()); |           tx_status_label.setText(t.trimmed()); | ||||||
| @ -3918,7 +3915,7 @@ void MainWindow::stopTx2() | |||||||
|     m_ntr=0; |     m_ntr=0; | ||||||
|   } |   } | ||||||
|   last_tx_label.setText("Last Tx: " + m_currentMessage.trimmed()); |   last_tx_label.setText("Last Tx: " + m_currentMessage.trimmed()); | ||||||
| //###  if(m_mode=="FT8" and (m_nContest == HOUND)) auto_tx_mode(false); ###
 | //###  if(m_mode=="FT8" and (SpecOp::HOUND == m_config.special_op_id())) auto_tx_mode(false); ###
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::ba2msg(QByteArray ba, char message[])             //ba2msg()
 | void MainWindow::ba2msg(QByteArray ba, char message[])             //ba2msg()
 | ||||||
| @ -3980,7 +3977,7 @@ void MainWindow::on_txrb1_toggled (bool status) | |||||||
| 
 | 
 | ||||||
| void MainWindow::on_txrb1_doubleClicked () | void MainWindow::on_txrb1_doubleClicked () | ||||||
| { | { | ||||||
|   if(m_mode=="FT8" and (m_nContest==HOUND)) return; |   if(m_mode=="FT8" and SpecOp::HOUND == m_config.special_op_id()) return; | ||||||
|   // skip Tx1, only allowed if not a type 2 compound callsign
 |   // skip Tx1, only allowed if not a type 2 compound callsign
 | ||||||
|   auto const& my_callsign = m_config.my_callsign (); |   auto const& my_callsign = m_config.my_callsign (); | ||||||
|   auto is_compound = my_callsign != m_baseCall; |   auto is_compound = my_callsign != m_baseCall; | ||||||
| @ -4060,7 +4057,7 @@ void MainWindow::on_txb1_clicked() | |||||||
| 
 | 
 | ||||||
| void MainWindow::on_txb1_doubleClicked() | void MainWindow::on_txb1_doubleClicked() | ||||||
| { | { | ||||||
|   if(m_mode=="FT8" and (m_nContest==HOUND)) return; |   if (m_mode=="FT8" and SpecOp::HOUND == m_config.special_op_id()) return; | ||||||
|   // skip Tx1, only allowed if not a type 1 compound callsign
 |   // skip Tx1, only allowed if not a type 1 compound callsign
 | ||||||
|   auto const& my_callsign = m_config.my_callsign (); |   auto const& my_callsign = m_config.my_callsign (); | ||||||
|   auto is_compound = my_callsign != m_baseCall; |   auto is_compound = my_callsign != m_baseCall; | ||||||
| @ -4149,7 +4146,7 @@ void MainWindow::doubleClickOnCall(Qt::KeyboardModifiers modifiers) | |||||||
|     cursor.setPosition(cursor.selectionStart()); |     cursor.setPosition(cursor.selectionStart()); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if(m_nContest==FOX and m_decodedText2) { |   if(SpecOp::FOX==m_config.special_op_id() and m_decodedText2) { | ||||||
|     if(m_houndQueue.count()<10 and m_nSortedHounds>0) { |     if(m_houndQueue.count()<10 and m_nSortedHounds>0) { | ||||||
|       QString t=cursor.block().text(); |       QString t=cursor.block().text(); | ||||||
|       selectHound(t); |       selectHound(t); | ||||||
| @ -4208,8 +4205,8 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
| 
 | 
 | ||||||
|   int nmod = message.timeInSeconds () % (2*m_TRperiod); |   int nmod = message.timeInSeconds () % (2*m_TRperiod); | ||||||
|   m_txFirst=(nmod!=0); |   m_txFirst=(nmod!=0); | ||||||
|   if(m_nContest==HOUND) m_txFirst=false;          //Hound must not transmit first
 |   if( SpecOp::HOUND == m_config.special_op_id() ) m_txFirst=false;          //Hound must not transmit first
 | ||||||
|   if(m_nContest==FOX) m_txFirst=true;             //Fox must always transmit first
 |   if( SpecOp::FOX == m_config.special_op_id() ) m_txFirst=true;             //Fox must always transmit first
 | ||||||
|   ui->txFirstCheckBox->setChecked(m_txFirst); |   ui->txFirstCheckBox->setChecked(m_txFirst); | ||||||
| 
 | 
 | ||||||
|   auto const& message_words = message.messageWords (); |   auto const& message_words = message.messageWords (); | ||||||
| @ -4260,7 +4257,7 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|          && firstcall != m_config.my_callsign () && firstcall != m_baseCall |          && firstcall != m_config.my_callsign () && firstcall != m_baseCall | ||||||
|          && firstcall != "DE") |          && firstcall != "DE") | ||||||
|         || "CQ" == firstcall || "QRZ" == firstcall || ctrl || shift) { |         || "CQ" == firstcall || "QRZ" == firstcall || ctrl || shift) { | ||||||
|       if (((m_nContest != HOUND) || m_mode != "FT8") |       if (((SpecOp::HOUND != m_config.special_op_id()) || m_mode != "FT8") | ||||||
|           && (!ui->cbHoldTxFreq->isChecked () || shift || ctrl)) { |           && (!ui->cbHoldTxFreq->isChecked () || shift || ctrl)) { | ||||||
|         ui->TxFreqSpinBox->setValue(frequency); |         ui->TxFreqSpinBox->setValue(frequency); | ||||||
|       } |       } | ||||||
| @ -4295,10 +4292,10 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|       w34=message_words.at(4); |       w34=message_words.at(4); | ||||||
|     } |     } | ||||||
|     bool bEU_VHF_w2=(nrpt>=520001 and nrpt<=594000); |     bool bEU_VHF_w2=(nrpt>=520001 and nrpt<=594000); | ||||||
|     if(bEU_VHF_w2 and m_nContest!=EU_VHF) { |     if(bEU_VHF_w2 and SpecOp::EU_VHF!=m_config.special_op_id()) { | ||||||
|       // Switch automatically to EU VHF Contest mode
 |       // Switch automatically to EU VHF Contest mode
 | ||||||
|       m_config.setEU_VHF_Contest(); |       m_config.setEU_VHF_Contest(); | ||||||
|       m_nContest=EU_VHF; | //      m_nContest=EU_VHF;
 | ||||||
|       if(m_transmitting) m_restart=true; |       if(m_transmitting) m_restart=true; | ||||||
|       ui->decodedTextBrowser2->displayQSY (QString{"Enabled EU VHF Contest messages."}); |       ui->decodedTextBrowser2->displayQSY (QString{"Enabled EU VHF Contest messages."}); | ||||||
|       QString t0="EU VHF"; |       QString t0="EU VHF"; | ||||||
| @ -4317,14 +4314,14 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|       t0=t.at(n-3); |       t0=t.at(n-3); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if(bFieldDay_msg and m_nContest!=FIELD_DAY) { |     if(bFieldDay_msg and SpecOp::FIELD_DAY!=m_config.special_op_id()) { | ||||||
|       // ### Should be in ARRL Field Day mode ??? ###
 |       // ### Should be in ARRL Field Day mode ??? ###
 | ||||||
|       MessageBox::information_message (this, tr ("Should you switch to ARRL Field Day mode?")); |       MessageBox::information_message (this, tr ("Should you switch to ARRL Field Day mode?")); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     n=w34.toInt(); |     n=w34.toInt(); | ||||||
|     bool bRTTY = (n>=529 and n<=599); |     bool bRTTY = (n>=529 and n<=599); | ||||||
|     if(bRTTY and m_nContest!=RTTY) { |     if(bRTTY and SpecOp::RTTY != m_config.special_op_id()) { | ||||||
|       // ### Should be in RTTY contest mode ??? ###
 |       // ### Should be in RTTY contest mode ??? ###
 | ||||||
|       MessageBox::information_message (this, tr ("Should you switch to RTTY contest mode?")); |       MessageBox::information_message (this, tr ("Should you switch to RTTY contest mode?")); | ||||||
|     } |     } | ||||||
| @ -4333,15 +4330,15 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|        && (message_words.at(1).contains(m_baseCall) || "DE" == message_words.at(1)) |        && (message_words.at(1).contains(m_baseCall) || "DE" == message_words.at(1)) | ||||||
|        && (message_words.at(2).contains(qso_partner_base_call) or bEU_VHF_w2)) { |        && (message_words.at(2).contains(qso_partner_base_call) or bEU_VHF_w2)) { | ||||||
| 
 | 
 | ||||||
|       if(message_words.at(3).contains(grid_regexp) and m_nContest!=EU_VHF) { |       if(message_words.at(3).contains(grid_regexp) and SpecOp::EU_VHF!=m_config.special_op_id()) { | ||||||
|         if(m_nContest==NA_VHF){ |         if(SpecOp::NA_VHF==m_config.special_op_id()){ | ||||||
|           gen_msg=setTxMsg(3); |           gen_msg=setTxMsg(3); | ||||||
|           m_QSOProgress=ROGER_REPORT; |           m_QSOProgress=ROGER_REPORT; | ||||||
|         } else { |         } else { | ||||||
|           gen_msg=setTxMsg(2); |           gen_msg=setTxMsg(2); | ||||||
|           m_QSOProgress=REPORT; |           m_QSOProgress=REPORT; | ||||||
|         } |         } | ||||||
|       } else if(w34.contains(grid_regexp) and m_nContest==EU_VHF) { |       } else if(w34.contains(grid_regexp) and SpecOp::EU_VHF==m_config.special_op_id()) { | ||||||
|         if(nrpt==0) { |         if(nrpt==0) { | ||||||
|           gen_msg=setTxMsg(2); |           gen_msg=setTxMsg(2); | ||||||
|           m_QSOProgress=REPORT; |           m_QSOProgress=REPORT; | ||||||
| @ -4354,12 +4351,12 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|             m_QSOProgress=ROGER_REPORT; |             m_QSOProgress=ROGER_REPORT; | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|       } else if(m_nContest==RTTY and bRTTY) { |       } else if(SpecOp::RTTY == m_config.special_op_id() and bRTTY) { | ||||||
|         gen_msg=setTxMsg(3); |         gen_msg=setTxMsg(3); | ||||||
|         m_QSOProgress=ROGER_REPORT; |         m_QSOProgress=ROGER_REPORT; | ||||||
|         int n=t.size(); |         int n=t.size(); | ||||||
|         m_xRcvd=t[n-2] + " " + t[n-1]; |         m_xRcvd=t[n-2] + " " + t[n-1]; | ||||||
|       } else if(m_nContest==FIELD_DAY and bFieldDay_msg) { |       } else if(SpecOp::FIELD_DAY==m_config.special_op_id() and bFieldDay_msg) { | ||||||
|         if(t0=="R") { |         if(t0=="R") { | ||||||
|           gen_msg=setTxMsg(4); |           gen_msg=setTxMsg(4); | ||||||
|           m_QSOProgress=ROGERS; |           m_QSOProgress=ROGERS; | ||||||
| @ -4376,7 +4373,7 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|             m_gen_message_is_cq = false; |             m_gen_message_is_cq = false; | ||||||
|           } else { |           } else { | ||||||
|             m_bTUmsg=false; |             m_bTUmsg=false; | ||||||
|             if(m_nContest==RTTY and m_nextCall!="") { |             if(SpecOp::RTTY == m_config.special_op_id() and m_nextCall!="") { | ||||||
| // We're in RTTY contest and have "nextCall" queued up: send a "TU; ..." message
 | // We're in RTTY contest and have "nextCall" queued up: send a "TU; ..." message
 | ||||||
|               on_logQSOButton_clicked(); |               on_logQSOButton_clicked(); | ||||||
|               ui->tx3->setText(ui->tx3->text().remove("TU; ")); |               ui->tx3->setText(ui->tx3->text().remove("TU; ")); | ||||||
| @ -4395,7 +4392,7 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|                    && r.mid(0,1)=="R") { |                    && r.mid(0,1)=="R") { | ||||||
|           m_ntx=4; |           m_ntx=4; | ||||||
|           m_QSOProgress = ROGERS; |           m_QSOProgress = ROGERS; | ||||||
|           if(m_nContest==RTTY) { |           if(SpecOp::RTTY == m_config.special_op_id()) { | ||||||
|             int n=t.size(); |             int n=t.size(); | ||||||
|             m_xRcvd=t[n-2] + " " + t[n-1]; |             m_xRcvd=t[n-2] + " " + t[n-1]; | ||||||
|           } |           } | ||||||
| @ -4407,7 +4404,9 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|           } |           } | ||||||
|         } else if(m_QSOProgress>=CALLING and |         } else if(m_QSOProgress>=CALLING and | ||||||
|               ((r.toInt()>=-50 && r.toInt()<=49) or (r.toInt()>=529 && r.toInt()<=599))) { |               ((r.toInt()>=-50 && r.toInt()<=49) or (r.toInt()>=529 && r.toInt()<=599))) { | ||||||
|           if(m_nContest==EU_VHF or m_nContest==FIELD_DAY or m_nContest==RTTY) { |           if(SpecOp::EU_VHF==m_config.special_op_id() or | ||||||
|  |              SpecOp::FIELD_DAY==m_config.special_op_id() or | ||||||
|  |              SpecOp::RTTY==m_config.special_op_id()) { | ||||||
|             gen_msg=setTxMsg(2); |             gen_msg=setTxMsg(2); | ||||||
|             m_QSOProgress=REPORT; |             m_QSOProgress=REPORT; | ||||||
|           } else { |           } else { | ||||||
| @ -4468,7 +4467,7 @@ void MainWindow::processMessage (DecodedText const& message, Qt::KeyboardModifie | |||||||
|     } |     } | ||||||
|     else {                  // nothing for us
 |     else {                  // nothing for us
 | ||||||
|       if(message_words.size () > 3   // enough fields for a normal message
 |       if(message_words.size () > 3   // enough fields for a normal message
 | ||||||
|          && m_nContest==RTTY |          && SpecOp::RTTY == m_config.special_op_id() | ||||||
|          && (message_words.at(1).contains(m_baseCall) || "DE" == message_words.at(1)) |          && (message_words.at(1).contains(m_baseCall) || "DE" == message_words.at(1)) | ||||||
|          && (!message_words.at(2).contains(qso_partner_base_call) and !bEU_VHF_w2)) { |          && (!message_words.at(2).contains(qso_partner_base_call) and !bEU_VHF_w2)) { | ||||||
| // Queue up the next QSO partner
 | // Queue up the next QSO partner
 | ||||||
| @ -4660,13 +4659,13 @@ void MainWindow::genCQMsg () | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     QString t=ui->tx6->text(); |     QString t=ui->tx6->text(); | ||||||
|     if((m_mode=="FT8" or m_mode=="MSK144") and m_nContest!=NONE and |     if((m_mode=="FT8" or m_mode=="MSK144") and SpecOp::NONE != m_config.special_op_id() and | ||||||
|        t.split(" ").at(1)==m_config.my_callsign() and stdCall(m_config.my_callsign())) { |        t.split(" ").at(1)==m_config.my_callsign() and stdCall(m_config.my_callsign())) { | ||||||
|       if(m_nContest==NA_VHF)    t="CQ TEST" + t.mid(2,-1); |       if(SpecOp::NA_VHF == m_config.special_op_id())    t="CQ TEST" + t.mid(2,-1); | ||||||
|       if(m_nContest==EU_VHF)    t="CQ TEST" + t.mid(2,-1); |       if(SpecOp::EU_VHF == m_config.special_op_id())    t="CQ TEST" + t.mid(2,-1); | ||||||
|       if(m_nContest==FIELD_DAY) t="CQ FD" + t.mid(2,-1); |       if(SpecOp::FIELD_DAY == m_config.special_op_id()) t="CQ FD" + t.mid(2,-1); | ||||||
|       if(m_nContest==RTTY)      t="CQ RU" + t.mid(2,-1); |       if(SpecOp::RTTY == m_config.special_op_id())      t="CQ RU" + t.mid(2,-1); | ||||||
|       if(m_nContest==FOX)       t="CQ HUND" + t.mid(2,-1); |       if(SpecOp::FOX == m_config.special_op_id())       t="CQ HUND" + t.mid(2,-1); | ||||||
|       ui->tx6->setText(t); |       ui->tx6->setText(t); | ||||||
|     } |     } | ||||||
|   } else { |   } else { | ||||||
| @ -4779,17 +4778,17 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|         t=t0a; |         t=t0a; | ||||||
|         msgtype(t0a, ui->tx1); |         msgtype(t0a, ui->tx1); | ||||||
|       } |       } | ||||||
|       if(m_nContest==NA_VHF) sent=my_grid; |       if(SpecOp::NA_VHF==m_config.special_op_id()) sent=my_grid; | ||||||
|       if(m_nContest==FIELD_DAY) sent=m_config.FieldDayExchange(); |       if(SpecOp::FIELD_DAY==m_config.special_op_id()) sent=m_config.Field_Day_Exchange(); | ||||||
|       if(m_nContest==RTTY) { |       if(SpecOp::RTTY==m_config.special_op_id()) { | ||||||
|         sent=rst + m_config.RTTYExchange(); |         sent=rst + m_config.RTTY_Exchange(); | ||||||
|         QString t1=m_config.RTTYExchange(); |         QString t1=m_config.RTTY_Exchange(); | ||||||
|         if(t1=="DX" or t1=="#") { |         if(t1=="DX" or t1=="#") { | ||||||
|           t1.sprintf("%4.4d",ui->sbSerialNumber->value()); |           t1.sprintf("%4.4d",ui->sbSerialNumber->value()); | ||||||
|           sent=rst + t1; |           sent=rst + t1; | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|       if(m_nContest==EU_VHF) { |       if(SpecOp::EU_VHF==m_config.special_op_id()) { | ||||||
|         QString t1,a; |         QString t1,a; | ||||||
|         t=t0.split(" ").at(0) + " "; |         t=t0.split(" ").at(0) + " "; | ||||||
|         a.sprintf("%4.4d ",ui->sbSerialNumber->value()); |         a.sprintf("%4.4d ",ui->sbSerialNumber->value()); | ||||||
| @ -4803,7 +4802,7 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|     if(m_mode=="MSK144" and m_bShMsgs) { |     if(m_mode=="MSK144" and m_bShMsgs) { | ||||||
|       int i=t0s.length()-1; |       int i=t0s.length()-1; | ||||||
|       t0="<" + t0s.mid(0,i) + "> "; |       t0="<" + t0s.mid(0,i) + "> "; | ||||||
|       if(m_nContest != NA_VHF) { |       if(SpecOp::NA_VHF != m_config.special_op_id()) { | ||||||
|         if(n<=-2) n=-3; |         if(n<=-2) n=-3; | ||||||
|         if(n>=-1 and n<=1) n=0; |         if(n>=-1 and n<=1) n=0; | ||||||
|         if(n>=2 and n<=4) n=3; |         if(n>=2 and n<=4) n=3; | ||||||
| @ -4821,7 +4820,7 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|       t=t0 + "R" + rpt; |       t=t0 + "R" + rpt; | ||||||
|       msgtype(t, ui->tx3); |       msgtype(t, ui->tx3); | ||||||
|     } |     } | ||||||
|     if(m_mode=="MSK144" and m_bShMsgs and m_nContest==NONE) { |     if(m_mode=="MSK144" and m_bShMsgs and SpecOp::NONE==m_config.special_op_id()) { | ||||||
|       t=t0 + "R" + rpt; |       t=t0 + "R" + rpt; | ||||||
|       msgtype(t, ui->tx3); |       msgtype(t, ui->tx3); | ||||||
|       m_send_RR73=false; |       m_send_RR73=false; | ||||||
| @ -4865,7 +4864,7 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|         case Configuration::type_2_msg_1_full: |         case Configuration::type_2_msg_1_full: | ||||||
|           msgtype(t + my_grid, ui->tx1); |           msgtype(t + my_grid, ui->tx1); | ||||||
|           if (!eme_short_codes) { |           if (!eme_short_codes) { | ||||||
|             if((m_mode=="MSK144" || m_mode=="FT8") && m_nContest == NA_VHF) { |             if((m_mode=="MSK144" || m_mode=="FT8") && SpecOp::NA_VHF == m_config.special_op_id()) { | ||||||
|               msgtype(t + "R " + my_grid, ui->tx3); |               msgtype(t + "R " + my_grid, ui->tx3); | ||||||
|             } else { |             } else { | ||||||
|               msgtype(t + "R" + rpt, ui->tx3); |               msgtype(t + "R" + rpt, ui->tx3); | ||||||
| @ -4877,7 +4876,7 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|           break; |           break; | ||||||
| 
 | 
 | ||||||
|         case Configuration::type_2_msg_3_full: |         case Configuration::type_2_msg_3_full: | ||||||
|           if ((m_mode=="MSK144" || m_mode=="FT8") && m_nContest==NA_VHF) { |           if ((m_mode=="MSK144" || m_mode=="FT8") && SpecOp::NA_VHF == m_config.special_op_id()) { | ||||||
|             msgtype(t + "R " + my_grid, ui->tx3); |             msgtype(t + "R " + my_grid, ui->tx3); | ||||||
|             msgtype(t + "RRR", ui->tx4); |             msgtype(t + "RRR", ui->tx4); | ||||||
|           } else { |           } else { | ||||||
| @ -4892,7 +4891,7 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|         case Configuration::type_2_msg_5_only: |         case Configuration::type_2_msg_5_only: | ||||||
|           msgtype(t00 + my_grid, ui->tx1); |           msgtype(t00 + my_grid, ui->tx1); | ||||||
|           if (!eme_short_codes) { |           if (!eme_short_codes) { | ||||||
|             if ((m_mode=="MSK144" || m_mode=="FT8") && m_nContest==NA_VHF) { |             if ((m_mode=="MSK144" || m_mode=="FT8") && SpecOp::NA_VHF == m_config.special_op_id()) { | ||||||
|               msgtype(t + "R " + my_grid, ui->tx3); |               msgtype(t + "R " + my_grid, ui->tx3); | ||||||
|               msgtype(t + "RRR", ui->tx4); |               msgtype(t + "RRR", ui->tx4); | ||||||
|             } else { |             } else { | ||||||
| @ -4913,7 +4912,7 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|       msgtype(t, ui->tx5->lineEdit ()); |       msgtype(t, ui->tx5->lineEdit ()); | ||||||
|     } |     } | ||||||
|   } else { |   } else { | ||||||
|     if (hisCall != hisBase and m_nContest != HOUND) { |     if (hisCall != hisBase and SpecOp::HOUND != m_config.special_op_id()) { | ||||||
|       if (shortList(hisCall)) { |       if (shortList(hisCall)) { | ||||||
|         // cfm we know his full call with a type 1 tx1 message
 |         // cfm we know his full call with a type 1 tx1 message
 | ||||||
|         t = hisCall + " " + my_callsign; |         t = hisCall + " " + my_callsign; | ||||||
| @ -4927,7 +4926,7 @@ void MainWindow::genStdMsgs(QString rpt, bool unconditional) | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   m_rpt=rpt; |   m_rpt=rpt; | ||||||
|   if(m_nContest==HOUND and is_compound) ui->tx1->setText("DE " + m_config.my_callsign()); |   if(SpecOp::HOUND == m_config.special_op_id() and is_compound) ui->tx1->setText("DE " + m_config.my_callsign()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::TxAgain() | void MainWindow::TxAgain() | ||||||
| @ -4955,7 +4954,7 @@ void MainWindow::clearDX () | |||||||
|     m_gen_message_is_cq = true; |     m_gen_message_is_cq = true; | ||||||
|     ui->rbGenMsg->setChecked(true); |     ui->rbGenMsg->setChecked(true); | ||||||
|   } else { |   } else { | ||||||
|     if(m_mode=="FT8" and m_nContest==HOUND) { |     if (m_mode=="FT8" and SpecOp::HOUND == m_config.special_op_id()) { | ||||||
|       m_ntx=1; |       m_ntx=1; | ||||||
|       ui->txrb1->setChecked(true); |       ui->txrb1->setChecked(true); | ||||||
|     } else { |     } else { | ||||||
| @ -5105,7 +5104,7 @@ void MainWindow::msgtype(QString t, QLineEdit* tx)               //msgtype() | |||||||
| //### Check this stuff ###
 | //### Check this stuff ###
 | ||||||
|   if(itype==7 and m_config.enable_VHF_features() and m_mode=="JT65") shortMsg=true; |   if(itype==7 and m_config.enable_VHF_features() and m_mode=="JT65") shortMsg=true; | ||||||
|   if(m_mode=="MSK144" and t.mid(0,1)=="<") text=false; |   if(m_mode=="MSK144" and t.mid(0,1)=="<") text=false; | ||||||
|   if((m_mode=="MSK144" or m_mode=="FT8") and m_nContest==NA_VHF) { |   if((m_mode=="MSK144" or m_mode=="FT8") and SpecOp::NA_VHF==m_config.special_op_id()) { | ||||||
|     int i0=t.trimmed().length()-7; |     int i0=t.trimmed().length()-7; | ||||||
|     if(t.mid(i0,3)==" R ") text=false; |     if(t.mid(i0,3)==" R ") text=false; | ||||||
|   } |   } | ||||||
| @ -5237,39 +5236,50 @@ void MainWindow::on_logQSOButton_clicked()                 //Log QSO button | |||||||
|   if (dateTimeQSOOff < m_dateTimeQSOOn) dateTimeQSOOff = m_dateTimeQSOOn; |   if (dateTimeQSOOff < m_dateTimeQSOOn) dateTimeQSOOff = m_dateTimeQSOOn; | ||||||
|   QString grid=m_hisGrid; |   QString grid=m_hisGrid; | ||||||
|   if(grid=="....") grid=""; |   if(grid=="....") grid=""; | ||||||
|   if(m_nContest>NONE and m_nContest<FOX) { |    | ||||||
|     if(m_nContest==NA_VHF) { |   switch( m_config.special_op_id() ) | ||||||
|  |     { | ||||||
|  |       case SpecOp::NONE: | ||||||
|  |         break; | ||||||
|  |       case SpecOp::NA_VHF: | ||||||
|         m_xSent=m_config.my_grid().left(4); |         m_xSent=m_config.my_grid().left(4); | ||||||
|         m_xRcvd=m_hisGrid; |         m_xRcvd=m_hisGrid; | ||||||
|     } |         break; | ||||||
|     if(m_nContest==EU_VHF) { |       case SpecOp::EU_VHF: | ||||||
|         m_rptSent=m_xSent.split(" ").at(0).left(2); |         m_rptSent=m_xSent.split(" ").at(0).left(2); | ||||||
|         m_rptRcvd=m_xRcvd.split(" ").at(0).left(2); |         m_rptRcvd=m_xRcvd.split(" ").at(0).left(2); | ||||||
|         m_hisGrid=m_xRcvd.split(" ").at(1); |         m_hisGrid=m_xRcvd.split(" ").at(1); | ||||||
|         grid=m_hisGrid; |         grid=m_hisGrid; | ||||||
|         ui->dxGridEntry->setText(grid); |         ui->dxGridEntry->setText(grid); | ||||||
|     } |         break; | ||||||
|     if(m_nContest==FIELD_DAY) { |       case SpecOp::FIELD_DAY: | ||||||
|         m_rptSent=m_xSent.split(" ").at(0); |         m_rptSent=m_xSent.split(" ").at(0); | ||||||
|         m_rptRcvd=m_xRcvd.split(" ").at(0); |         m_rptRcvd=m_xRcvd.split(" ").at(0); | ||||||
|     } |         break; | ||||||
|     if(m_nContest==RTTY) { |       case SpecOp::RTTY: | ||||||
|         m_rptSent=m_xSent.split(" ").at(0); |         m_rptSent=m_xSent.split(" ").at(0); | ||||||
|         m_rptRcvd=m_xRcvd.split(" ").at(0); |         m_rptRcvd=m_xRcvd.split(" ").at(0); | ||||||
|  |         break; | ||||||
|  |       case SpecOp::FOX: | ||||||
|  |         break; | ||||||
|  |       case SpecOp::HOUND: | ||||||
|  |         break; | ||||||
|     } |     } | ||||||
|  | 
 | ||||||
|  |   if(m_config.special_op_id()>SpecOp::NONE and SpecOp::FOX > m_config.special_op_id()) { | ||||||
|     int n=ui->sbSerialNumber->value(); |     int n=ui->sbSerialNumber->value(); | ||||||
|     ui->sbSerialNumber->setValue(n+1); |     ui->sbSerialNumber->setValue(n+1); | ||||||
|     cabLog();   //Call the Cabrillo contest logger
 |     cabLog();   //Call the Cabrillo contest logger
 | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   bool bAutoLog=m_config.autoLog() and m_nContest>0; |   bool bAutoLog=m_config.autoLog() and SpecOp::NONE < m_config.special_op_id(); | ||||||
|   bool bFoxMode= FOX==m_nContest; |   bool bFoxMode= SpecOp::FOX==m_config.special_op_id(); | ||||||
|   m_logDlg->initLogQSO (m_hisCall, grid, m_modeTx, m_rptSent, m_rptRcvd, |   m_logDlg->initLogQSO (m_hisCall, grid, m_modeTx, m_rptSent, m_rptRcvd, | ||||||
|                         m_dateTimeQSOOn, dateTimeQSOOff, m_freqNominal + |                         m_dateTimeQSOOn, dateTimeQSOOff, m_freqNominal + | ||||||
|                         ui->TxFreqSpinBox->value(), m_config.my_callsign(), |                         ui->TxFreqSpinBox->value(), m_config.my_callsign(), | ||||||
|                         m_config.my_grid(), m_noSuffix, m_config.log_as_RTTY(), |                         m_config.my_grid(), m_noSuffix, m_config.log_as_RTTY(), | ||||||
|                         m_config.report_in_comments(), bFoxMode, |                         m_config.report_in_comments(), bFoxMode, | ||||||
|                         bAutoLog, m_opCall, m_nContest, m_xSent, m_xRcvd); |                         bAutoLog, m_opCall, (qint32) m_config.special_op_id(), m_xSent, m_xRcvd); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MainWindow::cabLog() | void MainWindow::cabLog() | ||||||
| @ -5291,7 +5301,7 @@ void MainWindow::cabLog() | |||||||
|       band.sprintf(" %5d ",nfreq); |       band.sprintf(" %5d ",nfreq); | ||||||
|       t=QDateTime::currentDateTimeUtc().toString("yyyy-MM-dd hhmm ") + band + |       t=QDateTime::currentDateTimeUtc().toString("yyyy-MM-dd hhmm ") + band + | ||||||
|           m_hisCall.leftJustified(13,' ') + m_xSent.leftJustified(14,' ') + m_xRcvd; |           m_hisCall.leftJustified(13,' ') + m_xSent.leftJustified(14,' ') + m_xRcvd; | ||||||
|       m_msgAvgWidget->contestAddLog(m_nContest,t); |       m_msgAvgWidget->contestAddLog((qint32) m_config.special_op_id(),t); | ||||||
|     } |     } | ||||||
|     m_xSent=""; |     m_xSent=""; | ||||||
|     m_xRcvd=""; |     m_xRcvd=""; | ||||||
| @ -5332,7 +5342,7 @@ void MainWindow::acceptQSO (QDateTime const& QSO_date_off, QString const& call, | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|   if (m_config.clear_DX () and m_nContest!=HOUND) clearDX (); |   if (m_config.clear_DX () and SpecOp::HOUND != m_config.special_op_id()) clearDX (); | ||||||
|   m_dateTimeQSOOn = QDateTime {}; |   m_dateTimeQSOOn = QDateTime {}; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -5398,8 +5408,8 @@ void MainWindow::displayWidgets(qint64 n) | |||||||
|     if(i==32) ui->cbCQonly->setVisible(b); |     if(i==32) ui->cbCQonly->setVisible(b); | ||||||
|     j=j>>1; |     j=j>>1; | ||||||
|   } |   } | ||||||
|   b=m_nContest==EU_VHF or (m_nContest==RTTY and |   b=SpecOp::EU_VHF==m_config.special_op_id() or (SpecOp::RTTY==m_config.special_op_id() and | ||||||
|     (m_config.RTTYExchange()=="#" or m_config.RTTYExchange()=="DX")); |     (m_config.RTTY_Exchange()=="#" or m_config.RTTY_Exchange()=="DX")); | ||||||
|   ui->sbSerialNumber->setVisible(b); |   ui->sbSerialNumber->setVisible(b); | ||||||
|   m_lastCallsign.clear ();     // ensures Tx5 is updated for new modes
 |   m_lastCallsign.clear ();     // ensures Tx5 is updated for new modes
 | ||||||
|   genStdMsgs (m_rpt, true); |   genStdMsgs (m_rpt, true); | ||||||
| @ -5433,7 +5443,7 @@ void MainWindow::on_actionFT8_triggered() | |||||||
|   m_modulator->setTRPeriod(m_TRperiod); // TODO - not thread safe
 |   m_modulator->setTRPeriod(m_TRperiod); // TODO - not thread safe
 | ||||||
|   m_detector->setTRPeriod(m_TRperiod);  // TODO - not thread safe
 |   m_detector->setTRPeriod(m_TRperiod);  // TODO - not thread safe
 | ||||||
|   ui->label_7->setText("Rx Frequency"); |   ui->label_7->setText("Rx Frequency"); | ||||||
|   if(m_nContest==FOX) { |   if(SpecOp::FOX==m_config.special_op_id()) { | ||||||
|     ui->label_6->setText("Stations calling DXpedition " + m_config.my_callsign()); |     ui->label_6->setText("Stations calling DXpedition " + m_config.my_callsign()); | ||||||
|     ui->decodedTextLabel->setText( "Call         Grid   dB  Freq   Dist Age Continent"); |     ui->decodedTextLabel->setText( "Call         Grid   dB  Freq   Dist Age Continent"); | ||||||
|   } else { |   } else { | ||||||
| @ -5451,7 +5461,7 @@ void MainWindow::on_actionFT8_triggered() | |||||||
|   ui->txb6->setEnabled(true); |   ui->txb6->setEnabled(true); | ||||||
|   ui->txFirstCheckBox->setEnabled(true); |   ui->txFirstCheckBox->setEnabled(true); | ||||||
|   ui->cbAutoSeq->setEnabled(true); |   ui->cbAutoSeq->setEnabled(true); | ||||||
|   if(m_nContest==FOX) { |   if(SpecOp::FOX==m_config.special_op_id()) { | ||||||
|     ui->txFirstCheckBox->setChecked(true); |     ui->txFirstCheckBox->setChecked(true); | ||||||
|     ui->txFirstCheckBox->setEnabled(false); |     ui->txFirstCheckBox->setEnabled(false); | ||||||
|     ui->cbHoldTxFreq->setChecked(true); |     ui->cbHoldTxFreq->setChecked(true); | ||||||
| @ -5462,7 +5472,7 @@ void MainWindow::on_actionFT8_triggered() | |||||||
|     ui->labDXped->setText("Fox"); |     ui->labDXped->setText("Fox"); | ||||||
|     on_actionFox_Log_triggered(); |     on_actionFox_Log_triggered(); | ||||||
|   } |   } | ||||||
|   if(m_nContest == HOUND) { |   if(SpecOp::HOUND == m_config.special_op_id()) { | ||||||
|     ui->txFirstCheckBox->setChecked(false); |     ui->txFirstCheckBox->setChecked(false); | ||||||
|     ui->txFirstCheckBox->setEnabled(false); |     ui->txFirstCheckBox->setEnabled(false); | ||||||
|     ui->cbAutoSeq->setEnabled(false); |     ui->cbAutoSeq->setEnabled(false); | ||||||
| @ -5481,12 +5491,12 @@ void MainWindow::on_actionFT8_triggered() | |||||||
|     ui->txb6->setEnabled(false); |     ui->txb6->setEnabled(false); | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if(m_nContest<FOX) { |   if(SpecOp::FOX > m_config.special_op_id()) { | ||||||
|     QString t0=""; |     QString t0=""; | ||||||
|     if(m_nContest==NA_VHF) t0+="NA VHF"; |     if(SpecOp::NA_VHF==m_config.special_op_id()) t0+="NA VHF"; | ||||||
|     if(m_nContest==EU_VHF) t0+="EU VHF"; |     if(SpecOp::EU_VHF==m_config.special_op_id()) t0+="EU VHF"; | ||||||
|     if(m_nContest==FIELD_DAY) t0+="Field Day"; |     if(SpecOp::FIELD_DAY==m_config.special_op_id()) t0+="Field Day"; | ||||||
|     if(m_nContest==RTTY) t0+="RTTY"; |     if(SpecOp::RTTY==m_config.special_op_id()) t0+="RTTY"; | ||||||
|     if(t0=="") { |     if(t0=="") { | ||||||
|       ui->labDXped->setVisible(false); |       ui->labDXped->setVisible(false); | ||||||
|     } else { |     } else { | ||||||
| @ -5495,7 +5505,7 @@ void MainWindow::on_actionFT8_triggered() | |||||||
|     } |     } | ||||||
|   } |   } | ||||||
| 
 | 
 | ||||||
|   if((m_nContest==FOX or m_nContest==HOUND) and !m_config.split_mode() and !m_bWarnedSplit) { |   if((SpecOp::FOX==m_config.special_op_id() or SpecOp::HOUND==m_config.special_op_id()) and !m_config.split_mode() and !m_bWarnedSplit) { | ||||||
|     QString errorMsg; |     QString errorMsg; | ||||||
|     MessageBox::critical_message (this, |     MessageBox::critical_message (this, | ||||||
|        "Operation in FT8 DXpedition mode normally requires\n" |        "Operation in FT8 DXpedition mode normally requires\n" | ||||||
| @ -5757,7 +5767,7 @@ void MainWindow::on_actionISCAT_triggered() | |||||||
| 
 | 
 | ||||||
| void MainWindow::on_actionMSK144_triggered() | void MainWindow::on_actionMSK144_triggered() | ||||||
| { | { | ||||||
|   if(m_nContest>EU_VHF) { |   if(SpecOp::EU_VHF < m_config.special_op_id()) { | ||||||
| // We are rejecting the requested mode change, so re-check the old mode
 | // We are rejecting the requested mode change, so re-check the old mode
 | ||||||
|     if("FT8"==m_mode) ui->actionFT8->setChecked(true);  |     if("FT8"==m_mode) ui->actionFT8->setChecked(true);  | ||||||
|     if("JT4"==m_mode) ui->actionJT4->setChecked(true);  |     if("JT4"==m_mode) ui->actionJT4->setChecked(true);  | ||||||
| @ -5814,8 +5824,8 @@ void MainWindow::on_actionMSK144_triggered() | |||||||
|   statusChanged(); |   statusChanged(); | ||||||
| 
 | 
 | ||||||
|   QString t0=""; |   QString t0=""; | ||||||
|   if(m_nContest==NA_VHF) t0+="NA VHF"; |   if(SpecOp::NA_VHF==m_config.special_op_id()) t0+="NA VHF"; | ||||||
|   if(m_nContest==EU_VHF) t0+="EU VHF"; |   if(SpecOp::EU_VHF==m_config.special_op_id()) t0+="EU VHF"; | ||||||
|   if(t0=="") { |   if(t0=="") { | ||||||
|     ui->labDXped->setVisible(false); |     ui->labDXped->setVisible(false); | ||||||
|   } else { |   } else { | ||||||
| @ -6652,7 +6662,7 @@ void MainWindow::transmit (double snr) | |||||||
|     toneSpacing=12000.0/1920.0; |     toneSpacing=12000.0/1920.0; | ||||||
|     if(m_config.x2ToneSpacing()) toneSpacing=2*12000.0/1920.0; |     if(m_config.x2ToneSpacing()) toneSpacing=2*12000.0/1920.0; | ||||||
|     if(m_config.x4ToneSpacing()) toneSpacing=4*12000.0/1920.0; |     if(m_config.x4ToneSpacing()) toneSpacing=4*12000.0/1920.0; | ||||||
|     if(m_nContest==FOX and !m_tune) toneSpacing=-1; |     if(SpecOp::FOX==m_config.special_op_id() and !m_tune) toneSpacing=-1; | ||||||
|     Q_EMIT sendMessage (NUM_FT8_SYMBOLS, |     Q_EMIT sendMessage (NUM_FT8_SYMBOLS, | ||||||
|            1920.0, ui->TxFreqSpinBox->value () - m_XIT, |            1920.0, ui->TxFreqSpinBox->value () - m_XIT, | ||||||
|            toneSpacing, m_soundOutput, m_config.audio_output_channel (), |            toneSpacing, m_soundOutput, m_config.audio_output_channel (), | ||||||
| @ -6898,7 +6908,7 @@ void::MainWindow::VHF_features_enabled(bool b) | |||||||
|   ui->actionMessage_averaging->setEnabled(b); |   ui->actionMessage_averaging->setEnabled(b); | ||||||
|   ui->actionEnable_AP_DXcall->setVisible (m_mode=="QRA64"); |   ui->actionEnable_AP_DXcall->setVisible (m_mode=="QRA64"); | ||||||
|   ui->actionEnable_AP_JT65->setVisible (b && m_mode=="JT65"); |   ui->actionEnable_AP_JT65->setVisible (b && m_mode=="JT65"); | ||||||
|   if(!b && m_msgAvgWidget and (m_nContest!=FOX) and !m_config.autoLog()) { |   if(!b && m_msgAvgWidget and (SpecOp::FOX != m_config.special_op_id()) and !m_config.autoLog()) { | ||||||
|     if(m_msgAvgWidget->isVisible()) m_msgAvgWidget->close(); |     if(m_msgAvgWidget->isVisible()) m_msgAvgWidget->close(); | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | |||||||
							
								
								
									
										12
									
								
								mainwindow.h
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								mainwindow.h
									
									
									
									
									
								
							| @ -298,7 +298,7 @@ private slots: | |||||||
|   void on_pbFoxReset_clicked(); |   void on_pbFoxReset_clicked(); | ||||||
|   void on_comboBoxHoundSort_activated (int index); |   void on_comboBoxHoundSort_activated (int index); | ||||||
|   void not_GA_warning_message (); |   void not_GA_warning_message (); | ||||||
|   void setContestType(); |   void checkMSK144ContestType(); | ||||||
|   int  setTxMsg(int n); |   int  setTxMsg(int n); | ||||||
|   bool stdCall(QString w); |   bool stdCall(QString w); | ||||||
| 
 | 
 | ||||||
| @ -517,16 +517,6 @@ private: | |||||||
|     } |     } | ||||||
|     m_QSOProgress;        //State machine counter
 |     m_QSOProgress;        //State machine counter
 | ||||||
| 
 | 
 | ||||||
|   enum { |  | ||||||
|     NONE,                 // 0
 |  | ||||||
|     NA_VHF,               // 1
 |  | ||||||
|     EU_VHF,               // 2
 |  | ||||||
|     FIELD_DAY,            // 3
 |  | ||||||
|     RTTY,                 // 4
 |  | ||||||
|     FOX,                  // 5
 |  | ||||||
|     HOUND                 // 6
 |  | ||||||
|   } m_nContest;           //Contest type
 |  | ||||||
| 
 |  | ||||||
|   enum {CALL, GRID, DXCC, MULT}; |   enum {CALL, GRID, DXCC, MULT}; | ||||||
| 
 | 
 | ||||||
|   int			m_ihsym; |   int			m_ihsym; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user