mirror of
https://github.com/profanity-im/profanity.git
synced 2025-01-03 14:57:42 -05:00
Allow alt-num to select window
This commit is contained in:
parent
f7ad1c0335
commit
d30d31b57d
@ -216,6 +216,12 @@ inp_put_back(void)
|
|||||||
prefresh(inp_win, 0, pad_start, rows-1, 0, rows-1, cols-1);
|
prefresh(inp_win, 0, pad_start, rows-1, 0, rows-1, cols-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
inp_get_next_char(void)
|
||||||
|
{
|
||||||
|
return wgetch(inp_win);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
inp_replace_input(char *input, const char * const new_input, int *size)
|
inp_replace_input(char *input, const char * const new_input, int *size)
|
||||||
{
|
{
|
||||||
@ -242,6 +248,7 @@ _handle_edit(const int ch, char *input, int *size)
|
|||||||
char *next = NULL;
|
char *next = NULL;
|
||||||
int inp_y = 0;
|
int inp_y = 0;
|
||||||
int inp_x = 0;
|
int inp_x = 0;
|
||||||
|
int next_ch;
|
||||||
|
|
||||||
getmaxyx(stdscr, rows, cols);
|
getmaxyx(stdscr, rows, cols);
|
||||||
getyx(inp_win, inp_y, inp_x);
|
getyx(inp_win, inp_y, inp_x);
|
||||||
@ -249,9 +256,50 @@ _handle_edit(const int ch, char *input, int *size)
|
|||||||
switch(ch) {
|
switch(ch) {
|
||||||
|
|
||||||
case 27: // ESC
|
case 27: // ESC
|
||||||
|
// check for ALT-num
|
||||||
|
next_ch = inp_get_next_char();
|
||||||
|
if (next_ch != ERR) {
|
||||||
|
switch (next_ch)
|
||||||
|
{
|
||||||
|
case '1':
|
||||||
|
win_switch_if_active(0);
|
||||||
|
break;
|
||||||
|
case '2':
|
||||||
|
win_switch_if_active(1);
|
||||||
|
break;
|
||||||
|
case '3':
|
||||||
|
win_switch_if_active(2);
|
||||||
|
break;
|
||||||
|
case '4':
|
||||||
|
win_switch_if_active(3);
|
||||||
|
break;
|
||||||
|
case '5':
|
||||||
|
win_switch_if_active(4);
|
||||||
|
break;
|
||||||
|
case '6':
|
||||||
|
win_switch_if_active(5);
|
||||||
|
break;
|
||||||
|
case '7':
|
||||||
|
win_switch_if_active(6);
|
||||||
|
break;
|
||||||
|
case '8':
|
||||||
|
win_switch_if_active(7);
|
||||||
|
break;
|
||||||
|
case '9':
|
||||||
|
win_switch_if_active(8);
|
||||||
|
break;
|
||||||
|
case '0':
|
||||||
|
win_switch_if_active(9);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return 1;
|
||||||
|
} else {
|
||||||
*size = 0;
|
*size = 0;
|
||||||
inp_clear();
|
inp_clear();
|
||||||
return 1;
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
case 127:
|
case 127:
|
||||||
case KEY_BACKSPACE:
|
case KEY_BACKSPACE:
|
||||||
|
@ -59,7 +59,7 @@ create_status_bar(void)
|
|||||||
status_bar = newwin(1, cols, rows-2, 0);
|
status_bar = newwin(1, cols, rows-2, 0);
|
||||||
wbkgd(status_bar, COLOUR_STATUS_TEXT);
|
wbkgd(status_bar, COLOUR_STATUS_TEXT);
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 29, _active);
|
mvwprintw(status_bar, 0, cols - 28, _active);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
last_time = g_date_time_new_now_local();
|
last_time = g_date_time_new_now_local();
|
||||||
@ -99,7 +99,7 @@ status_bar_resize(void)
|
|||||||
wbkgd(status_bar, COLOUR_STATUS_TEXT);
|
wbkgd(status_bar, COLOUR_STATUS_TEXT);
|
||||||
wclear(status_bar);
|
wclear(status_bar);
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 29, _active);
|
mvwprintw(status_bar, 0, cols - 28, _active);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
for(i = 0; i < 9; i++) {
|
for(i = 0; i < 9; i++) {
|
||||||
@ -126,9 +126,9 @@ status_bar_inactive(const int win)
|
|||||||
|
|
||||||
int cols = getmaxx(stdscr);
|
int cols = getmaxx(stdscr);
|
||||||
|
|
||||||
mvwaddch(status_bar, 0, cols - 29 + active_pos, ' ');
|
mvwaddch(status_bar, 0, cols - 28 + active_pos, ' ');
|
||||||
if (win == 9)
|
if (win == 9)
|
||||||
mvwaddch(status_bar, 0, cols - 29 + active_pos + 1, ' ');
|
mvwaddch(status_bar, 0, cols - 28 + active_pos + 1, ' ');
|
||||||
|
|
||||||
dirty = TRUE;
|
dirty = TRUE;
|
||||||
}
|
}
|
||||||
@ -145,9 +145,9 @@ status_bar_active(const int win)
|
|||||||
|
|
||||||
wattron(status_bar, COLOUR_STATUS_ACTIVE);
|
wattron(status_bar, COLOUR_STATUS_ACTIVE);
|
||||||
if (win < 9)
|
if (win < 9)
|
||||||
mvwprintw(status_bar, 0, cols - 29 + active_pos, "%d", win+1);
|
mvwprintw(status_bar, 0, cols - 28 + active_pos, "%d", win+1);
|
||||||
else
|
else
|
||||||
mvwprintw(status_bar, 0, cols - 29 + active_pos, "10");
|
mvwprintw(status_bar, 0, cols - 28 + active_pos, "0");
|
||||||
wattroff(status_bar, COLOUR_STATUS_ACTIVE);
|
wattroff(status_bar, COLOUR_STATUS_ACTIVE);
|
||||||
|
|
||||||
dirty = TRUE;
|
dirty = TRUE;
|
||||||
@ -166,9 +166,9 @@ status_bar_new(const int win)
|
|||||||
wattron(status_bar, COLOUR_STATUS_NEW);
|
wattron(status_bar, COLOUR_STATUS_NEW);
|
||||||
wattron(status_bar, A_BLINK);
|
wattron(status_bar, A_BLINK);
|
||||||
if (win < 9)
|
if (win < 9)
|
||||||
mvwprintw(status_bar, 0, cols - 29 + active_pos, "%d", win+1);
|
mvwprintw(status_bar, 0, cols - 28 + active_pos, "%d", win+1);
|
||||||
else
|
else
|
||||||
mvwprintw(status_bar, 0, cols - 29 + active_pos, "10");
|
mvwprintw(status_bar, 0, cols - 28 + active_pos, "0");
|
||||||
wattroff(status_bar, COLOUR_STATUS_NEW);
|
wattroff(status_bar, COLOUR_STATUS_NEW);
|
||||||
wattroff(status_bar, A_BLINK);
|
wattroff(status_bar, A_BLINK);
|
||||||
|
|
||||||
@ -199,7 +199,7 @@ status_bar_print_message(const char * const msg)
|
|||||||
int cols = getmaxx(stdscr);
|
int cols = getmaxx(stdscr);
|
||||||
|
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 29, _active);
|
mvwprintw(status_bar, 0, cols - 28, _active);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
@ -232,7 +232,7 @@ status_bar_clear(void)
|
|||||||
int cols = getmaxx(stdscr);
|
int cols = getmaxx(stdscr);
|
||||||
|
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 29, _active);
|
mvwprintw(status_bar, 0, cols - 28, _active);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
dirty = TRUE;
|
dirty = TRUE;
|
||||||
@ -251,7 +251,7 @@ status_bar_clear_message(void)
|
|||||||
int cols = getmaxx(stdscr);
|
int cols = getmaxx(stdscr);
|
||||||
|
|
||||||
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
wattron(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
mvwprintw(status_bar, 0, cols - 29, _active);
|
mvwprintw(status_bar, 0, cols - 28, _active);
|
||||||
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
wattroff(status_bar, COLOUR_STATUS_BRACKET);
|
||||||
|
|
||||||
int i;
|
int i;
|
||||||
|
2
src/ui.h
2
src/ui.h
@ -103,6 +103,7 @@ void win_bad_show(const char * const msg);
|
|||||||
void win_remind(void);
|
void win_remind(void);
|
||||||
void win_activity(void);
|
void win_activity(void);
|
||||||
void win_no_activity(void);
|
void win_no_activity(void);
|
||||||
|
void win_switch_if_active(const int i);
|
||||||
|
|
||||||
void win_join_chat(const char * const room, const char * const nick);
|
void win_join_chat(const char * const room, const char * const nick);
|
||||||
void win_show_room_roster(const char * const room);
|
void win_show_room_roster(const char * const room);
|
||||||
@ -166,5 +167,6 @@ void inp_non_block(void);
|
|||||||
void inp_block(void);
|
void inp_block(void);
|
||||||
void inp_get_password(char *passwd);
|
void inp_get_password(char *passwd);
|
||||||
void inp_replace_input(char *input, const char * const new_input, int *size);
|
void inp_replace_input(char *input, const char * const new_input, int *size);
|
||||||
|
int inp_get_next_char(void);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@ -74,7 +74,6 @@ static void _cons_show_contact(PContact contact);
|
|||||||
static int _find_prof_win_index(const char * const contact);
|
static int _find_prof_win_index(const char * const contact);
|
||||||
static int _new_prof_win(const char * const contact, win_type_t type);
|
static int _new_prof_win(const char * const contact, win_type_t type);
|
||||||
static void _current_window_refresh(void);
|
static void _current_window_refresh(void);
|
||||||
static void _win_switch_if_active(const int i);
|
|
||||||
static void _win_show_time(WINDOW *win);
|
static void _win_show_time(WINDOW *win);
|
||||||
static void _win_show_user(WINDOW *win, const char * const user, const int colour);
|
static void _win_show_user(WINDOW *win, const char * const user, const int colour);
|
||||||
static void _win_show_message(WINDOW *win, const char * const message);
|
static void _win_show_message(WINDOW *win, const char * const message);
|
||||||
@ -644,7 +643,7 @@ win_show_outgoing_msg(const char * const from, const char * const to,
|
|||||||
_win_show_user(win, from, 0);
|
_win_show_user(win, from, 0);
|
||||||
_win_show_message(win, message);
|
_win_show_message(win, message);
|
||||||
}
|
}
|
||||||
_win_switch_if_active(win_index);
|
win_switch_if_active(win_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -657,7 +656,7 @@ win_join_chat(const char * const room, const char * const nick)
|
|||||||
win_index = _new_prof_win(room, WIN_MUC);
|
win_index = _new_prof_win(room, WIN_MUC);
|
||||||
}
|
}
|
||||||
|
|
||||||
_win_switch_if_active(win_index);
|
win_switch_if_active(win_index);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -1467,8 +1466,8 @@ _new_prof_win(const char * const contact, win_type_t type)
|
|||||||
return i;
|
return i;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
void
|
||||||
_win_switch_if_active(const int i)
|
win_switch_if_active(const int i)
|
||||||
{
|
{
|
||||||
win_page_off();
|
win_page_off();
|
||||||
if (windows[i] != NULL) {
|
if (windows[i] != NULL) {
|
||||||
@ -1695,25 +1694,25 @@ static void
|
|||||||
_win_handle_switch(const int * const ch)
|
_win_handle_switch(const int * const ch)
|
||||||
{
|
{
|
||||||
if (*ch == KEY_F(1)) {
|
if (*ch == KEY_F(1)) {
|
||||||
_win_switch_if_active(0);
|
win_switch_if_active(0);
|
||||||
} else if (*ch == KEY_F(2)) {
|
} else if (*ch == KEY_F(2)) {
|
||||||
_win_switch_if_active(1);
|
win_switch_if_active(1);
|
||||||
} else if (*ch == KEY_F(3)) {
|
} else if (*ch == KEY_F(3)) {
|
||||||
_win_switch_if_active(2);
|
win_switch_if_active(2);
|
||||||
} else if (*ch == KEY_F(4)) {
|
} else if (*ch == KEY_F(4)) {
|
||||||
_win_switch_if_active(3);
|
win_switch_if_active(3);
|
||||||
} else if (*ch == KEY_F(5)) {
|
} else if (*ch == KEY_F(5)) {
|
||||||
_win_switch_if_active(4);
|
win_switch_if_active(4);
|
||||||
} else if (*ch == KEY_F(6)) {
|
} else if (*ch == KEY_F(6)) {
|
||||||
_win_switch_if_active(5);
|
win_switch_if_active(5);
|
||||||
} else if (*ch == KEY_F(7)) {
|
} else if (*ch == KEY_F(7)) {
|
||||||
_win_switch_if_active(6);
|
win_switch_if_active(6);
|
||||||
} else if (*ch == KEY_F(8)) {
|
} else if (*ch == KEY_F(8)) {
|
||||||
_win_switch_if_active(7);
|
win_switch_if_active(7);
|
||||||
} else if (*ch == KEY_F(9)) {
|
} else if (*ch == KEY_F(9)) {
|
||||||
_win_switch_if_active(8);
|
win_switch_if_active(8);
|
||||||
} else if (*ch == KEY_F(10)) {
|
} else if (*ch == KEY_F(10)) {
|
||||||
_win_switch_if_active(9);
|
win_switch_if_active(9);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user