X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Factions%2Flayer.c;h=bbfda57218f122ae1784dc11ba03c9372d4cebf1;hb=a1746ab2158da2324aefb7ce81e7b5edc9c41e79;hp=6f83983d4b89f8a62f464123929112efced0cd7a;hpb=7f50e04925e539dbe28997a6b07369d9f5cb43e3;p=chaz%2Fopenbox diff --git a/openbox/actions/layer.c b/openbox/actions/layer.c index 6f83983d..bbfda572 100644 --- a/openbox/actions/layer.c +++ b/openbox/actions/layer.c @@ -4,32 +4,48 @@ 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 gboolean run_func(ObActionsData *data, gpointer options); -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, g_free, + run_func, NULL, NULL); + actions_register("ToggleAlwaysOnBottom", setup_func_bottom, g_free, + run_func, NULL, NULL); + actions_register("SendToLayer", setup_func_send, g_free, + run_func, NULL, NULL); } -static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node) +static gpointer setup_func_top(xmlNodePtr node) +{ + Options *o = g_new0(Options, 1); + o->layer = 1; + o->toggle = TRUE; + return o; +} + +static gpointer setup_func_bottom(xmlNodePtr node) +{ + Options *o = g_new0(Options, 1); + 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; - if ((n = parse_find_node("layer", node))) { - gchar *s = parse_string(doc, n); + if ((n = obt_parse_find_node(node, "layer"))) { + gchar *s = obt_parse_node_string(n); if (!g_ascii_strcasecmp(s, "above") || !g_ascii_strcasecmp(s, "top")) o->layer = 1; @@ -41,25 +57,10 @@ 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) -{ - Options *o = options; - - g_free(o); -} - /* Always return FALSE because its not interactive */ static gboolean run_func(ObActionsData *data, gpointer options) { @@ -71,17 +72,15 @@ 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); }