char *prefix;
} Completion;
-static GList *init_completion(GList *target, GList *source,
- Comp_Func func, const char *input, const char *prefix);
-static GList *prepend_bookmark_completion(GList *target, GList *source, const char *prefix);
-static void pack_boxes(GList *list);
+static GList *filter_list(GList *target, GList *source, Comp_Func func, const char *input);
+static GList *init_completion(GList *target, GList *source, const char *prefix);
+static GList *prepend_bookmark_completion(GList *target, GList *source);
static GList *update(GList *completion, GList *active, gboolean back);
static void show(gboolean back);
static void set_entry_text(Completion *completion);
gboolean completion_complete(gboolean back)
{
const char *input = GET_TEXT();
- GList *source = NULL;
+ GList *source = NULL, *tmp = NULL;
if (vb.comps.completions
&& vb.comps.active
gtk_box_pack_start(GTK_BOX(vb.gui.box), vb.gui.compbox, false, false, 0);
/* TODO move these decision to a more generic place */
- /* TODO simplify this logic - seperate the list preparation, filtering and
- * gtk box creation from another */
if (!strncmp(input, ":set ", 5)) {
source = g_hash_table_get_keys(vb.settings);
source = g_list_sort(source, (GCompareFunc)g_strcmp0);
vb.comps.completions = init_completion(
- vb.comps.completions, source, (Comp_Func)g_str_has_prefix, &input[5], ":set "
+ vb.comps.completions,
+ filter_list(tmp, source, (Comp_Func)g_str_has_prefix, &input[5]),
+ ":set "
);
g_list_free(source);
} else if (!strncmp(input, ":open ", 6)) {
source = history_get_all(HISTORY_URL);
+ tmp = filter_list(tmp, source, (Comp_Func)util_strcasestr, &input[6]),
+ /* prepend the bookmark items */
+ tmp = prepend_bookmark_completion(tmp, bookmark_get_by_tags(&input[6]));
vb.comps.completions = init_completion(
- vb.comps.completions, source, (Comp_Func)util_strcasestr, &input[6], ":open "
+ vb.comps.completions,
+ tmp,
+ ":open "
);
- history_list_free(&source);
- /* prepend the bookmark items */
- source = bookmark_get_by_tags(&input[6]);
- vb.comps.completions = prepend_bookmark_completion(
- vb.comps.completions, source, ":open "
- );
history_list_free(&source);
} else if (!strncmp(input, ":tabopen ", 9)) {
source = history_get_all(HISTORY_URL);
+ tmp = filter_list(tmp, source, (Comp_Func)util_strcasestr, &input[9]),
+ /* prepend the bookmark items */
+ tmp = prepend_bookmark_completion(tmp, bookmark_get_by_tags(&input[9]));
vb.comps.completions = init_completion(
- vb.comps.completions, source, (Comp_Func)util_strcasestr, &input[9], ":tabopen "
+ vb.comps.completions,
+ tmp,
+ ":tabopen "
);
- history_list_free(&source);
- /* prepend the bookmark items */
- source = bookmark_get_by_tags(&input[9]);
- vb.comps.completions = prepend_bookmark_completion(
- vb.comps.completions, source, ":tabopen "
- );
history_list_free(&source);
} else {
source = g_hash_table_get_keys(vb.behave.commands);
source = g_list_sort(source, (GCompareFunc)g_strcmp0);
vb.comps.completions = init_completion(
- vb.comps.completions, source, (Comp_Func)g_str_has_prefix, &input[1], ":"
+ vb.comps.completions,
+ filter_list(tmp, source, (Comp_Func)g_str_has_prefix, &input[1]),
+ ":"
);
g_list_free(source);
}
if (!vb.comps.completions) {
return false;
}
- pack_boxes(vb.comps.completions);
show(back);
return TRUE;
vb.state.mode &= ~VB_MODE_COMPLETE;
}
-static GList *init_completion(GList *target, GList *source,
- Comp_Func func, const char *input, const char *prefix)
+/* TODO remove none matching entries from given source list */
+static GList *filter_list(GList *target, GList *source, Comp_Func func, const char *input)
{
- char *command = NULL, *data = NULL, **token = NULL;
+ char **token = NULL;
gboolean match;
- /* remove counts before command and save it to print it later in inputbox */
- vb.comps.count = g_ascii_strtoll(input, &command, 10);
- OVERWRITE_STRING(vb.comps.prefix, prefix);
-
- token = g_strsplit(command, " ", -1);
+ token = g_strsplit(input, " ", 0);
for (GList *l = source; l; l = l->next) {
- data = l->data;
+ char *data = l->data;
match = false;
- if (*command == 0) {
+ if (*input == 0) {
match = TRUE;
} else {
for (int i = 0; token[i]; i++) {
}
}
if (match) {
- /* use prepend because that faster */
- target = g_list_prepend(target, get_new(data, prefix));
+ target = g_list_prepend(target, data);
}
}
return target;
}
-static GList *prepend_bookmark_completion(GList *target, GList *source, const char *prefix)
+static GList *init_completion(GList *target, GList *source, const char *prefix)
{
+ OVERWRITE_STRING(vb.comps.prefix, prefix);
+
for (GList *l = source; l; l = l->next) {
- target = g_list_prepend(target, get_new(l->data, prefix));
+ Completion *c = get_new(l->data, prefix);
+ target = g_list_prepend(target, c);
+ gtk_box_pack_start(GTK_BOX(vb.gui.compbox), c->event, TRUE, TRUE, 0);
}
+ target = g_list_reverse(target);
+
return target;
}
-static void pack_boxes(GList *list)
+static GList *prepend_bookmark_completion(GList *target, GList *source)
{
- for (GList *l = list; l; l = l->next) {
- Completion *c = (Completion*)l->data;
- gtk_box_pack_start(GTK_BOX(vb.gui.compbox), c->event, TRUE, TRUE, 0);
+ for (GList *l = source; l; l = l->next) {
+ target = g_list_prepend(target, l->data);
}
+
+ return target;
}
static GList *update(GList *completion, GList *active, gboolean back)