split shade back into shade/unshade/toggleshade
This commit is contained in:
parent
355981bf14
commit
9a0aab8d8d
1 changed files with 28 additions and 48 deletions
|
@ -1,64 +1,44 @@
|
|||
#include "openbox/actions.h"
|
||||
#include "openbox/client.h"
|
||||
|
||||
typedef struct {
|
||||
gboolean toggle;
|
||||
gboolean on;
|
||||
} Options;
|
||||
|
||||
static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node);
|
||||
static void free_func(gpointer options);
|
||||
static gboolean run_func(ObActionsData *data, gpointer options);
|
||||
static gboolean run_func_on(ObActionsData *data, gpointer options);
|
||||
static gboolean run_func_off(ObActionsData *data, gpointer options);
|
||||
static gboolean run_func_toggle(ObActionsData *data, gpointer options);
|
||||
|
||||
void action_shade_startup()
|
||||
{
|
||||
actions_register("Shade",
|
||||
setup_func,
|
||||
free_func,
|
||||
run_func,
|
||||
NULL, NULL);
|
||||
}
|
||||
|
||||
static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node)
|
||||
{
|
||||
xmlNodePtr n;
|
||||
Options *o;
|
||||
|
||||
o = g_new0(Options, 1);
|
||||
o->toggle = TRUE;
|
||||
|
||||
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);
|
||||
actions_register("Shade", NULL, NULL, run_func_on, NULL, NULL);
|
||||
actions_register("Unshade", NULL, NULL, run_func_off, NULL, NULL);
|
||||
actions_register("ToggleShade", NULL, NULL, run_func_toggle, NULL, NULL);
|
||||
}
|
||||
|
||||
/* Always return FALSE because its not interactive */
|
||||
static gboolean run_func(ObActionsData *data, gpointer options)
|
||||
static gboolean run_func_on(ObActionsData *data, gpointer options)
|
||||
{
|
||||
Options *o = options;
|
||||
|
||||
if (data->client) {
|
||||
actions_client_move(data, TRUE);
|
||||
if (o->toggle)
|
||||
client_shade(data->client, !data->client->shaded);
|
||||
else
|
||||
client_shade(data->client, o->on);
|
||||
client_shade(data->client, TRUE);
|
||||
actions_client_move(data, FALSE);
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static gboolean run_func_off(ObActionsData *data, gpointer options)
|
||||
{
|
||||
if (data->client) {
|
||||
actions_client_move(data, TRUE);
|
||||
client_shade(data->client, FALSE);
|
||||
actions_client_move(data, FALSE);
|
||||
}
|
||||
return FALSE;
|
||||
}
|
||||
|
||||
static gboolean run_func_toggle(ObActionsData *data, gpointer options)
|
||||
{
|
||||
if (data->client) {
|
||||
actions_client_move(data, TRUE);
|
||||
client_shade(data->client, !data->client->shaded);
|
||||
actions_client_move(data, FALSE);
|
||||
}
|
||||
|
||||
return FALSE;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue