1
0
mirror of https://github.com/profanity-im/profanity.git synced 2024-12-04 14:46:46 -05:00

Merge branch 'master' into plugins

This commit is contained in:
James Booth 2014-04-24 23:09:58 +01:00
commit cb4deb18bb
6 changed files with 88 additions and 7 deletions

View File

@ -346,13 +346,14 @@ static struct cmd_t command_defs[] =
NULL } } }, NULL } } },
{ "/wins", { "/wins",
cmd_wins, parse_args, 0, 1, NULL, cmd_wins, parse_args, 0, 3, NULL,
{ "/wins [tidy|prune]", "List or tidy active windows.", { "/wins [tidy|prune|swap] [source] [target]", "List or tidy active windows.",
{ "/wins [tidy|prune]", { "/wins [tidy|prune|swap] [source] [target]",
"------------------", "-----------------------------------------",
"Passing no argument will list all currently active windows and information about their usage.", "Passing no argument will list all currently active windows and information about their usage.",
"tidy : Shuffle windows so there are no gaps.", "tidy : Shuffle windows so there are no gaps.",
"prune : Close all windows with no unread messages, and then tidy as above.", "prune : Close all windows with no unread messages, and then tidy as above.",
"swap source target : Swap windows, target may be an empty position.",
NULL } } }, NULL } } },
{ "/sub", { "/sub",
@ -1033,6 +1034,7 @@ cmd_init(void)
wins_ac = autocomplete_new(); wins_ac = autocomplete_new();
autocomplete_add(wins_ac, "prune"); autocomplete_add(wins_ac, "prune");
autocomplete_add(wins_ac, "tidy"); autocomplete_add(wins_ac, "tidy");
autocomplete_add(wins_ac, "swap");
roster_ac = autocomplete_new(); roster_ac = autocomplete_new();
autocomplete_add(roster_ac, "add"); autocomplete_add(roster_ac, "add");

View File

@ -471,7 +471,29 @@ cmd_wins(gchar **args, struct cmd_help_t help)
ui_tidy_wins(); ui_tidy_wins();
} else if (strcmp(args[0], "prune") == 0) { } else if (strcmp(args[0], "prune") == 0) {
ui_prune_wins(); ui_prune_wins();
} else if (strcmp(args[0], "swap") == 0) {
if ((args[1] == NULL) || (args[2] == NULL)) {
cons_show("Usage: %s", help.usage);
} else {
int source_win = atoi(args[1]);
int target_win = atoi(args[2]);
if ((source_win == 1) || (target_win == 1)) {
cons_show("Cannot move console window.");
} else if (source_win == 10 || target_win == 10) {
cons_show("Window 10 does not exist");
} else if (source_win != target_win) {
gboolean swapped = ui_swap_wins(source_win, target_win);
if (swapped) {
cons_show("Swapped windows %d <-> %d", source_win, target_win);
} else {
cons_show("Window %d does not exist", source_win);
}
} else {
cons_show("Same source and target window supplied.");
}
}
} }
return TRUE; return TRUE;
} }

View File

@ -694,7 +694,6 @@ static gboolean
_ui_switch_win(const int i) _ui_switch_win(const int i)
{ {
if (ui_win_exists(i)) { if (ui_win_exists(i)) {
ui_current_page_off();
ProfWin *new_current = wins_get_by_num(i); ProfWin *new_current = wins_get_by_num(i);
wins_set_current_by_num(i); wins_set_current_by_num(i);
ui_current_page_off(); ui_current_page_off();
@ -953,6 +952,12 @@ _ui_prune_wins(void)
} }
} }
static gboolean
_ui_swap_wins(int source_win, int target_win)
{
return wins_swap(source_win, target_win);
}
static win_type_t static win_type_t
_ui_current_win_type(void) _ui_current_win_type(void)
{ {
@ -1992,4 +1997,5 @@ ui_init_module(void)
ui_create_xmlconsole_win = _ui_create_xmlconsole_win; ui_create_xmlconsole_win = _ui_create_xmlconsole_win;
ui_xmlconsole_exists = _ui_xmlconsole_exists; ui_xmlconsole_exists = _ui_xmlconsole_exists;
ui_handle_room_join_error = _ui_handle_room_join_error; ui_handle_room_join_error = _ui_handle_room_join_error;
ui_swap_wins = _ui_swap_wins;
} }

View File

@ -147,6 +147,7 @@ gboolean (*ui_duck_exists)(void);
void (*ui_tidy_wins)(void); void (*ui_tidy_wins)(void);
void (*ui_prune_wins)(void); void (*ui_prune_wins)(void);
gboolean (*ui_swap_wins)(int source_win, int target_win);
void (*ui_auto_away)(void); void (*ui_auto_away)(void);
void (*ui_end_auto_away)(void); void (*ui_end_auto_away)(void);

View File

@ -386,6 +386,55 @@ wins_lost_connection(void)
} }
} }
gboolean
wins_swap(int source_win, int target_win)
{
ProfWin *source = g_hash_table_lookup(windows, GINT_TO_POINTER(source_win));
if (source != NULL) {
ProfWin *target = g_hash_table_lookup(windows, GINT_TO_POINTER(target_win));
// target window empty
if (target == NULL) {
g_hash_table_steal(windows, GINT_TO_POINTER(source_win));
status_bar_inactive(source_win);
g_hash_table_insert(windows, GINT_TO_POINTER(target_win), source);
if (source->unread > 0) {
status_bar_new(target_win);
} else {
status_bar_active(target_win);
}
if ((wins_get_current_num() == source_win) || (wins_get_current_num() == target_win)) {
ui_switch_win(1);
}
return TRUE;
// target window occupied
} else {
g_hash_table_steal(windows, GINT_TO_POINTER(source_win));
g_hash_table_steal(windows, GINT_TO_POINTER(target_win));
g_hash_table_insert(windows, GINT_TO_POINTER(source_win), target);
g_hash_table_insert(windows, GINT_TO_POINTER(target_win), source);
if (source->unread > 0) {
status_bar_new(target_win);
} else {
status_bar_active(target_win);
}
if (target->unread > 0) {
status_bar_new(source_win);
} else {
status_bar_active(source_win);
}
if ((wins_get_current_num() == source_win) || (wins_get_current_num() == target_win)) {
ui_switch_win(1);
}
return TRUE;
}
} else {
return FALSE;
}
}
gboolean gboolean
wins_tidy(void) wins_tidy(void)
{ {

View File

@ -52,5 +52,6 @@ void wins_destroy(void);
GList * wins_get_nums(void); GList * wins_get_nums(void);
gboolean wins_xmlconsole_exists(void); gboolean wins_xmlconsole_exists(void);
ProfWin * wins_get_xmlconsole(void); ProfWin * wins_get_xmlconsole(void);
gboolean wins_swap(int source_win, int target_win);
#endif #endif