mirror of
				https://github.com/saitohirga/WSJT-X.git
				synced 2025-10-26 02:20:20 -04:00 
			
		
		
		
	
		
			
	
	
		
			166 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			166 lines
		
	
	
		
			5.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|  | #ifndef NETWORK_MESSAGE_HPP__
 | ||
|  | #define NETWORK_MESSAGE_HPP__
 | ||
|  | 
 | ||
|  | /*
 | ||
|  |  * WSJT-X Message Formats | ||
|  |  * ====================== | ||
|  |  * | ||
|  |  * All messages are written or  read using the QDataStream derivatives | ||
|  |  * defined below. | ||
|  |  * | ||
|  |  *  Message is big endian format | ||
|  |  * | ||
|  |  *   Header format: | ||
|  |  * | ||
|  |  *      32-bit unsigned integer magic number 0xadbccbda | ||
|  |  *      32-bit unsigned integer schema number | ||
|  |  * | ||
|  |  *   Payload format: | ||
|  |  * | ||
|  |  *      As per  the QDataStream format,  see below for version  used and | ||
|  |  *      here: | ||
|  |  * | ||
|  |  *        http://doc.qt.io/qt-5/datastreamformat.html
 | ||
|  |  * | ||
|  |  *      for the serialization details for each type. | ||
|  |  * | ||
|  |  * Type utf8  is a  utf-8 byte  string formatted  as a  QByteArray for | ||
|  |  * serialization purposes  (currently a quint32 size  followed by size | ||
|  |  * bytes, no terminator is present or counted). | ||
|  |  * | ||
|  |  * Schema Version 1: | ||
|  |  * ----------------- | ||
|  |  * | ||
|  |  * Message       Direction Value                  Type | ||
|  |  * ------------- --------- ---------------------- ----------- | ||
|  |  * Heartbeat     Out       0                      quint32 | ||
|  |  *                         Id (unique key)        utf8 | ||
|  |  * | ||
|  |  * Status        Out       1                      quint32 | ||
|  |  *                         Id (unique key)        utf8 | ||
|  |  *                         Dial Frequency (Hz)    quint64 | ||
|  |  *                         Mode                   utf8 | ||
|  |  *                         DX call                utf8 | ||
|  |  *                         Report                 utf8 | ||
|  |  *                         Tx Mode                utf8 | ||
|  |  * | ||
|  |  * Decode        Out       2                      quint32 | ||
|  |  *                         Id (unique key)        utf8 | ||
|  |  *                         New                    bool | ||
|  |  *                         Time                   QTime | ||
|  |  *                         snr                    qint32 | ||
|  |  *                         Delta time (S)         float | ||
|  |  *                         Delta frequency (Hz)   quint32 | ||
|  |  *                         Mode                   utf8 | ||
|  |  *                         Message                utf8 | ||
|  |  * | ||
|  |  * Clear         Out       3                      quint32 | ||
|  |  *                         Id (unique key)        utf8 | ||
|  |  * | ||
|  |  * Reply         In        4                      quint32 | ||
|  |  *                         Id (target unique key) utf8 | ||
|  |  *                         Time                   QTime | ||
|  |  *                         snr                    qint32 | ||
|  |  *                         Delta time (S)         float | ||
|  |  *                         Delta frequency (Hz)   quint32 | ||
|  |  *                         Mode                   utf8 | ||
|  |  *                         Message                utf8 | ||
|  |  * | ||
|  |  * QSO Logged    Out       5                      quint32 | ||
|  |  *                         Id (unique key)        utf8 | ||
|  |  *                         Date & Time            QDateTime | ||
|  |  *                         DX call                utf8 | ||
|  |  *                         DX grid                utf8 | ||
|  |  *                         Dial frequency (Hz)    quint64 | ||
|  |  *                         Mode                   utf8 | ||
|  |  *                         Report send            utf8 | ||
|  |  *                         Report received        utf8 | ||
|  |  *                         Tx power               utf8 | ||
|  |  *                         Comments               utf8 | ||
|  |  *                         Name                   utf8 | ||
|  |  * | ||
|  |  * Close         Out       6                      quint32 | ||
|  |  *                         Id (unique key)        utf8 | ||
|  |  * | ||
|  |  * Replay        In        7                      quint32 | ||
|  |  *                         Id (unique key)        utf8 | ||
|  |  */ | ||
|  | 
 | ||
|  | #include <QDataStream>
 | ||
|  | 
 | ||
|  | #include "pimpl_h.hpp"
 | ||
|  | 
 | ||
|  | class QIODevice; | ||
|  | class QByteArray; | ||
|  | class QString; | ||
|  | 
 | ||
|  | namespace NetworkMessage | ||
|  | { | ||
|  |   // NEVER DELETE MESSAGE TYPES
 | ||
|  |   enum Type | ||
|  |     { | ||
|  |       Heartbeat, | ||
|  |       Status, | ||
|  |       Decode, | ||
|  |       Clear, | ||
|  |       Reply, | ||
|  |       QSOLogged, | ||
|  |       Close, | ||
|  |       Replay, | ||
|  |       maximum_message_type_     // ONLY add new message types
 | ||
|  |                                 // immediately before here
 | ||
|  |     }; | ||
|  | 
 | ||
|  |   quint32 constexpr pulse {15}; // seconds
 | ||
|  | 
 | ||
|  |   //
 | ||
|  |   // NetworkMessage::Build - build a message containing serialized Qt types
 | ||
|  |   //
 | ||
|  |   class Builder | ||
|  |     : public QDataStream | ||
|  |   { | ||
|  |   public: | ||
|  |     static quint32 constexpr magic {0xadbccbda}; // never change this
 | ||
|  | 
 | ||
|  |     // increment this if a newer Qt schema is required and add decode
 | ||
|  |     // logic to InputMessageStream below
 | ||
|  |     static quint32 constexpr schema_number {1}; | ||
|  | 
 | ||
|  |     explicit Builder (QIODevice *, Type, QString const& id); | ||
|  |     explicit Builder (QByteArray *, Type, QString const& id); | ||
|  |     Builder (Builder const&) = delete; | ||
|  |     Builder& operator = (Builder const&) = delete; | ||
|  | 
 | ||
|  |   private: | ||
|  |     void common_initialization (Type type, QString const& id); | ||
|  |   }; | ||
|  | 
 | ||
|  |   //
 | ||
|  |   // NetworkMessage::Reader - read a message containing serialized Qt types
 | ||
|  |   //
 | ||
|  |   // Message  is as  per NetworkMessage::Builder  above, the  schema()
 | ||
|  |   // member  may be  used  to  determine the  schema  of the  original
 | ||
|  |   // message.
 | ||
|  |   //
 | ||
|  |   class Reader | ||
|  |     : public QDataStream | ||
|  |   { | ||
|  |   public: | ||
|  |     explicit Reader (QIODevice *); | ||
|  |     explicit Reader (QByteArray const&); | ||
|  |     Reader (Reader const&) = delete; | ||
|  |     Reader& operator = (Reader const&) = delete; | ||
|  |     ~Reader (); | ||
|  | 
 | ||
|  |     quint32 schema () const; | ||
|  |     Type type () const; | ||
|  |     QString id () const; | ||
|  | 
 | ||
|  |   private: | ||
|  |     class impl; | ||
|  |     pimpl<impl> m_; | ||
|  |   }; | ||
|  | } | ||
|  | 
 | ||
|  | #endif
 |