mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-03 06:28:27 -04:00
AP_Param: fixed handling of long lines in defaults.parm
lines longer than 100 bytes were causing the parsing to stop
This commit is contained in:
parent
adaa620855
commit
299a6a5168
@ -2299,28 +2299,25 @@ bool AP_Param::load_defaults_file(const char *filename, bool last_pass)
|
||||
bool AP_Param::count_embedded_param_defaults(uint16_t &count)
|
||||
{
|
||||
const volatile char *ptr = param_defaults_data.data;
|
||||
uint16_t length = param_defaults_data.length;
|
||||
int32_t length = param_defaults_data.length;
|
||||
count = 0;
|
||||
|
||||
while (length) {
|
||||
while (length>0) {
|
||||
char line[100];
|
||||
char *pname;
|
||||
float value;
|
||||
bool read_only;
|
||||
uint16_t i;
|
||||
uint16_t n = MIN(length, sizeof(line)-1);
|
||||
uint16_t n = length;
|
||||
for (i=0;i<n;i++) {
|
||||
if (ptr[i] == '\n') {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (i == n) {
|
||||
// no newline
|
||||
break;
|
||||
}
|
||||
|
||||
memcpy(line, (void *)ptr, i);
|
||||
line[i] = 0;
|
||||
uint16_t linelen = MIN(i,sizeof(line)-1);
|
||||
memcpy(line, (void *)ptr, linelen);
|
||||
line[linelen] = 0;
|
||||
|
||||
length -= i+1;
|
||||
ptr += i+1;
|
||||
@ -2367,27 +2364,25 @@ void AP_Param::load_embedded_param_defaults(bool last_pass)
|
||||
}
|
||||
|
||||
const volatile char *ptr = param_defaults_data.data;
|
||||
uint16_t length = param_defaults_data.length;
|
||||
int32_t length = param_defaults_data.length;
|
||||
uint16_t idx = 0;
|
||||
|
||||
while (idx < num_defaults && length) {
|
||||
while (idx < num_defaults && length > 0) {
|
||||
char line[100];
|
||||
char *pname;
|
||||
float value;
|
||||
bool read_only;
|
||||
uint16_t i;
|
||||
uint16_t n = MIN(length, sizeof(line)-1);
|
||||
uint16_t n = length;
|
||||
for (i=0;i<n;i++) {
|
||||
if (ptr[i] == '\n') {
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (i == n) {
|
||||
// no newline
|
||||
break;
|
||||
}
|
||||
memcpy(line, (void*)ptr, i);
|
||||
line[i] = 0;
|
||||
|
||||
uint16_t linelen = MIN(i,sizeof(line)-1);
|
||||
memcpy(line, (void *)ptr, linelen);
|
||||
line[linelen] = 0;
|
||||
|
||||
length -= i+1;
|
||||
ptr += i+1;
|
||||
|
Loading…
Reference in New Issue
Block a user