Fixed completion groups

This commit is contained in:
Moritz Lipp 2010-07-04 10:39:16 +02:00
parent 9e58af0113
commit 7da1a65b2f

View file

@ -2445,10 +2445,18 @@ isc_completion(Argument* argument)
for(element = group->elements; element != NULL; element = element->next) for(element = group->elements; element != NULL; element = element->next)
{ {
if( (element->value) && if(element->value)
(current_parameter_length <= strlen(element->value)) && !strncmp(current_parameter, element->value, current_parameter_length)
)
{ {
if(group->value && !group_elements)
{
rows = realloc(rows, (n_items + 1) * sizeof(CompletionRow));
rows[n_items].command = group->value;
rows[n_items].description = NULL;
rows[n_items].command_id = -1;
rows[n_items].is_group = TRUE;
rows[n_items++].row = GTK_WIDGET(createCompletionRow(results, group->value, NULL, TRUE));
}
rows = realloc(rows, (n_items + 1) * sizeof(CompletionRow)); rows = realloc(rows, (n_items + 1) * sizeof(CompletionRow));
rows[n_items].command = element->value; rows[n_items].command = element->value;
rows[n_items].description = element->description; rows[n_items].description = element->description;
@ -2458,24 +2466,6 @@ isc_completion(Argument* argument)
group_elements++; group_elements++;
} }
} }
if(group->value && group_elements > 0)
{
rows = realloc(rows, (n_items + 1) * sizeof(CompletionRow));
rows[n_items].command = group->value;
rows[n_items].description = NULL;
rows[n_items].command_id = -1;
rows[n_items].is_group = TRUE;
rows[n_items].row = GTK_WIDGET(createCompletionRow(results, group->value, NULL, TRUE));
/* Swap group element with first element of the list */
CompletionRow temp = rows[n_items - group_elements];
gtk_box_reorder_child(results, rows[n_items].row, n_items - group_elements);
rows[n_items - group_elements] = rows[n_items];
rows[n_items] = temp;
n_items++;
}
} }
/* clean up */ /* clean up */