X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=openbox%2Factions%2Flayer.c;h=92fa4806ebd36990d934117c7711d3beed2ab855;hb=7f36e21ea9d86df5e6fa62d2888891ed957c4639;hp=6f83983d4b89f8a62f464123929112efced0cd7a;hpb=7f50e04925e539dbe28997a6b07369d9f5cb43e3;p=chaz%2Fopenbox diff --git a/openbox/actions/layer.c b/openbox/actions/layer.c index 6f83983d..92fa4806 100644 --- a/openbox/actions/layer.c +++ b/openbox/actions/layer.c @@ -4,29 +4,49 @@ 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(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node); +static gpointer setup_func_bottom(ObParseInst *i, xmlDocPtr doc, + xmlNodePtr node); +static gpointer setup_func_send(ObParseInst *i, xmlDocPtr doc, + 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(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node) +{ + Options *o = g_new0(Options, 1); + o->layer = 1; + o->toggle = TRUE; + return o; +} + +static gpointer setup_func_bottom(ObParseInst *i, xmlDocPtr doc, + xmlNodePtr node) +{ + Options *o = g_new0(Options, 1); + o->layer = -1; + o->toggle = TRUE; + return o; +} + +static gpointer setup_func_send(ObParseInst *i, xmlDocPtr doc, + 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); @@ -41,25 +61,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 +76,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); }