mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Added autocomplete for setting room config form tags
This commit is contained in:
parent
6c45f8ffae
commit
128a4a811f
@ -65,6 +65,7 @@
|
|||||||
#include "xmpp/xmpp.h"
|
#include "xmpp/xmpp.h"
|
||||||
#include "xmpp/bookmark.h"
|
#include "xmpp/bookmark.h"
|
||||||
#include "ui/ui.h"
|
#include "ui/ui.h"
|
||||||
|
#include "ui/windows.h"
|
||||||
|
|
||||||
typedef char*(*autocompleter)(char*, int*);
|
typedef char*(*autocompleter)(char*, int*);
|
||||||
|
|
||||||
@ -2078,6 +2079,17 @@ _room_autocomplete(char *input, int *size)
|
|||||||
{
|
{
|
||||||
char *result = NULL;
|
char *result = NULL;
|
||||||
|
|
||||||
|
ProfWin *current = wins_get_current();
|
||||||
|
if (current != NULL) {
|
||||||
|
DataForm *form = current->form;
|
||||||
|
if (form != NULL) {
|
||||||
|
result = autocomplete_param_with_ac(input, size, "/room set", form->tag_ac, TRUE);
|
||||||
|
if (result != NULL) {
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
result = autocomplete_param_with_ac(input, size, "/room", room_ac, TRUE);
|
result = autocomplete_param_with_ac(input, size, "/room", room_ac, TRUE);
|
||||||
if (result != NULL) {
|
if (result != NULL) {
|
||||||
return result;
|
return result;
|
||||||
|
@ -190,6 +190,7 @@ form_create(xmpp_stanza_t * const form_stanza)
|
|||||||
form->instructions = _get_property(form_stanza, "instructions");
|
form->instructions = _get_property(form_stanza, "instructions");
|
||||||
form->var_to_tag = g_hash_table_new_full(g_str_hash, g_str_equal, free, free);
|
form->var_to_tag = g_hash_table_new_full(g_str_hash, g_str_equal, free, free);
|
||||||
form->tag_to_var = g_hash_table_new_full(g_str_hash, g_str_equal, free, free);
|
form->tag_to_var = g_hash_table_new_full(g_str_hash, g_str_equal, free, free);
|
||||||
|
form->tag_ac = autocomplete_new();
|
||||||
|
|
||||||
int tag_num = 1;
|
int tag_num = 1;
|
||||||
|
|
||||||
@ -210,6 +211,7 @@ form_create(xmpp_stanza_t * const form_stanza)
|
|||||||
g_string_printf(tag, "field%d", tag_num++);
|
g_string_printf(tag, "field%d", tag_num++);
|
||||||
g_hash_table_insert(form->var_to_tag, strdup(field->var), strdup(tag->str));
|
g_hash_table_insert(form->var_to_tag, strdup(field->var), strdup(tag->str));
|
||||||
g_hash_table_insert(form->tag_to_var, strdup(tag->str), strdup(field->var));
|
g_hash_table_insert(form->tag_to_var, strdup(tag->str), strdup(field->var));
|
||||||
|
autocomplete_add(form->tag_ac, tag->str);
|
||||||
g_string_free(tag, TRUE);
|
g_string_free(tag, TRUE);
|
||||||
|
|
||||||
field->description = _get_property(field_stanza, "desc");
|
field->description = _get_property(field_stanza, "desc");
|
||||||
@ -363,6 +365,7 @@ _form_destroy(DataForm *form)
|
|||||||
g_slist_free_full(form->fields, (GDestroyNotify)_free_field);
|
g_slist_free_full(form->fields, (GDestroyNotify)_free_field);
|
||||||
g_hash_table_destroy(form->var_to_tag);
|
g_hash_table_destroy(form->var_to_tag);
|
||||||
g_hash_table_destroy(form->tag_to_var);
|
g_hash_table_destroy(form->tag_to_var);
|
||||||
|
autocomplete_free(form->tag_ac);
|
||||||
free(form);
|
free(form);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -40,6 +40,7 @@
|
|||||||
#include "config/accounts.h"
|
#include "config/accounts.h"
|
||||||
#include "contact.h"
|
#include "contact.h"
|
||||||
#include "jid.h"
|
#include "jid.h"
|
||||||
|
#include "tools/autocomplete.h"
|
||||||
|
|
||||||
#define JABBER_PRIORITY_MIN -128
|
#define JABBER_PRIORITY_MIN -128
|
||||||
#define JABBER_PRIORITY_MAX 127
|
#define JABBER_PRIORITY_MAX 127
|
||||||
@ -123,6 +124,7 @@ typedef struct data_form_t {
|
|||||||
GSList *fields;
|
GSList *fields;
|
||||||
GHashTable *var_to_tag;
|
GHashTable *var_to_tag;
|
||||||
GHashTable *tag_to_var;
|
GHashTable *tag_to_var;
|
||||||
|
Autocomplete tag_ac;
|
||||||
} DataForm;
|
} DataForm;
|
||||||
|
|
||||||
void jabber_init_module(void);
|
void jabber_init_module(void);
|
||||||
|
Loading…
Reference in New Issue
Block a user