1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

SImple window switching for message and console

This commit is contained in:
James Booth 2012-02-07 22:59:47 +00:00
parent bb3878bc76
commit e2665944cb
3 changed files with 142 additions and 66 deletions

44
app.c
View File

@ -7,37 +7,49 @@
#include "windows.h" #include "windows.h"
#include "jabber.h" #include "jabber.h"
#define CHAT 0
#define CONS 1
static void main_event_loop(void); static void main_event_loop(void);
void start_profanity(void) void start_profanity(void)
{ {
char cmd[50]; char cmd[50];
while (TRUE) { while (TRUE) {
cmd_get_command_str(cmd); inp_get_command_str(cmd);
if (strcmp(cmd, "/quit") == 0) { if (strcmp(cmd, "/quit") == 0) {
break; break;
} else if (strncmp(cmd, "/help", 5) == 0) {
cons_help();
cons_show();
inp_clear();
} else if (strncmp(cmd, "/connect ", 9) == 0) { } else if (strncmp(cmd, "/connect ", 9) == 0) {
char *user; char *user;
user = strndup(cmd+9, strlen(cmd)-9); user = strndup(cmd+9, strlen(cmd)-9);
bar_print_message("Enter password:"); bar_print_message("Enter password:");
char passwd[20]; char passwd[20];
cmd_get_password(passwd); inp_get_password(passwd);
bar_print_message(user); bar_print_message(user);
jabber_connect(user, passwd); jabber_connect(user, passwd);
chat_show();
main_event_loop(); main_event_loop();
break; break;
} else { } else {
cmd_clear(); cons_bad_command(cmd);
cons_show();
inp_clear();
} }
} }
} }
static void main_event_loop(void) static void main_event_loop(void)
{ {
cmd_non_block(); int showing = CHAT;
inp_non_block();
while(TRUE) { while(TRUE) {
int ch = ERR; int ch = ERR;
@ -50,9 +62,20 @@ static void main_event_loop(void)
// handle incoming messages // handle incoming messages
jabber_process_events(); jabber_process_events();
if (showing == CHAT) {
chat_show();
}
// determine if they changed windows
if (ch == KEY_F(1)) {
cons_show();
showing = CONS;
} else if (ch == KEY_F(2)) {
chat_show();
showing = CHAT;
}
// get another character from the command box // get another character from the command box
cmd_poll_char(&ch, command, &size); inp_poll_char(&ch, command, &size);
} }
// null terminate the input // null terminate the input
@ -61,10 +84,19 @@ static void main_event_loop(void)
// newline was hit, check if /quit command issued // newline was hit, check if /quit command issued
if (strcmp(command, "/quit") == 0) { if (strcmp(command, "/quit") == 0) {
break; break;
} else if (strncmp(command, "/help", 5) == 0) {
cons_help();
if (showing == CONS) {
cons_show();
}
inp_clear();
} else { } else {
jabber_send(command); jabber_send(command);
show_outgoing_msg("me", command); show_outgoing_msg("me", command);
cmd_clear(); if (showing == CHAT) {
chat_show();
}
inp_clear();
} }
} }

149
windows.c
View File

@ -2,16 +2,21 @@
#include "windows.h" #include "windows.h"
// window references // common window references
static WINDOW *title_bar; static WINDOW *title_bar;
static WINDOW *cmd_bar; static WINDOW *inp_bar;
static WINDOW *cmd_win; static WINDOW *inp_win;
static WINDOW *main_win;
// main windows
static WINDOW *chat_win;
static WINDOW *cons_win;
static void create_title_bar(void); static void create_title_bar(void);
static void create_command_bar(void); static void create_input_bar(void);
static void create_command_window(void); static void create_input_window(void);
static void create_main_window(void);
static void create_chat_window(void);
static void create_console_window(void);
void gui_init(void) void gui_init(void)
{ {
@ -34,14 +39,15 @@ void gui_init(void)
create_title_bar(); create_title_bar();
wrefresh(title_bar); wrefresh(title_bar);
create_command_bar(); create_input_bar();
wrefresh(cmd_bar); wrefresh(inp_bar);
create_command_window(); create_input_window();
wrefresh(cmd_win); wrefresh(inp_win);
create_main_window();
wrefresh(main_win);
wmove(cmd_win, 0, 0); create_chat_window();
create_console_window();
wmove(inp_win, 0, 0);
} }
void gui_close(void) void gui_close(void)
@ -54,8 +60,7 @@ void show_incomming_msg(char *from, char *message)
char line[100]; char line[100];
sprintf(line, "%s: %s\n", from, message); sprintf(line, "%s: %s\n", from, message);
wprintw(main_win, line); wprintw(chat_win, line);
wrefresh(main_win);
} }
void show_outgoing_msg(char *from, char* message) void show_outgoing_msg(char *from, char* message)
@ -63,73 +68,96 @@ void show_outgoing_msg(char *from, char* message)
char line[100]; char line[100];
sprintf(line, "%s: %s\n", from, message); sprintf(line, "%s: %s\n", from, message);
wprintw(main_win, line); wprintw(chat_win, line);
wrefresh(main_win);
} }
void cmd_get_command_str(char *cmd) void inp_get_command_str(char *cmd)
{ {
wmove(cmd_win, 0, 0); wmove(inp_win, 0, 0);
wgetstr(cmd_win, cmd); wgetstr(inp_win, cmd);
} }
void cmd_clear(void) void inp_clear(void)
{ {
wclear(cmd_win); wclear(inp_win);
wmove(cmd_win, 0, 0); wmove(inp_win, 0, 0);
wrefresh(cmd_win); wrefresh(inp_win);
} }
void cmd_non_block(void) void inp_non_block(void)
{ {
wtimeout(cmd_win, 0); wtimeout(inp_win, 0);
} }
void cmd_poll_char(int *ch, char command[], int *size) void inp_poll_char(int *ch, char command[], int *size)
{ {
int cmd_y = 0; int inp_y = 0;
int cmd_x = 0; int inp_x = 0;
// move cursor back to cmd_win // move cursor back to inp_win
getyx(cmd_win, cmd_y, cmd_x); getyx(inp_win, inp_y, inp_x);
wmove(cmd_win, cmd_y, cmd_x); wmove(inp_win, inp_y, inp_x);
// echo off, and get some more input // echo off, and get some more input
noecho(); noecho();
*ch = wgetch(cmd_win); *ch = wgetch(inp_win);
// if delete pressed, go back and delete it // if delete pressed, go back and delete it
if (*ch == 127) { if (*ch == 127) {
if (*size > 0) { if (*size > 0) {
getyx(cmd_win, cmd_y, cmd_x); getyx(inp_win, inp_y, inp_x);
wmove(cmd_win, cmd_y, cmd_x-1); wmove(inp_win, inp_y, inp_x-1);
wdelch(cmd_win); wdelch(inp_win);
(*size)--; (*size)--;
} }
} }
// else if not error or newline, show it and store it // else if not error or newline, show it and store it
else if (*ch != ERR && *ch != '\n') { else if (*ch != ERR && *ch != '\n') {
waddch(cmd_win, *ch); waddch(inp_win, *ch);
command[(*size)++] = *ch; command[(*size)++] = *ch;
} }
echo(); echo();
} }
void cmd_get_password(char *passwd) void inp_get_password(char *passwd)
{ {
wclear(cmd_win); wclear(inp_win);
noecho(); noecho();
mvwgetstr(cmd_win, 0, 0, passwd); mvwgetstr(inp_win, 0, 0, passwd);
echo(); echo();
} }
void bar_print_message(char *msg) void bar_print_message(char *msg)
{ {
mvwprintw(cmd_bar, 0, 0, msg); mvwprintw(inp_bar, 0, 0, msg);
wrefresh(cmd_bar); wrefresh(inp_bar);
}
void cons_help(void)
{
waddstr(cons_win, "Help\n");
waddstr(cons_win, "----\n");
waddstr(cons_win, "/quit - Quits Profanity.\n");
waddstr(cons_win, "/connect <username@host> - Login to jabber.\n");
}
void cons_bad_command(char *cmd)
{
wprintw(cons_win, "Unknown command: %s\n", cmd);
}
void cons_show(void)
{
touchwin(cons_win);
wrefresh(cons_win);
}
void chat_show(void)
{
touchwin(chat_win);
wrefresh(chat_win);
} }
static void create_title_bar(void) static void create_title_bar(void)
@ -144,30 +172,43 @@ static void create_title_bar(void)
mvwprintw(title_bar, 0, 0, title); mvwprintw(title_bar, 0, 0, title);
} }
static void create_command_bar(void) static void create_input_bar(void)
{ {
int rows, cols; int rows, cols;
getmaxyx(stdscr, rows, cols); getmaxyx(stdscr, rows, cols);
cmd_bar = newwin(1, cols, rows-2, 0); inp_bar = newwin(1, cols, rows-2, 0);
wbkgd(cmd_bar, COLOR_PAIR(3)); wbkgd(inp_bar, COLOR_PAIR(3));
} }
static void create_command_window(void) static void create_input_window(void)
{ {
int rows, cols; int rows, cols;
getmaxyx(stdscr, rows, cols); getmaxyx(stdscr, rows, cols);
cmd_win = newwin(1, cols, rows-1, 0); inp_win = newwin(1, cols, rows-1, 0);
keypad(cmd_win, TRUE); keypad(inp_win, TRUE);
} }
static void create_main_window(void) static void create_chat_window(void)
{ {
int rows, cols; int rows, cols;
getmaxyx(stdscr, rows, cols); getmaxyx(stdscr, rows, cols);
main_win = newwin(rows-3, cols, 1, 0); chat_win = newwin(rows-3, cols, 1, 0);
scrollok(main_win, TRUE); scrollok(chat_win, TRUE);
} }
static void create_console_window(void)
{
int rows, cols;
getmaxyx(stdscr, rows, cols);
cons_win = newwin(rows-3, cols, 1, 0);
scrollok(cons_win, TRUE);
waddstr(cons_win, "Welcome to Profanity.\n");
touchwin(cons_win);
wrefresh(cons_win);
}

View File

@ -8,11 +8,14 @@ void gui_init(void);
void gui_close(void); void gui_close(void);
void show_incomming_msg(char *from, char *message); void show_incomming_msg(char *from, char *message);
void show_outgoing_msg(char *from, char *message); void show_outgoing_msg(char *from, char *message);
void cmd_get_command_str(char *cmd); void inp_get_command_str(char *cmd);
void cmd_poll_char(int *ch, char command[], int *size); void inp_poll_char(int *ch, char command[], int *size);
void cmd_clear(void); void inp_clear(void);
void cmd_non_block(void); void inp_non_block(void);
void cmd_get_password(char *passwd); void inp_get_password(char *passwd);
void bar_print_message(char *msg); void bar_print_message(char *msg);
void cons_help(void);
void cons_show(void);
void chat_show(void);
void cons_bad_command(char *cmd);
#endif #endif