28 CNTRIPEmitter::CNTRIPEmitter()
32 m_transmit_to_server(true),
52 std::vector<uint8_t> buf;
65 "[NTRIP %s] Rate: %.02f B/s\n",
74 "[NTRIP %s] RX (%u bytes)\n",
76 (
unsigned int)buf.size());
82 "[NTRIP %s] RX: %u bytes\n",
84 (
unsigned)buf.size());
91 reinterpret_cast<const char*>(&buf[0]), buf.size());
99 const size_t nReadActual =
m_out_COM.
Read(rxbuf,
sizeof(rxbuf) - 1);
102 rxbuf[nReadActual] = 0;
105 "[NTRIP %s] TX (%u bytes)\n",
108 (
unsigned int)nReadActual);
112 std::this_thread::sleep_for(1ms);
144 fil.c_str(), std::ofstream::out | std::ofstream::binary);
147 "Error opening output raw file: `%s`", fil.c_str());
153 "ERROR trying to connect to NTRIP caster: %s", errstr.c_str());
172 "At least one of either raw file output or serial COM file must be " 173 "specified in configuration file!");
void initialize()
Set up the NTRIP communications, raising an exception on fatal errors.
double Tac() noexcept
Stops the stopwatch.
bool open(const NTRIPArgs ¶ms, std::string &out_errmsg)
Tries to open a given NTRIP stream and, if successful, launches a thread for continuously reading fro...
std::string m_com_port
If set to non-empty, the serial port will be attempted to be opened automatically when this class is ...
CNTRIPClient m_client
The NTRIP comms object.
void open()
Open the port.
mrpt::system::TTimeStamp now()
A shortcut for system::getCurrentTime.
Contains classes for various device interfaces.
std::string fileNameStripInvalidChars(const std::string &filename, const char replacement_to_invalid_chars='_')
Replace invalid filename chars by underscores ('_') or any other user-given char. ...
void close()
Closes the connection.
void setConfig(int baudRate, int parity=0, int bits=8, int nStopBits=1, bool enableFlowControl=false)
Changes the configuration of the port.
std::string m_raw_output_file_prefix
This class allows loading and storing values and vectors of different types from a configuration text...
bool isOpen() const
Returns if port has been correctly open.
This namespace contains representation of robot actions and observations.
size_t Write(const void *Buffer, size_t Count) override
Introduces a pure virtual method responsible for writing to the stream.
#define ASSERTMSG_(f, __ERROR_MSG)
Defines an assertion mechanism.
void purgeBuffers()
Purge tx and rx buffers.
GLsizei const GLchar ** string
#define IMPLEMENTS_GENERIC_SENSOR(class_name, NameSpace)
This must be inserted in all CGenericSensor classes implementation files:
void loadConfig_sensorSpecific(const mrpt::config::CConfigFileBase &configSource, const std::string &iniSection)
See the class documentation at the top for expected parameters.
void close()
Close the port.
void setTimeouts(int ReadIntervalTimeout, int ReadTotalTimeoutMultiplier, int ReadTotalTimeoutConstant, int WriteTotalTimeoutMultiplier, int WriteTotalTimeoutConstant)
Changes the timeouts of the port, in milliseconds.
CNTRIPClient::NTRIPArgs m_ntrip_args
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
std::ofstream m_raw_output_file_stream
void doProcess()
The main loop, which must be called in a timely fashion in order to process the incomming NTRIP data ...
std::string format(const char *fmt,...) MRPT_printf_format_check(1
A std::string version of C sprintf.
virtual ~CNTRIPEmitter()
Destructor.
std::string timeLocalToString(const mrpt::system::TTimeStamp t, unsigned int secondFractionDigits=6)
Convert a timestamp into this textual form (in local time): HH:MM:SS.MMMMMM.
bool m_transmit_to_server
std::string trim(const std::string &str)
Removes leading and trailing spaces.
mrpt::comms::CSerialPort m_out_COM
The output serial port.
mrpt::system::CTicTac m_rate_timer
void readAndClear(std::vector< uint8_t > &d)
Read the whole buffer and empty it.
void Tic() noexcept
Starts the stopwatch.
std::string dateTimeLocalToString(const mrpt::system::TTimeStamp t)
Convert a timestamp into this textual form (in local time): YEAR/MONTH/DAY,HH:MM:SS.MMM.
This "virtual driver" encapsulates a NTRIP client (see CNTRIPClient) but adds the functionality of du...
#define THROW_EXCEPTION_FMT(_FORMAT_STRING,...)
size_t Read(void *Buffer, size_t Count)
Implements the virtual method responsible for reading from the stream - Unlike CStream::ReadBuffer, this method will not raise an exception on zero bytes read, as long as there is not any fatal error in the communications.
mrpt::containers::MT_buffer stream_data
The buffer with all the bytes so-far read from the NTRIP server stream.