mirror of
https://github.com/saitohirga/WSJT-X.git
synced 2025-10-23 17:10:25 -04:00
Don't keep querying split status on rigs where it doesn't work
git-svn-id: svn+ssh://svn.code.sf.net/p/wsjt/wsjt/branches/wsjtx-1.4@4690 ab8295b8-cf94-4d9e-aec4-7959e3be5d79
This commit is contained in:
parent
20678117cb
commit
c8b00d17c9
@ -168,6 +168,7 @@ HamlibTransceiver::HamlibTransceiver (int model_number
|
|||||||
, back_ptt_port_ {TransceiverFactory::TX_audio_source_rear == back_ptt_port}
|
, back_ptt_port_ {TransceiverFactory::TX_audio_source_rear == back_ptt_port}
|
||||||
, is_dummy_ {RIG_MODEL_DUMMY == model_number}
|
, is_dummy_ {RIG_MODEL_DUMMY == model_number}
|
||||||
, reversed_ {false}
|
, reversed_ {false}
|
||||||
|
, split_query_works_ {true}
|
||||||
{
|
{
|
||||||
if (!rig_)
|
if (!rig_)
|
||||||
{
|
{
|
||||||
@ -265,23 +266,6 @@ void HamlibTransceiver::do_start ()
|
|||||||
|
|
||||||
error_check (rig_open (rig_.data ()), tr ("opening connection to rig"));
|
error_check (rig_open (rig_.data ()), tr ("opening connection to rig"));
|
||||||
|
|
||||||
init_rig ();
|
|
||||||
}
|
|
||||||
|
|
||||||
void HamlibTransceiver::do_stop ()
|
|
||||||
{
|
|
||||||
if (rig_)
|
|
||||||
{
|
|
||||||
rig_close (rig_.data ());
|
|
||||||
}
|
|
||||||
|
|
||||||
#if WSJT_TRACE_CAT
|
|
||||||
qDebug () << "HamlibTransceiver::do_stop: state:" << state () << "reversed =" << reversed_;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
void HamlibTransceiver::init_rig ()
|
|
||||||
{
|
|
||||||
if (!is_dummy_)
|
if (!is_dummy_)
|
||||||
{
|
{
|
||||||
freq_t f1;
|
freq_t f1;
|
||||||
@ -429,6 +413,18 @@ void HamlibTransceiver::init_rig ()
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void HamlibTransceiver::do_stop ()
|
||||||
|
{
|
||||||
|
if (rig_)
|
||||||
|
{
|
||||||
|
rig_close (rig_.data ());
|
||||||
|
}
|
||||||
|
|
||||||
|
#if WSJT_TRACE_CAT
|
||||||
|
qDebug () << "HamlibTransceiver::do_stop: state:" << state () << "reversed =" << reversed_;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
auto HamlibTransceiver::get_vfos () const -> std::tuple<vfo_t, vfo_t>
|
auto HamlibTransceiver::get_vfos () const -> std::tuple<vfo_t, vfo_t>
|
||||||
{
|
{
|
||||||
if (rig_->caps->get_vfo)
|
if (rig_->caps->get_vfo)
|
||||||
@ -696,42 +692,46 @@ void HamlibTransceiver::poll ()
|
|||||||
|
|
||||||
update_mode (map_mode (m));
|
update_mode (map_mode (m));
|
||||||
|
|
||||||
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
if (rig_->caps->get_split_vfo && split_query_works_)
|
||||||
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo";
|
|
||||||
#endif
|
|
||||||
vfo_t v {RIG_VFO_NONE}; // so we can tell if it doesn't get updated :(
|
|
||||||
auto rc = rig_get_split_vfo (rig_.data (), RIG_VFO_CURR, &s, &v);
|
|
||||||
if (-RIG_OK == rc && RIG_SPLIT_ON == s)
|
|
||||||
{
|
{
|
||||||
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
||||||
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo split = " << s << " VFO = 0x" << hex << v;
|
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo";
|
||||||
|
#endif
|
||||||
|
vfo_t v {RIG_VFO_NONE}; // so we can tell if it doesn't get updated :(
|
||||||
|
auto rc = rig_get_split_vfo (rig_.data (), RIG_VFO_CURR, &s, &v);
|
||||||
|
if (-RIG_OK == rc && RIG_SPLIT_ON == s)
|
||||||
|
{
|
||||||
|
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
||||||
|
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo split = " << s << " VFO = 0x" << hex << v;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
update_split (true);
|
update_split (true);
|
||||||
// if (RIG_VFO_A == v)
|
// if (RIG_VFO_A == v)
|
||||||
// {
|
// {
|
||||||
// reversed_ = true; // not sure if this helps us here
|
// reversed_ = true; // not sure if this helps us here
|
||||||
// }
|
// }
|
||||||
}
|
}
|
||||||
else if (-RIG_OK == rc) // not split
|
else if (-RIG_OK == rc) // not split
|
||||||
{
|
{
|
||||||
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
||||||
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo split = " << s << " VFO = 0x" << hex << v;
|
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo split = " << s << " VFO = 0x" << hex << v;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
update_split (false);
|
update_split (false);
|
||||||
}
|
}
|
||||||
else if (-RIG_ENAVAIL == rc || -RIG_ENIMPL == rc) // Some rigs (Icom) don't have a way of reporting SPLIT mode
|
else if (-RIG_ENAVAIL == rc || -RIG_ENIMPL == rc) // Some rigs (Icom) don't have a way of reporting SPLIT mode
|
||||||
{
|
{
|
||||||
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
#if WSJT_TRACE_CAT && WSJT_TRACE_CAT_POLLS
|
||||||
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo can't do on this rig";
|
qDebug ().nospace () << "HamlibTransceiver::poll rig_get_split_vfo can't do on this rig";
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// just report how we see it based on prior commands
|
// just report how we see it based on prior commands
|
||||||
}
|
split_query_works_ = false;
|
||||||
else
|
}
|
||||||
{
|
else
|
||||||
error_check (rc, tr ("getting split TX VFO"));
|
{
|
||||||
|
error_check (rc, tr ("getting split TX VFO"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (RIG_PTT_NONE != rig_->state.pttport.type.ptt && rig_->caps->get_ptt)
|
if (RIG_PTT_NONE != rig_->state.pttport.type.ptt && rig_->caps->get_ptt)
|
||||||
|
@ -55,7 +55,6 @@ class HamlibTransceiver final
|
|||||||
QByteArray get_conf (char const * item);
|
QByteArray get_conf (char const * item);
|
||||||
Transceiver::MODE map_mode (rmode_t) const;
|
Transceiver::MODE map_mode (rmode_t) const;
|
||||||
rmode_t map_mode (Transceiver::MODE mode) const;
|
rmode_t map_mode (Transceiver::MODE mode) const;
|
||||||
void init_rig ();
|
|
||||||
std::tuple<vfo_t, vfo_t> get_vfos () const;
|
std::tuple<vfo_t, vfo_t> get_vfos () const;
|
||||||
|
|
||||||
struct RIGDeleter {static void cleanup (RIG *);};
|
struct RIGDeleter {static void cleanup (RIG *);};
|
||||||
@ -65,6 +64,8 @@ class HamlibTransceiver final
|
|||||||
bool is_dummy_;
|
bool is_dummy_;
|
||||||
|
|
||||||
bool mutable reversed_;
|
bool mutable reversed_;
|
||||||
|
|
||||||
|
bool split_query_works_;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user