Config: Some clean-ups and the items in the main sections are now sorted alphabetically for easier readability.

This commit is contained in:
OBattler
2024-11-03 02:13:17 +01:00
parent fd1b448502
commit aae600b325
2 changed files with 125 additions and 32 deletions

View File

@@ -181,7 +181,48 @@ delete_section_if_empty(list_t *head, section_t *section)
if (section == NULL)
return;
if (entries_num(section) == 0) {
int n = entries_num(section);
if (n > 0) {
int i = 0;
entry_t *i_ent = (entry_t *) section->entry_head.next;
while (i_ent != NULL) {
int i_nlen = strlen(i_ent->name);
entry_t* i_next = (entry_t *) i_ent->list.next;
if (i_nlen > 0) {
int j = 0;
entry_t *j_ent = (entry_t *) section->entry_head.next;
while (j_ent != NULL) {
int j_nlen = strlen(j_ent->name);
entry_t* j_next = (entry_t *) j_ent->list.next;
if (j_nlen > 0) {
pclog("Comparing \"%s\" with \"%s\"...\n", j_ent->name, i_ent->name);
if ((j != i) && (strcmp(j_ent->name, i_ent->name) > 0)) {
pclog("Swapping \"%s\" with \"%s\"...\n", j_ent->name, i_ent->name);
entry_t t_ent = { 0 };
memcpy(&t_ent, j_ent, sizeof(entry_t));
/* J: Contents of I, list of J */
memcpy(j_ent->name, i_ent->name, sizeof(entry_t) - sizeof(i_ent->list));
/* I: Contents of J, list of I */
memcpy(i_ent->name, t_ent.name, sizeof(entry_t) - sizeof(i_ent->list));
}
j++;
}
j_ent = (entry_t *) j_next;
}
i++;
}
i_ent = (entry_t *) i_next;
}
} else {
list_delete(&section->list, head);
free(section);
}