mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Minor config/conflists.c
refactoring
Refactor functions `conf_string_list_add`, `conf_string_list_remove`: simplify the logic, improve readability and avoid unnecessary allocations.
This commit is contained in:
parent
bba8278bb7
commit
1cf7973245
@ -35,6 +35,7 @@
|
|||||||
|
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include "log.h"
|
||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
@ -42,46 +43,36 @@
|
|||||||
gboolean
|
gboolean
|
||||||
conf_string_list_add(GKeyFile* keyfile, const char* const group, const char* const key, const char* const item)
|
conf_string_list_add(GKeyFile* keyfile, const char* const group, const char* const key, const char* const item)
|
||||||
{
|
{
|
||||||
gsize length;
|
if (!item) {
|
||||||
auto_gcharv gchar** list = g_key_file_get_string_list(keyfile, group, key, &length, NULL);
|
log_warning("Invalid parameter in `conf_string_list_add`: item is NULL. group=%s, key=%s", group, key);
|
||||||
GList* glist = NULL;
|
return FALSE;
|
||||||
|
|
||||||
// list found
|
|
||||||
if (list) {
|
|
||||||
int i = 0;
|
|
||||||
for (i = 0; i < length; i++) {
|
|
||||||
// item already in list, exit function
|
|
||||||
if (strcmp(list[i], item) == 0) {
|
|
||||||
g_list_free_full(glist, g_free);
|
|
||||||
return FALSE;
|
|
||||||
}
|
|
||||||
// add item to our g_list
|
|
||||||
glist = g_list_append(glist, strdup(list[i]));
|
|
||||||
}
|
|
||||||
|
|
||||||
// item not found, add to our g_list
|
|
||||||
glist = g_list_append(glist, strdup(item));
|
|
||||||
|
|
||||||
// create the new list entry
|
|
||||||
const gchar* new_list[g_list_length(glist) + 1];
|
|
||||||
GList* curr = glist;
|
|
||||||
i = 0;
|
|
||||||
while (curr) {
|
|
||||||
new_list[i++] = curr->data;
|
|
||||||
curr = g_list_next(curr);
|
|
||||||
}
|
|
||||||
new_list[i] = NULL;
|
|
||||||
g_key_file_set_string_list(keyfile, group, key, new_list, g_list_length(glist));
|
|
||||||
|
|
||||||
// list not found
|
|
||||||
} else {
|
|
||||||
const gchar* new_list[2];
|
|
||||||
new_list[0] = item;
|
|
||||||
new_list[1] = NULL;
|
|
||||||
g_key_file_set_string_list(keyfile, group, key, new_list, 1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
g_list_free_full(glist, g_free);
|
gsize length;
|
||||||
|
auto_gcharv gchar** list = g_key_file_get_string_list(keyfile, group, key, &length, NULL);
|
||||||
|
|
||||||
|
if (!list) {
|
||||||
|
const gchar* new_list[2] = { item, NULL };
|
||||||
|
g_key_file_set_string_list(keyfile, group, key, new_list, 1);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if item is already in the list
|
||||||
|
for (gsize i = 0; i < length; ++i) {
|
||||||
|
if (strcmp(list[i], item) == 0) {
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add item to the existing list
|
||||||
|
gchar** new_list = g_new(gchar*, length + 2);
|
||||||
|
for (gsize i = 0; i < length; ++i) {
|
||||||
|
new_list[i] = g_strdup(list[i]);
|
||||||
|
}
|
||||||
|
new_list[length] = g_strdup(item);
|
||||||
|
new_list[length + 1] = NULL;
|
||||||
|
|
||||||
|
g_key_file_set_string_list(keyfile, group, key, (const gchar* const*)new_list, length + 1);
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
@ -92,41 +83,37 @@ conf_string_list_remove(GKeyFile* keyfile, const char* const group, const char*
|
|||||||
gsize length;
|
gsize length;
|
||||||
auto_gcharv gchar** list = g_key_file_get_string_list(keyfile, group, key, &length, NULL);
|
auto_gcharv gchar** list = g_key_file_get_string_list(keyfile, group, key, &length, NULL);
|
||||||
|
|
||||||
gboolean deleted = FALSE;
|
|
||||||
if (!list) {
|
if (!list) {
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
int i = 0;
|
|
||||||
GList* glist = NULL;
|
|
||||||
|
|
||||||
for (i = 0; i < length; i++) {
|
GList* glist = NULL;
|
||||||
// item found, mark as deleted
|
gboolean deleted = FALSE;
|
||||||
|
|
||||||
|
for (int i = 0; i < length; i++) {
|
||||||
if (strcmp(list[i], item) == 0) {
|
if (strcmp(list[i], item) == 0) {
|
||||||
deleted = TRUE;
|
deleted = TRUE;
|
||||||
} else {
|
continue;
|
||||||
// add item to our g_list
|
|
||||||
glist = g_list_append(glist, strdup(list[i]));
|
|
||||||
}
|
}
|
||||||
|
glist = g_list_append(glist, strdup(list[i]));
|
||||||
}
|
}
|
||||||
|
|
||||||
if (deleted) {
|
if (deleted) {
|
||||||
if (g_list_length(glist) == 0) {
|
if (g_list_length(glist) == 0) {
|
||||||
g_key_file_remove_key(keyfile, group, key, NULL);
|
g_key_file_remove_key(keyfile, group, key, NULL);
|
||||||
} else {
|
} else {
|
||||||
// create the new list entry
|
|
||||||
const gchar* new_list[g_list_length(glist) + 1];
|
const gchar* new_list[g_list_length(glist) + 1];
|
||||||
GList* curr = glist;
|
int i = 0;
|
||||||
i = 0;
|
|
||||||
while (curr) {
|
for (GList* curr = glist; curr; curr = g_list_next(curr)) {
|
||||||
new_list[i++] = curr->data;
|
new_list[i++] = curr->data;
|
||||||
curr = g_list_next(curr);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
new_list[i] = NULL;
|
new_list[i] = NULL;
|
||||||
g_key_file_set_string_list(keyfile, group, key, new_list, g_list_length(glist));
|
g_key_file_set_string_list(keyfile, group, key, new_list, g_list_length(glist));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
g_list_free_full(glist, g_free);
|
g_list_free_full(glist, g_free);
|
||||||
|
|
||||||
return deleted;
|
return deleted;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user