mirror of
https://github.com/irssi/irssi.git
synced 2024-12-04 14:46:39 -05:00
Moved PARAM_FLAG_OPTCHAN handling to core. Removed support for adding own
command parameter parsers, it's probably useless now that opt.channels are in core. git-svn-id: http://svn.irssi.org/repos/irssi/trunk@1482 dbcabf3a-b0e7-0310-adc4-f8d773084564
This commit is contained in:
parent
d44b803c3c
commit
e3b33796ff
@ -22,9 +22,11 @@
|
|||||||
#include "signals.h"
|
#include "signals.h"
|
||||||
#include "commands.h"
|
#include "commands.h"
|
||||||
#include "misc.h"
|
#include "misc.h"
|
||||||
|
#include "special-vars.h"
|
||||||
|
|
||||||
#include "servers.h"
|
#include "servers.h"
|
||||||
#include "servers-redirect.h"
|
#include "servers-redirect.h"
|
||||||
#include "special-vars.h"
|
#include "channels.h"
|
||||||
|
|
||||||
#include "lib-config/iconfig.h"
|
#include "lib-config/iconfig.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
@ -32,7 +34,6 @@
|
|||||||
GSList *commands;
|
GSList *commands;
|
||||||
char *current_command;
|
char *current_command;
|
||||||
|
|
||||||
static GSList *cmdget_funcs;
|
|
||||||
static int signal_default_command;
|
static int signal_default_command;
|
||||||
|
|
||||||
static GSList *alias_runstack;
|
static GSList *alias_runstack;
|
||||||
@ -613,69 +614,56 @@ static int get_cmd_options(char **data, int ignore_unknown,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
char *cmd_get_callfuncs(const char *data, int *count, va_list *args)
|
|
||||||
{
|
|
||||||
CMD_GET_FUNC func;
|
|
||||||
GSList *tmp;
|
|
||||||
char *ret, *old;
|
|
||||||
|
|
||||||
ret = g_strdup(data);
|
|
||||||
for (tmp = cmdget_funcs; tmp != NULL; tmp = tmp->next) {
|
|
||||||
func = (CMD_GET_FUNC) tmp->data;
|
|
||||||
|
|
||||||
old = ret;
|
|
||||||
ret = func(ret, count, args);
|
|
||||||
g_free(old);
|
|
||||||
}
|
|
||||||
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
char *data;
|
char *data;
|
||||||
GHashTable *options;
|
GHashTable *options;
|
||||||
} CMD_TEMP_REC;
|
} CMD_TEMP_REC;
|
||||||
|
|
||||||
|
static char *get_optional_channel(CHANNEL_REC *active_channel, char **data)
|
||||||
|
{
|
||||||
|
CHANNEL_REC *chanrec;
|
||||||
|
char *tmp, *origtmp, *channel, *ret;
|
||||||
|
|
||||||
|
if (active_channel == NULL) {
|
||||||
|
/* no active channel in window, channel required */
|
||||||
|
return cmd_get_param(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
origtmp = tmp = g_strdup(*data);
|
||||||
|
channel = cmd_get_param(&tmp);
|
||||||
|
|
||||||
|
if (strcmp(channel, "*") == 0 ||
|
||||||
|
!active_channel->server->ischannel(channel))
|
||||||
|
ret = active_channel->name;
|
||||||
|
else {
|
||||||
|
/* Find the channel first and use it's name if found.
|
||||||
|
This allows automatic !channel -> !XXXXXchannel replaces. */
|
||||||
|
chanrec = channel_find(active_channel->server, channel);
|
||||||
|
ret = chanrec == NULL ? channel : chanrec->name;
|
||||||
|
cmd_get_param(data);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free(origtmp);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
int cmd_get_params(const char *data, gpointer *free_me, int count, ...)
|
int cmd_get_params(const char *data, gpointer *free_me, int count, ...)
|
||||||
{
|
{
|
||||||
CMD_TEMP_REC *rec;
|
CMD_TEMP_REC *rec;
|
||||||
GHashTable **opthash;
|
GHashTable **opthash;
|
||||||
char **str, *arg, *datad, *old;
|
char **str, *arg, *datad;
|
||||||
va_list args;
|
va_list args;
|
||||||
int cnt, error, len, ignore_unknown;
|
int cnt, error, ignore_unknown;
|
||||||
|
|
||||||
g_return_val_if_fail(data != NULL, FALSE);
|
g_return_val_if_fail(data != NULL, FALSE);
|
||||||
|
|
||||||
va_start(args, count);
|
va_start(args, count);
|
||||||
|
|
||||||
/* get the length of the options in string */
|
|
||||||
if ((count & PARAM_FLAG_OPTIONS) == 0)
|
|
||||||
len = 0;
|
|
||||||
else {
|
|
||||||
old = datad = g_strdup(data);
|
|
||||||
get_cmd_options(&datad, TRUE, NULL, NULL);
|
|
||||||
len = (int) (datad-old);
|
|
||||||
g_free(old);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* send the text to custom functions to handle - skip options */
|
|
||||||
old = datad = cmd_get_callfuncs(data+len, &count, &args);
|
|
||||||
|
|
||||||
if (len > 0) {
|
|
||||||
/* put the options + the new data to one string */
|
|
||||||
datad = g_malloc(len+1 + strlen(old)+1);
|
|
||||||
memcpy(datad, data, len);
|
|
||||||
datad[len] = ' ';
|
|
||||||
memcpy(datad+len+1, old, strlen(old)+1);
|
|
||||||
g_free(old);
|
|
||||||
|
|
||||||
old = datad;
|
|
||||||
}
|
|
||||||
|
|
||||||
rec = g_new0(CMD_TEMP_REC, 1);
|
rec = g_new0(CMD_TEMP_REC, 1);
|
||||||
rec->data = old;
|
rec->data = g_strdup(data);
|
||||||
*free_me = rec;
|
*free_me = rec;
|
||||||
|
|
||||||
|
datad = rec->data;
|
||||||
error = FALSE;
|
error = FALSE;
|
||||||
if (count & PARAM_FLAG_OPTIONS) {
|
if (count & PARAM_FLAG_OPTIONS) {
|
||||||
arg = (char *) va_arg(args, char *);
|
arg = (char *) va_arg(args, char *);
|
||||||
@ -693,6 +681,18 @@ int cmd_get_params(const char *data, gpointer *free_me, int count, ...)
|
|||||||
if (!error) {
|
if (!error) {
|
||||||
/* and now handle the string */
|
/* and now handle the string */
|
||||||
cnt = PARAM_WITHOUT_FLAGS(count);
|
cnt = PARAM_WITHOUT_FLAGS(count);
|
||||||
|
if (count & PARAM_FLAG_OPTCHAN) {
|
||||||
|
/* optional channel as first parameter */
|
||||||
|
CHANNEL_REC *chanrec;
|
||||||
|
|
||||||
|
chanrec = (CHANNEL_REC *) va_arg(args, CHANNEL_REC *);
|
||||||
|
arg = get_optional_channel(chanrec, &datad);
|
||||||
|
|
||||||
|
str = (char **) va_arg(args, char **);
|
||||||
|
if (str != NULL) *str = arg;
|
||||||
|
cnt--;
|
||||||
|
}
|
||||||
|
|
||||||
while (cnt-- > 0) {
|
while (cnt-- > 0) {
|
||||||
if (cnt == 0 && count & PARAM_FLAG_GETREST) {
|
if (cnt == 0 && count & PARAM_FLAG_GETREST) {
|
||||||
/* get rest */
|
/* get rest */
|
||||||
@ -729,16 +729,6 @@ void cmd_params_free(void *free_me)
|
|||||||
g_free(rec);
|
g_free(rec);
|
||||||
}
|
}
|
||||||
|
|
||||||
void cmd_get_add_func(CMD_GET_FUNC func)
|
|
||||||
{
|
|
||||||
cmdget_funcs = g_slist_prepend(cmdget_funcs, (void *) func);
|
|
||||||
}
|
|
||||||
|
|
||||||
void cmd_get_remove_func(CMD_GET_FUNC func)
|
|
||||||
{
|
|
||||||
cmdget_funcs = g_slist_prepend(cmdget_funcs, (void *) func);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void command_module_unbind_all(COMMAND_REC *rec,
|
static void command_module_unbind_all(COMMAND_REC *rec,
|
||||||
COMMAND_MODULE_REC *modrec)
|
COMMAND_MODULE_REC *modrec)
|
||||||
{
|
{
|
||||||
@ -894,7 +884,6 @@ static void cmd_cd(const char *data)
|
|||||||
void commands_init(void)
|
void commands_init(void)
|
||||||
{
|
{
|
||||||
commands = NULL;
|
commands = NULL;
|
||||||
cmdget_funcs = NULL;
|
|
||||||
current_command = NULL;
|
current_command = NULL;
|
||||||
alias_runstack = NULL;
|
alias_runstack = NULL;
|
||||||
|
|
||||||
@ -910,7 +899,6 @@ void commands_init(void)
|
|||||||
void commands_deinit(void)
|
void commands_deinit(void)
|
||||||
{
|
{
|
||||||
g_free_not_null(current_command);
|
g_free_not_null(current_command);
|
||||||
g_slist_free(cmdget_funcs);
|
|
||||||
|
|
||||||
signal_remove("send command", (SIGNAL_FUNC) event_command);
|
signal_remove("send command", (SIGNAL_FUNC) event_command);
|
||||||
|
|
||||||
|
@ -97,11 +97,11 @@ void command_set_options_module(const char *module,
|
|||||||
int command_have_option(const char *cmd, const char *option);
|
int command_have_option(const char *cmd, const char *option);
|
||||||
|
|
||||||
/* count can have these flags: */
|
/* count can have these flags: */
|
||||||
#define PARAM_WITHOUT_FLAGS(a) ((a) & 0x00ffffff)
|
#define PARAM_WITHOUT_FLAGS(a) ((a) & 0x00000fff)
|
||||||
/* don't check for quotes - "arg1 arg2" is NOT treated as one argument */
|
/* don't check for quotes - "arg1 arg2" is NOT treated as one argument */
|
||||||
#define PARAM_FLAG_NOQUOTES 0x01000000
|
#define PARAM_FLAG_NOQUOTES 0x00001000
|
||||||
/* final argument gets all the rest of the arguments */
|
/* final argument gets all the rest of the arguments */
|
||||||
#define PARAM_FLAG_GETREST 0x02000000
|
#define PARAM_FLAG_GETREST 0x00002000
|
||||||
/* command contains options - first you need to specify them with
|
/* command contains options - first you need to specify them with
|
||||||
command_set_options() function. Example:
|
command_set_options() function. Example:
|
||||||
|
|
||||||
@ -124,9 +124,11 @@ int command_have_option(const char *cmd, const char *option);
|
|||||||
"cmd2" = "another arg"
|
"cmd2" = "another arg"
|
||||||
"optnumarg" = "" - this is because "rest" isn't a numeric value
|
"optnumarg" = "" - this is because "rest" isn't a numeric value
|
||||||
*/
|
*/
|
||||||
#define PARAM_FLAG_OPTIONS 0x04000000
|
#define PARAM_FLAG_OPTIONS 0x00004000
|
||||||
/* don't complain about unknown options */
|
/* don't complain about unknown options */
|
||||||
#define PARAM_FLAG_UNKNOWN_OPTIONS 0x08000000
|
#define PARAM_FLAG_UNKNOWN_OPTIONS 0x00008000
|
||||||
|
/* optional channel in first argument */
|
||||||
|
#define PARAM_FLAG_OPTCHAN 0x00010000
|
||||||
|
|
||||||
char *cmd_get_param(char **data);
|
char *cmd_get_param(char **data);
|
||||||
/* get parameters from command - you should point free_me somewhere and
|
/* get parameters from command - you should point free_me somewhere and
|
||||||
@ -137,10 +139,6 @@ int cmd_get_params(const char *data, gpointer *free_me, int count, ...);
|
|||||||
|
|
||||||
void cmd_params_free(void *free_me);
|
void cmd_params_free(void *free_me);
|
||||||
|
|
||||||
typedef char* (*CMD_GET_FUNC) (const char *data, int *count, va_list *args);
|
|
||||||
void cmd_get_add_func(CMD_GET_FUNC func);
|
|
||||||
void cmd_get_remove_func(CMD_GET_FUNC func);
|
|
||||||
|
|
||||||
void commands_remove_module(const char *module);
|
void commands_remove_module(const char *module);
|
||||||
|
|
||||||
void commands_init(void);
|
void commands_init(void);
|
||||||
|
@ -377,44 +377,8 @@ static void irc_init_server(IRC_SERVER_REC *server)
|
|||||||
(GInputFunction) irc_parse_incoming, server);
|
(GInputFunction) irc_parse_incoming, server);
|
||||||
}
|
}
|
||||||
|
|
||||||
#define isoptchan(a) \
|
|
||||||
(ischannel((a)[0]) || ((a)[0] == '*' && ((a)[1] == '\0' || (a)[1] == ' ')))
|
|
||||||
|
|
||||||
static char *irc_cmd_get_func(const char *data, int *count, va_list *vargs)
|
|
||||||
{
|
|
||||||
IRC_CHANNEL_REC *channel;
|
|
||||||
char *ret, *args, *chan, *p;
|
|
||||||
|
|
||||||
if ((*count & PARAM_FLAG_OPTCHAN) == 0)
|
|
||||||
return g_strdup(data);
|
|
||||||
|
|
||||||
*count &= ~PARAM_FLAG_OPTCHAN;
|
|
||||||
channel = (void *) va_arg(*vargs, void *);
|
|
||||||
channel = IRC_CHANNEL(channel);
|
|
||||||
|
|
||||||
/* change first argument in data to full channel name. */
|
|
||||||
p = args = g_strdup(data);
|
|
||||||
|
|
||||||
chan = isoptchan(args) ? cmd_get_param(&args) : NULL;
|
|
||||||
if (chan != NULL && *chan == '!' && channel != NULL) {
|
|
||||||
/* whenever trying to send something to !channel,
|
|
||||||
change it to the real joined !XXXXXchannel */
|
|
||||||
channel = irc_channel_find(channel->server, chan);
|
|
||||||
if (channel != NULL) chan = channel->name;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (chan == NULL || strcmp(chan, "*") == 0)
|
|
||||||
chan = channel == NULL ? "*" : channel->name;
|
|
||||||
|
|
||||||
ret = g_strconcat(chan, " ", args, NULL);
|
|
||||||
g_free(p);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
void irc_irc_init(void)
|
void irc_irc_init(void)
|
||||||
{
|
{
|
||||||
cmd_get_add_func(irc_cmd_get_func);
|
|
||||||
|
|
||||||
signal_add("server event", (SIGNAL_FUNC) irc_server_event);
|
signal_add("server event", (SIGNAL_FUNC) irc_server_event);
|
||||||
signal_add("server connected", (SIGNAL_FUNC) irc_init_server);
|
signal_add("server connected", (SIGNAL_FUNC) irc_init_server);
|
||||||
signal_add("server incoming", (SIGNAL_FUNC) irc_parse_incoming_line);
|
signal_add("server incoming", (SIGNAL_FUNC) irc_parse_incoming_line);
|
||||||
|
@ -50,12 +50,8 @@ void irc_send_cmd_now(IRC_SERVER_REC *server, const char *cmd);
|
|||||||
void irc_send_cmd_full(IRC_SERVER_REC *server, const char *cmd,
|
void irc_send_cmd_full(IRC_SERVER_REC *server, const char *cmd,
|
||||||
int send_now, int immediate, int raw);
|
int send_now, int immediate, int raw);
|
||||||
|
|
||||||
#include "commands.h" /* contains the generic PARAM_FLAG_xxx defines */
|
|
||||||
|
|
||||||
/* IRC specific: optional channel in first argument */
|
|
||||||
#define PARAM_FLAG_OPTCHAN 0x10000000
|
|
||||||
|
|
||||||
/* Get count parameters from data */
|
/* Get count parameters from data */
|
||||||
|
#include "commands.h"
|
||||||
char *event_get_param(char **data);
|
char *event_get_param(char **data);
|
||||||
char *event_get_params(const char *data, int count, ...);
|
char *event_get_params(const char *data, int count, ...);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user