Somehow this compiled...

This commit is contained in:
Rob French 2020-06-13 09:59:11 -05:00
parent 28cbb0363f
commit 2da162f7c2
8 changed files with 213 additions and 278 deletions

View File

@ -48,7 +48,7 @@ void recvIOPMessage(IOPMessage& msg, const uint8_t* buf, int len)
//======================================================================
void sendIOPModeCommand(RigMode mode)
void sendIOPModeCommand(rig_mode mode)
{
IOPMessage m;
m.id = IOP_MODE_COMMAND;
@ -101,69 +101,69 @@ void sendIOPDebugMessage(const char* text)
sendIOPMessage(m);
};
//======================================================================
// SSB STATUS MESSAGE
//======================================================================
////======================================================================
//// SSB STATUS MESSAGE
////======================================================================
void sendIOPSSBStatus(SSBConfig const &c)
{
IOPMessage m;
m.id = IOP_SSB_STATUS_MSG;
m.len = 4;
m.data[0] = 'S'; // current mode; redundant w/ Raduino mode, but maybe useful for debugging
m.data[1] = '-'; // placeholder for transmit filter/compressor
m.data[2] = RX_FILTER_LETTER[c.filter];
m.data[3] = '\0';
sendIOPMessage(m);
}
//void sendIOPSSBStatus(SSBConfig const &c)
//{
//IOPMessage m;
//m.id = IOP_SSB_STATUS_MSG;
//m.len = 4;
//m.data[0] = 'S'; // current mode; redundant w/ Raduino mode, but maybe useful for debugging
//m.data[1] = '-'; // placeholder for transmit filter/compressor
//m.data[2] = RX_FILTER_LETTER[c.filter];
//m.data[3] = '\0';
//sendIOPMessage(m);
//}
//======================================================================
// DGT STATUS MESSAGE
//======================================================================
////======================================================================
//// DGT STATUS MESSAGE
////======================================================================
void sendIOPDGTStatus(DGTConfig const &c)
{
IOPMessage m;
m.id = IOP_DGT_STATUS_MSG;
m.len = 4;
m.data[0] = 'D'; // current mode; redundant w/ Raduino mode, but maybe useful for debugging
m.data[1] = '-'; // placeholder for future digital submodes?
m.data[2] = RX_FILTER_LETTER[c.filter];
m.data[3] = '\0';
sendIOPMessage(m);
}
//void sendIOPDGTStatus(DGTConfig const &c)
//{
//IOPMessage m;
//m.id = IOP_DGT_STATUS_MSG;
//m.len = 4;
//m.data[0] = 'D'; // current mode; redundant w/ Raduino mode, but maybe useful for debugging
//m.data[1] = '-'; // placeholder for future digital submodes?
//m.data[2] = RX_FILTER_LETTER[c.filter];
//m.data[3] = '\0';
//sendIOPMessage(m);
//}
//======================================================================
// CW STATUS MESSAGE
//======================================================================
////======================================================================
//// CW STATUS MESSAGE
////======================================================================
void sendIOPCWStatus(CWConfig const &c)
{
IOPMessage m;
m.id = IOP_CW_STATUS_MSG;
m.len = 4;
m.data[0] = 'C'; // current mode; redundant w/ Raduino mode, but maybe useful for debugging
m.data[1] = KEYER_MODE_LETTER[c.mode];
m.data[2] = RX_FILTER_LETTER[c.filter];
m.data[3] = '\0';
sendIOPMessage(m);
}
//void sendIOPCWStatus(CWConfig const &c)
//{
//IOPMessage m;
//m.id = IOP_CW_STATUS_MSG;
//m.len = 4;
//m.data[0] = 'C'; // current mode; redundant w/ Raduino mode, but maybe useful for debugging
//m.data[1] = KEYER_MODE_LETTER[c.mode];
//m.data[2] = RX_FILTER_LETTER[c.filter];
//m.data[3] = '\0';
//sendIOPMessage(m);
//}
//======================================================================
// TEST STATUS MESSAGE
//======================================================================
////======================================================================
//// TEST STATUS MESSAGE
////======================================================================
void sendIOPTestStatus()
{
IOPMessage m;
m.id = IOP_TEST_STATUS_MSG;
m.len = 4;
m.data[0] = ' ';
m.data[1] = 'T';
m.data[2] = 'T';
m.data[3] = '\0';
sendIOPMessage(m);
}
//void sendIOPTestStatus()
//{
//IOPMessage m;
//m.id = IOP_TEST_STATUS_MSG;
//m.len = 4;
//m.data[0] = ' ';
//m.data[1] = 'T';
//m.data[2] = 'T';
//m.data[3] = '\0';
//sendIOPMessage(m);
//}
//======================================================================
// MENU DISPLAY MESSAGE

View File

@ -97,42 +97,46 @@ enum MessageID {
* (e.g. USB, LSB, etc.)
*/
enum RigMode {
RIG_MODE_LSB = 0,
RIG_MODE_USB,
RIG_MODE_CWL,
RIG_MODE_CWU,
RIG_MODE_DGL,
RIG_MODE_DGU,
RIG_MODE_TTL,
RIG_MODE_TTU,
enum rig_mode {
lsb = 0,
usb,
cw,
cwr,
dig,
// add new items here
NUM_RIG_MODES
num_rig_modes
};
/* Keyer modes.
*/
enum KeyerMode {
KEYER_MODE_STRAIGHT = 0,
KEYER_MODE_IAMBIC_A,
KEYER_MODE_IAMBIC_B,
//KEYER_ULTIMATIC,
//KEYER_BUG,
// add any new elements here
NUM_KEYER_MODES
enum keyer_mode {
straight = 0,
iambic_a,
iambic_b,
//ultimatic,
//bug,
// add any new items here
num_keyer_modes
};
enum RxFilter {
RX_FILTER_WIDE = 0,
RX_FILTER_MEDIUM,
RX_FILTER_NARROW,
NUM_RX_FILTERS
enum rx_filter {
wide = 0,
medium,
narrow,
num_rx_filters
};
const unsigned char RIG_MODE_LETTER[NUM_RIG_MODES] = {'s', 'S', 'c', 'C', 'd', 'D', 't', 'T'};
const unsigned char KEYER_MODE_LETTER[NUM_KEYER_MODES] = {'S', 'A', 'B'};
const unsigned char RX_FILTER_LETTER[NUM_RX_FILTERS] = {'W', 'M', 'N'};
enum digi_mode {
rtty = 0,
psk31,
user_defined,
num_digi_modes
};
//const unsigned char RIG_MODE_LETTER[num_rig_modes] = {'s', 'S', 'c', 'C', 'd', 'D', 't', 'T'};
//const unsigned char KEYER_MODE_LETTER[num_keyer_modes] = {'S', 'A', 'B'};
//const unsigned char RX_FILTER_LETTER[num_rx_filters] = {'W', 'M', 'N'};
const uint8_t NO_FLAGS = 0;
const uint8_t REVERSED = 1;
@ -150,67 +154,86 @@ struct IOPMessage {
// Interface to a configuration object.
//======================================================================
class IConfig {
public:
virtual ~IConfig() {}
struct filter_config {
float lo;
float hi;
float gain;
};
struct mode_config {
mode_config(bool usb, rx_filter f, const filter_config *fc) : is_usb(usb), filter(f) {
for (int i = 0; i < num_rx_filters; i++) {
filtercfg[i] = fc[i];
}
}
bool is_usb;
rx_filter filter;
filter_config filtercfg[num_rx_filters];
};
//======================================================================
// SSB CONFIGURATION
//======================================================================
class SSBConfig : public IConfig {
public:
SSBConfig(RxFilter f): filter(f) {}
// parameters
RxFilter filter = RX_FILTER_MEDIUM;
// bool comp_enable = false;
// float comp_threshold = 0.1;
// float comp_ratio = 20.0;
// float comp_gain = 2.0;
const filter_config ssb_filter_config[num_rx_filters] =
{filter_config{ 300.0, 3100.0, 1.0},
filter_config{ 500.0, 2900.0, 1.0},
filter_config{ 700.0, 2500.0, 1.0}};
struct ssb_config : public mode_config {
ssb_config() : mode_config(true, wide, ssb_filter_config) {}
// speech compressor parameters
bool comp_enable = false;
float comp_threshold = 0.1;
float comp_ratio = 20.0;
float comp_gain = 2.0;
};
//======================================================================
// DGT CONFIGURATION
// DIG CONFIGURATION
//======================================================================
class DGTConfig : public IConfig {
public:
DGTConfig(RxFilter f): filter(f) {}
// parameters
RxFilter filter = RX_FILTER_MEDIUM;
const filter_config dig_filter_config[num_rx_filters] =
{filter_config{ 300.0, 3100.0, 1.0},
filter_config{ 500.0, 2900.0, 1.0},
filter_config{1250.0, 1750.0, 1.0}};
struct dig_config : public mode_config {
dig_config() : mode_config(true, wide, dig_filter_config) {}
digi_mode submode = user_defined;
};
//======================================================================
// CW CONFIGURATION
//======================================================================
class CWConfig : public IConfig {
public:
CWConfig(KeyerMode m, bool rev, uint8_t w, float wt, uint16_t st, RxFilter f):
mode(m), reversed(rev), wpm(w), weight(wt), sidetone(st), filter(f) {}
// mode
KeyerMode mode = KEYER_MODE_IAMBIC_A;
const filter_config cw_filter_config[num_rx_filters] =
{filter_config{ 300.0, 1300.0, 1.0},
filter_config{ 450.0, 950.0, 1.0},
filter_config{ 575.0, 825.0, 1.0}};
struct cw_config : public mode_config {
cw_config() : mode_config(true, wide, cw_filter_config) {}
keyer_mode mode = iambic_a;
// flags
bool reversed = false;
// parameters
uint8_t wpm = 15;
float weight = 3.0;
uint16_t sidetone = 700;
RxFilter filter = RX_FILTER_MEDIUM;
};
//======================================================================
// TT CONFIGURATION
//======================================================================
class TTConfig : public IConfig {
/*
struct TTConfig : public IConfig {
public:
TTConfig(RxFilter f): filter(f) {}
// parameters
RxFilter filter = RX_FILTER_MEDIUM;
};
*/
//======================================================================
// FUNCTION PROTOTYPES
//======================================================================
@ -219,58 +242,19 @@ void sendCATMessage(const uint8_t*);
void sendIOPMessage(IOPMessage const&);
void recvIOPMessage(IOPMessage&, const uint8_t*, int);
void sendIOPModeCommand(RigMode);
void sendIOPModeCommand(rig_mode);
void sendIOPStartTxCommand();
void sendIOPStopTxCommand();
void sendIOPDebugMessage(const char*);
void sendIOPModeRequest();
void sendIOPSSBStatus(SSBConfig const&);
void sendIOPDGTStatus(DGTConfig const&);
void sendIOPCWStatus(CWConfig const&);
void sendIOPTestStatus();
//void sendIOPSSBStatus(SSBConfig const&);
//void sendIOPDGTStatus(DGTConfig const&);
//void sendIOPCWStatus(CWConfig const&);
//void sendIOPTestStatus();
void sendIOPMenuDisplay(const char*);
void sendIOPMenuInactive();
//======================================================================
// TRANSLATOR
//======================================================================
/*
class Translator
{
public:
Translator(RigMode&, CWConfig&, Stream&);
void registerPrefixCb(PrefixID id, void (*func)(void*));
void registerMessageCb(MessageID id, void (*func)(void*));
void sendACK();
void sendIOPMessage(IOPMessage const&);
void receive();
void pack_ModeCommand(IOPMessage&, RigMode);
void pack_CWConfig(IOPMessage&, CWConfig const&);
void pack_ModeRequest(IOPMessage&);
void unpack(IOPMessage const&);
protected:
void unpack_ModeCommand(IOPMessage const&);
void unpack_CWConfig(IOPMessage const&);
void unpack_ModeRequest(IOPMessage const&);
private:
RigMode& mode;
CWConfig& cwConfig;
Stream& serial;
void (*prefixCb[NUM_PREFIX_IDS])(void*);
void (*messageCb[NUM_MESSAGE_IDS])(void*);
};
*/
#endif
//======================================================================

View File

@ -24,14 +24,14 @@
class IMode {
public:
IMode(IConfig& c, RigAudio& a, IFilter& f):
IMode(mode_config& c, RigAudio& a, IFilter& f):
_config(c), _audio(a), _filter(f), _active(false), _transmitting(false)
{
}
virtual ~IMode() {}
inline IConfig& config() { return _config; }
inline mode_config& config() { return _config; }
inline RigAudio& audio() { return _audio; }
@ -110,7 +110,7 @@ class IMode {
private:
IConfig& _config;
mode_config& _config;
RigAudio& _audio;
IFilter& _filter;
bool _active;
@ -125,7 +125,7 @@ class SSBMode : public IMode
{
public:
SSBMode(IConfig& c, RigAudio& a, IFilter& f, bool default_mic=true):
SSBMode(mode_config& c, RigAudio& a, IFilter& f, bool default_mic=true):
IMode(c, a, f), _use_mic(default_mic)
{
}
@ -215,7 +215,7 @@ class DGTMode : public IMode
{
public:
DGTMode(IConfig& c, RigAudio& a, IFilter& f):
DGTMode(mode_config& c, RigAudio& a, IFilter& f):
IMode(c, a, f)
{
}
@ -277,7 +277,7 @@ class CWMode : public IMode
{
public:
CWMode(IConfig& c, RigAudio& a, IFilter& f):
CWMode(mode_config& c, RigAudio& a, IFilter& f):
IMode(c, a, f)
{
}
@ -310,7 +310,7 @@ class CWMode : public IMode
}
virtual void setWideRxFilter(){
float st = float(((CWConfig&)config()).sidetone);
float st = float(((cw_config&)config()).sidetone);
float width = 1000.0;
float low = st - (width * 0.5);
if (low < 300.0) {
@ -322,7 +322,7 @@ class CWMode : public IMode
}
virtual void setMediumRxFilter(){
float st = float(((CWConfig&)config()).sidetone);
float st = float(((cw_config&)config()).sidetone);
float width = 500.0;
float low = st - (width * 0.5);
if (low < 300.0) {
@ -334,7 +334,7 @@ class CWMode : public IMode
}
virtual void setNarrowRxFilter(){
float st = float(((CWConfig&)config()).sidetone);
float st = float(((cw_config&)config()).sidetone);
float width = 250.0;
float low = st - (width * 0.5);
if (low < 300.0) {
@ -355,7 +355,7 @@ class TTMode : public IMode
{
public:
TTMode(IConfig& c, RigAudio& a, IFilter& f):
TTMode(mode_config& c, RigAudio& a, IFilter& f):
IMode(c, a, f)
{
}

View File

@ -57,32 +57,23 @@ void processIOPCommand(IOPMessage const& m)
if (m.len < 1) {
return;
} else {
rig.switchMode(RigMode(m.data[0]));
rig.switchMode(rig_mode(m.data[0]));
#if defined(DEBUG)
switch(rig.modeNum()) {
case RIG_MODE_CWL:
USBDEBUG("new mode - CWL");
case cwr:
USBDEBUG("new mode - CWR");
break;
case RIG_MODE_CWU:
USBDEBUG("new mode - CWU");
case cw:
USBDEBUG("new mode - CW");
break;
case RIG_MODE_LSB:
case lsb:
USBDEBUG("new mode - LSB");
break;
case RIG_MODE_USB:
case usb:
USBDEBUG("new mode - USB");
break;
case RIG_MODE_DGL:
USBDEBUG("new mode - DGL");
break;
case RIG_MODE_DGU:
USBDEBUG("new mode - DGU");
break;
case RIG_MODE_TTL:
USBDEBUG("new mode - TTL");
break;
case RIG_MODE_TTU:
USBDEBUG("new mode - TTU");
case dig:
USBDEBUG("new mode - DIG");
break;
default:
char errormessage[32];

View File

@ -115,42 +115,18 @@ class AudioConfig {
class RigConfig {
public:
RigConfig() {}
// audio configuration
AudioConfig audio;
// SSB configuration
SSBConfig lsb{RX_FILTER_WIDE};
SSBConfig usb{RX_FILTER_WIDE};
// DGT configuration
DGTConfig dgl{RX_FILTER_WIDE};
DGTConfig dgu{RX_FILTER_WIDE};
// CW configuration
CWConfig cwl{
KEYER_MODE_IAMBIC_A,
false,
15,
3.0,
700,
RX_FILTER_WIDE,
};
CWConfig cwu{
KEYER_MODE_IAMBIC_A,
false,
15,
3.0,
700,
RX_FILTER_WIDE,
};
// TT configuration
TTConfig ttl{RX_FILTER_WIDE};
TTConfig ttu{RX_FILTER_WIDE};
// mode configuration
ssb_config ssb;
dig_config dig;
cw_config cw;
// General rig configuration entries.
RigMode numModes = NUM_RIG_MODES;
RigMode startMode = RIG_MODE_LSB;
rig_mode numModes = num_rig_modes;
rig_mode startMode = lsb;
};
extern RigConfig rigConfig;

View File

@ -211,15 +211,12 @@ class Parm_float : public Config_parm<float> {
//======================================================================
const char modeID[] = {'s', 'S', 'c', 'C', 'd', 'D', 't', 'T'};
const char* const filterID[NUM_RIG_MODES][NUM_RX_FILTERS] = {
const char* const filterID[num_rig_modes][num_rx_filters] = {
{"2.8", "2.4", "1.8"}, // LSB
{"2.8", "2.4", "1.8"}, // USB
{"1.0", "500", "250"}, // CWL
{"1.0", "500", "250"}, // CWU
{"2.8", "2.4", "500"}, // DGL
{"2.8", "2.4", "500"}, // DGU
{"2.8", "2.4", "1.8"}, // TTL
{"2.8", "2.4", "1.8"}, // TTU
{"1.0", "500", "250"}, // CW
{"1.0", "500", "250"}, // CWR
{"2.8", "2.4", "500"}, // DIG
};
//======================================================================

View File

@ -21,7 +21,7 @@ class Rig {
// Constructor/destructor.
//--------------------------------------------------------------------
Rig(RigConfig& c, RigAudio& a): _config(c), _audio(a), _filter(RX_FILTER_WIDE)
Rig(RigConfig& c, RigAudio& a): _config(c), _audio(a), _filter(wide)
{
_modes = new IMode*[c.numModes];
_modesLen = c.numModes;
@ -38,12 +38,12 @@ class Rig {
_modes[RIG_MODE_TTL] = new TTMode(c.ttl, a);
_modes[RIG_MODE_TTU] = new TTMode(c.ttu, a);*/
/*
_rxFilters = new (IFilter*)[NUM_RX_FILTERS];
_rxFiltersLen = NUM_RX_FILTERS;
_rxFilters = new (IFilter*)[num_rx_filters];
_rxFiltersLen = num_rx_filters;
_rxFiltersIndex = 0; // need to get default filter from current mode...
_rxFilters[RX_FILTER_WIDE] = mode()->filterWide();
_rxFilters[RX_FILTER_MEDIUM] = mode()->filterMedium();
_rxFilters[RX_FILTER_NARROW] = mode()->filterNarrow();
_rxFilters[wide] = mode()->filterWide();
_rxFilters[medium] = mode()->filterMedium();
_rxFilters[narrow] = mode()->filterNarrow();
*/
}
@ -69,21 +69,16 @@ class Rig {
return _modeText;
}
*/
inline bool isSSBMode() const { return (_modesIndex == RIG_MODE_USB || _modesIndex == RIG_MODE_LSB); }
inline bool isUSBMode() const { return (_modesIndex == RIG_MODE_USB); }
inline bool isLSBMode() const { return (_modesIndex == RIG_MODE_LSB); }
inline bool isDGTMode() const { return (_modesIndex == RIG_MODE_DGU || _modesIndex == RIG_MODE_DGL); }
inline bool isDGUMode() const { return (_modesIndex == RIG_MODE_DGU); }
inline bool isDGLMode() const { return (_modesIndex == RIG_MODE_DGL); }
inline bool isCWMode() const { return (_modesIndex == RIG_MODE_CWU || _modesIndex == RIG_MODE_CWL); }
inline bool isCWUMode() const { return (_modesIndex == RIG_MODE_CWU); }
inline bool isCWLMode() const { return (_modesIndex == RIG_MODE_CWL); }
inline bool isTTMode() const { return (_modesIndex == RIG_MODE_TTU || _modesIndex == RIG_MODE_TTL); }
inline bool isTTUMode() const { return (_modesIndex == RIG_MODE_TTU); }
inline bool isTTLMode() const { return (_modesIndex == RIG_MODE_TTL); }
inline bool isSSBMode() const { return (_modesIndex == usb || _modesIndex == lsb); }
// inline bool isUSBMode() const { return (_modesIndex == usb); }
// inline bool isLSBMode() const { return (_modesIndex == lsb); }
inline bool isDIGMode() const { return (_modesIndex == dig); }
inline bool isCWMode() const { return (_modesIndex == cw || _modesIndex == cwr); }
// inline bool isCWUMode() const { return (_modesIndex == RIG_MODE_CWU); }
// inline bool isCWLMode() const { return (_modesIndex == RIG_MODE_CWL); }
// Assign a pointer to a mode object. Returns true if successful, false otherwise.
bool addNewMode(RigMode i, IMode* mode) {
bool addNewMode(rig_mode i, IMode* mode) {
if (i > _modesLen) {
return false;
} else {
@ -98,7 +93,7 @@ class Rig {
}
// Returns the array index of the current mode.
inline RigMode modeNum() const {
inline rig_mode modeNum() const {
return _modesIndex;
}
@ -109,12 +104,12 @@ class Rig {
// Switch to the mode specified by the provided index. Returns a
// pointer to the new mode.
IMode* switchMode(RigMode i) {
IMode* switchMode(rig_mode i) {
// exit the previous mode
mode()->exit(); // NOTE: This could currently occur during TX, which is NOT desirable.
// select the new mode
_modesIndex = RigMode(i % _modesLen);
_modesIndex = rig_mode(i % _modesLen);
//enter the new mode
mode()->enter();
@ -132,9 +127,9 @@ class Rig {
// select the new mode
if (prev) {
_modesIndex = RigMode(_modesIndex > 0 ? _modesIndex - 1 : _modesLen - 1);
_modesIndex = rig_mode(_modesIndex > 0 ? _modesIndex - 1 : _modesLen - 1);
} else {
_modesIndex = RigMode((_modesIndex + 1) % _modesLen);
_modesIndex = rig_mode((_modesIndex + 1) % _modesLen);
}
// enter the new mode
@ -170,51 +165,51 @@ class Rig {
//--------------------------------------------------------------------
inline void setWideRxFilter() {
_filter = RX_FILTER_WIDE;
_filter = wide;
mode()->setWideRxFilter();
USBDEBUG("selected wide RX filter");
}
inline void setMediumRxFilter() {
_filter = RX_FILTER_MEDIUM;
_filter = medium;
mode()->setMediumRxFilter();
USBDEBUG("selected medium RX filter");
}
inline void setNarrowRxFilter() {
_filter = RX_FILTER_NARROW;
_filter = narrow;
mode()->setNarrowRxFilter();
USBDEBUG("selected narrow RX filter");
}
void switchRxFilter(RxFilter f) {
void switchRxFilter(rx_filter f) {
switch(f) {
case RX_FILTER_WIDE:
case wide:
setWideRxFilter();
break;
case RX_FILTER_MEDIUM:
case medium:
setMediumRxFilter();
break;
case RX_FILTER_NARROW:
case narrow:
setNarrowRxFilter();
break;
}
}
void switchRxFilter(bool prev=false) {
RxFilter f;
rx_filter f;
if (prev) {
f = RxFilter(_filter > 0 ? _filter - 1 : NUM_RX_FILTERS - 1);
f = rx_filter(_filter > 0 ? _filter - 1 : num_rx_filters - 1);
} else {
f = RxFilter((_filter + 1) % NUM_RX_FILTERS);
f = rx_filter((_filter + 1) % num_rx_filters);
}
switchRxFilter(f);
}
// Returns the array index of the current mode.
inline RxFilter filterNum() const {
inline rx_filter filterNum() const {
return _filter;
}
@ -321,10 +316,10 @@ class Rig {
RigAudio& _audio;
IMode** _modes;
RigMode _modesLen;
RigMode _modesIndex;
rig_mode _modesLen;
rig_mode _modesIndex;
RxFilter _filter;
rx_filter _filter;
// char _modeText[17];

View File

@ -20,14 +20,9 @@ Rig rig{rigConfig, rigAudio};
BPFilter rxFilter{300, 3100, false};
SSBMode lsbMode{rigConfig.lsb, rigAudio, rxFilter};
SSBMode usbMode{rigConfig.usb, rigAudio, rxFilter};
CWMode cwlMode{rigConfig.cwl, rigAudio, rxFilter};
CWMode cwuMode{rigConfig.cwu, rigAudio, rxFilter};
DGTMode dglMode{rigConfig.dgl, rigAudio, rxFilter};
DGTMode dguMode{rigConfig.dgu, rigAudio, rxFilter};
TTMode ttlMode{rigConfig.ttl, rigAudio, rxFilter};
TTMode ttuMode{rigConfig.ttu, rigAudio, rxFilter};
SSBMode ssbMode{rigConfig.ssb, rigAudio, rxFilter};
DGTMode digMode{rigConfig.dig, rigAudio, rxFilter};
CWMode cwMode {rigConfig.cw, rigAudio, rxFilter};
CATSwitch catPTT;
//MicSwitch micPTTHelper;
@ -63,14 +58,11 @@ void setup() {
rxFilter.init();
// adding all of the modes to the rig
rig.addNewMode(RIG_MODE_LSB, &lsbMode);
rig.addNewMode(RIG_MODE_USB, &usbMode);
rig.addNewMode(RIG_MODE_CWL, &cwlMode);
rig.addNewMode(RIG_MODE_CWU, &cwuMode);
rig.addNewMode(RIG_MODE_DGL, &dglMode);
rig.addNewMode(RIG_MODE_DGU, &dguMode);
rig.addNewMode(RIG_MODE_TTL, &ttlMode);
rig.addNewMode(RIG_MODE_TTU, &ttuMode);
rig.addNewMode(lsb, &ssbMode);
rig.addNewMode(usb, &ssbMode);
rig.addNewMode(cw, &cwMode);
rig.addNewMode(cwr, &cwMode);
rig.addNewMode(dig, &digMode);
initKeyLine();
rigAudio.init();
@ -122,7 +114,7 @@ void loop()
static bool paddle_loop = false;
// long oldPos = knobPos;
RigMode oldRigMode;
rig_mode oldRigMode;
frameCounter++;
@ -169,14 +161,14 @@ void loop()
// need to make it inactive if we're in DGT mode, since only CAT will be
// used to start transmitting in that case.
micPTT.setSSBMode(rig.isSSBMode());
micPTT.update(rig.mode(), !rig.isDGTMode());
micPTT.update(rig.mode(), !rig.isDIGMode());
// Update the line PTT. We need to tell it if we're in SSB mode, so that
// it knows if it should switch to the line input if pressed. We also
// need to make it inactive if we're in DGT mode, since only CAT will be
// used to start transmitting in that case.
linePTT.setSSBMode(rig.isSSBMode());
linePTT.update(rig.mode(), !rig.isDGTMode());
linePTT.update(rig.mode(), !rig.isDIGMode());
serviceCAT();