1
0
mirror of https://github.com/Tha14/toxic.git synced 2024-11-26 16:03:27 +01:00

refactored prompt command parser to work with chat and groupchat windows

This commit is contained in:
Jfreegman 2013-09-19 06:37:42 -04:00
parent b4512811ba
commit e2de6a829e
4 changed files with 232 additions and 301 deletions

View File

@ -168,173 +168,54 @@ char *wc_to_char(wchar_t ch)
return ret; return ret;
} }
static void print_help(ChatContext *self) static void print_chat_help(ChatContext *ctx)
{ {
wattron(self->history, COLOR_PAIR(CYAN) | A_BOLD); wattron(ctx->history, COLOR_PAIR(CYAN) | A_BOLD);
wprintw(self->history, "Commands:\n"); wprintw(ctx->history, "Chat commands:\n");
wattroff(self->history, A_BOLD); wattroff(ctx->history, A_BOLD);
wprintw(self->history, " /status <type> <message> : Set your status with optional note\n"); wprintw(ctx->history, " /status <type> <message> : Set your status with optional note\n");
wprintw(self->history, " /note <message> : Set a personal note\n"); wprintw(ctx->history, " /note <message> : Set a personal note\n");
wprintw(self->history, " /nick <nickname> : Set your nickname\n"); wprintw(ctx->history, " /nick <nickname> : Set your nickname\n");
wprintw(self->history, " /me <action> : Do an action\n"); wprintw(ctx->history, " /invite <nickname> <n> : Invite friend to a groupchat\n");
wprintw(self->history, " /myid : Print your ID\n"); wprintw(ctx->history, " /me <action> : Do an action\n");
wprintw(self->history, " /clear : Clear the screen\n"); wprintw(ctx->history, " /myid : Print your ID\n");
wprintw(self->history, " /close : Close the current chat window\n"); wprintw(ctx->history, " /clear : Clear the screen\n");
wprintw(self->history, " /quit or /exit : Exit Toxic\n"); wprintw(ctx->history, " /close : Close the current chat window\n");
wprintw(self->history, " /help : Print this message again\n\n"); wprintw(ctx->history, " /quit or /exit : Exit Toxic\n");
wprintw(ctx->history, " /help : Print this message again\n");
wattroff(self->history, COLOR_PAIR(CYAN)); wattron(ctx->history, A_BOLD);
wprintw(ctx->history, "\n * Messages must be enclosed in quotation marks.\n");
wattroff(ctx->history, A_BOLD);
wattroff(ctx->history, COLOR_PAIR(CYAN));
} }
static void execute(ToxWindow *self, ChatContext *ctx, StatusBar *statusbar, Tox *m, char *cmd) static void send_action(ToxWindow *self, ChatContext *ctx, Tox *m, uint8_t *action) {
{ struct tm *timeinfo = get_time();
if (!strcmp(cmd, "/clear") || !strcmp(cmd, "/c")) {
wclear(self->window); if (action == NULL) {
wclear(ctx->history); wprintw(ctx->history, "Invalid syntax.\n");
wprintw(ctx->history, "\n\n"); return;
int x, y;
getmaxyx(self->window, y, x);
(void) x;
wmove(self->window, y - CURS_Y_OFFSET, 0);
} }
else if (!strcmp(cmd, "/help") || !strcmp(cmd, "/h")) wattron(ctx->history, COLOR_PAIR(CYAN));
print_help(ctx); wprintw(ctx->history, "[%02d:%02d:%02d] ", timeinfo->tm_hour, timeinfo->tm_min, timeinfo->tm_sec);
wattroff(ctx->history, COLOR_PAIR(CYAN));
else if (!strcmp(cmd, "/quit") || !strcmp(cmd, "/exit") || !strcmp(cmd, "/q")) { uint8_t selfname[TOX_MAX_NAME_LENGTH];
exit_toxic(m); tox_getselfname(m, selfname, TOX_MAX_NAME_LENGTH);
wattron(ctx->history, COLOR_PAIR(YELLOW));
wprintw(ctx->history, "* %s %s\n", selfname, action);
wattroff(ctx->history, COLOR_PAIR(YELLOW));
if (tox_sendaction(m, self->num, action, strlen(action) + 1) == 0) {
wattron(ctx->history, COLOR_PAIR(RED));
wprintw(ctx->history, " * Failed to send action\n");
wattroff(ctx->history, COLOR_PAIR(RED));
} }
else if (!strncmp(cmd, "/me ", strlen("/me "))) {
struct tm *timeinfo = get_time();
uint8_t *action = strchr(cmd, ' ');
if (action == NULL) {
wprintw(self->window, "Invalid syntax.\n");
return;
}
action++;
wattron(ctx->history, COLOR_PAIR(CYAN));
wprintw(ctx->history, "[%02d:%02d:%02d] ", timeinfo->tm_hour, timeinfo->tm_min, timeinfo->tm_sec);
wattroff(ctx->history, COLOR_PAIR(CYAN));
uint8_t selfname[TOX_MAX_NAME_LENGTH];
tox_getselfname(m, selfname, TOX_MAX_NAME_LENGTH);
wattron(ctx->history, COLOR_PAIR(YELLOW));
wprintw(ctx->history, "* %s %s\n", selfname, action);
wattroff(ctx->history, COLOR_PAIR(YELLOW));
if (!statusbar->is_online
|| tox_sendaction(m, self->num, action, strlen(action) + 1) == 0) {
wattron(ctx->history, COLOR_PAIR(RED));
wprintw(ctx->history, " * Failed to send action\n");
wattroff(ctx->history, COLOR_PAIR(RED));
}
}
else if (!strncmp(cmd, "/status ", strlen("/status "))) {
char *status = strchr(cmd, ' ');
if (status == NULL) {
wprintw(ctx->history, "Invalid syntax.\n");
return;
}
status++;
TOX_USERSTATUS status_kind;
if (!strncmp(status, "online", strlen("online"))) {
status_kind = TOX_USERSTATUS_NONE;
wprintw(ctx->history, "Status set to: ");
wattron(ctx->history, COLOR_PAIR(GREEN) | A_BOLD);
wprintw(ctx->history, "[Online]\n");
wattroff(ctx->history, COLOR_PAIR(GREEN) | A_BOLD);
}
else if (!strncmp(status, "away", strlen("away"))) {
status_kind = TOX_USERSTATUS_AWAY;
wprintw(ctx->history, "Status set to: ");
wattron(ctx->history, COLOR_PAIR(YELLOW) | A_BOLD);
wprintw(ctx->history, "[Away]\n");
wattroff(ctx->history, COLOR_PAIR(YELLOW) | A_BOLD);
}
else if (!strncmp(status, "busy", strlen("busy"))) {
status_kind = TOX_USERSTATUS_BUSY;
wprintw(ctx->history, "Status set to: ");
wattron(ctx->history, COLOR_PAIR(RED) | A_BOLD);
wprintw(ctx->history, "[Busy]\n");
wattroff(ctx->history, COLOR_PAIR(RED) | A_BOLD);
}
else {
wprintw(ctx->history, "Invalid status.\n");
return;
}
tox_set_userstatus(m, status_kind);
prompt_update_status(self->prompt, status_kind);
uint8_t *msg = strchr(status, ' ');
if (msg != NULL) {
msg++;
uint16_t len = strlen(msg) + 1;
tox_set_statusmessage(m, msg, len);
prompt_update_statusmessage(self->prompt, msg, len);
wprintw(ctx->history, "Personal note set to: %s\n", msg);
}
}
else if (!strncmp(cmd, "/note ", strlen("/note "))) {
uint8_t *msg = strchr(cmd, ' ');
msg++;
uint16_t len = strlen(msg) + 1;
tox_set_statusmessage(m, msg, len);
prompt_update_statusmessage(self->prompt, msg, len);
wprintw(ctx->history, "Personal note set to: %s\n", msg);
}
else if (!strncmp(cmd, "/nick ", strlen("/nick "))) {
uint8_t *nick = strchr(cmd, ' ');
if (nick == NULL) {
wprintw(ctx->history, "Invalid syntax.\n");
return;
}
int len = strlen(++nick);
if (len > TOXIC_MAX_NAME_LENGTH) {
nick[TOXIC_MAX_NAME_LENGTH] = L'\0';
len = TOXIC_MAX_NAME_LENGTH;
}
tox_setname(m, nick, len+1);
prompt_update_nick(self->prompt, nick, len+1);
wprintw(ctx->history, "Nickname set to: %s\n", nick);
}
else if (!strcmp(cmd, "/myid")) {
char id[TOX_FRIEND_ADDRESS_SIZE * 2 + 1] = {'\0'};
size_t i;
uint8_t address[TOX_FRIEND_ADDRESS_SIZE];
tox_getaddress(m, address);
for (i = 0; i < TOX_FRIEND_ADDRESS_SIZE; i++) {
char xx[3];
snprintf(xx, sizeof(xx), "%02X", address[i] & 0xff);
strcat(id, xx);
}
wprintw(ctx->history, "%s\n", id);
}
else
wprintw(ctx->history, "Invalid command.\n");
} }
static void chat_onKey(ToxWindow *self, Tox *m, wint_t key) static void chat_onKey(ToxWindow *self, Tox *m, wint_t key)
@ -388,8 +269,12 @@ static void chat_onKey(ToxWindow *self, Tox *m, wint_t key)
delwin(statusbar->topline); delwin(statusbar->topline);
del_window(self); del_window(self);
disable_chatwin(f_num); disable_chatwin(f_num);
} else } else if (!strncmp(line, "/me ", strlen("/me ")))
execute(self, ctx, statusbar, m, line); send_action(self, ctx, m, line+4);
else if (!strncmp(line, "/help", strlen("/help")))
print_chat_help(ctx);
else
execute(ctx->history, self->prompt, m, line, ctx->pos);
} else { } else {
/* make sure the string has at least non-space character */ /* make sure the string has at least non-space character */
if (!string_is_empty(line)) { if (!string_is_empty(line)) {
@ -524,7 +409,7 @@ static void chat_onInit(ToxWindow *self, Tox *m)
scrollok(ctx->history, 1); scrollok(ctx->history, 1);
ctx->linewin = subwin(self->window, 0, x, y-4, 0); ctx->linewin = subwin(self->window, 0, x, y-4, 0);
wprintw(ctx->history, "\n\n"); wprintw(ctx->history, "\n\n");
print_help(ctx); print_chat_help(ctx);
wmove(self->window, y - CURS_Y_OFFSET, 0); wmove(self->window, y - CURS_Y_OFFSET, 0);
} }

View File

@ -15,6 +15,7 @@
#include "toxic_windows.h" #include "toxic_windows.h"
#include "chat.h" #include "chat.h"
#include "prompt.h"
static GroupChat groupchats[MAX_GROUPCHAT_NUM]; static GroupChat groupchats[MAX_GROUPCHAT_NUM];
static int group_chat_index = 0; static int group_chat_index = 0;
@ -71,6 +72,31 @@ static void close_groupchatwin(Tox *m, int groupnum)
group_chat_index = i; group_chat_index = i;
} }
static void print_groupchat_help(ChatContext *ctx)
{
wattron(ctx->history, COLOR_PAIR(CYAN) | A_BOLD);
wprintw(ctx->history, "Group chat commands:\n");
wattroff(ctx->history, A_BOLD);
wprintw(ctx->history, " /add <id> <message> : Add friend with optional message\n");
wprintw(ctx->history, " /status <type> <message> : Set your status with optional note\n");
wprintw(ctx->history, " /note <message> : Set a personal note\n");
wprintw(ctx->history, " /nick <nickname> : Set your nickname\n");
wprintw(ctx->history, " /invite <nickname> <n> : Invite friend to a groupchat\n");
wprintw(ctx->history, " /groupchat : Create a group chat\n");
wprintw(ctx->history, " /myid : Print your ID\n");
wprintw(ctx->history, " /clear : Clear the screen\n");
wprintw(ctx->history, " /close : Close the current group chat\n");
wprintw(ctx->history, " /quit or /exit : Exit Toxic\n");
wprintw(ctx->history, " /help : Print this message again\n");
wattron(ctx->history, A_BOLD);
wprintw(ctx->history, "\n * Messages must be enclosed in quotation marks.\n");
wattroff(ctx->history, A_BOLD);
wattroff(ctx->history, COLOR_PAIR(CYAN));
}
static void groupchat_onGroupMessage(ToxWindow *self, Tox *m, int groupnum, int peernum, uint8_t *msg, uint16_t len) static void groupchat_onGroupMessage(ToxWindow *self, Tox *m, int groupnum, int peernum, uint8_t *msg, uint16_t len)
{ {
if (self->num != groupnum) if (self->num != groupnum)
@ -138,14 +164,16 @@ static void groupchat_onKey(ToxWindow *self, Tox *m, wint_t key)
bool close_win = false; bool close_win = false;
if (line[0] == '/') { if (line[0] == '/') {
if (close_win = !strncmp(line, "/close", strlen("/close"))) { if (close_win = strncmp(line, "/close", strlen(line)) == 0) {
set_active_window(0); set_active_window(0);
int groupnum = self->num; int groupnum = self->num;
delwin(ctx->linewin); delwin(ctx->linewin);
del_window(self); del_window(self);
close_groupchatwin(m, groupnum); close_groupchatwin(m, groupnum);
} //else } else if (strncmp(line, "/help", strlen("/help")) == 0)
//execute(self, ctx, statusbar, m, line); print_groupchat_help(ctx);
else
execute(ctx->history, self->prompt, m, line, ctx->pos);
} else { } else {
/* make sure the string has at least non-space character */ /* make sure the string has at least non-space character */
if (!string_is_empty(line)) { if (!string_is_empty(line)) {
@ -197,7 +225,7 @@ static void groupchat_onInit(ToxWindow *self, Tox *m)
ctx->history = subwin(self->window, y-3, x, 0, 0); ctx->history = subwin(self->window, y-3, x, 0, 0);
scrollok(ctx->history, 1); scrollok(ctx->history, 1);
ctx->linewin = subwin(self->window, 2, x, y-4, 0); ctx->linewin = subwin(self->window, 2, x, y-4, 0);
// print_help(ctx); print_groupchat_help(ctx);
wmove(self->window, y - CURS_Y_OFFSET, 0); wmove(self->window, y - CURS_Y_OFFSET, 0);
} }

View File

@ -25,43 +25,43 @@ static char prompt_buf[MAX_STR_SIZE] = {'\0'};
static int prompt_buf_pos = 0; static int prompt_buf_pos = 0;
/* commands */ /* commands */
void cmd_accept(ToxWindow *, Tox *m, int, char **); void cmd_accept(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_add(ToxWindow *, Tox *m, int, char **); void cmd_add(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_clear(ToxWindow *, Tox *m, int, char **); void cmd_clear(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_connect(ToxWindow *, Tox *m, int, char **); void cmd_connect(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_groupchat(ToxWindow *, Tox *m, int, char **); void cmd_groupchat(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_help(ToxWindow *, Tox *m, int, char **); void cmd_help(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_invite(ToxWindow *, Tox *m, int, char **); void cmd_invite(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_join(ToxWindow *, Tox *m, int, char **); void cmd_join(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_msg(ToxWindow *, Tox *m, int, char **); void cmd_msg(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_myid(ToxWindow *, Tox *m, int, char **); void cmd_myid(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_nick(ToxWindow *, Tox *m, int, char **); void cmd_nick(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_quit(ToxWindow *, Tox *m, int, char **); void cmd_quit(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_status(ToxWindow *, Tox *m, int, char **); void cmd_status(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_note(ToxWindow *, Tox *m, int, char **); void cmd_note(WINDOW *, ToxWindow *, Tox *m, int, char **);
#define NUM_COMMANDS 16 #define NUM_COMMANDS 16
static struct { static struct {
char *name; char *name;
void (*func)(ToxWindow *, Tox *m, int, char **); void (*func)(WINDOW *, ToxWindow *, Tox *m, int, char **);
} commands[] = { } commands[] = {
{ "accept", cmd_accept }, { "/accept", cmd_accept },
{ "add", cmd_add }, { "/add", cmd_add },
{ "clear", cmd_clear }, { "/clear", cmd_clear },
{ "connect", cmd_connect }, { "/connect", cmd_connect },
{ "exit", cmd_quit }, { "/exit", cmd_quit },
{ "groupchat", cmd_groupchat }, { "/groupchat", cmd_groupchat },
{ "help", cmd_help }, { "/help", cmd_help },
{ "invite", cmd_invite }, { "/invite", cmd_invite },
{ "join", cmd_join }, { "/join", cmd_join },
{ "msg", cmd_msg }, { "/msg", cmd_msg },
{ "myid", cmd_myid }, { "/myid", cmd_myid },
{ "nick", cmd_nick }, { "/nick", cmd_nick },
{ "q", cmd_quit }, { "/q", cmd_quit },
{ "quit", cmd_quit }, { "/quit", cmd_quit },
{ "status", cmd_status }, { "/status", cmd_status },
{ "note", cmd_note }, { "/note", cmd_note },
}; };
/* Updates own nick in prompt statusbar */ /* Updates own nick in prompt statusbar */
@ -140,42 +140,42 @@ unsigned char *hex_string_to_bin(char hex_string[])
} }
/* command functions */ /* command functions */
void cmd_accept(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_accept(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
/* check arguments */ /* check arguments */
if (argc != 1) { if (argc != 1) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
int num = atoi(argv[1]); int num = atoi(argv[1]);
if (num < 0 || num >= num_frnd_requests) { if (num < 0 || num >= num_frnd_requests) {
wprintw(self->window, "No pending friend request with that number.\n"); wprintw(window, "No pending friend request with that number.\n");
return; return;
} }
int friendnum = tox_addfriend_norequest(m, pending_frnd_requests[num]); int friendnum = tox_addfriend_norequest(m, pending_frnd_requests[num]);
if (friendnum == -1) if (friendnum == -1)
wprintw(self->window, "Failed to add friend.\n"); wprintw(window, "Failed to add friend.\n");
else { else {
wprintw(self->window, "Friend request accepted.\n"); wprintw(window, "Friend request accepted.\n");
on_friendadded(m, friendnum); on_friendadded(m, friendnum);
} }
} }
void cmd_add(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_add(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
if (argc < 1 || argc > 2) { if (argc < 1 || argc > 2) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
char *id = argv[1]; char *id = argv[1];
if (id == NULL) { if (id == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
@ -185,12 +185,12 @@ void cmd_add(ToxWindow *self, Tox *m, int argc, char **argv)
msg = argv[2]; msg = argv[2];
if (msg == NULL) { if (msg == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
if (msg[0] != '\"') { if (msg[0] != '\"') {
wprintw(self->window, "Messages must be enclosed in quotes.\n"); wprintw(window, "Messages must be enclosed in quotes.\n");
return; return;
} }
@ -200,7 +200,7 @@ void cmd_add(ToxWindow *self, Tox *m, int argc, char **argv)
msg = "Let's tox."; msg = "Let's tox.";
if (strlen(id) != 2 * TOX_FRIEND_ADDRESS_SIZE) { if (strlen(id) != 2 * TOX_FRIEND_ADDRESS_SIZE) {
wprintw(self->window, "Invalid ID length.\n"); wprintw(window, "Invalid ID length.\n");
return; return;
} }
@ -215,7 +215,7 @@ void cmd_add(ToxWindow *self, Tox *m, int argc, char **argv)
xx[2] = '\0'; xx[2] = '\0';
if (sscanf(xx, "%02x", &x) != 1) { if (sscanf(xx, "%02x", &x) != 1) {
wprintw(self->window, "Invalid ID.\n"); wprintw(window, "Invalid ID.\n");
return; return;
} }
@ -230,51 +230,51 @@ void cmd_add(ToxWindow *self, Tox *m, int argc, char **argv)
switch (num) { switch (num) {
case TOX_FAERR_TOOLONG: case TOX_FAERR_TOOLONG:
wprintw(self->window, "Message is too long.\n"); wprintw(window, "Message is too long.\n");
break; break;
case TOX_FAERR_NOMESSAGE: case TOX_FAERR_NOMESSAGE:
wprintw(self->window, "Please add a message to your request.\n"); wprintw(window, "Please add a message to your request.\n");
break; break;
case TOX_FAERR_OWNKEY: case TOX_FAERR_OWNKEY:
wprintw(self->window, "That appears to be your own ID.\n"); wprintw(window, "That appears to be your own ID.\n");
break; break;
case TOX_FAERR_ALREADYSENT: case TOX_FAERR_ALREADYSENT:
wprintw(self->window, "Friend request already sent.\n"); wprintw(window, "Friend request already sent.\n");
break; break;
case TOX_FAERR_UNKNOWN: case TOX_FAERR_UNKNOWN:
wprintw(self->window, "Undefined error when adding friend.\n"); wprintw(window, "Undefined error when adding friend.\n");
break; break;
case TOX_FAERR_BADCHECKSUM: case TOX_FAERR_BADCHECKSUM:
wprintw(self->window, "Bad checksum in address.\n"); wprintw(window, "Bad checksum in address.\n");
break; break;
case TOX_FAERR_SETNEWNOSPAM: case TOX_FAERR_SETNEWNOSPAM:
wprintw(self->window, "Nospam was different.\n"); wprintw(window, "Nospam was different.\n");
break; break;
default: default:
wprintw(self->window, "Friend added as %d.\n", num); wprintw(window, "Friend added as %d.\n", num);
on_friendadded(m, num); on_friendadded(m, num);
break; break;
} }
} }
void cmd_clear(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_clear(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
wclear(self->window); wclear(window);
wprintw(self->window, "\n\n"); wprintw(window, "\n\n");
} }
void cmd_connect(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_connect(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
/* check arguments */ /* check arguments */
if (argc != 3) { if (argc != 3) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
@ -284,12 +284,12 @@ void cmd_connect(ToxWindow *self, Tox *m, int argc, char **argv)
char *key = argv[3]; char *key = argv[3];
if (ip == NULL || port == NULL || key == NULL) { if (ip == NULL || port == NULL || key == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
if (atoi(port) == 0) { if (atoi(port) == 0) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
@ -299,74 +299,74 @@ void cmd_connect(ToxWindow *self, Tox *m, int argc, char **argv)
free(binary_string); free(binary_string);
} }
void cmd_quit(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_quit(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
exit_toxic(m); exit_toxic(m);
} }
void cmd_groupchat(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_groupchat(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
int ngc = get_num_groupchats(); int ngc = get_num_groupchats();
if (ngc < 0 || ngc > MAX_GROUPCHAT_NUM) { if (ngc < 0 || ngc > MAX_GROUPCHAT_NUM) {
wprintw(self->window, "\nMaximum number of group chats has been reached.\n"); wprintw(window, "\nMaximum number of group chats has been reached.\n");
return; return;
} }
int groupnum = tox_add_groupchat(m); int groupnum = tox_add_groupchat(m);
if (groupnum == -1) { if (groupnum == -1) {
wprintw(self->window, "Group chat failed to initialize.\n"); wprintw(window, "Group chat failed to initialize.\n");
return; return;
} }
if (init_groupchat_win(self, m, groupnum) == -1) { if (init_groupchat_win(prompt, m, groupnum) == -1) {
wprintw(self->window, "Group chat failed to initialize.\n"); wprintw(window, "Group chat failed to initialize.\n");
tox_del_groupchat(m, groupnum); tox_del_groupchat(m, groupnum);
return; return;
} }
wprintw(self->window, "Group chat created as %d.\n", groupnum); wprintw(window, "Group chat created as %d.\n", groupnum);
} }
void cmd_help(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_help(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
wclear(self->window); wclear(window);
wattron(self->window, COLOR_PAIR(CYAN) | A_BOLD); wattron(window, COLOR_PAIR(CYAN) | A_BOLD);
wprintw(self->window, "\n\nCommands:\n"); wprintw(window, "\n\nCommands:\n");
wattroff(self->window, A_BOLD); wattroff(window, A_BOLD);
wprintw(self->window, " connect <ip> <port> <key> : Connect to DHT server\n"); wprintw(window, " /connect <ip> <port> <key> : Connect to DHT server\n");
wprintw(self->window, " add <id> <message> : Add friend with optional message\n"); wprintw(window, " /add <id> <message> : Add friend with optional message\n");
wprintw(self->window, " accept <n> : Accept friend request\n"); wprintw(window, " /accept <n> : Accept friend request\n");
wprintw(self->window, " status <type> <message> : Set your status with optional note\n"); wprintw(window, " /status <type> <message> : Set your status with optional note\n");
wprintw(self->window, " note <message> : Set a personal note\n"); wprintw(window, " /note <message> : Set a personal note\n");
wprintw(self->window, " nick <nickname> : Set your nickname\n"); wprintw(window, " /nick <nickname> : Set your nickname\n");
wprintw(self->window, " join <n> : Join a group chat\n"); wprintw(window, " /join <n> : Join a group chat\n");
wprintw(self->window, " invite <nickname> <n> : Invite friend to a groupchat\n"); wprintw(window, " /invite <nickname> <n> : Invite friend to a groupchat\n");
wprintw(self->window, " groupchat : Create a group chat\n"); wprintw(window, " /groupchat : Create a group chat\n");
wprintw(self->window, " myid : Print your ID\n"); wprintw(window, " /myid : Print your ID\n");
wprintw(self->window, " quit/exit : Exit Toxic\n"); wprintw(window, " /quit or /exit : Exit Toxic\n");
wprintw(self->window, " help : Print this message again\n"); wprintw(window, " /help : Print this message again\n");
wprintw(self->window, " clear : Clear this window\n"); wprintw(window, " /clear : Clear this window\n");
wattron(self->window, A_BOLD); wattron(window, A_BOLD);
wprintw(self->window, " * Messages must be enclosed in quotation marks.\n"); wprintw(window, "\n * Messages must be enclosed in quotation marks.\n");
wprintw(self->window, " * Use the TAB key to navigate through the tabs.\n\n"); wprintw(window, " * Use the TAB key to navigate through the tabs.\n\n");
wattroff(self->window, A_BOLD); wattroff(window, A_BOLD);
wattroff(self->window, COLOR_PAIR(CYAN)); wattroff(window, COLOR_PAIR(CYAN));
} }
void cmd_invite(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_invite(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
if (argc != 2) { if (argc != 2) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
if (argv[1] == NULL || argv[2] == NULL) { if (argv[1] == NULL || argv[2] == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
@ -379,56 +379,56 @@ void cmd_invite(ToxWindow *self, Tox *m, int argc, char **argv)
int friendnum = get_friendnum(friendname); int friendnum = get_friendnum(friendname);
if (friendnum == -1) { if (friendnum == -1) {
wprintw(self->window, "Friend '%s' not found.\n", friendname); wprintw(window, "Friend '%s' not found.\n", friendname);
return; return;
} }
if (tox_invite_friend(m, friendnum, groupnum) == -1) { if (tox_invite_friend(m, friendnum, groupnum) == -1) {
wprintw(self->window, "Failed to invite friend.\n"); wprintw(window, "Failed to invite friend.\n");
return; return;
} }
wprintw(self->window, "Invited friend %s to group chat %d.\n", friendname, groupnum); wprintw(window, "Invited friend %s to group chat %d.\n", friendname, groupnum);
} }
void cmd_join(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_join(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
if (argc != 1) { if (argc != 1) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
if (argv[1] == NULL) { if (argv[1] == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
int num = atoi(argv[1]); int num = atoi(argv[1]);
if (num < 0 || num >= num_grp_requests) { if (num < 0 || num >= num_grp_requests) {
wprintw(self->window, "No pending group chat invites with that number.\n"); wprintw(window, "No pending group chat invites with that number.\n");
return; return;
} }
int groupnum = tox_join_groupchat(m, num, pending_grp_requests[num]); int groupnum = tox_join_groupchat(m, num, pending_grp_requests[num]);
if (groupnum == -1) { if (groupnum == -1) {
wprintw(self->window, "Group chat failed to initialize.\n"); wprintw(window, "Group chat failed to initialize.\n");
return; return;
} }
if (init_groupchat_win(self, m, groupnum) == -1) { if (init_groupchat_win(prompt, m, groupnum) == -1) {
wprintw(self->window, "Group chat failed to initialize.\n"); wprintw(window, "Group chat window failed to initialize.\n");
tox_del_groupchat(m, groupnum); tox_del_groupchat(m, groupnum);
return; return;
} }
} }
void cmd_msg(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_msg(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
/* check arguments */ /* check arguments */
if (argc != 2) { if (argc != 2) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
@ -436,19 +436,19 @@ void cmd_msg(ToxWindow *self, Tox *m, int argc, char **argv)
uint8_t *msg = argv[2]; uint8_t *msg = argv[2];
if (id == NULL || msg == NULL) { if (id == NULL || msg == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
msg[strlen(++msg)-1] = L'\0'; msg[strlen(++msg)-1] = L'\0';
if (tox_sendmessage(m, atoi(id), msg, strlen(msg) + 1) == 0) if (tox_sendmessage(m, atoi(id), msg, strlen(msg) + 1) == 0)
wprintw(self->window, "Failed to send message.\n"); wprintw(window, "Failed to send message.\n");
else else
wprintw(self->window, "Message successfully sent.\n"); wprintw(window, "Message successfully sent.\n");
} }
void cmd_myid(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_myid(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
char id[TOX_FRIEND_ADDRESS_SIZE * 2 + 1] = {0}; char id[TOX_FRIEND_ADDRESS_SIZE * 2 + 1] = {0};
uint8_t address[TOX_FRIEND_ADDRESS_SIZE]; uint8_t address[TOX_FRIEND_ADDRESS_SIZE];
@ -462,21 +462,21 @@ void cmd_myid(ToxWindow *self, Tox *m, int argc, char **argv)
strcat(id, xx); strcat(id, xx);
} }
wprintw(self->window, "%s\n", id); wprintw(window, "%s\n", id);
} }
void cmd_nick(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_nick(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
/* check arguments */ /* check arguments */
if (argc != 1) { if (argc != 1) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
uint8_t *nick = argv[1]; uint8_t *nick = argv[1];
if (nick == NULL) { if (nick == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
@ -494,12 +494,12 @@ void cmd_nick(ToxWindow *self, Tox *m, int argc, char **argv)
} }
tox_setname(m, nick, len+1); tox_setname(m, nick, len+1);
prompt_update_nick(self, nick, len+1); prompt_update_nick(prompt, nick, len+1);
store_data(m, DATA_FILE); store_data(m, DATA_FILE);
} }
void cmd_status(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_status(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
uint8_t *msg = NULL; uint8_t *msg = NULL;
@ -508,23 +508,23 @@ void cmd_status(ToxWindow *self, Tox *m, int argc, char **argv)
msg = argv[2]; msg = argv[2];
if (msg == NULL) { if (msg == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
if (msg[0] != '\"') { if (msg[0] != '\"') {
wprintw(self->window, "Messages must be enclosed in quotes.\n"); wprintw(window, "Messages must be enclosed in quotes.\n");
return; return;
} }
} else if (argc != 1) { } else if (argc != 1) {
wprintw(self->window, "Wrong number of arguments.\n"); wprintw(window, "Wrong number of arguments.\n");
return; return;
} }
char *status = argv[1]; char *status = argv[1];
if (status == NULL) { if (status == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
@ -540,51 +540,51 @@ void cmd_status(ToxWindow *self, Tox *m, int argc, char **argv)
status_kind = TOX_USERSTATUS_BUSY; status_kind = TOX_USERSTATUS_BUSY;
else else
wprintw(self->window, "Invalid status.\n"); wprintw(window, "Invalid status.\n");
tox_set_userstatus(m, status_kind); tox_set_userstatus(m, status_kind);
prompt_update_status(self, status_kind); prompt_update_status(prompt, status_kind);
if (msg != NULL) { if (msg != NULL) {
msg[strlen(++msg)-1] = L'\0'; /* remove opening and closing quotes */ msg[strlen(++msg)-1] = L'\0'; /* remove opening and closing quotes */
uint16_t len = strlen(msg) + 1; uint16_t len = strlen(msg) + 1;
tox_set_statusmessage(m, msg, len); tox_set_statusmessage(m, msg, len);
prompt_update_statusmessage(self, msg, len); prompt_update_statusmessage(prompt, msg, len);
} }
} }
void cmd_note(ToxWindow *self, Tox *m, int argc, char **argv) void cmd_note(WINDOW *window, ToxWindow *prompt, Tox *m, int argc, char **argv)
{ {
if (argc != 1) { if (argc != 1) {
wprintw(self->window, "Wrong number of arguments.\n"); wprintw(window, "Wrong number of arguments.\n");
return; return;
} }
uint8_t *msg = argv[1]; uint8_t *msg = argv[1];
if (msg == NULL) { if (msg == NULL) {
wprintw(self->window, "Invalid syntax.\n"); wprintw(window, "Invalid syntax.\n");
return; return;
} }
if (msg[0] != '\"') { if (msg[0] != '\"') {
wprintw(self->window, "Messages must be enclosed in quotes.\n"); wprintw(window, "Messages must be enclosed in quotes.\n");
return; return;
} }
msg[strlen(++msg)-1] = L'\0'; msg[strlen(++msg)-1] = L'\0';
uint16_t len = strlen(msg) + 1; uint16_t len = strlen(msg) + 1;
tox_set_statusmessage(m, msg, len); tox_set_statusmessage(m, msg, len);
prompt_update_statusmessage(self, msg, len); prompt_update_statusmessage(prompt, msg, len);
} }
static void execute(ToxWindow *self, Tox *m, char *u_cmd) void execute(WINDOW *window, ToxWindow *prompt, Tox *m, char *u_cmd, int buf_len)
{ {
int newlines = 0; int newlines = 0;
char cmd[MAX_STR_SIZE] = {'\0'}; char cmd[MAX_STR_SIZE] = {'\0'};
size_t i; size_t i;
for (i = 0; i < strlen(prompt_buf); ++i) { for (i = 0; i < buf_len; ++i) {
if (u_cmd[i] == '\n') if (u_cmd[i] == '\n')
++newlines; ++newlines;
else else
@ -617,7 +617,7 @@ static void execute(ToxWindow *self, Tox *m, char *u_cmd)
else if (cmd[i] == '\"') { else if (cmd[i] == '\"') {
while (cmd[++i] != '\"') { while (cmd[++i] != '\"') {
if (cmd[i] == '\0') { if (cmd[i] == '\0') {
wprintw(self->window, "Invalid command: did you forget an opening or closing \"?\n"); wprintw(window, "Invalid command: did you forget an opening or closing \"?\n");
return; return;
} }
} }
@ -627,7 +627,7 @@ static void execute(ToxWindow *self, Tox *m, char *u_cmd)
/* read arguments into array */ /* read arguments into array */
char **cmdargs = malloc((numargs + 1) * sizeof(char *)); char **cmdargs = malloc((numargs + 1) * sizeof(char *));
if (!cmdargs) { if (!cmdargs) {
wprintw(self->window, "Invalid command: too many arguments.\n"); wprintw(window, "Invalid command: too many arguments.\n");
return; return;
} }
@ -650,7 +650,7 @@ static void execute(ToxWindow *self, Tox *m, char *u_cmd)
/* match input to command list */ /* match input to command list */
for (i = 0; i < NUM_COMMANDS; i++) { for (i = 0; i < NUM_COMMANDS; i++) {
if (!strcmp(cmdargs[0], commands[i].name)) { if (!strcmp(cmdargs[0], commands[i].name)) {
(commands[i].func)(self, m, numargs, cmdargs); (commands[i].func)(window, prompt, m, numargs, cmdargs);
free(cmdargs); free(cmdargs);
return; return;
} }
@ -658,7 +658,7 @@ static void execute(ToxWindow *self, Tox *m, char *u_cmd)
/* no match */ /* no match */
free(cmdargs); free(cmdargs);
wprintw(self->window, "Invalid command.\n"); wprintw(window, "Invalid command.\n");
} }
static void prompt_onKey(ToxWindow *self, Tox *m, wint_t key) static void prompt_onKey(ToxWindow *self, Tox *m, wint_t key)
@ -684,7 +684,7 @@ static void prompt_onKey(ToxWindow *self, Tox *m, wint_t key)
/* RETURN key: execute command */ /* RETURN key: execute command */
else if (key == '\n') { else if (key == '\n') {
wprintw(self->window, "\n"); wprintw(self->window, "\n");
execute(self, m, prompt_buf); execute(self->window, self, m, prompt_buf, prompt_buf_pos);
prompt_buf_pos = 0; prompt_buf_pos = 0;
prompt_buf[0] = 0; prompt_buf[0] = 0;
} }
@ -762,7 +762,7 @@ static void prompt_onDraw(ToxWindow *self, Tox *m)
static void prompt_onInit(ToxWindow *self, Tox *m) static void prompt_onInit(ToxWindow *self, Tox *m)
{ {
scrollok(self->window, 1); scrollok(self->window, 1);
cmd_help(self, m, 0, NULL); cmd_help(self->window, self, m, 0, NULL);
wclrtoeol(self->window); wclrtoeol(self->window);
} }
@ -784,7 +784,7 @@ void prompt_onFriendRequest(ToxWindow *self, uint8_t *key, uint8_t *data, uint16
} }
wprintw(self->window, "\n\nWith the message: %s\n\n", data); wprintw(self->window, "\n\nWith the message: %s\n\n", data);
wprintw(self->window, "Type \"accept %d\" to accept it.\n", n); wprintw(self->window, "Type \"/accept %d\" to accept it.\n", n);
self->blink = true; self->blink = true;
beep(); beep();
@ -817,7 +817,7 @@ void prompt_onGroupInvite(ToxWindow *self, Tox *m, int friendnumber, uint8_t *gr
return; return;
} }
wprintw(self->window, "Type \"join %d\" to join the chat.\n", n); wprintw(self->window, "Type \"/join %d\" to join the chat.\n", n);
self->blink = true; self->blink = true;
beep(); beep();

View File

@ -12,4 +12,22 @@ void prompt_update_statusmessage(ToxWindow *prompt, uint8_t *statusmsg, uint16_t
void prompt_update_status(ToxWindow *prompt, TOX_USERSTATUS status); void prompt_update_status(ToxWindow *prompt, TOX_USERSTATUS status);
void prompt_update_connectionstatus(ToxWindow *prompt, bool is_connected); void prompt_update_connectionstatus(ToxWindow *prompt, bool is_connected);
/* commands */
void cmd_accept(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_add(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_clear(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_connect(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_groupchat(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_help(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_invite(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_join(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_msg(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_myid(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_nick(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_quit(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_status(WINDOW *, ToxWindow *, Tox *m, int, char **);
void cmd_note(WINDOW *, ToxWindow *, Tox *m, int, char **);
void execute(WINDOW *window, ToxWindow *prompt, Tox *m, char *u_cmd, int buf_len);
#endif /* end of include guard: PROMPT_H_UZYGWFFL */ #endif /* end of include guard: PROMPT_H_UZYGWFFL */