all repos — openbox @ e48325700788622cc82b34f1ede5f02f74911d41

openbox fork - make it a bit more like ryudo

soem changes to desktop actions.
instead of having *wrap actions, just default to having wrap on, and let it be optionally placed into the rc to disable it.
instead of next/prev desktop, just have actions for desktop to the right/left/up/down. this applies to sendtodesktop actions too.
Dana Jansens danakj@orodu.net
commit

e48325700788622cc82b34f1ede5f02f74911d41

parent

26ebe251a9231c967e70d3c5bd0cfcf872acddae

2 files changed, 165 insertions(+), 166 deletions(-)

jump to
M openbox/action.copenbox/action.c

@@ -84,26 +84,15 @@ {

a->data.sendto.follow = TRUE; } -void setup_action_send_to_np_desktop(Action *a) +void setup_action_send_to_desktop_direction(Action *a) { - a->data.sendtonextprev.wrap = FALSE; - a->data.sendtonextprev.follow = TRUE; + a->data.sendtodir.wrap = TRUE; + a->data.sendtodir.follow = TRUE; } -void setup_action_send_to_np_desktop_wrap(Action *a) +void setup_action_desktop_direction(Action *a) { - a->data.sendtonextprev.wrap = TRUE; - a->data.sendtonextprev.follow = TRUE; -} - -void setup_action_np_desktop(Action *a) -{ - a->data.nextprevdesktop.wrap = FALSE; -} - -void setup_action_np_desktop_wrap(Action *a) -{ - a->data.nextprevdesktop.wrap = TRUE; + a->data.desktopdir.wrap = TRUE; } void setup_action_move_keyboard(Action *a)

@@ -373,24 +362,24 @@ action_send_to_desktop,

setup_action_send_to_desktop }, { - "sendtonextdesktop", - action_send_to_next_desktop, - setup_action_send_to_np_desktop + "sendtodesktopright", + action_send_to_desktop_right, + setup_action_send_to_desktop_direction }, { - "sendtonextdesktopwrap", - action_send_to_next_desktop, - setup_action_send_to_np_desktop_wrap + "sendtodesktopleft", + action_send_to_desktop_left, + setup_action_send_to_desktop_direction }, { - "sendtopreviousdesktop", - action_send_to_previous_desktop, - setup_action_send_to_np_desktop + "sendtodesktopup", + action_send_to_desktop_up, + setup_action_send_to_desktop_direction }, { - "sendtopreviousdesktopwrap", - action_send_to_previous_desktop, - setup_action_send_to_np_desktop_wrap + "sendtodesktopdown", + action_send_to_desktop_down, + setup_action_send_to_desktop_direction }, { "desktop",

@@ -398,64 +387,24 @@ action_desktop,

NULL }, { - "nextdesktop", - action_next_desktop, - setup_action_np_desktop - }, - { - "nextdesktopwrap", - action_next_desktop, - setup_action_np_desktop_wrap - }, - { - "previousdesktop", - action_previous_desktop, - setup_action_np_desktop - }, - { - "previousdesktopwrap", - action_previous_desktop, - setup_action_np_desktop_wrap - }, - { - "nextdesktopcolumn", - action_next_desktop_column, - setup_action_np_desktop - }, - { - "nextdesktopcolumnwrap", - action_next_desktop_column, - setup_action_np_desktop_wrap - }, - { - "previousdesktopcolumn", - action_previous_desktop_column, - setup_action_np_desktop - }, - { - "previousdesktopcolumnwrap", - action_previous_desktop_column, - setup_action_np_desktop_wrap - }, - { - "nextdesktoprow", - action_next_desktop_row, - setup_action_np_desktop + "desktopright", + action_desktop_right, + setup_action_desktop_direction }, { - "nextdesktoprowwrap", - action_next_desktop_row, - setup_action_np_desktop_wrap + "desktopleft", + action_desktop_left, + setup_action_desktop_direction }, { - "previousdesktoprow", - action_previous_desktop_row, - setup_action_np_desktop + "desktopup", + action_desktop_up, + setup_action_desktop_direction }, { - "previousdesktoprowwrap", - action_previous_desktop_row, - setup_action_np_desktop_wrap + "desktopdown", + action_desktop_down, + setup_action_desktop_direction }, { "toggledecorations",

@@ -797,36 +746,6 @@ }

} } -void action_send_to_next_desktop(union ActionData *data) -{ - guint d; - - if (!data->sendtonextprev.c) return; - - d = screen_desktop + 1; - if (d >= screen_num_desktops) { - if (!data->sendtonextprev.wrap) return; - d = 0; - } - client_set_desktop(data->sendtonextprev.c, d, data->sendtonextprev.follow); - if (data->sendtonextprev.follow) screen_set_desktop(d); -} - -void action_send_to_previous_desktop(union ActionData *data) -{ - guint d; - - if (!data->sendtonextprev.c) return; - - d = screen_desktop - 1; - if (d >= screen_num_desktops) { - if (!data->sendtonextprev.wrap) return; - d = screen_num_desktops - 1; - } - client_set_desktop(data->sendtonextprev.c, d, data->sendtonextprev.follow); - if (data->sendtonextprev.follow) screen_set_desktop(d); -} - void action_desktop(union ActionData *data) { if (data->desktop.desk < screen_num_desktops ||

@@ -834,30 +753,6 @@ data->desktop.desk == DESKTOP_ALL)

screen_set_desktop(data->desktop.desk); } -void action_next_desktop(union ActionData *data) -{ - guint d; - - d = screen_desktop + 1; - if (d >= screen_num_desktops) { - if (!data->nextprevdesktop.wrap) return; - d = 0; - } - screen_set_desktop(d); -} - -void action_previous_desktop(union ActionData *data) -{ - guint d; - - d = screen_desktop - 1; - if (d >= screen_num_desktops) { - if (!data->nextprevdesktop.wrap) return; - d = screen_num_desktops - 1; - } - screen_set_desktop(d); -} - static void cur_row_col(guint *r, guint *c) { switch (screen_desktop_layout.orientation) {

@@ -966,17 +861,19 @@ g_assert_not_reached();

return 0; } -void action_next_desktop_column(union ActionData *data) +void action_desktop_right(union ActionData *data) { guint r, c, d; cur_row_col(&r, &c); ++c; - if (c >= screen_desktop_layout.columns) + if (c >= screen_desktop_layout.columns) { + if (!data->desktopdir.wrap) return; c = 0; + } d = translate_row_col(r, c); if (d >= screen_num_desktops) { - if (!data->nextprevdesktop.wrap) return; + if (!data->desktopdir.wrap) return; ++c; } d = translate_row_col(r, c);

@@ -984,17 +881,43 @@ if (d < screen_num_desktops)

screen_set_desktop(d); } -void action_previous_desktop_column(union ActionData *data) +void action_send_to_desktop_right(union ActionData *data) +{ + guint r, c, d; + + if (data->sendtodir.c) { + cur_row_col(&r, &c); + ++c; + if (c >= screen_desktop_layout.columns) { + if (!data->sendtodir.wrap) return; + c = 0; + } + d = translate_row_col(r, c); + if (d >= screen_num_desktops) { + if (!data->sendtodir.wrap) return; + ++c; + } + d = translate_row_col(r, c); + if (d < screen_num_desktops) { + client_set_desktop(data->sendtodir.c, d, data->sendtodir.follow); + if (data->sendtodir.follow) screen_set_desktop(d); + } + } +} + +void action_desktop_left(union ActionData *data) { guint r, c, d; cur_row_col(&r, &c); --c; - if (c >= screen_desktop_layout.columns) + if (c >= screen_desktop_layout.columns) { + if (!data->desktopdir.wrap) return; c = screen_desktop_layout.columns - 1; + } d = translate_row_col(r, c); if (d >= screen_num_desktops) { - if (!data->nextprevdesktop.wrap) return; + if (!data->desktopdir.wrap) return; --c; } d = translate_row_col(r, c);

@@ -1002,17 +925,43 @@ if (d < screen_num_desktops)

screen_set_desktop(d); } -void action_next_desktop_row(union ActionData *data) +void action_send_to_desktop_left(union ActionData *data) +{ + guint r, c, d; + + if (data->sendtodir.c) { + cur_row_col(&r, &c); + --c; + if (c >= screen_desktop_layout.columns) { + if (!data->sendtodir.wrap) return; + c = screen_desktop_layout.columns - 1; + } + d = translate_row_col(r, c); + if (d >= screen_num_desktops) { + if (!data->sendtodir.wrap) return; + --c; + } + d = translate_row_col(r, c); + if (d < screen_num_desktops) { + client_set_desktop(data->sendtodir.c, d, data->sendtodir.follow); + if (data->sendtodir.follow) screen_set_desktop(d); + } + } +} + +void action_desktop_down(union ActionData *data) { guint r, c, d; cur_row_col(&r, &c); ++r; - if (r >= screen_desktop_layout.rows) + if (r >= screen_desktop_layout.rows) { + if (!data->desktopdir.wrap) return; r = 0; + } d = translate_row_col(r, c); if (d >= screen_num_desktops) { - if (!data->nextprevdesktop.wrap) return; + if (!data->desktopdir.wrap) return; ++r; } d = translate_row_col(r, c);

@@ -1020,22 +969,72 @@ if (d < screen_num_desktops)

screen_set_desktop(d); } -void action_previous_desktop_row(union ActionData *data) +void action_send_to_desktop_down(union ActionData *data) +{ + guint r, c, d; + + if (data->sendtodir.c) { + cur_row_col(&r, &c); + ++r; + if (r >= screen_desktop_layout.rows) { + if (!data->sendtodir.wrap) return; + r = 0; + } + d = translate_row_col(r, c); + if (d >= screen_num_desktops) { + if (!data->sendtodir.wrap) return; + ++r; + } + d = translate_row_col(r, c); + if (d < screen_num_desktops) { + client_set_desktop(data->sendtodir.c, d, data->sendtodir.follow); + if (data->sendtodir.follow) screen_set_desktop(d); + } + } +} + +void action_desktop_up(union ActionData *data) { guint r, c, d; cur_row_col(&r, &c); --r; - if (r >= screen_desktop_layout.rows) + if (r >= screen_desktop_layout.rows) { + if (!data->desktopdir.wrap) return; r = screen_desktop_layout.rows - 1; + } d = translate_row_col(r, c); if (d >= screen_num_desktops) { - if (!data->nextprevdesktop.wrap) return; + if (!data->desktopdir.wrap) return; --r; } d = translate_row_col(r, c); if (d < screen_num_desktops) screen_set_desktop(d); +} + +void action_send_to_desktop_up(union ActionData *data) +{ + guint r, c, d; + + if (data->sendtodir.c) { + cur_row_col(&r, &c); + --r; + if (r >= screen_desktop_layout.rows) { + if (!data->sendtodir.wrap) return; + r = screen_desktop_layout.rows - 1; + } + d = translate_row_col(r, c); + if (d >= screen_num_desktops) { + if (!data->sendtodir.wrap) return; + --r; + } + d = translate_row_col(r, c); + if (d < screen_num_desktops) { + client_set_desktop(data->sendtodir.c, d, data->sendtodir.follow); + if (data->sendtodir.follow) screen_set_desktop(d); + } + } } void action_toggle_decorations(union ActionData *data)
M openbox/action.hopenbox/action.h

@@ -37,7 +37,7 @@ guint desk;

gboolean follow; }; -struct SendToNextPreviousDesktop { +struct SendToDesktopDirection { Client *c; gboolean wrap; gboolean follow;

@@ -53,7 +53,7 @@ Client *c;

int layer; /* < 0 = below, 0 = normal, > 0 = above */ }; -struct NextPreviousDesktop { +struct DesktopDirection { Client *c; gboolean wrap; };

@@ -88,9 +88,9 @@ struct Execute execute;

struct ClientAction client; struct MoveResizeRelative relative; struct SendToDesktop sendto; - struct SendToNextPreviousDesktop sendtonextprev; + struct SendToDesktopDirection sendtodir; struct Desktop desktop; - struct NextPreviousDesktop nextprevdesktop; + struct DesktopDirection desktopdir; struct MoveResize moveresize; struct ShowMenu showmenu; struct CycleWindows cycle;

@@ -180,24 +180,24 @@ /* ClientAction */

void action_toggle_maximize_vert(union ActionData *data); /* SendToDesktop */ void action_send_to_desktop(union ActionData *data); -/* SendToNextPreviousDesktop */ -void action_send_to_next_desktop(union ActionData *data); -/* SendToNextPreviousDesktop */ -void action_send_to_previous_desktop(union ActionData *data); +/* SendToDesktopDirection */ +void action_send_to_desktop_right(union ActionData *data); +/* SendToDesktopDirection */ +void action_send_to_desktop_left(union ActionData *data); +/* SendToDesktopDirection */ +void action_send_to_desktop_up(union ActionData *data); +/* SendToDesktopDirection */ +void action_send_to_desktop_down(union ActionData *data); /* Desktop */ void action_desktop(union ActionData *data); -/* NextPreviousDesktop */ -void action_next_desktop(union ActionData *data); -/* NextPreviousDesktop */ -void action_previous_desktop(union ActionData *data); -/* NextPreviousDesktop */ -void action_next_desktop_column(union ActionData *data); -/* NextPreviousDesktop */ -void action_previous_desktop_column(union ActionData *data); -/* NextPreviousDesktop */ -void action_next_desktop_row(union ActionData *data); -/* NextPreviousDesktop */ -void action_previous_desktop_row(union ActionData *data); +/* DesktopDirection */ +void action_desktop_right(union ActionData *data); +/* DesktopDirection */ +void action_desktop_left(union ActionData *data); +/* DesktopDirection */ +void action_desktop_up(union ActionData *data); +/* DesktopDirection */ +void action_desktop_down(union ActionData *data); /* ClientAction */ void action_toggle_decorations(union ActionData *data); /* MoveResize */