mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Split validation between /who for rooms and roster
This commit is contained in:
parent
58fb89ad33
commit
2d05601259
@ -74,8 +74,8 @@ static gboolean _cmd_set_boolean_preference(gchar *arg, struct cmd_help_t help,
|
|||||||
static int _strtoi(char *str, int *saveptr, int min, int max);
|
static int _strtoi(char *str, int *saveptr, int min, int max);
|
||||||
static void _cmd_show_filtered_help(char *heading, gchar *cmd_filter[], int filter_size);
|
static void _cmd_show_filtered_help(char *heading, gchar *cmd_filter[], int filter_size);
|
||||||
static gint _compare_commands(Command *a, Command *b);
|
static gint _compare_commands(Command *a, Command *b);
|
||||||
static void _who_room(const char * const presence);
|
static void _who_room(gchar **args, struct cmd_help_t help);
|
||||||
static void _who_roster(const char * const group, const char * const presence);
|
static void _who_roster(gchar **args, struct cmd_help_t help);
|
||||||
|
|
||||||
extern GHashTable *commands;
|
extern GHashTable *commands;
|
||||||
|
|
||||||
@ -723,8 +723,28 @@ cmd_theme(gchar **args, struct cmd_help_t help)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_who_room(const char * const presence)
|
_who_room(gchar **args, struct cmd_help_t help)
|
||||||
{
|
{
|
||||||
|
char *presence = args[0];
|
||||||
|
if ((g_strv_length(args) == 2) && (args[1] != NULL)) {
|
||||||
|
cons_show("Argument group is not applicable to chat rooms.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// bad arg
|
||||||
|
if ((presence != NULL)
|
||||||
|
&& (strcmp(presence, "online") != 0)
|
||||||
|
&& (strcmp(presence, "available") != 0)
|
||||||
|
&& (strcmp(presence, "unavailable") != 0)
|
||||||
|
&& (strcmp(presence, "away") != 0)
|
||||||
|
&& (strcmp(presence, "chat") != 0)
|
||||||
|
&& (strcmp(presence, "xa") != 0)
|
||||||
|
&& (strcmp(presence, "dnd") != 0)
|
||||||
|
&& (strcmp(presence, "any") != 0)) {
|
||||||
|
cons_show("Usage: %s", help.usage);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
char *room = ui_current_recipient();
|
char *room = ui_current_recipient();
|
||||||
GList *list = muc_roster(room);
|
GList *list = muc_roster(room);
|
||||||
|
|
||||||
@ -778,8 +798,30 @@ _who_room(const char * const presence)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_who_roster(const char * const group, const char * const presence)
|
_who_roster(gchar **args, struct cmd_help_t help)
|
||||||
{
|
{
|
||||||
|
char *presence = args[0];
|
||||||
|
|
||||||
|
// bad arg
|
||||||
|
if ((presence != NULL)
|
||||||
|
&& (strcmp(presence, "online") != 0)
|
||||||
|
&& (strcmp(presence, "available") != 0)
|
||||||
|
&& (strcmp(presence, "unavailable") != 0)
|
||||||
|
&& (strcmp(presence, "offline") != 0)
|
||||||
|
&& (strcmp(presence, "away") != 0)
|
||||||
|
&& (strcmp(presence, "chat") != 0)
|
||||||
|
&& (strcmp(presence, "xa") != 0)
|
||||||
|
&& (strcmp(presence, "dnd") != 0)
|
||||||
|
&& (strcmp(presence, "any") != 0)) {
|
||||||
|
cons_show("Usage: %s", help.usage);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
char *group = NULL;
|
||||||
|
if ((g_strv_length(args) == 2) && (args[1] != NULL)) {
|
||||||
|
group = args[1];
|
||||||
|
}
|
||||||
|
|
||||||
cons_show("");
|
cons_show("");
|
||||||
GSList *list = NULL;
|
GSList *list = NULL;
|
||||||
if (group != NULL) {
|
if (group != NULL) {
|
||||||
@ -965,36 +1007,10 @@ cmd_who(gchar **args, struct cmd_help_t help)
|
|||||||
if (conn_status != JABBER_CONNECTED) {
|
if (conn_status != JABBER_CONNECTED) {
|
||||||
cons_show("You are not currently connected.");
|
cons_show("You are not currently connected.");
|
||||||
} else {
|
} else {
|
||||||
char *presence = args[0];
|
if (win_type == WIN_MUC) {
|
||||||
char *group = NULL;
|
_who_room(args, help);
|
||||||
if ((g_strv_length(args) == 2) && (args[1] != NULL)) {
|
|
||||||
group = args[1];
|
|
||||||
}
|
|
||||||
|
|
||||||
// bad arg
|
|
||||||
if ((presence != NULL)
|
|
||||||
&& (strcmp(presence, "online") != 0)
|
|
||||||
&& (strcmp(presence, "available") != 0)
|
|
||||||
&& (strcmp(presence, "unavailable") != 0)
|
|
||||||
&& (strcmp(presence, "offline") != 0)
|
|
||||||
&& (strcmp(presence, "away") != 0)
|
|
||||||
&& (strcmp(presence, "chat") != 0)
|
|
||||||
&& (strcmp(presence, "xa") != 0)
|
|
||||||
&& (strcmp(presence, "dnd") != 0)
|
|
||||||
&& (strcmp(presence, "any") != 0)) {
|
|
||||||
cons_show("Usage: %s", help.usage);
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
if (win_type == WIN_MUC) {
|
_who_roster(args, help);
|
||||||
if (group != NULL) {
|
|
||||||
cons_show("The group argument is not valid when in a chat room.");
|
|
||||||
} else {
|
|
||||||
_who_room(presence);
|
|
||||||
}
|
|
||||||
|
|
||||||
} else {
|
|
||||||
_who_roster(group, presence);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user