Remove direct struct access from usage of the Hamlib API

Preparation for safe dynamic linking to Hamlib where minor Hamlib
upgrades can be deployed just by replacing the DLL/SO.
This commit is contained in:
Bill Somerville 2021-02-02 22:45:45 +00:00
parent eecebc710d
commit f972fc18e1
No known key found for this signature in database
GPG Key ID: D864B06D1E81618F
10 changed files with 939 additions and 910 deletions

View File

@ -39,7 +39,7 @@ namespace
void DXLabSuiteCommanderTransceiver::register_transceivers (logger_type * /*logger*/, void DXLabSuiteCommanderTransceiver::register_transceivers (logger_type * /*logger*/,
TransceiverFactory::Transceivers * registry, TransceiverFactory::Transceivers * registry,
int id) unsigned id)
{ {
(*registry)[commander_transceiver_name] = TransceiverFactory::Capabilities {id, TransceiverFactory::Capabilities::network, true}; (*registry)[commander_transceiver_name] = TransceiverFactory::Capabilities {id, TransceiverFactory::Capabilities::network, true};
} }

View File

@ -24,7 +24,7 @@ class DXLabSuiteCommanderTransceiver final
Q_OBJECT; // for translation context Q_OBJECT; // for translation context
public: public:
static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *, int id); static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *, unsigned id);
// takes ownership of wrapped Transceiver // takes ownership of wrapped Transceiver
explicit DXLabSuiteCommanderTransceiver (logger_type *, std::unique_ptr<TransceiverBase> wrapped, explicit DXLabSuiteCommanderTransceiver (logger_type *, std::unique_ptr<TransceiverBase> wrapped,

View File

@ -25,7 +25,7 @@ namespace
void HRDTransceiver::register_transceivers (logger_type *, void HRDTransceiver::register_transceivers (logger_type *,
TransceiverFactory::Transceivers * registry, TransceiverFactory::Transceivers * registry,
int id) unsigned id)
{ {
(*registry)[HRD_transceiver_name] = TransceiverFactory::Capabilities (id, TransceiverFactory::Capabilities::network, true, true /* maybe */); (*registry)[HRD_transceiver_name] = TransceiverFactory::Capabilities (id, TransceiverFactory::Capabilities::network, true, true /* maybe */);
} }

View File

@ -30,7 +30,7 @@ class HRDTransceiver final
Q_OBJECT Q_OBJECT
public: public:
static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *, int id); static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *, unsigned id);
// takes ownership of wrapped Transceiver // takes ownership of wrapped Transceiver
explicit HRDTransceiver (logger_type * explicit HRDTransceiver (logger_type *

File diff suppressed because it is too large Load Diff

View File

@ -1,14 +1,11 @@
#ifndef HAMLIB_TRANSCEIVER_HPP_ #ifndef HAMLIB_TRANSCEIVER_HPP_
#define HAMLIB_TRANSCEIVER_HPP_ #define HAMLIB_TRANSCEIVER_HPP_
#include <tuple>
#include <QString> #include <QString>
#include <hamlib/rig.h>
#include "TransceiverFactory.hpp" #include "TransceiverFactory.hpp"
#include "PollingTransceiver.hpp" #include "PollingTransceiver.hpp"
#include "pimpl_h.hpp"
// hamlib transceiver and PTT mostly delegated directly to hamlib Rig class // hamlib transceiver and PTT mostly delegated directly to hamlib Rig class
class HamlibTransceiver final class HamlibTransceiver final
@ -20,10 +17,11 @@ public:
static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *); static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *);
static void unregister_transceivers (); static void unregister_transceivers ();
explicit HamlibTransceiver (logger_type *, int model_number, TransceiverFactory::ParameterPack const&, explicit HamlibTransceiver (logger_type *, unsigned model_number, TransceiverFactory::ParameterPack const&,
QObject * parent = nullptr); QObject * parent = nullptr);
explicit HamlibTransceiver (logger_type *, TransceiverFactory::PTTMethod ptt_type, QString const& ptt_port, explicit HamlibTransceiver (logger_type *, TransceiverFactory::PTTMethod ptt_type, QString const& ptt_port,
QObject * parent = nullptr); QObject * parent = nullptr);
~HamlibTransceiver ();
private: private:
int do_start () override; int do_start () override;
@ -35,38 +33,8 @@ private:
void do_poll () override; void do_poll () override;
void error_check (int ret_code, QString const& doing) const; class impl;
void set_conf (char const * item, char const * value); pimpl<impl> m_;
QByteArray get_conf (char const * item);
Transceiver::MODE map_mode (rmode_t) const;
rmode_t map_mode (Transceiver::MODE mode) const;
std::tuple<vfo_t, vfo_t> get_vfos (bool for_split) const;
struct RIGDeleter {static void cleanup (RIG *);};
QScopedPointer<RIG, RIGDeleter> rig_;
bool ptt_only_; // we can use a dummy device for PTT
bool back_ptt_port_;
bool one_VFO_;
bool is_dummy_;
// these are saved on destruction so we can start new instances
// where the last one left off
static freq_t dummy_frequency_;
static rmode_t dummy_mode_;
bool mutable reversed_;
bool freq_query_works_;
bool mode_query_works_;
bool split_query_works_;
bool tickle_hamlib_; // Hamlib requires a
// rig_set_split_vfo() call to
// establish the Tx VFO
bool get_vfo_works_; // Net rigctl promises what it can't deliver
bool set_vfo_works_; // More rigctl promises which it can't deliver
static int debug_callback (enum rig_debug_level_e level, rig_ptr_t arg, char const * format, va_list ap);
}; };
#endif #endif

View File

@ -76,7 +76,7 @@ OmniRig::RigParamX OmniRigTransceiver::map_mode (MODE mode)
void OmniRigTransceiver::register_transceivers (logger_type *, void OmniRigTransceiver::register_transceivers (logger_type *,
TransceiverFactory::Transceivers * registry, TransceiverFactory::Transceivers * registry,
int id1, int id2) unsigned id1, unsigned id2)
{ {
(*registry)[OmniRig_transceiver_one_name] = TransceiverFactory::Capabilities { (*registry)[OmniRig_transceiver_one_name] = TransceiverFactory::Capabilities {
id1 id1

View File

@ -26,7 +26,7 @@ class OmniRigTransceiver final
Q_OBJECT; Q_OBJECT;
public: public:
static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *, int id1, int id2); static void register_transceivers (logger_type *, TransceiverFactory::Transceivers *, unsigned id1, unsigned id2);
enum RigNumber {One = 1, Two}; enum RigNumber {One = 1, Two};

View File

@ -23,7 +23,7 @@ namespace
{ {
enum // supported non-hamlib radio interfaces enum // supported non-hamlib radio interfaces
{ {
NonHamlibBaseId = 9899 NonHamlibBaseId = 99899
, CommanderId , CommanderId
, HRDId , HRDId
, OmniRigOneId , OmniRigOneId

View File

@ -35,7 +35,7 @@ public:
{ {
enum PortType {none, serial, network, usb}; enum PortType {none, serial, network, usb};
explicit Capabilities (int model_number = 0 explicit Capabilities (unsigned model_number = 0
, PortType port_type = none , PortType port_type = none
, bool has_CAT_PTT = false , bool has_CAT_PTT = false
, bool has_CAT_PTT_mic_data = false , bool has_CAT_PTT_mic_data = false
@ -50,7 +50,7 @@ public:
{ {
} }
int model_number_; unsigned model_number_;
PortType port_type_; PortType port_type_;
bool has_CAT_PTT_; bool has_CAT_PTT_;
bool has_CAT_PTT_mic_data_; bool has_CAT_PTT_mic_data_;