mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Added autocomplete for bookmark options
This commit is contained in:
parent
c0fc4256de
commit
7e359c171c
@ -887,6 +887,7 @@ static Autocomplete wins_ac;
|
||||
static Autocomplete roster_ac;
|
||||
static Autocomplete group_ac;
|
||||
static Autocomplete bookmark_ac;
|
||||
static Autocomplete bookmark_property_ac;
|
||||
static Autocomplete otr_ac;
|
||||
static Autocomplete otr_log_ac;
|
||||
static Autocomplete otr_policy_ac;
|
||||
@ -1070,6 +1071,11 @@ cmd_init(void)
|
||||
autocomplete_add(bookmark_ac, "remove");
|
||||
autocomplete_add(bookmark_ac, "join");
|
||||
|
||||
bookmark_property_ac = autocomplete_new();
|
||||
autocomplete_add(bookmark_property_ac, "nick");
|
||||
autocomplete_add(bookmark_property_ac, "password");
|
||||
autocomplete_add(bookmark_property_ac, "autojoin");
|
||||
|
||||
otr_ac = autocomplete_new();
|
||||
autocomplete_add(otr_ac, "gen");
|
||||
autocomplete_add(otr_ac, "start");
|
||||
@ -1149,6 +1155,7 @@ cmd_uninit(void)
|
||||
autocomplete_free(roster_ac);
|
||||
autocomplete_free(group_ac);
|
||||
autocomplete_free(bookmark_ac);
|
||||
autocomplete_free(bookmark_property_ac);
|
||||
autocomplete_free(otr_ac);
|
||||
autocomplete_free(otr_log_ac);
|
||||
autocomplete_free(otr_policy_ac);
|
||||
@ -1270,6 +1277,7 @@ cmd_reset_autocomplete()
|
||||
autocomplete_reset(roster_ac);
|
||||
autocomplete_reset(group_ac);
|
||||
autocomplete_reset(bookmark_ac);
|
||||
autocomplete_reset(bookmark_property_ac);
|
||||
autocomplete_reset(otr_ac);
|
||||
autocomplete_reset(otr_log_ac);
|
||||
autocomplete_reset(otr_policy_ac);
|
||||
@ -1649,33 +1657,56 @@ _group_autocomplete(char *input, int *size)
|
||||
static char *
|
||||
_bookmark_autocomplete(char *input, int *size)
|
||||
{
|
||||
char *result = NULL;
|
||||
char *found = NULL;
|
||||
|
||||
if (strcmp(input, "/bookmark add ") == 0) {
|
||||
GString *str = g_string_new(input);
|
||||
gboolean result;
|
||||
gchar **args = parse_args(input, 3, 7, &result);
|
||||
|
||||
str = g_string_append(str, "autojoin");
|
||||
result = str->str;
|
||||
g_string_free(str, FALSE);
|
||||
return result;
|
||||
if (result && ((strcmp(args[0], "add") == 0) || (strcmp(args[0], "update") == 0)) ) {
|
||||
GString *beginning = g_string_new("/bookmark ");
|
||||
|
||||
if (g_strv_length(args) > 2) {
|
||||
g_string_append(beginning, args[0]);
|
||||
g_string_append(beginning, " ");
|
||||
g_string_append(beginning, args[1]);
|
||||
|
||||
if (g_strv_length(args) > 4) {
|
||||
g_string_append(beginning, " ");
|
||||
g_string_append(beginning, args[2]);
|
||||
g_string_append(beginning, " ");
|
||||
g_string_append(beginning, args[3]);
|
||||
|
||||
if (g_strv_length(args) > 6) {
|
||||
g_string_append(beginning, " ");
|
||||
g_string_append(beginning, args[4]);
|
||||
g_string_append(beginning, " ");
|
||||
g_string_append(beginning, args[5]);
|
||||
}
|
||||
}
|
||||
|
||||
found = autocomplete_param_with_ac(input, size, beginning->str, bookmark_property_ac);
|
||||
g_string_free(beginning, TRUE);
|
||||
if (found != NULL) {
|
||||
return found;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
result = autocomplete_param_with_func(input, size, "/bookmark remove", bookmark_find);
|
||||
if (result != NULL) {
|
||||
return result;
|
||||
found = autocomplete_param_with_func(input, size, "/bookmark remove", bookmark_find);
|
||||
if (found != NULL) {
|
||||
return found;
|
||||
}
|
||||
result = autocomplete_param_with_func(input, size, "/bookmark join", bookmark_find);
|
||||
if (result != NULL) {
|
||||
return result;
|
||||
found = autocomplete_param_with_func(input, size, "/bookmark join", bookmark_find);
|
||||
if (found != NULL) {
|
||||
return found;
|
||||
}
|
||||
result = autocomplete_param_with_func(input, size, "/bookmark update", bookmark_find);
|
||||
if (result != NULL) {
|
||||
return result;
|
||||
found = autocomplete_param_with_func(input, size, "/bookmark update", bookmark_find);
|
||||
if (found != NULL) {
|
||||
return found;
|
||||
}
|
||||
|
||||
result = autocomplete_param_with_ac(input, size, "/bookmark", bookmark_ac);
|
||||
|
||||
return result;
|
||||
found = autocomplete_param_with_ac(input, size, "/bookmark", bookmark_ac);
|
||||
return found;
|
||||
}
|
||||
|
||||
static char *
|
||||
|
Loading…
Reference in New Issue
Block a user