AP_Common: add NMEA output to a buffer

This commit is contained in:
Tom Pittenger 2023-01-04 20:50:25 -08:00 committed by Peter Barker
parent a929a5006a
commit ea35b28b22
2 changed files with 36 additions and 0 deletions

View File

@ -82,3 +82,32 @@ bool nmea_printf(AP_HAL::UARTDriver *uart, const char *fmt, ...)
free(s); free(s);
return true; return true;
} }
/*
formatted print of NMEA message to a buffer, with checksum appended.
Returns the length of the string filled into buf. If the NMEA string does not fit in the buffer, returns 0
*/
uint16_t nmea_printf_buffer(char* buf, const uint16_t buf_max_len, const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
char *s = nmea_vaprintf(fmt, ap);
va_end(ap);
if (s == nullptr) {
return 0;
}
size_t len = strlen(s);
if (len > buf_max_len) {
// our string is larger than the buffer we've supplied.
// Instead of populating the buffer with a partial message, just quietly fail and do nothing
len = 0;
} else {
strncpy(buf, s, buf_max_len);
}
free(s);
return len;
}

View File

@ -25,3 +25,10 @@ char *nmea_vaprintf(const char *fmt, va_list ap);
formatted print of NMEA message to a uart, with checksum appended formatted print of NMEA message to a uart, with checksum appended
*/ */
bool nmea_printf(AP_HAL::UARTDriver *uart, const char *fmt, ...) FMT_PRINTF(2,3); bool nmea_printf(AP_HAL::UARTDriver *uart, const char *fmt, ...) FMT_PRINTF(2,3);
/*
formatted print of NMEA message to a buffer, with checksum appended.
Returns the length of the string filled into buf. If the NMEA string does not fit in the buffer, returns 0
*/
uint16_t nmea_printf_buffer(char* buf, const uint16_t buf_max_len, const char *fmt, ...);