diff options
author | Dirk Hohndel <dirk@hohndel.org> | 2013-01-01 13:27:49 -0800 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2013-01-01 13:30:20 -0800 |
commit | 8fa81a5577b71e72a22186bf7dd0e07e58c1c49a (patch) | |
tree | 9f33223f80178797ea8ccd69a3cec83eb20b057f | |
parent | 1c72d90b37d5f362a262a521a86f5b089daf8e62 (diff) | |
download | subsurface-8fa81a5577b71e72a22186bf7dd0e07e58c1c49a.tar.gz |
Add ability to remove a divecomputer from our data structures
Right now this isn't used but it will be needed for the yet to be written
UI to manage our divecomputer database.
This commit also fixes an oversight in the remember_dc function. Updates
to nicknames weren't committed to the config.
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r-- | gtk-gui.c | 52 |
1 files changed, 50 insertions, 2 deletions
@@ -2229,6 +2229,53 @@ bail: } +void remove_dc(const char *model, uint32_t deviceid, gboolean change_conf) +{ + struct dcnicknamelist *nn_entry, **prevp = &nicknamelist; + char pattern[160]; + char *nnstring, *brace; + + if (!deviceid || !model || !*model) + return; + nn_entry = get_dc_nicknameentry(model, deviceid); + if (!nn_entry) + return; + while (prevp && *prevp != nn_entry) + prevp = &(*prevp)->next; + if (!prevp) + /* that should be impossible */ + goto bail; + (*prevp) = nn_entry->next; + + /* now remove it from the config string */ + snprintf(pattern, sizeof(pattern), "{%08x,%s", deviceid, model); + nnstring = strstr(nicknamestring, pattern); + if (!nnstring) + goto bail; + brace = strchr(nnstring, '}'); + if (!brace) + goto bail; + brace++; + memmove(nnstring, brace, strlen(brace) + 1); + + if (change_conf) + subsurface_set_conf("dc_nicknames", PREF_STRING, nicknamestring); + +#if defined(NICKNAME_DEBUG) + struct dcnicknamelist *nn_entry = nicknamelist; + fprintf(debugfile, "nicknames:\n"); + while (nn_entry) { + fprintf(debugfile, "id %8x model %s nickname %s\n", nn_entry->deviceid, nn_entry->model, + nn_entry->nickname && *nn_entry->nickname ? nn_entry->nickname : "(none)"); + nn_entry = nn_entry->next; + } + fprintf(debugfile, "----------\n"); +#endif + +bail: + free(nn_entry); +} + void remember_dc(const char *model, uint32_t deviceid, const char *nickname, gboolean change_conf) { /* we don't want to record entries with a deviceid of 0; those are from earlier @@ -2254,8 +2301,6 @@ void remember_dc(const char *model, uint32_t deviceid, const char *nickname, gbo snprintf(buffer, sizeof(buffer), "{%08x,%s}", deviceid, model); nicknamestring = realloc(nicknamestring, strlen(nicknamestring) + strlen(buffer) + 1); strcat(nicknamestring, buffer); - if (change_conf) - subsurface_set_conf("dc_nicknames", PREF_STRING, nicknamestring); } else { /* modify existing entry */ struct dcnicknamelist *nn_entry = get_dc_nicknameentry(model, deviceid); @@ -2264,6 +2309,9 @@ void remember_dc(const char *model, uint32_t deviceid, const char *nickname, gbo nn_entry->nickname = cleanedup_nickname(nickname, 80); replace_nickname_nicknamestring(model, deviceid, nickname); } + if (change_conf) + subsurface_set_conf("dc_nicknames", PREF_STRING, nicknamestring); + #if defined(NICKNAME_DEBUG) struct dcnicknamelist *nn_entry = nicknamelist; fprintf(debugfile, "nicknames:\n"); |