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;
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)
{
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);
}