X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Factions%2Flayer.c;h=ed1eeedc0462c26ed22557edbeb39ef028b4c61e;hb=d179d6428ae585a3b8a13479bfe4586e41de2ff9;hp=6f83983d4b89f8a62f464123929112efced0cd7a;hpb=7f50e04925e539dbe28997a6b07369d9f5cb43e3;p=chaz%2Fopenbox diff --git a/openbox/actions/layer.c b/openbox/actions/layer.c index 6f83983d..ed1eeedc 100644 --- a/openbox/actions/layer.c +++ b/openbox/actions/layer.c @@ -4,32 +4,60 @@ typedef struct { gint layer; /*!< -1 for below, 0 for normal, and 1 for above */ gboolean toggle; - gboolean on; } Options; -static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node); -static void free_func(gpointer options); +static gpointer setup_func_top(xmlNodePtr node); +static gpointer setup_func_bottom(xmlNodePtr node); +static gpointer setup_func_send(xmlNodePtr node); +static void free_func(gpointer o); static gboolean run_func(ObActionsData *data, gpointer options); +/* 3.4-compatibility */ +static gpointer setup_sendtop_func(xmlNodePtr node); +static gpointer setup_sendbottom_func(xmlNodePtr node); +static gpointer setup_sendnormal_func(xmlNodePtr node); -void action_layer_startup() +void action_layer_startup(void) { - actions_register("Layer", - setup_func, - free_func, - run_func, - NULL, NULL); + actions_register("ToggleAlwaysOnTop", setup_func_top, free_func, + run_func); + actions_register("ToggleAlwaysOnBottom", setup_func_bottom, free_func, + run_func); + actions_register("SendToLayer", setup_func_send, free_func, + run_func); + /* 3.4-compatibility */ + actions_register("SendToTopLayer", setup_sendtop_func, free_func, + run_func); + actions_register("SendToBottomLayer", setup_sendbottom_func, free_func, + run_func); + actions_register("SendToNormalLayer", setup_sendnormal_func, free_func, + run_func); } -static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node) +static gpointer setup_func_top(xmlNodePtr node) +{ + Options *o = g_slice_new0(Options); + o->layer = 1; + o->toggle = TRUE; + return o; +} + +static gpointer setup_func_bottom(xmlNodePtr node) +{ + Options *o = g_slice_new0(Options); + o->layer = -1; + o->toggle = TRUE; + return o; +} + +static gpointer setup_func_send(xmlNodePtr node) { xmlNodePtr n; Options *o; - o = g_new0(Options, 1); - o->toggle = TRUE; + o = g_slice_new0(Options); - if ((n = parse_find_node("layer", node))) { - gchar *s = parse_string(doc, n); + if ((n = obt_xml_find_node(node, "layer"))) { + gchar *s = obt_xml_node_string(n); if (!g_ascii_strcasecmp(s, "above") || !g_ascii_strcasecmp(s, "top")) o->layer = 1; @@ -41,23 +69,13 @@ static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node) o->layer = 0; g_free(s); } - if ((n = parse_find_node("state", node))) { - gchar *s = parse_string(doc, n); - if (g_ascii_strcasecmp(s, "toggle")) { - o->toggle = FALSE; - o->on = parse_bool(doc, n); - } - g_free(s); - } return o; } -static void free_func(gpointer options) +static void free_func(gpointer o) { - Options *o = options; - - g_free(o); + g_slice_free(Options, o); } /* Always return FALSE because its not interactive */ @@ -71,20 +89,44 @@ static gboolean run_func(ObActionsData *data, gpointer options) actions_client_move(data, TRUE); if (o->layer < 0) { - if (o->toggle || c->below != o->on) + if (o->toggle || !c->below) client_set_layer(c, c->below ? 0 : -1); } else if (o->layer > 0) { - if (o->toggle || c->above != o->on) + if (o->toggle || !c->above) client_set_layer(c, c->above ? 0 : 1); } - else { - if ((o->toggle || o->on) && (c->above || c->below)) - client_set_layer(c, 0); - } + else if (c->above || c->below) + client_set_layer(c, 0); actions_client_move(data, FALSE); } return FALSE; } + +/* 3.4-compatibility */ +static gpointer setup_sendtop_func(xmlNodePtr node) +{ + Options *o = g_slice_new0(Options); + o->layer = 1; + o->toggle = FALSE; + return o; +} + +static gpointer setup_sendbottom_func(xmlNodePtr node) +{ + Options *o = g_slice_new0(Options); + o->layer = -1; + o->toggle = FALSE; + return o; +} + +static gpointer setup_sendnormal_func(xmlNodePtr node) +{ + Options *o = g_slice_new0(Options); + o->layer = 0; + o->toggle = FALSE; + return o; +} +