Send input errors to the current tag
parent
2797ac8abf
commit
0d165fadfa
19
input.c
19
input.c
|
@ -39,10 +39,11 @@ static void privmsg(struct Tag tag, bool action, const char *mesg) {
|
||||||
free(line);
|
free(line);
|
||||||
}
|
}
|
||||||
|
|
||||||
static char *param(const char *command, char **params, const char *name) {
|
static char *
|
||||||
|
param(struct Tag tag, const char *command, char **params, const char *name) {
|
||||||
char *param = strsep(params, " ");
|
char *param = strsep(params, " ");
|
||||||
if (param) return param;
|
if (param) return param;
|
||||||
uiFmt(TagStatus, UIHot, "%s requires a %s", command, name);
|
uiFmt(tag, UIHot, "%s requires a %s", command, name);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,14 +55,14 @@ static void inputMe(struct Tag tag, char *params) {
|
||||||
|
|
||||||
static void inputNick(struct Tag tag, char *params) {
|
static void inputNick(struct Tag tag, char *params) {
|
||||||
(void)tag;
|
(void)tag;
|
||||||
char *nick = param("/nick", ¶ms, "name");
|
char *nick = param(tag, "/nick", ¶ms, "name");
|
||||||
if (!nick) return;
|
if (!nick) return;
|
||||||
ircFmt("NICK %s\r\n", nick);
|
ircFmt("NICK %s\r\n", nick);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void inputJoin(struct Tag tag, char *params) {
|
static void inputJoin(struct Tag tag, char *params) {
|
||||||
(void)tag;
|
(void)tag;
|
||||||
char *chan = param("/join", ¶ms, "channel");
|
char *chan = param(tag, "/join", ¶ms, "channel");
|
||||||
if (!chan) return;
|
if (!chan) return;
|
||||||
ircFmt("JOIN %s\r\n", chan);
|
ircFmt("JOIN %s\r\n", chan);
|
||||||
}
|
}
|
||||||
|
@ -76,7 +77,7 @@ static void inputPart(struct Tag tag, char *params) {
|
||||||
|
|
||||||
static void inputQuery(struct Tag tag, char *params) {
|
static void inputQuery(struct Tag tag, char *params) {
|
||||||
(void)tag;
|
(void)tag;
|
||||||
char *nick = param("/query", ¶ms, "nick");
|
char *nick = param(tag, "/query", ¶ms, "nick");
|
||||||
if (!nick) return;
|
if (!nick) return;
|
||||||
tabTouch(TagNone, nick);
|
tabTouch(TagNone, nick);
|
||||||
uiViewTag(tagFor(nick));
|
uiViewTag(tagFor(nick));
|
||||||
|
@ -90,7 +91,7 @@ static void inputWho(struct Tag tag, char *params) {
|
||||||
|
|
||||||
static void inputWhois(struct Tag tag, char *params) {
|
static void inputWhois(struct Tag tag, char *params) {
|
||||||
(void)tag;
|
(void)tag;
|
||||||
char *nick = param("/whois", ¶ms, "nick");
|
char *nick = param(tag, "/whois", ¶ms, "nick");
|
||||||
if (!nick) return;
|
if (!nick) return;
|
||||||
ircFmt("WHOIS %s\r\n", nick);
|
ircFmt("WHOIS %s\r\n", nick);
|
||||||
}
|
}
|
||||||
|
@ -125,7 +126,7 @@ static void inputOpen(struct Tag tag, char *params) {
|
||||||
|
|
||||||
static void inputView(struct Tag tag, char *params) {
|
static void inputView(struct Tag tag, char *params) {
|
||||||
(void)tag;
|
(void)tag;
|
||||||
char *view = param("/view", ¶ms, "name or number");
|
char *view = param(tag, "/view", ¶ms, "name or number");
|
||||||
if (!view) return;
|
if (!view) return;
|
||||||
int num = strtol(view, &view, 0);
|
int num = strtol(view, &view, 0);
|
||||||
if (!view[0]) {
|
if (!view[0]) {
|
||||||
|
@ -135,7 +136,7 @@ static void inputView(struct Tag tag, char *params) {
|
||||||
if (tag.id != TagNone.id) {
|
if (tag.id != TagNone.id) {
|
||||||
uiViewTag(tag);
|
uiViewTag(tag);
|
||||||
} else {
|
} else {
|
||||||
uiFmt(TagStatus, UIHot, "No view for %s", view);
|
uiFmt(tag, UIHot, "No view for %s", view);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -216,7 +217,7 @@ void input(struct Tag tag, char *input) {
|
||||||
Commands[i].handler(tag, input);
|
Commands[i].handler(tag, input);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
uiFmt(TagStatus, UIHot, "%s isn't a recognized command", command);
|
uiFmt(tag, UICold, "%s isn't a recognized command", command);
|
||||||
}
|
}
|
||||||
|
|
||||||
void inputTab(void) {
|
void inputTab(void) {
|
||||||
|
|
Loading…
Reference in New Issue