UV380: use the same CSV parsing routines as D868UV.

This commit is contained in:
Serge Vakulenko 2018-11-23 21:03:22 -08:00
parent 46203f940e
commit 7aaa39f6e4
2 changed files with 29 additions and 42 deletions

14
util.c
View File

@ -761,17 +761,17 @@ int csv_init(FILE *csv)
field1 = trim_quotes(field1); field1 = trim_quotes(field1);
field2 = trim_quotes(field2); field2 = trim_quotes(field2);
field3 = trim_quotes(field3); field3 = trim_quotes(field3);
//printf("Line: %s,%s,%s\n", field1, field2, field3); //printf("Line: %s,%s,%s\n", field1, field2, field3);
if (strcmp(field1, "Radio ID") == 0 && if (strcasecmp(field1, "Radio ID") == 0 &&
strcmp(field2, "Callsign") == 0) { strcasecmp(field2, "Callsign") == 0) {
// Correct format: // Correct format:
// Radio ID,Callsign,Name,City,State,Country,Remarks // Radio ID,Callsign,Name,City,State,Country,Remarks
csv_skip_field1 = 0; csv_skip_field1 = 0;
return 0; return 0;
} }
if (strcmp(field2, "Radio ID") == 0 && if (strcasecmp(field2, "Radio ID") == 0 &&
strcmp(field3, "Callsign") == 0) { strcasecmp(field3, "Callsign") == 0) {
// Correct format: // Correct format:
// "No.","Radio ID","Callsign","Name","City","State","Country","Remarks" // "No.","Radio ID","Callsign","Name","City","State","Country","Remarks"
csv_skip_field1 = 1; csv_skip_field1 = 1;
@ -794,7 +794,7 @@ int csv_read(FILE *csv, char **radioid, char **callsign, char **name,
again: again:
if (!fgets(line, sizeof(line), csv)) if (!fgets(line, sizeof(line), csv))
return 0; return 0;
//printf("Line: '%s'\n", line); //printf("Line: '%s'\n", line);
// Replace non-ASCII characters with '?'. // Replace non-ASCII characters with '?'.
char *p; char *p;
@ -827,7 +827,7 @@ again:
*state = trim_spaces(trim_quotes(*state), 16); *state = trim_spaces(trim_quotes(*state), 16);
*country = trim_spaces(trim_quotes(*country), 16); *country = trim_spaces(trim_quotes(*country), 16);
*remarks = trim_spaces(trim_quotes(*remarks), 16); *remarks = trim_spaces(trim_quotes(*remarks), 16);
//printf("%s,%s,%s,%s,%s,%s,%s\n", *radioid, *callsign, *name, *city, *state, *country, *remarks); //printf("%s,%s,%s,%s,%s,%s,%s\n", *radioid, *callsign, *name, *city, *state, *country, *remarks);
if (**radioid < '1' || **radioid > '9') if (**radioid < '1' || **radioid > '9')
goto again; goto again;

57
uv380.c
View File

@ -2420,7 +2420,8 @@ static void build_callsign_index(uint8_t *mem, int nrecords)
static void uv380_write_csv(radio_device_t *radio, FILE *csv) static void uv380_write_csv(radio_device_t *radio, FILE *csv)
{ {
uint8_t *mem; uint8_t *mem;
char line[256], *callsign, *name; char line[256];
char *radioid, *callsign, *name, *city, *state, *country, *remarks;
int id, bno, nbytes, nrecords = 0; int id, bno, nbytes, nrecords = 0;
unsigned finish; unsigned finish;
callsign_t *cs; callsign_t *cs;
@ -2434,49 +2435,33 @@ static void uv380_write_csv(radio_device_t *radio, FILE *csv)
} }
memset(mem, 0xff, nbytes); memset(mem, 0xff, nbytes);
//
// Parse CSV file. // Parse CSV file.
while (fgets(line, sizeof(line), csv)) { //
if (line[0] < '0' || line[0] > '9') { if (csv_init(csv) < 0) {
// Skip header. free(mem);
continue; return;
} }
while (csv_read(csv, &radioid, &callsign, &name, &city, &state, &country, &remarks)) {
//printf("%s,%s,%s,%s,%s,%s,%s\n", radioid, callsign, name, city, state, country, remarks);
// Strip trailing spaces and newline. id = strtoul(radioid, 0, 10);
char *e = line + strlen(line) - 1;
while (e >= line && (*e=='\n' || *e=='\r' || *e==' ' || *e=='\t'))
*e-- = 0;
id = strtoul(line, 0, 10);
if (id < 1 || id > 0xffffff) { if (id < 1 || id > 0xffffff) {
fprintf(stderr, "Bad id: %d\n", id); fprintf(stderr, "Bad id: %d\n", id);
fprintf(stderr, "Line: '%s'\n", line); fprintf(stderr, "Line: '%s,%s,%s,%s,%s,%s,%s'\n",
radioid, callsign, name, city, state, country, remarks);
return; return;
} }
callsign = strchr(line, ',');
if (! callsign) {
fprintf(stderr, "Cannot find callsign!\n");
fprintf(stderr, "Line: '%s'\n", line);
return;
}
*callsign++ = 0;
name = strchr(callsign, ',');
if (! name) {
fprintf(stderr, "Cannot find name!\n");
fprintf(stderr, "Line: '%s,%s'\n", line, callsign);
return;
}
*name++ = 0;
//printf("%-10d%-10s%s\n", id, callsign, name);
cs = GET_CALLSIGN(mem, nrecords); cs = GET_CALLSIGN(mem, nrecords);
nrecords++; nrecords++;
// Fill callsign structure. // Fill callsign structure.
cs->dmrid = id; cs->dmrid = id;
strncpy(cs->callsign, callsign, sizeof(cs->callsign)); strncpy(cs->callsign, callsign, sizeof(cs->callsign));
strncpy(cs->name, name, sizeof(cs->name)); snprintf(line, sizeof(line), "%s,%s,%s,%s,%s",
name, city, state, country, remarks);
strncpy(cs->name, line, sizeof(cs->name));
} }
fprintf(stderr, "Total %d contacts.\n", nrecords); fprintf(stderr, "Total %d contacts.\n", nrecords);
@ -2488,21 +2473,21 @@ static void uv380_write_csv(radio_device_t *radio, FILE *csv)
// Align to 1kbyte. // Align to 1kbyte.
finish = CALLSIGN_START + (CALLSIGN_OFFSET + nrecords*120 + 1023) / 1024 * 1024; finish = CALLSIGN_START + (CALLSIGN_OFFSET + nrecords*120 + 1023) / 1024 * 1024;
if (finish > CALLSIGN_FINISH) { if (finish > CALLSIGN_FINISH) {
// Limit is 122197 contacts. // Limit is 122197 contacts.
fprintf(stderr, "Too many contacts!\n"); fprintf(stderr, "Too many contacts!\n");
return; return;
} }
//
// Erase whole region.
// Align finish to 64kbytes.
//
radio_progress = 0; radio_progress = 0;
if (! trace_flag) { if (! trace_flag) {
fprintf(stderr, "Erase: "); fprintf(stderr, "Erase: ");
fflush(stderr); fflush(stderr);
} }
// Erase whole region.
// Align finish to 64kbytes.
dfu_erase(CALLSIGN_START, (finish + 0xffff) / 0x10000 * 0x10000); dfu_erase(CALLSIGN_START, (finish + 0xffff) / 0x10000 * 0x10000);
if (! trace_flag) { if (! trace_flag) {
fprintf(stderr, "# done.\n"); fprintf(stderr, "# done.\n");
@ -2510,7 +2495,9 @@ static void uv380_write_csv(radio_device_t *radio, FILE *csv)
fflush(stderr); fflush(stderr);
} }
//
// Write callsigns. // Write callsigns.
//
for (bno = CALLSIGN_START/1024; bno < finish/1024; bno++) { for (bno = CALLSIGN_START/1024; bno < finish/1024; bno++) {
dfu_write_block(bno, &mem[bno*1024 - CALLSIGN_START], 1024); dfu_write_block(bno, &mem[bno*1024 - CALLSIGN_START], 1024);