libdrmconf  0.12.0
A library to program DMR radios.
Public Member Functions | Static Public Member Functions | Protected Attributes | List of all members

Implements an USB interface to the Baofeng DM-1701 and Retevis RT84 VHF/UHF 5W DMR (Tier I&II) radios. More...

#include <dm1701.hh>

Inheritance diagram for DM1701:
Inheritance graph
[legend]
Collaboration diagram for DM1701:
Collaboration graph
[legend]

Public Member Functions

 DM1701 (TyTInterface *device=nullptr, QObject *parent=nullptr)
 Do not construct this class directly, rather use Radio::detect.
 
const QString & name () const
 Returns the name of the radio (e.g., device identifier).
 
const RadioLimitslimits () const
 Returns the limits for this radio. More...
 
const Codeplugcodeplug () const
 Returns the codeplug instance.
 
Codeplugcodeplug ()
 Returns the codeplug instance.
 
const CallsignDBcallsignDB () const
 Returns the call-sign DB instance.
 
CallsignDBcallsignDB ()
 Returns the call-sign DB instance.
 
- Public Member Functions inherited from TyTRadio
 TyTRadio (TyTInterface *device=nullptr, QObject *parent=nullptr)
 Do not construct this class directly, rather use Radio::detect.
 
- Public Member Functions inherited from Radio
 Radio (QObject *parent=nullptr)
 Default constructor.
 
Status status () const
 Returns the current status.
 
const ErrorStackerrorStack () const
 Returns the error stack, passed to startDownload, startUpload or startUploadCallsignDB. More...
 

Static Public Member Functions

static RadioInfo defaultRadioInfo ()
 Returns the default radio information. More...
 
- Static Public Member Functions inherited from Radio
static Radiodetect (const USBDeviceDescriptor &descr, const RadioInfo &force=RadioInfo(), const ErrorStack &err=ErrorStack())
 Tries to detect the radio connected to the specified interface or constructs the specified radio using the RadioInfo passed by force.
 

Protected Attributes

QString _name
 The device identifier.
 
DM1701Codeplug _codeplug
 The actual binary codeplug representation.
 
DM1701CallsignDB _callsigndb
 The callsign DB object.
 
- Protected Attributes inherited from TyTRadio
TyTInterface_dev
 The interface to the radio.
 
Codeplug::Flags _codeplugFlags
 Holds the flags to control assembly and upload of code-plugs.
 
Config_config
 The generic configuration.
 
UserDatabase_userDB
 A weak reference to the user-database.
 
- Protected Attributes inherited from Radio
Status _task
 The current state/task.
 
ErrorStack _errorStack
 The error stack.
 

Additional Inherited Members

- Public Types inherited from Radio
enum  Status {
  StatusIdle , StatusDownload , StatusUpload , StatusUploadCallsigns ,
  StatusError
}
 Possible states of the radio object. More...
 
- Public Slots inherited from TyTRadio
bool startDownload (bool blocking=false, const ErrorStack &err=ErrorStack())
 Starts the download of the codeplug and derives the generic configuration from it.
 
bool startUpload (Config *config, bool blocking=false, const Codeplug::Flags &flags=Codeplug::Flags(), const ErrorStack &err=ErrorStack())
 Derives the device-specific codeplug from the generic configuration and uploads that codeplug to the radio.
 
bool startUploadCallsignDB (UserDatabase *db, bool blocking=false, const CallsignDB::Selection &selection=CallsignDB::Selection(), const ErrorStack &err=ErrorStack())
 Encodes the given user-database and uploades it to the device.
 
- Public Slots inherited from Radio
virtual bool startDownload (bool blocking=false, const ErrorStack &err=ErrorStack())=0
 Starts the download of the codeplug. More...
 
virtual bool startUpload (Config *config, bool blocking=false, const Codeplug::Flags &flags=Codeplug::Flags(), const ErrorStack &err=ErrorStack())=0
 Derives the device-specific codeplug from the generic configuration and uploads that codeplug to the radio.
 
virtual bool startUploadCallsignDB (UserDatabase *db, bool blocking=false, const CallsignDB::Selection &selection=CallsignDB::Selection(), const ErrorStack &err=ErrorStack())=0
 Assembles the callsign DB from the given one and uploads it to the device.
 
- Signals inherited from Radio
void downloadStarted ()
 Gets emitted once the codeplug download has been started.
 
void downloadProgress (int percent)
 Gets emitted on download progress (e.g., for progress bars).
 
void downloadFinished (Radio *radio, Codeplug *codeplug)
 Gets emitted once the codeplug download has been finished.
 
void downloadError (Radio *radio)
 Gets emitted if there was an error during the codeplug download.
 
void uploadStarted ()
 Gets emitted once the codeplug upload has been started.
 
void uploadProgress (int percent)
 Gets emitted on upload progress (e.g., for progress bars).
 
void uploadError (Radio *radio)
 Gets emitted if there was an error during the upload.
 
void uploadComplete (Radio *radio)
 Gets emitted once the codeplug upload has been completed successfully.
 
- Protected Member Functions inherited from TyTRadio
void run ()
 Thread main routine, performs all blocking IO operations for codeplug up- and download.
 

Detailed Description

Implements an USB interface to the Baofeng DM-1701 and Retevis RT84 VHF/UHF 5W DMR (Tier I&II) radios.

The Baofeng DM-1701 and Retevis RT84 radios use a DFU-style communication protocol to read and write codeplugs onto the radio (see DFUDevice). This class implements the communication details using DFU protocol.

Member Function Documentation

◆ defaultRadioInfo()

RadioInfo DM1701::defaultRadioInfo ( )
static

Returns the default radio information.

The actual instance may have different properties due to variants of the same radio.

◆ limits()

const RadioLimits & DM1701::limits ( ) const
virtual

Returns the limits for this radio.

Call RadioLimits::verifyConfig to verify a codeplug with respect to a radio.

Since
Version 0.10.2

Implements Radio.


The documentation for this class was generated from the following files: