nmealib 0.0.4
NMEA 0183/NMEA 2000 parsing library
Loading...
Searching...
No Matches
Public Member Functions | Friends | List of all members
nmealib::nmea0183::MTW Class Reference

Represents a parsed NMEA 0183 MTW (Mean Temperature of Water) sentence. More...

#include <mtw.h>

Inheritance diagram for nmealib::nmea0183::MTW:
Inheritance graph
[legend]
Collaboration diagram for nmealib::nmea0183::MTW:
Collaboration graph
[legend]

Public Member Functions

 MTW (std::string talkerId, double temperature, char unit)
 Construct an MTW message from individual field values.
 
 MTW (const MTW &)=default
 
MTWoperator= (const MTW &)=default
 
 MTW (MTW &&) noexcept=default
 
MTWoperator= (MTW &&) noexcept=default
 
 ~MTW () override=default
 
std::unique_ptr< nmealib::Messageclone () const override
 Create a polymorphic copy of this MTW message.
 
double getTemperature () const noexcept
 Get the water temperature value.
 
char getUnit () const noexcept
 Get the temperature unit character.
 
std::string getStringContent (bool verbose) const noexcept override
 Return a human-readable string representation of this message.
 
bool operator== (const MTW &other) const noexcept
 Compare two MTW messages for equality.
 
- Public Member Functions inherited from nmealib::nmea0183::Message0183
 Message0183 (const Message0183 &)=default
 Copy constructor.
 
Message0183operator= (const Message0183 &)=default
 Copy assignment operator.
 
 Message0183 (Message0183 &&) noexcept=default
 Move constructor.
 
Message0183operator= (Message0183 &&) noexcept=default
 Move assignment operator.
 
 ~Message0183 () override=default
 Destructor.
 
char getStartChar () const noexcept
 Returns the start character of the NMEA 0183 sentence.
 
std::string getTalker () const noexcept
 Returns the talker identifier extracted from the sentence.
 
std::string getSentenceType () const noexcept
 Returns the sentence type identifier extracted from the sentence.
 
std::string getPayload () const noexcept
 Returns the payload of the NMEA 0183 sentence.
 
std::string getChecksumStr () const
 Get the checksum string extracted from the raw sentence.
 
std::string getCalculatedChecksumStr () const noexcept
 Get the calculated checksum string for the sentence payload.
 
std::string serialize () const override
 Returns the wire-format representation of the NMEA 0183 sentence, that is, the raw information that was passed when the message was created.
 
bool operator== (const Message0183 &other) const noexcept
 Compares two Message0183 objects for equality based on their content and timestamp.
 
bool validate () const noexcept override
 Returns whether the message is valid or not.
 
- Public Member Functions inherited from nmealib::Message
 Message ()
 
 Message (std::string raw, Type type=Type::Unknown, TimePoint ts=std::chrono::system_clock::now()) noexcept
 
virtual ~Message ()
 
 Message (const Message &)=default
 
Messageoperator= (const Message &)=default
 
 Message (Message &&) noexcept=default
 
Messageoperator= (Message &&) noexcept=default
 
Type getType () const noexcept
 Returns the message type.
 
const std::string & getRawData () const noexcept
 Returns the raw, unmodified data string as received.
 
TimePoint getTimestamp () const noexcept
 Returns the timestamp associated with this message.
 
bool operator== (const Message &other) const noexcept
 Compares two Message objects for equality based on their content.
 

Friends

class Nmea0183Factory
 
class MessageRegistry
 

Additional Inherited Members

- Public Types inherited from nmealib::Message
enum class  Type { Unknown , NMEA0183 , NMEA2000 }
 Defines the type of NMEA message, allowing for differentiation between various standards. More...
 
using TimePoint = std::chrono::system_clock::time_point
 
- Static Public Member Functions inherited from nmealib::nmea0183::Message0183
static double convertNmeaCoordinateToDecimalDegrees (const std::string &nmeaCoordinate)
 Converts an NMEA coordinate in ddmm.mmmm / dddmm.mmmm format to decimal degrees.
 
- Static Public Member Functions inherited from nmealib::Message
static std::string typeToString (Type t)
 Converts a Message::Type enum value to its string representation.
 
- Protected Member Functions inherited from nmealib::nmea0183::Message0183
std::string toString (bool verbose) const noexcept
 Provides the common string representation for every NMEA 0183 message, which can be used by derived classes to implement their own getStringContent method.
 
- Protected Member Functions inherited from nmealib::Message
void setType (Type t) noexcept
 Sets the message type.
 
void setRaw (std::string r) noexcept
 Sets the raw data string.
 
void setTimestamp (TimePoint ts) noexcept
 Sets the message timestamp.
 
- Static Protected Member Functions inherited from nmealib::nmea0183::Message0183
static std::unique_ptr< Message0183create (const std::string &raw, TimePoint ts=std::chrono::system_clock::now())
 Protected factory method to create a Message0183 from a raw sentence string.
 
- Protected Attributes inherited from nmealib::nmea0183::Message0183
char startChar_
 
std::string talker_
 
std::string sentenceType_
 
std::string payload_
 
std::string checksumStr_
 
std::string calculatedChecksumStr_
 
- Protected Attributes inherited from nmealib::Message
std::string rawData_
 
Type type_ {Type::Unknown}
 
TimePoint timestamp_ {}
 

Detailed Description

Represents a parsed NMEA 0183 MTW (Mean Temperature of Water) sentence.

The MTW sentence reports the mean temperature of the water as measured by the instrument. The sentence format is:

$--MTW,x.x,C*hh<CR><LF>
Represents a parsed NMEA 0183 MTW (Mean Temperature of Water) sentence.
Definition mtw.h:46

Fields:

Example sentence:

$IIMTW,23.5,C*1E\r\n

Definition at line 46 of file mtw.h.

Constructor & Destructor Documentation

◆ MTW() [1/3]

nmealib::nmea0183::MTW::MTW ( std::string  talkerId,
double  temperature,
char  unit 
)

Construct an MTW message from individual field values.

Composes the raw NMEA sentence from the supplied fields and initialises the object. A checksum is automatically appended to the raw sentence.

Parameters
talkerIdTwo-character talker identifier (e.g., "II", "GP").
temperatureWater temperature in degrees Celsius.
unitUnit of temperature. Should be 'C' (Celsius) as required by the NMEA 0183 standard.

Definition at line 59 of file mtw.cpp.

◆ MTW() [2/3]

nmealib::nmea0183::MTW::MTW ( const MTW )
default

◆ MTW() [3/3]

nmealib::nmea0183::MTW::MTW ( MTW &&  )
defaultnoexcept

◆ ~MTW()

nmealib::nmea0183::MTW::~MTW ( )
overridedefault

Member Function Documentation

◆ clone()

std::unique_ptr< nmealib::Message > nmealib::nmea0183::MTW::clone ( ) const
overridevirtual

Create a polymorphic copy of this MTW message.

Returns
std::unique_ptr<nmealib::Message> A heap-allocated copy of this object.

Reimplemented from nmealib::nmea0183::Message0183.

Definition at line 66 of file mtw.cpp.

◆ getStringContent()

std::string nmealib::nmea0183::MTW::getStringContent ( bool  verbose) const
overridevirtualnoexcept

Return a human-readable string representation of this message.

Parameters
verboseWhen true, every field is printed on its own labelled line. When false, a compact single-line summary is returned instead.
Returns
std::string The formatted string content.

Reimplemented from nmealib::nmea0183::Message0183.

Definition at line 70 of file mtw.cpp.

◆ getTemperature()

double nmealib::nmea0183::MTW::getTemperature ( ) const
noexcept

Get the water temperature value.

Returns
double The water temperature (in the units indicated by getUnit()).

Definition at line 97 of file mtw.cpp.

◆ getUnit()

char nmealib::nmea0183::MTW::getUnit ( ) const
noexcept

Get the temperature unit character.

Per the NMEA 0183 standard this is always 'C' (degrees Celsius).

Returns
char The unit character (typically 'C').

Definition at line 101 of file mtw.cpp.

◆ operator=() [1/2]

MTW & nmealib::nmea0183::MTW::operator= ( const MTW )
default

◆ operator=() [2/2]

MTW & nmealib::nmea0183::MTW::operator= ( MTW &&  )
defaultnoexcept

◆ operator==()

bool nmealib::nmea0183::MTW::operator== ( const MTW other) const
noexcept

Compare two MTW messages for equality.

Two MTW messages are equal when their underlying Message0183 representations are equal (raw sentence, talker, checksum, and timestamp all match).

Parameters
otherThe MTW message to compare with.
Returns
bool true if the messages are equal, false otherwise.

Definition at line 105 of file mtw.cpp.

Friends And Related Symbol Documentation

◆ MessageRegistry

friend class MessageRegistry
friend

Definition at line 130 of file mtw.h.

◆ Nmea0183Factory

friend class Nmea0183Factory
friend

Definition at line 129 of file mtw.h.


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