mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Make add_dc_to_string() skip redundant entries
There is no point writing out divecomputer nicknames that do not exist (or that match the dive computer model), so don't. Also, make the function to do this static to save-xml.c, which is the only user (I initially didn't _find_ the function to create the XML string because it was illogically hidden in gtk-gui.c), and change the calling convention to be more direct (pass in a string and return a result, rather than modify a "pointer to string"). Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
parent
fc1bb0a32c
commit
3b136f23ee
3 changed files with 33 additions and 36 deletions
34
gtk-gui.c
34
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("<divecomputerid/>\n");
|
||||
tmp = malloc(len);
|
||||
snprintf(tmp, len, "%s<divecomputerid%s/>\n", *dc_xml, pattern);
|
||||
} else {
|
||||
len += strlen(*dc_xml) + strlen(nickname) + sizeof("<divecomputerid nickname=''/>\n");
|
||||
tmp = malloc(len);
|
||||
snprintf(tmp, len, "%s<divecomputerid%s nickname='%s'/>\n", *dc_xml, pattern, nickname);
|
||||
}
|
||||
free(pattern);
|
||||
free(*dc_xml);
|
||||
*dc_xml = tmp;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue