mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Command help now looked up
No longer need to write help strings in windows.c Usage and help are part of the command structure
This commit is contained in:
parent
4f4f780e60
commit
9fd7b2b3c2
@ -36,12 +36,6 @@
|
|||||||
#include "prof_autocomplete.h"
|
#include "prof_autocomplete.h"
|
||||||
#include "tinyurl.h"
|
#include "tinyurl.h"
|
||||||
|
|
||||||
// command help strings
|
|
||||||
struct cmd_help_t {
|
|
||||||
const gchar *usage;
|
|
||||||
const gchar *short_help;
|
|
||||||
};
|
|
||||||
|
|
||||||
/* command structure
|
/* command structure
|
||||||
* cmd - The actual string of the command
|
* cmd - The actual string of the command
|
||||||
* func - The function to execute for the command
|
* func - The function to execute for the command
|
||||||
@ -84,17 +78,17 @@ static gboolean _cmd_default(const char * const inp);
|
|||||||
// The commands
|
// The commands
|
||||||
static struct cmd_t main_commands[] =
|
static struct cmd_t main_commands[] =
|
||||||
{
|
{
|
||||||
{ "/close",
|
{ "/help",
|
||||||
_cmd_close,
|
_cmd_help,
|
||||||
{ NULL, "Close current chat window." } },
|
{ "/help", "This help." } },
|
||||||
|
|
||||||
{ "/connect",
|
{ "/connect",
|
||||||
_cmd_connect,
|
_cmd_connect,
|
||||||
{ "/connect user@host", "Login to jabber." } },
|
{ "/connect user@host", "Login to jabber." } },
|
||||||
|
|
||||||
{ "/prefs",
|
{ "/prefs",
|
||||||
_cmd_prefs,
|
_cmd_prefs,
|
||||||
{ NULL, "Show current preferences." } },
|
{ "/prefs", "Show current preferences." } },
|
||||||
|
|
||||||
{ "/msg",
|
{ "/msg",
|
||||||
_cmd_msg,
|
_cmd_msg,
|
||||||
@ -104,21 +98,21 @@ static struct cmd_t main_commands[] =
|
|||||||
_cmd_tiny,
|
_cmd_tiny,
|
||||||
{ "/tiny url", "Send url as tinyurl in current chat." } },
|
{ "/tiny url", "Send url as tinyurl in current chat." } },
|
||||||
|
|
||||||
{ "/quit",
|
|
||||||
_cmd_quit,
|
|
||||||
{ NULL, "Quit Profanity." } },
|
|
||||||
|
|
||||||
{ "/ros",
|
{ "/ros",
|
||||||
_cmd_ros,
|
_cmd_ros,
|
||||||
{ NULL, "List all contacts." } },
|
{ "/ros", "List all contacts." } },
|
||||||
|
|
||||||
{ "/who",
|
{ "/who",
|
||||||
_cmd_who,
|
_cmd_who,
|
||||||
{ NULL, "Find out who is online." } },
|
{ "/who", "Find out who is online." } },
|
||||||
|
|
||||||
{ "/help",
|
{ "/close",
|
||||||
_cmd_help,
|
_cmd_close,
|
||||||
{ NULL, "This help." } }
|
{ "/close", "Close current chat window." } },
|
||||||
|
|
||||||
|
{ "/quit",
|
||||||
|
_cmd_quit,
|
||||||
|
{ "/quit", "Quit Profanity." } }
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct cmd_t setting_commands[] =
|
static struct cmd_t setting_commands[] =
|
||||||
@ -232,6 +226,45 @@ reset_command_completer(void)
|
|||||||
p_autocomplete_reset(commands_ac);
|
p_autocomplete_reset(commands_ac);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GSList *
|
||||||
|
cmd_get_help_list_basic(void)
|
||||||
|
{
|
||||||
|
GSList *result = NULL;
|
||||||
|
|
||||||
|
unsigned int i;
|
||||||
|
for (i = 0; i < ARRAY_SIZE(main_commands); i++) {
|
||||||
|
result = g_slist_append(result, &((main_commands+i)->help));
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
GSList *
|
||||||
|
cmd_get_help_list_settings(void)
|
||||||
|
{
|
||||||
|
GSList *result = NULL;
|
||||||
|
|
||||||
|
unsigned int i;
|
||||||
|
for (i = 0; i < ARRAY_SIZE(setting_commands); i++) {
|
||||||
|
result = g_slist_append(result, &((setting_commands+i)->help));
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
GSList *
|
||||||
|
cmd_get_help_list_status(void)
|
||||||
|
{
|
||||||
|
GSList *result = NULL;
|
||||||
|
|
||||||
|
unsigned int i;
|
||||||
|
for (i = 0; i < ARRAY_SIZE(status_commands); i++) {
|
||||||
|
result = g_slist_append(result, &((status_commands+i)->help));
|
||||||
|
}
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
_handle_command(const char * const command, const char * const inp)
|
_handle_command(const char * const command, const char * const inp)
|
||||||
{
|
{
|
||||||
|
@ -23,9 +23,18 @@
|
|||||||
#ifndef COMMAND_H
|
#ifndef COMMAND_H
|
||||||
#define COMMAND_H
|
#define COMMAND_H
|
||||||
|
|
||||||
|
// command help strings
|
||||||
|
struct cmd_help_t {
|
||||||
|
const gchar *usage;
|
||||||
|
const gchar *short_help;
|
||||||
|
};
|
||||||
|
|
||||||
void command_init(void);
|
void command_init(void);
|
||||||
gboolean process_input(char *inp);
|
gboolean process_input(char *inp);
|
||||||
char * cmd_complete(char *inp);
|
char * cmd_complete(char *inp);
|
||||||
void reset_command_completer(void);
|
void reset_command_completer(void);
|
||||||
|
GSList * cmd_get_help_list_basic(void);
|
||||||
|
GSList * cmd_get_help_list_settings(void);
|
||||||
|
GSList * cmd_get_help_list_status(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include "ui.h"
|
#include "ui.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "contact.h"
|
#include "contact.h"
|
||||||
|
#include "command.h"
|
||||||
#include "preferences.h"
|
#include "preferences.h"
|
||||||
#include "tinyurl.h"
|
#include "tinyurl.h"
|
||||||
|
|
||||||
@ -380,31 +381,58 @@ cons_help(void)
|
|||||||
cons_show("");
|
cons_show("");
|
||||||
cons_show("Basic Commands:");
|
cons_show("Basic Commands:");
|
||||||
cons_show("");
|
cons_show("");
|
||||||
cons_show("/help : This help.");
|
|
||||||
cons_show("/prefs : Show current UI preferences.");
|
GSList *basic_helpers = cmd_get_help_list_basic();
|
||||||
cons_show("/connect user@host : Login to jabber.");
|
while (basic_helpers != NULL) {
|
||||||
cons_show("/msg user@host mesg : Send mesg to user.");
|
struct cmd_help_t *help = (struct cmd_help_t *)basic_helpers->data;
|
||||||
cons_show("/tiny url : Send url as tinyurl in current chat.");
|
char line[25 + 2 + strlen(help->short_help)];
|
||||||
cons_show("/close : Close a chat window.");
|
sprintf(line, "%-25s: %s", help->usage, help->short_help);
|
||||||
cons_show("/who : Find out who is online.");
|
cons_show(line);
|
||||||
cons_show("/ros : List all contacts.");
|
basic_helpers = g_slist_next(basic_helpers);
|
||||||
cons_show("/quit : Quit Profanity.");
|
}
|
||||||
|
|
||||||
cons_show("");
|
cons_show("");
|
||||||
cons_show("Settings:");
|
cons_show("Settings:");
|
||||||
cons_show("");
|
cons_show("");
|
||||||
|
|
||||||
|
GSList *settings_helpers = cmd_get_help_list_settings();
|
||||||
|
while (settings_helpers != NULL) {
|
||||||
|
struct cmd_help_t *help = (struct cmd_help_t *)settings_helpers->data;
|
||||||
|
char line[25 + 2 + strlen(help->short_help)];
|
||||||
|
sprintf(line, "%-25s: %s", help->usage, help->short_help);
|
||||||
|
cons_show(line);
|
||||||
|
settings_helpers = g_slist_next(settings_helpers);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
cons_show("/beep <on/off> : Enable/disable sound notification");
|
cons_show("/beep <on/off> : Enable/disable sound notification");
|
||||||
cons_show("/notify <on/off> : Enable/disable desktop notifications");
|
cons_show("/notify <on/off> : Enable/disable desktop notifications");
|
||||||
cons_show("/flash <on/off> : Enable/disable screen flash notification");
|
cons_show("/flash <on/off> : Enable/disable screen flash notification");
|
||||||
cons_show("/showsplash <on/off> : Enable/disable splash logo on startup");
|
cons_show("/showsplash <on/off> : Enable/disable splash logo on startup");
|
||||||
cons_show("/chlog <on/off> : Enable/disable chat logging");
|
cons_show("/chlog <on/off> : Enable/disable chat logging");
|
||||||
|
*/
|
||||||
|
|
||||||
cons_show("");
|
cons_show("");
|
||||||
cons_show("Status changes (msg is optional):");
|
cons_show("Status changes:");
|
||||||
cons_show("");
|
cons_show("");
|
||||||
|
|
||||||
|
GSList *status_helpers = cmd_get_help_list_status();
|
||||||
|
while (status_helpers != NULL) {
|
||||||
|
struct cmd_help_t *help = (struct cmd_help_t *)status_helpers->data;
|
||||||
|
char line[25 + 2 + strlen(help->short_help)];
|
||||||
|
sprintf(line, "%-25s: %s", help->usage, help->short_help);
|
||||||
|
cons_show(line);
|
||||||
|
status_helpers = g_slist_next(status_helpers);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
cons_show("/away <msg> : Set status to away.");
|
cons_show("/away <msg> : Set status to away.");
|
||||||
cons_show("/online <msg> : Set status to online.");
|
cons_show("/online <msg> : Set status to online.");
|
||||||
cons_show("/dnd <msg> : Set status to dnd (do not disturb).");
|
cons_show("/dnd <msg> : Set status to dnd (do not disturb).");
|
||||||
cons_show("/chat <msg> : Set status to chat (available for chat).");
|
cons_show("/chat <msg> : Set status to chat (available for chat).");
|
||||||
cons_show("/xa <msg> : Set status to xa (extended away).");
|
cons_show("/xa <msg> : Set status to xa (extended away).");
|
||||||
|
*/
|
||||||
|
|
||||||
cons_show("");
|
cons_show("");
|
||||||
cons_show("Navigation:");
|
cons_show("Navigation:");
|
||||||
cons_show("");
|
cons_show("");
|
||||||
|
Loading…
Reference in New Issue
Block a user