mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-26 02:20:20 -04:00 
			
		
		
		
	V12.2.6 of teh DX Lab Suite Commander finally has a way to suppress mode rationalization when setting the split Tx frequency. This now means that we can now honor the radio setting to not change the rig modulation mode. This should help with a number of rigs that require different modes on teh Tx and Rx VFOs for optimal wide band digital operation. This will also help with some rig and interface combinations that lock up or otherwise misbehave when setting the Tx VFO mode at certain times with respect to other rig control commands. This change also improves mode setting in general hopefully closing a few corner case issues when starting up and when transmitting for the first time in a session. Included is the latest DX Lab Suite Commander TCP/IP commands documentation correct for v12.2.6. git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx@7030 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
		
			
				
	
	
		
			77 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			77 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef POLLING_TRANSCEIVER_HPP__
 | |
| #define POLLING_TRANSCEIVER_HPP__
 | |
| 
 | |
| #include <QObject>
 | |
| 
 | |
| #include "TransceiverBase.hpp"
 | |
| 
 | |
| class QTimer;
 | |
| 
 | |
| //
 | |
| // Polling Transceiver
 | |
| //
 | |
| //  Helper base  class that  encapsulates the emulation  of continuous
 | |
| //  update and caching of a transceiver state.
 | |
| //
 | |
| // Collaborations
 | |
| //
 | |
| //  Implements the TransceiverBase post  action interface and provides
 | |
| //  the abstract  poll() operation  for sub-classes to  implement. The
 | |
| //  poll operation is invoked every poll_interval seconds.
 | |
| //
 | |
| // Responsibilities
 | |
| //
 | |
| //  Because some rig interfaces don't immediately update after a state
 | |
| //  change request; this  class allows a rig a few  polls to stabilise
 | |
| //  to the  requested state before  signalling the change.  This means
 | |
| //  that  clients don't  see  intermediate states  that are  sometimes
 | |
| //  inaccurate,  e.g. changing  the split  TX frequency  on Icom  rigs
 | |
| //  requires a  VFO switch  and polls while  switched will  return the
 | |
| //  wrong current frequency.
 | |
| //
 | |
| class PollingTransceiver
 | |
|   : public TransceiverBase
 | |
| {
 | |
|   Q_OBJECT;                     // for translation context
 | |
| 
 | |
| protected:
 | |
|   explicit PollingTransceiver (int poll_interval, // in seconds
 | |
|                                QObject * parent);
 | |
| 
 | |
| protected:
 | |
|   void do_sync (bool force_signal = false, bool no_poll = false) override final;
 | |
| 
 | |
|   // Sub-classes implement this and fetch what they can from the rig
 | |
|   // in a non-intrusive manner.
 | |
|   virtual void poll () = 0;
 | |
| 
 | |
|   void do_post_start () override final;
 | |
|   void do_post_stop () override final;
 | |
|   void do_post_frequency (Frequency, MODE) override final;
 | |
|   void do_post_tx_frequency (Frequency, MODE) override final;
 | |
|   void do_post_mode (MODE) override final;
 | |
|   void do_post_ptt (bool = true) override final;
 | |
|   bool do_pre_update () override final;
 | |
| 
 | |
| private:
 | |
|   void start_timer ();
 | |
|   void stop_timer ();
 | |
| 
 | |
|   Q_SLOT void handle_timeout ();
 | |
| 
 | |
|   int interval_;    // polling interval in milliseconds
 | |
|   QTimer * poll_timer_;
 | |
| 
 | |
|   // keep a record of the last state signalled so we can elide
 | |
|   // duplicate updates
 | |
|   Transceiver::TransceiverState last_signalled_state_;
 | |
| 
 | |
|   // keep a record of expected state so we can compare with actual
 | |
|   // updates to determine when state changes have bubbled through
 | |
|   Transceiver::TransceiverState next_state_;
 | |
| 
 | |
|   unsigned retries_;            // number of incorrect polls left
 | |
| };
 | |
| 
 | |
| #endif
 |