diff --git a/dive.h b/dive.h index b77a08468..1191ec6b6 100644 --- a/dive.h +++ b/dive.h @@ -530,7 +530,6 @@ extern void flush_divelist(struct dive *dive); extern void set_dc_nickname(struct dive *dive); extern const char *get_dc_nickname(const char *model, uint32_t deviceid); extern void remember_dc(const char *model, uint32_t deviceid, const char *nickname, gboolean change_conf); -extern void add_dc_to_string(char **dc_xml, struct divecomputer *dc); #define DIVE_ERROR_PARSE 1 diff --git a/gtk-gui.c b/gtk-gui.c index 974cfe29d..60a1f18d3 100644 --- a/gtk-gui.c +++ b/gtk-gui.c @@ -2281,37 +2281,3 @@ void set_dc_nickname(struct dive *dive) dc = dc->next; } } - -void add_dc_to_string(char **dc_xml, struct divecomputer *dc) -{ - char *pattern, *tmp; - const char *nickname; - int len; - - if (!dc || !dc->model || !*dc->model || !dc->deviceid) - /* we have no dc or no model or no deviceid information... nothing to do here */ - return; - len = sizeof(" model='' deviceid=''") + strlen(dc->model) + 8; - pattern = malloc(len); - snprintf(pattern, len, " model='%s' deviceid='%08x'", dc->model, dc->deviceid); - if (*dc_xml && strstr(*dc_xml, pattern)) { - /* already have that one */ - free(pattern); - return; - } - nickname = get_dc_nickname(dc->model, dc->deviceid); - if (!nickname || !*nickname || !strcmp(dc->model, nickname)) { - /* we still want to store this entry as it explicitly tells us - * "no nickname needed, use model" */ - len += strlen(*dc_xml) + sizeof("\n"); - tmp = malloc(len); - snprintf(tmp, len, "%s\n", *dc_xml, pattern); - } else { - len += strlen(*dc_xml) + strlen(nickname) + sizeof("\n"); - tmp = malloc(len); - snprintf(tmp, len, "%s\n", *dc_xml, pattern, nickname); - } - free(pattern); - free(*dc_xml); - *dc_xml = tmp; -} diff --git a/save-xml.c b/save-xml.c index 88ae4e1e9..45caefe4c 100644 --- a/save-xml.c +++ b/save-xml.c @@ -443,6 +443,38 @@ static void save_dive(FILE *f, struct dive *dive) fprintf(f, "\n"); } +static char *add_dc_to_string(char *dc_xml, struct divecomputer *dc) +{ + char *pattern, *tmp; + const char *nickname; + int len; + + /* we have no dc or no model or no deviceid information... nothing to do here */ + if (!dc || !dc->model || !*dc->model || !dc->deviceid) + return dc_xml; + + nickname = get_dc_nickname(dc->model, dc->deviceid); + /* We have no nickname, or it is the same as the model ID - nothing interesting */ + if (!nickname || !*nickname || !strcmp(dc->model, nickname)) + return dc_xml; + + len = sizeof(" model='' deviceid=''") + strlen(dc->model) + 8; + pattern = malloc(len); + snprintf(pattern, len, " model='%s' deviceid='%08x'", dc->model, dc->deviceid); + if (dc_xml && strstr(dc_xml, pattern)) { + /* already have that one */ + free(pattern); + return dc_xml; + } + + len += strlen(dc_xml) + strlen(nickname) + sizeof("\n"); + tmp = malloc(len); + snprintf(tmp, len, "%s\n", dc_xml, pattern, nickname); + free(pattern); + free(dc_xml); + return tmp; +} + #define VERSION 2 void save_dives(const char *filename) @@ -464,7 +496,7 @@ void save_dives(const char *filename) for_each_dive(i, dive) { struct divecomputer *dc = &dive->dc; while (dc) { - add_dc_to_string(&dc_xml, dc); + dc_xml = add_dc_to_string(dc_xml, dc); dc = dc->next; } }